@itwin/core-geometry 5.5.0-dev.4 → 5.5.0-dev.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (611) hide show
  1. package/lib/cjs/Geometry.d.ts +7 -0
  2. package/lib/cjs/Geometry.d.ts.map +1 -1
  3. package/lib/cjs/Geometry.js +9 -0
  4. package/lib/cjs/Geometry.js.map +1 -1
  5. package/lib/cjs/bspline/BSplineCurve.d.ts.map +1 -1
  6. package/lib/cjs/bspline/BSplineCurve.js +2 -1
  7. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  8. package/lib/cjs/bspline/BSplineCurveOps.d.ts.map +1 -1
  9. package/lib/cjs/bspline/BSplineCurveOps.js +4 -1
  10. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  11. package/lib/cjs/bspline/BezierCurve3d.d.ts.map +1 -1
  12. package/lib/cjs/bspline/BezierCurve3d.js +14 -4
  13. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  14. package/lib/cjs/bspline/BezierCurve3dH.d.ts +2 -0
  15. package/lib/cjs/bspline/BezierCurve3dH.d.ts.map +1 -1
  16. package/lib/cjs/bspline/BezierCurve3dH.js +19 -3
  17. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  18. package/lib/cjs/bspline/BezierCurveBase.d.ts +8 -2
  19. package/lib/cjs/bspline/BezierCurveBase.d.ts.map +1 -1
  20. package/lib/cjs/bspline/BezierCurveBase.js +10 -4
  21. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  22. package/lib/cjs/clipping/AlternatingConvexClipTree.js +4 -4
  23. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  24. package/lib/cjs/clipping/ClipPlane.d.ts +0 -3
  25. package/lib/cjs/clipping/ClipPlane.d.ts.map +1 -1
  26. package/lib/cjs/clipping/ClipPlane.js +9 -2
  27. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  28. package/lib/cjs/clipping/ClipPrimitive.d.ts +59 -9
  29. package/lib/cjs/clipping/ClipPrimitive.d.ts.map +1 -1
  30. package/lib/cjs/clipping/ClipPrimitive.js +124 -55
  31. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  32. package/lib/cjs/clipping/ClipUtils.js +1 -1
  33. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  34. package/lib/cjs/clipping/ClipVector.d.ts.map +1 -1
  35. package/lib/cjs/clipping/ClipVector.js +12 -8
  36. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  37. package/lib/cjs/clipping/ConvexClipPlaneSet.d.ts +0 -2
  38. package/lib/cjs/clipping/ConvexClipPlaneSet.d.ts.map +1 -1
  39. package/lib/cjs/clipping/ConvexClipPlaneSet.js +19 -18
  40. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  41. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.d.ts +1 -1
  42. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.d.ts.map +1 -1
  43. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js +4 -5
  44. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  45. package/lib/cjs/core-geometry.d.ts +0 -1
  46. package/lib/cjs/core-geometry.d.ts.map +1 -1
  47. package/lib/cjs/core-geometry.js +0 -1
  48. package/lib/cjs/core-geometry.js.map +1 -1
  49. package/lib/cjs/curve/Arc3d.js +2 -2
  50. package/lib/cjs/curve/Arc3d.js.map +1 -1
  51. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts +12 -4
  52. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  53. package/lib/cjs/curve/CurveChainWithDistanceIndex.js +52 -33
  54. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  55. package/lib/cjs/curve/CurveCollection.d.ts.map +1 -1
  56. package/lib/cjs/curve/CurveCollection.js +13 -6
  57. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  58. package/lib/cjs/curve/CurveCurve.js +1 -1
  59. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  60. package/lib/cjs/curve/CurveFactory.d.ts.map +1 -1
  61. package/lib/cjs/curve/CurveFactory.js +13 -1
  62. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  63. package/lib/cjs/curve/CurveLocationDetail.d.ts +12 -4
  64. package/lib/cjs/curve/CurveLocationDetail.d.ts.map +1 -1
  65. package/lib/cjs/curve/CurveLocationDetail.js +14 -5
  66. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  67. package/lib/cjs/curve/CurvePrimitive.d.ts +5 -4
  68. package/lib/cjs/curve/CurvePrimitive.d.ts.map +1 -1
  69. package/lib/cjs/curve/CurvePrimitive.js +7 -4
  70. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  71. package/lib/cjs/curve/LineString3d.d.ts +25 -16
  72. package/lib/cjs/curve/LineString3d.d.ts.map +1 -1
  73. package/lib/cjs/curve/LineString3d.js +90 -72
  74. package/lib/cjs/curve/LineString3d.js.map +1 -1
  75. package/lib/cjs/curve/Path.d.ts +0 -3
  76. package/lib/cjs/curve/Path.d.ts.map +1 -1
  77. package/lib/cjs/curve/Path.js +9 -2
  78. package/lib/cjs/curve/Path.js.map +1 -1
  79. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  80. package/lib/cjs/curve/Query/PlanarSubdivision.d.ts.map +1 -1
  81. package/lib/cjs/curve/Query/PlanarSubdivision.js +25 -31
  82. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  83. package/lib/cjs/curve/Query/StrokeCountChain.d.ts +7 -1
  84. package/lib/cjs/curve/Query/StrokeCountChain.d.ts.map +1 -1
  85. package/lib/cjs/curve/Query/StrokeCountChain.js +27 -36
  86. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  87. package/lib/cjs/curve/RegionMomentsXY.d.ts.map +1 -1
  88. package/lib/cjs/curve/RegionMomentsXY.js +7 -1
  89. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  90. package/lib/cjs/curve/RegionOps.d.ts.map +1 -1
  91. package/lib/cjs/curve/RegionOps.js +8 -5
  92. package/lib/cjs/curve/RegionOps.js.map +1 -1
  93. package/lib/cjs/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  94. package/lib/cjs/curve/RegionOpsClassificationSweeps.js +6 -6
  95. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  96. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -1
  97. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js +4 -1
  98. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  99. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  100. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js +6 -1
  101. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  102. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.d.ts +5 -21
  103. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.d.ts.map +1 -1
  104. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js +29 -73
  105. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  106. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.d.ts +55 -13
  107. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.d.ts.map +1 -1
  108. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js +238 -110
  109. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  110. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js +1 -1
  111. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  112. package/lib/cjs/curve/spiral/DirectSpiral3d.d.ts +1 -4
  113. package/lib/cjs/curve/spiral/DirectSpiral3d.d.ts.map +1 -1
  114. package/lib/cjs/curve/spiral/DirectSpiral3d.js +9 -9
  115. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  116. package/lib/cjs/curve/spiral/IntegratedSpiral3d.d.ts +11 -14
  117. package/lib/cjs/curve/spiral/IntegratedSpiral3d.d.ts.map +1 -1
  118. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js +18 -18
  119. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  120. package/lib/cjs/curve/spiral/TransitionConditionalProperties.d.ts +7 -1
  121. package/lib/cjs/curve/spiral/TransitionConditionalProperties.d.ts.map +1 -1
  122. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  123. package/lib/cjs/geometry3d/Ellipsoid.d.ts +19 -7
  124. package/lib/cjs/geometry3d/Ellipsoid.d.ts.map +1 -1
  125. package/lib/cjs/geometry3d/Ellipsoid.js +26 -11
  126. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  127. package/lib/cjs/geometry3d/FrustumAnimation.d.ts.map +1 -1
  128. package/lib/cjs/geometry3d/FrustumAnimation.js +11 -1
  129. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  130. package/lib/cjs/geometry3d/GrowableFloat64Array.d.ts +5 -1
  131. package/lib/cjs/geometry3d/GrowableFloat64Array.d.ts.map +1 -1
  132. package/lib/cjs/geometry3d/GrowableFloat64Array.js +11 -1
  133. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  134. package/lib/cjs/geometry3d/GrowableXYArray.d.ts +1 -1
  135. package/lib/cjs/geometry3d/GrowableXYArray.js +1 -1
  136. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  137. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts +49 -8
  138. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  139. package/lib/cjs/geometry3d/GrowableXYZArray.js +90 -37
  140. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  141. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts +100 -3
  142. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  143. package/lib/cjs/geometry3d/IndexedXYZCollection.js +125 -0
  144. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  145. package/lib/cjs/geometry3d/Matrix3d.d.ts +10 -1
  146. package/lib/cjs/geometry3d/Matrix3d.d.ts.map +1 -1
  147. package/lib/cjs/geometry3d/Matrix3d.js +53 -34
  148. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  149. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js +1 -1
  150. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  151. package/lib/cjs/geometry3d/Point3dArrayCarrier.d.ts +49 -2
  152. package/lib/cjs/geometry3d/Point3dArrayCarrier.d.ts.map +1 -1
  153. package/lib/cjs/geometry3d/Point3dArrayCarrier.js +67 -9
  154. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  155. package/lib/cjs/geometry3d/Point3dVector3d.d.ts +1 -1
  156. package/lib/cjs/geometry3d/Point3dVector3d.js +1 -1
  157. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  158. package/lib/cjs/geometry3d/PointStreaming.js +1 -1
  159. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  160. package/lib/cjs/geometry3d/PolygonOps.d.ts +24 -32
  161. package/lib/cjs/geometry3d/PolygonOps.d.ts.map +1 -1
  162. package/lib/cjs/geometry3d/PolygonOps.js +147 -180
  163. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  164. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js +5 -5
  165. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  166. package/lib/cjs/geometry3d/PolylineOps.d.ts.map +1 -1
  167. package/lib/cjs/geometry3d/PolylineOps.js +13 -3
  168. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  169. package/lib/cjs/geometry3d/Range.js.map +1 -1
  170. package/lib/cjs/geometry3d/Ray3d.d.ts +0 -3
  171. package/lib/cjs/geometry3d/Ray3d.d.ts.map +1 -1
  172. package/lib/cjs/geometry3d/Ray3d.js +5 -1
  173. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  174. package/lib/cjs/geometry3d/SortablePolygon.d.ts +2 -2
  175. package/lib/cjs/geometry3d/SortablePolygon.d.ts.map +1 -1
  176. package/lib/cjs/geometry3d/SortablePolygon.js +14 -18
  177. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  178. package/lib/cjs/geometry3d/Transform.d.ts +8 -0
  179. package/lib/cjs/geometry3d/Transform.d.ts.map +1 -1
  180. package/lib/cjs/geometry3d/Transform.js +15 -9
  181. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  182. package/lib/cjs/numerics/ClusterableArray.d.ts +4 -2
  183. package/lib/cjs/numerics/ClusterableArray.d.ts.map +1 -1
  184. package/lib/cjs/numerics/ClusterableArray.js +6 -4
  185. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  186. package/lib/cjs/numerics/Newton.d.ts +3 -1
  187. package/lib/cjs/numerics/Newton.d.ts.map +1 -1
  188. package/lib/cjs/numerics/Newton.js +5 -1
  189. package/lib/cjs/numerics/Newton.js.map +1 -1
  190. package/lib/cjs/polyface/AuxData.d.ts +1 -4
  191. package/lib/cjs/polyface/AuxData.d.ts.map +1 -1
  192. package/lib/cjs/polyface/AuxData.js +5 -1
  193. package/lib/cjs/polyface/AuxData.js.map +1 -1
  194. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js +3 -3
  195. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  196. package/lib/cjs/polyface/Polyface.d.ts.map +1 -1
  197. package/lib/cjs/polyface/Polyface.js +14 -16
  198. package/lib/cjs/polyface/Polyface.js.map +1 -1
  199. package/lib/cjs/polyface/PolyfaceBuilder.d.ts +84 -28
  200. package/lib/cjs/polyface/PolyfaceBuilder.d.ts.map +1 -1
  201. package/lib/cjs/polyface/PolyfaceBuilder.js +277 -217
  202. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  203. package/lib/cjs/polyface/PolyfaceClip.d.ts +4 -3
  204. package/lib/cjs/polyface/PolyfaceClip.d.ts.map +1 -1
  205. package/lib/cjs/polyface/PolyfaceClip.js +11 -4
  206. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  207. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  208. package/lib/cjs/polyface/PolyfaceQuery.d.ts.map +1 -1
  209. package/lib/cjs/polyface/PolyfaceQuery.js +9 -7
  210. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  211. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.d.ts.map +1 -1
  212. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js +3 -2
  213. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  214. package/lib/cjs/polyface/RangeTree/RangeTreeNode.d.ts +1 -1
  215. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js +2 -2
  216. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  217. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.d.ts.map +1 -1
  218. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js +14 -12
  219. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  220. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.d.ts +1 -1
  221. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.d.ts.map +1 -1
  222. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js +10 -6
  223. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  224. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js +4 -3
  225. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  226. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.d.ts.map +1 -1
  227. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js +3 -5
  228. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  229. package/lib/cjs/polyface/multiclip/XYPointBuckets.d.ts +1 -1
  230. package/lib/cjs/polyface/multiclip/XYPointBuckets.d.ts.map +1 -1
  231. package/lib/cjs/polyface/multiclip/XYPointBuckets.js +4 -8
  232. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  233. package/lib/cjs/serialization/BGFBAccessors.d.ts.map +1 -1
  234. package/lib/cjs/serialization/BGFBAccessors.js +1 -0
  235. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  236. package/lib/cjs/serialization/BGFBReader.d.ts.map +1 -1
  237. package/lib/cjs/serialization/BGFBReader.js +37 -7
  238. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  239. package/lib/cjs/serialization/BGFBWriter.d.ts +4 -4
  240. package/lib/cjs/serialization/BGFBWriter.d.ts.map +1 -1
  241. package/lib/cjs/serialization/BGFBWriter.js +24 -40
  242. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  243. package/lib/cjs/serialization/IModelJsonSchema.d.ts.map +1 -1
  244. package/lib/cjs/serialization/IModelJsonSchema.js +9 -3
  245. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  246. package/lib/cjs/serialization/SerializationHelpers.d.ts +0 -3
  247. package/lib/cjs/serialization/SerializationHelpers.d.ts.map +1 -1
  248. package/lib/cjs/serialization/SerializationHelpers.js +16 -7
  249. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  250. package/lib/cjs/solid/Box.d.ts +2 -2
  251. package/lib/cjs/solid/Box.d.ts.map +1 -1
  252. package/lib/cjs/solid/Box.js.map +1 -1
  253. package/lib/cjs/solid/Cone.d.ts +3 -2
  254. package/lib/cjs/solid/Cone.d.ts.map +1 -1
  255. package/lib/cjs/solid/Cone.js +4 -1
  256. package/lib/cjs/solid/Cone.js.map +1 -1
  257. package/lib/cjs/solid/LinearSweep.d.ts +1 -1
  258. package/lib/cjs/solid/LinearSweep.d.ts.map +1 -1
  259. package/lib/cjs/solid/LinearSweep.js +1 -1
  260. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  261. package/lib/cjs/solid/RotationalSweep.d.ts.map +1 -1
  262. package/lib/cjs/solid/RotationalSweep.js +1 -3
  263. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  264. package/lib/cjs/solid/TorusPipe.d.ts +4 -3
  265. package/lib/cjs/solid/TorusPipe.d.ts.map +1 -1
  266. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  267. package/lib/cjs/topology/ChainMerge.d.ts +4 -4
  268. package/lib/cjs/topology/ChainMerge.d.ts.map +1 -1
  269. package/lib/cjs/topology/ChainMerge.js +11 -1
  270. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  271. package/lib/cjs/topology/Graph.d.ts +2 -0
  272. package/lib/cjs/topology/Graph.d.ts.map +1 -1
  273. package/lib/cjs/topology/Graph.js +5 -0
  274. package/lib/cjs/topology/Graph.js.map +1 -1
  275. package/lib/cjs/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  276. package/lib/cjs/topology/HalfEdgeGraphSearch.js +2 -0
  277. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  278. package/lib/cjs/topology/HalfEdgePointInGraphSearch.d.ts.map +1 -1
  279. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js +23 -16
  280. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  281. package/lib/cjs/topology/HalfEdgePositionDetail.d.ts +20 -9
  282. package/lib/cjs/topology/HalfEdgePositionDetail.d.ts.map +1 -1
  283. package/lib/cjs/topology/HalfEdgePositionDetail.js +17 -13
  284. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  285. package/lib/cjs/topology/HalfEdgePriorityQueue.d.ts.map +1 -1
  286. package/lib/cjs/topology/HalfEdgePriorityQueue.js +3 -1
  287. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  288. package/lib/cjs/topology/InsertAndRetriangulateContext.d.ts +6 -2
  289. package/lib/cjs/topology/InsertAndRetriangulateContext.d.ts.map +1 -1
  290. package/lib/cjs/topology/InsertAndRetriangulateContext.js +41 -35
  291. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  292. package/lib/cjs/topology/MaskManager.d.ts +7 -3
  293. package/lib/cjs/topology/MaskManager.d.ts.map +1 -1
  294. package/lib/cjs/topology/MaskManager.js +10 -4
  295. package/lib/cjs/topology/MaskManager.js.map +1 -1
  296. package/lib/cjs/topology/RegularizeFace.d.ts.map +1 -1
  297. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  298. package/lib/cjs/topology/Triangulation.d.ts +2 -1
  299. package/lib/cjs/topology/Triangulation.d.ts.map +1 -1
  300. package/lib/cjs/topology/Triangulation.js +12 -7
  301. package/lib/cjs/topology/Triangulation.js.map +1 -1
  302. package/lib/esm/Geometry.d.ts +7 -0
  303. package/lib/esm/Geometry.d.ts.map +1 -1
  304. package/lib/esm/Geometry.js +9 -0
  305. package/lib/esm/Geometry.js.map +1 -1
  306. package/lib/esm/bspline/BSplineCurve.d.ts.map +1 -1
  307. package/lib/esm/bspline/BSplineCurve.js +2 -1
  308. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  309. package/lib/esm/bspline/BSplineCurveOps.d.ts.map +1 -1
  310. package/lib/esm/bspline/BSplineCurveOps.js +4 -1
  311. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  312. package/lib/esm/bspline/BezierCurve3d.d.ts.map +1 -1
  313. package/lib/esm/bspline/BezierCurve3d.js +14 -4
  314. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  315. package/lib/esm/bspline/BezierCurve3dH.d.ts +2 -0
  316. package/lib/esm/bspline/BezierCurve3dH.d.ts.map +1 -1
  317. package/lib/esm/bspline/BezierCurve3dH.js +19 -3
  318. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  319. package/lib/esm/bspline/BezierCurveBase.d.ts +8 -2
  320. package/lib/esm/bspline/BezierCurveBase.d.ts.map +1 -1
  321. package/lib/esm/bspline/BezierCurveBase.js +10 -4
  322. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  323. package/lib/esm/clipping/AlternatingConvexClipTree.js +4 -4
  324. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  325. package/lib/esm/clipping/ClipPlane.d.ts +0 -3
  326. package/lib/esm/clipping/ClipPlane.d.ts.map +1 -1
  327. package/lib/esm/clipping/ClipPlane.js +9 -2
  328. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  329. package/lib/esm/clipping/ClipPrimitive.d.ts +59 -9
  330. package/lib/esm/clipping/ClipPrimitive.d.ts.map +1 -1
  331. package/lib/esm/clipping/ClipPrimitive.js +124 -55
  332. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  333. package/lib/esm/clipping/ClipUtils.js +1 -1
  334. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  335. package/lib/esm/clipping/ClipVector.d.ts.map +1 -1
  336. package/lib/esm/clipping/ClipVector.js +12 -8
  337. package/lib/esm/clipping/ClipVector.js.map +1 -1
  338. package/lib/esm/clipping/ConvexClipPlaneSet.d.ts +0 -2
  339. package/lib/esm/clipping/ConvexClipPlaneSet.d.ts.map +1 -1
  340. package/lib/esm/clipping/ConvexClipPlaneSet.js +20 -19
  341. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  342. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.d.ts +1 -1
  343. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.d.ts.map +1 -1
  344. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js +4 -5
  345. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  346. package/lib/esm/core-geometry.d.ts +0 -1
  347. package/lib/esm/core-geometry.d.ts.map +1 -1
  348. package/lib/esm/core-geometry.js +0 -1
  349. package/lib/esm/core-geometry.js.map +1 -1
  350. package/lib/esm/curve/Arc3d.js +2 -2
  351. package/lib/esm/curve/Arc3d.js.map +1 -1
  352. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts +12 -4
  353. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  354. package/lib/esm/curve/CurveChainWithDistanceIndex.js +53 -34
  355. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  356. package/lib/esm/curve/CurveCollection.d.ts.map +1 -1
  357. package/lib/esm/curve/CurveCollection.js +13 -6
  358. package/lib/esm/curve/CurveCollection.js.map +1 -1
  359. package/lib/esm/curve/CurveCurve.js +1 -1
  360. package/lib/esm/curve/CurveCurve.js.map +1 -1
  361. package/lib/esm/curve/CurveFactory.d.ts.map +1 -1
  362. package/lib/esm/curve/CurveFactory.js +13 -1
  363. package/lib/esm/curve/CurveFactory.js.map +1 -1
  364. package/lib/esm/curve/CurveLocationDetail.d.ts +12 -4
  365. package/lib/esm/curve/CurveLocationDetail.d.ts.map +1 -1
  366. package/lib/esm/curve/CurveLocationDetail.js +14 -5
  367. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  368. package/lib/esm/curve/CurvePrimitive.d.ts +5 -4
  369. package/lib/esm/curve/CurvePrimitive.d.ts.map +1 -1
  370. package/lib/esm/curve/CurvePrimitive.js +7 -4
  371. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  372. package/lib/esm/curve/LineString3d.d.ts +25 -16
  373. package/lib/esm/curve/LineString3d.d.ts.map +1 -1
  374. package/lib/esm/curve/LineString3d.js +90 -72
  375. package/lib/esm/curve/LineString3d.js.map +1 -1
  376. package/lib/esm/curve/Path.d.ts +0 -3
  377. package/lib/esm/curve/Path.d.ts.map +1 -1
  378. package/lib/esm/curve/Path.js +9 -2
  379. package/lib/esm/curve/Path.js.map +1 -1
  380. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  381. package/lib/esm/curve/Query/PlanarSubdivision.d.ts.map +1 -1
  382. package/lib/esm/curve/Query/PlanarSubdivision.js +25 -31
  383. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  384. package/lib/esm/curve/Query/StrokeCountChain.d.ts +7 -1
  385. package/lib/esm/curve/Query/StrokeCountChain.d.ts.map +1 -1
  386. package/lib/esm/curve/Query/StrokeCountChain.js +27 -36
  387. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  388. package/lib/esm/curve/RegionMomentsXY.d.ts.map +1 -1
  389. package/lib/esm/curve/RegionMomentsXY.js +7 -1
  390. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  391. package/lib/esm/curve/RegionOps.d.ts.map +1 -1
  392. package/lib/esm/curve/RegionOps.js +8 -5
  393. package/lib/esm/curve/RegionOps.js.map +1 -1
  394. package/lib/esm/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  395. package/lib/esm/curve/RegionOpsClassificationSweeps.js +6 -6
  396. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  397. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -1
  398. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js +4 -1
  399. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  400. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  401. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js +6 -1
  402. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  403. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.d.ts +5 -21
  404. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.d.ts.map +1 -1
  405. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js +29 -73
  406. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  407. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.d.ts +55 -13
  408. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.d.ts.map +1 -1
  409. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js +239 -111
  410. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  411. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js +1 -1
  412. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  413. package/lib/esm/curve/spiral/DirectSpiral3d.d.ts +1 -4
  414. package/lib/esm/curve/spiral/DirectSpiral3d.d.ts.map +1 -1
  415. package/lib/esm/curve/spiral/DirectSpiral3d.js +9 -9
  416. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  417. package/lib/esm/curve/spiral/IntegratedSpiral3d.d.ts +11 -14
  418. package/lib/esm/curve/spiral/IntegratedSpiral3d.d.ts.map +1 -1
  419. package/lib/esm/curve/spiral/IntegratedSpiral3d.js +18 -18
  420. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  421. package/lib/esm/curve/spiral/TransitionConditionalProperties.d.ts +7 -1
  422. package/lib/esm/curve/spiral/TransitionConditionalProperties.d.ts.map +1 -1
  423. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  424. package/lib/esm/geometry3d/Ellipsoid.d.ts +19 -7
  425. package/lib/esm/geometry3d/Ellipsoid.d.ts.map +1 -1
  426. package/lib/esm/geometry3d/Ellipsoid.js +26 -11
  427. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  428. package/lib/esm/geometry3d/FrustumAnimation.d.ts.map +1 -1
  429. package/lib/esm/geometry3d/FrustumAnimation.js +11 -1
  430. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  431. package/lib/esm/geometry3d/GrowableFloat64Array.d.ts +5 -1
  432. package/lib/esm/geometry3d/GrowableFloat64Array.d.ts.map +1 -1
  433. package/lib/esm/geometry3d/GrowableFloat64Array.js +11 -1
  434. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  435. package/lib/esm/geometry3d/GrowableXYArray.d.ts +1 -1
  436. package/lib/esm/geometry3d/GrowableXYArray.js +1 -1
  437. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  438. package/lib/esm/geometry3d/GrowableXYZArray.d.ts +49 -8
  439. package/lib/esm/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  440. package/lib/esm/geometry3d/GrowableXYZArray.js +90 -37
  441. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  442. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts +100 -3
  443. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  444. package/lib/esm/geometry3d/IndexedXYZCollection.js +125 -0
  445. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  446. package/lib/esm/geometry3d/Matrix3d.d.ts +10 -1
  447. package/lib/esm/geometry3d/Matrix3d.d.ts.map +1 -1
  448. package/lib/esm/geometry3d/Matrix3d.js +53 -34
  449. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  450. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js +1 -1
  451. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  452. package/lib/esm/geometry3d/Point3dArrayCarrier.d.ts +49 -2
  453. package/lib/esm/geometry3d/Point3dArrayCarrier.d.ts.map +1 -1
  454. package/lib/esm/geometry3d/Point3dArrayCarrier.js +67 -9
  455. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  456. package/lib/esm/geometry3d/Point3dVector3d.d.ts +1 -1
  457. package/lib/esm/geometry3d/Point3dVector3d.js +1 -1
  458. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  459. package/lib/esm/geometry3d/PointStreaming.js +1 -1
  460. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  461. package/lib/esm/geometry3d/PolygonOps.d.ts +24 -32
  462. package/lib/esm/geometry3d/PolygonOps.d.ts.map +1 -1
  463. package/lib/esm/geometry3d/PolygonOps.js +147 -180
  464. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  465. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js +5 -5
  466. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  467. package/lib/esm/geometry3d/PolylineOps.d.ts.map +1 -1
  468. package/lib/esm/geometry3d/PolylineOps.js +13 -3
  469. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  470. package/lib/esm/geometry3d/Range.js.map +1 -1
  471. package/lib/esm/geometry3d/Ray3d.d.ts +0 -3
  472. package/lib/esm/geometry3d/Ray3d.d.ts.map +1 -1
  473. package/lib/esm/geometry3d/Ray3d.js +5 -1
  474. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  475. package/lib/esm/geometry3d/SortablePolygon.d.ts +2 -2
  476. package/lib/esm/geometry3d/SortablePolygon.d.ts.map +1 -1
  477. package/lib/esm/geometry3d/SortablePolygon.js +14 -18
  478. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  479. package/lib/esm/geometry3d/Transform.d.ts +8 -0
  480. package/lib/esm/geometry3d/Transform.d.ts.map +1 -1
  481. package/lib/esm/geometry3d/Transform.js +15 -9
  482. package/lib/esm/geometry3d/Transform.js.map +1 -1
  483. package/lib/esm/numerics/ClusterableArray.d.ts +4 -2
  484. package/lib/esm/numerics/ClusterableArray.d.ts.map +1 -1
  485. package/lib/esm/numerics/ClusterableArray.js +6 -4
  486. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  487. package/lib/esm/numerics/Newton.d.ts +3 -1
  488. package/lib/esm/numerics/Newton.d.ts.map +1 -1
  489. package/lib/esm/numerics/Newton.js +5 -1
  490. package/lib/esm/numerics/Newton.js.map +1 -1
  491. package/lib/esm/polyface/AuxData.d.ts +1 -4
  492. package/lib/esm/polyface/AuxData.d.ts.map +1 -1
  493. package/lib/esm/polyface/AuxData.js +5 -1
  494. package/lib/esm/polyface/AuxData.js.map +1 -1
  495. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js +3 -3
  496. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  497. package/lib/esm/polyface/Polyface.d.ts.map +1 -1
  498. package/lib/esm/polyface/Polyface.js +14 -16
  499. package/lib/esm/polyface/Polyface.js.map +1 -1
  500. package/lib/esm/polyface/PolyfaceBuilder.d.ts +84 -28
  501. package/lib/esm/polyface/PolyfaceBuilder.d.ts.map +1 -1
  502. package/lib/esm/polyface/PolyfaceBuilder.js +277 -217
  503. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  504. package/lib/esm/polyface/PolyfaceClip.d.ts +4 -3
  505. package/lib/esm/polyface/PolyfaceClip.d.ts.map +1 -1
  506. package/lib/esm/polyface/PolyfaceClip.js +11 -4
  507. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  508. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  509. package/lib/esm/polyface/PolyfaceQuery.d.ts.map +1 -1
  510. package/lib/esm/polyface/PolyfaceQuery.js +9 -7
  511. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  512. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.d.ts.map +1 -1
  513. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js +3 -2
  514. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  515. package/lib/esm/polyface/RangeTree/RangeTreeNode.d.ts +1 -1
  516. package/lib/esm/polyface/RangeTree/RangeTreeNode.js +2 -2
  517. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  518. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.d.ts.map +1 -1
  519. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js +14 -12
  520. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  521. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.d.ts +1 -1
  522. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.d.ts.map +1 -1
  523. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js +10 -6
  524. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  525. package/lib/esm/polyface/multiclip/OffsetMeshContext.js +4 -3
  526. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  527. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.d.ts.map +1 -1
  528. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js +3 -5
  529. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  530. package/lib/esm/polyface/multiclip/XYPointBuckets.d.ts +1 -1
  531. package/lib/esm/polyface/multiclip/XYPointBuckets.d.ts.map +1 -1
  532. package/lib/esm/polyface/multiclip/XYPointBuckets.js +4 -8
  533. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  534. package/lib/esm/serialization/BGFBAccessors.d.ts.map +1 -1
  535. package/lib/esm/serialization/BGFBAccessors.js +1 -0
  536. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  537. package/lib/esm/serialization/BGFBReader.d.ts.map +1 -1
  538. package/lib/esm/serialization/BGFBReader.js +37 -7
  539. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  540. package/lib/esm/serialization/BGFBWriter.d.ts +4 -4
  541. package/lib/esm/serialization/BGFBWriter.d.ts.map +1 -1
  542. package/lib/esm/serialization/BGFBWriter.js +24 -40
  543. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  544. package/lib/esm/serialization/IModelJsonSchema.d.ts.map +1 -1
  545. package/lib/esm/serialization/IModelJsonSchema.js +9 -3
  546. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  547. package/lib/esm/serialization/SerializationHelpers.d.ts +0 -3
  548. package/lib/esm/serialization/SerializationHelpers.d.ts.map +1 -1
  549. package/lib/esm/serialization/SerializationHelpers.js +16 -7
  550. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  551. package/lib/esm/solid/Box.d.ts +2 -2
  552. package/lib/esm/solid/Box.d.ts.map +1 -1
  553. package/lib/esm/solid/Box.js.map +1 -1
  554. package/lib/esm/solid/Cone.d.ts +3 -2
  555. package/lib/esm/solid/Cone.d.ts.map +1 -1
  556. package/lib/esm/solid/Cone.js +4 -1
  557. package/lib/esm/solid/Cone.js.map +1 -1
  558. package/lib/esm/solid/LinearSweep.d.ts +1 -1
  559. package/lib/esm/solid/LinearSweep.d.ts.map +1 -1
  560. package/lib/esm/solid/LinearSweep.js +1 -1
  561. package/lib/esm/solid/LinearSweep.js.map +1 -1
  562. package/lib/esm/solid/RotationalSweep.d.ts.map +1 -1
  563. package/lib/esm/solid/RotationalSweep.js +1 -3
  564. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  565. package/lib/esm/solid/TorusPipe.d.ts +4 -3
  566. package/lib/esm/solid/TorusPipe.d.ts.map +1 -1
  567. package/lib/esm/solid/TorusPipe.js.map +1 -1
  568. package/lib/esm/topology/ChainMerge.d.ts +4 -4
  569. package/lib/esm/topology/ChainMerge.d.ts.map +1 -1
  570. package/lib/esm/topology/ChainMerge.js +11 -1
  571. package/lib/esm/topology/ChainMerge.js.map +1 -1
  572. package/lib/esm/topology/Graph.d.ts +2 -0
  573. package/lib/esm/topology/Graph.d.ts.map +1 -1
  574. package/lib/esm/topology/Graph.js +5 -0
  575. package/lib/esm/topology/Graph.js.map +1 -1
  576. package/lib/esm/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  577. package/lib/esm/topology/HalfEdgeGraphSearch.js +2 -0
  578. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  579. package/lib/esm/topology/HalfEdgePointInGraphSearch.d.ts.map +1 -1
  580. package/lib/esm/topology/HalfEdgePointInGraphSearch.js +23 -16
  581. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  582. package/lib/esm/topology/HalfEdgePositionDetail.d.ts +20 -9
  583. package/lib/esm/topology/HalfEdgePositionDetail.d.ts.map +1 -1
  584. package/lib/esm/topology/HalfEdgePositionDetail.js +17 -13
  585. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  586. package/lib/esm/topology/HalfEdgePriorityQueue.d.ts.map +1 -1
  587. package/lib/esm/topology/HalfEdgePriorityQueue.js +4 -2
  588. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  589. package/lib/esm/topology/InsertAndRetriangulateContext.d.ts +6 -2
  590. package/lib/esm/topology/InsertAndRetriangulateContext.d.ts.map +1 -1
  591. package/lib/esm/topology/InsertAndRetriangulateContext.js +41 -35
  592. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  593. package/lib/esm/topology/MaskManager.d.ts +7 -3
  594. package/lib/esm/topology/MaskManager.d.ts.map +1 -1
  595. package/lib/esm/topology/MaskManager.js +10 -4
  596. package/lib/esm/topology/MaskManager.js.map +1 -1
  597. package/lib/esm/topology/RegularizeFace.d.ts.map +1 -1
  598. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  599. package/lib/esm/topology/Triangulation.d.ts +2 -1
  600. package/lib/esm/topology/Triangulation.d.ts.map +1 -1
  601. package/lib/esm/topology/Triangulation.js +12 -7
  602. package/lib/esm/topology/Triangulation.js.map +1 -1
  603. package/package.json +3 -3
  604. package/lib/cjs/serialization/GeometrySamples.d.ts +0 -705
  605. package/lib/cjs/serialization/GeometrySamples.d.ts.map +0 -1
  606. package/lib/cjs/serialization/GeometrySamples.js +0 -2433
  607. package/lib/cjs/serialization/GeometrySamples.js.map +0 -1
  608. package/lib/esm/serialization/GeometrySamples.d.ts +0 -705
  609. package/lib/esm/serialization/GeometrySamples.d.ts.map +0 -1
  610. package/lib/esm/serialization/GeometrySamples.js +0 -2428
  611. package/lib/esm/serialization/GeometrySamples.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"BGFBReader.d.ts","sourceRoot":"","sources":["../../../src/serialization/BGFBReader.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BGFBReader.d.ts","sourceRoot":"","sources":["../../../src/serialization/BGFBReader.ts"],"names":[],"mappings":"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"}
@@ -162,9 +162,11 @@ export class BGFBReader {
162
162
  readTransitionSpiral(header) {
163
163
  const detailHeader = header.detail();
164
164
  if (detailHeader) {
165
- const directDetailHeader = header.directDetail();
166
- const _extraDataArray = header.extraDataArray();
165
+ const directDetailHeader = header.directDetail(); // unpersisted but repopulated
166
+ // const extraDataArray = header.extraDataArray(); // unpersisted and ignored
167
167
  const spiralTypeName = DgnSpiralTypeQueries.typeCodeToString(detailHeader.spiralType());
168
+ if (!spiralTypeName)
169
+ return undefined;
168
170
  const curvature0 = detailHeader.curvature0();
169
171
  const curvature1 = detailHeader.curvature1();
170
172
  const bearing0Radians = detailHeader.bearing0Radians();
@@ -195,20 +197,29 @@ export class BGFBReader {
195
197
  const geometryType = variant.geometryType();
196
198
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineSegment) {
197
199
  const offsetToLineSegment = variant.geometry(new BGFBAccessors.LineSegment());
200
+ assert(offsetToLineSegment !== null, "expect defined because LineSegment is defined by VariantGeometryUnion schema");
198
201
  const offsetToCoordinates = offsetToLineSegment.segment();
202
+ assert(offsetToCoordinates !== null, "expect defined because `segment` is defined by LineSegment schema");
199
203
  return LineSegment3d.createXYZXYZ(offsetToCoordinates.point0X(), offsetToCoordinates.point0Y(), offsetToCoordinates.point0Z(), offsetToCoordinates.point1X(), offsetToCoordinates.point1Y(), offsetToCoordinates.point1Z());
200
204
  }
201
205
  else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagEllipticArc) {
202
206
  const offsetToEllipticArc = variant.geometry(new BGFBAccessors.EllipticArc());
207
+ assert(offsetToEllipticArc !== null, "expect defined because EllipticArc is defined by VariantGeometryUnion schema");
203
208
  const offsetToCoordinates = offsetToEllipticArc.arc();
204
- return Arc3d.createXYZXYZXYZ(offsetToCoordinates.centerX(), offsetToCoordinates.centerY(), offsetToCoordinates.centerZ(), offsetToCoordinates.vector0X(), offsetToCoordinates.vector0Y(), offsetToCoordinates.vector0Z(), offsetToCoordinates.vector90X(), offsetToCoordinates.vector90Y(), offsetToCoordinates.vector90Z(), AngleSweep.createStartSweepRadians(offsetToCoordinates.startRadians(), offsetToCoordinates?.sweepRadians()));
209
+ assert(offsetToCoordinates !== null, "expect defined because `arc` is defined by EllipticArc schema");
210
+ return Arc3d.createXYZXYZXYZ(offsetToCoordinates.centerX(), offsetToCoordinates.centerY(), offsetToCoordinates.centerZ(), offsetToCoordinates.vector0X(), offsetToCoordinates.vector0Y(), offsetToCoordinates.vector0Z(), offsetToCoordinates.vector90X(), offsetToCoordinates.vector90Y(), offsetToCoordinates.vector90Z(), AngleSweep.createStartSweepRadians(offsetToCoordinates.startRadians(), offsetToCoordinates.sweepRadians()));
205
211
  }
206
212
  else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineString) {
207
213
  const offsetToLineString = variant.geometry(new BGFBAccessors.LineString());
214
+ assert(offsetToLineString !== null, "expect defined because LineString is defined by VariantGeometryUnion schema");
208
215
  const numCoordinates = offsetToLineString.pointsLength();
209
216
  const result = LineString3d.create();
210
217
  for (let i = 0; i + 2 < numCoordinates; i += 3) {
211
- result.packedPoints.pushXYZ(offsetToLineString.points(i), offsetToLineString.points(i + 1), offsetToLineString.points(i + 2));
218
+ const p0 = offsetToLineString.points(i);
219
+ const p1 = offsetToLineString.points(i + 1);
220
+ const p2 = offsetToLineString.points(i + 2);
221
+ assert(p0 !== null && p1 !== null && p2 !== null, "expect defined because `points` is defined by LineString schema and indices are valid");
222
+ result.packedPoints.pushXYZ(p0, p1, p2);
212
223
  }
213
224
  return result;
214
225
  }
@@ -242,10 +253,15 @@ export class BGFBReader {
242
253
  const geometryType = variant.geometryType();
243
254
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPointString) {
244
255
  const offsetToLineString = variant.geometry(new BGFBAccessors.PointString());
256
+ assert(offsetToLineString !== null, "expect defined because PointString is defined by VariantGeometryUnion schema");
245
257
  const numCoordinates = offsetToLineString.pointsLength();
246
258
  const result = PointString3d.create();
247
259
  for (let i = 0; i + 2 < numCoordinates; i += 3) {
248
- result.points.push(Point3d.create(offsetToLineString.points(i), offsetToLineString.points(i + 1), offsetToLineString.points(i + 2)));
260
+ const p0 = offsetToLineString.points(i);
261
+ const p1 = offsetToLineString.points(i + 1);
262
+ const p2 = offsetToLineString.points(i + 2);
263
+ assert(p0 !== null && p1 !== null && p2 !== null, "expect defined because `points` is defined by PointString schema and indices are valid");
264
+ result.points.push(Point3d.create(p0, p1, p2));
249
265
  }
250
266
  return result;
251
267
  }
@@ -501,6 +517,7 @@ export class BGFBReader {
501
517
  const geometryType = variant.geometryType();
502
518
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagCurveVector) {
503
519
  const cvTable = variant.geometry(new BGFBAccessors.CurveVector());
520
+ assert(cvTable !== null, "expect defined because CurveVector is defined by VariantGeometryUnion schema");
504
521
  return this.readCurveCollectionFromCurveVectorTable(cvTable);
505
522
  }
506
523
  return undefined;
@@ -513,19 +530,26 @@ export class BGFBReader {
513
530
  const geometryType = variant.geometryType();
514
531
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnBox) {
515
532
  const header = variant.geometry(new BGFBAccessors.DgnBox());
533
+ assert(header !== null, "expect defined because DgnBox is defined by VariantGeometryUnion schema");
516
534
  const detail = header.detail();
535
+ assert(detail !== null, "expect defined because `detail` is defined by DgnBox schema");
517
536
  return Box.createDgnBox(Point3d.create(detail.baseOriginX(), detail.baseOriginY(), detail.baseOriginZ()), Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ()), Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ()), Point3d.create(detail.topOriginX(), detail.topOriginY(), detail.topOriginZ()), detail.baseX(), detail.baseY(), detail.topX(), detail.topY(), detail.capped());
518
537
  }
519
538
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnSphere) {
520
539
  const header = variant.geometry(new BGFBAccessors.DgnSphere());
540
+ assert(header !== null, "expect defined because DgnSphere is defined by VariantGeometryUnion schema");
521
541
  const detail = header.detail();
522
- const lToWDetail = detail.localToWorld();
523
- const localToWorld = Transform.createRowValues(lToWDetail.axx(), lToWDetail.axy(), lToWDetail.axz(), lToWDetail.axw(), lToWDetail.ayx(), lToWDetail.ayy(), lToWDetail.ayz(), lToWDetail.ayw(), lToWDetail.azx(), lToWDetail.azy(), lToWDetail.azz(), lToWDetail.azw());
542
+ assert(detail !== null, "expect defined because `detail` is defined by DgnSphere schema");
543
+ const dLocalToWorld = detail.localToWorld();
544
+ assert(dLocalToWorld !== null, "expect defined because `localToWorld` is defined by DgnSphereDetail schema");
545
+ const localToWorld = Transform.createRowValues(dLocalToWorld.axx(), dLocalToWorld.axy(), dLocalToWorld.axz(), dLocalToWorld.axw(), dLocalToWorld.ayx(), dLocalToWorld.ayy(), dLocalToWorld.ayz(), dLocalToWorld.ayw(), dLocalToWorld.azx(), dLocalToWorld.azy(), dLocalToWorld.azz(), dLocalToWorld.azw());
524
546
  return Sphere.createEllipsoid(localToWorld, AngleSweep.createStartSweepRadians(detail.startLatitudeRadians(), detail.latitudeSweepRadians()), detail.capped());
525
547
  }
526
548
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnCone) {
527
549
  const header = variant.geometry(new BGFBAccessors.DgnCone());
550
+ assert(header !== null, "expect defined because DgnCone is defined by VariantGeometryUnion schema");
528
551
  const detail = header.detail();
552
+ assert(detail !== null, "expect defined because `detail` is defined by DgnCone schema");
529
553
  const centerA = Point3d.create(detail.centerAX(), detail.centerAY(), detail.centerAZ());
530
554
  const centerB = Point3d.create(detail.centerBX(), detail.centerBY(), detail.centerBZ());
531
555
  const vector0 = Vector3d.create(detail.vector0X(), detail.vector0Y(), detail.vector0Z());
@@ -536,7 +560,9 @@ export class BGFBReader {
536
560
  }
537
561
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe) {
538
562
  const header = variant.geometry(new BGFBAccessors.DgnTorusPipe());
563
+ assert(header !== null, "expect defined because DgnTorusPipe is defined by VariantGeometryUnion schema");
539
564
  const detail = header.detail();
565
+ assert(detail !== null, "expect defined because `detail` is defined by DgnTorusPipe schema");
540
566
  const center = Point3d.create(detail.centerX(), detail.centerY(), detail.centerZ());
541
567
  const vectorX = Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ());
542
568
  const vectorY = Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ());
@@ -547,6 +573,7 @@ export class BGFBReader {
547
573
  }
548
574
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion) {
549
575
  const header = variant.geometry(new BGFBAccessors.DgnExtrusion());
576
+ assert(header !== null, "expect defined because DgnExtrusion is defined by VariantGeometryUnion schema");
550
577
  const dVector = new BGFBAccessors.DVector3d();
551
578
  header.extrusionVector(dVector);
552
579
  const extrusionVector = Vector3d.create(dVector.x(), dVector.y(), dVector.z());
@@ -558,6 +585,7 @@ export class BGFBReader {
558
585
  }
559
586
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep) {
560
587
  const header = variant.geometry(new BGFBAccessors.DgnRotationalSweep());
588
+ assert(header !== null, "expect defined because DgnRotationalSweep is defined by VariantGeometryUnion schema");
561
589
  const dAxis = new BGFBAccessors.DRay3d();
562
590
  header.axis(dAxis);
563
591
  const axis = Ray3d.createXYZUVW(dAxis.x(), dAxis.y(), dAxis.z(), dAxis.ux(), dAxis.uy(), dAxis.uz());
@@ -571,6 +599,7 @@ export class BGFBReader {
571
599
  }
572
600
  if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep) {
573
601
  const header = variant.geometry(new BGFBAccessors.DgnRuledSweep());
602
+ assert(header !== null, "expect defined because DgnRuledSweep is defined by VariantGeometryUnion schema");
574
603
  const numCurves = header.curvesLength();
575
604
  const contours = [];
576
605
  for (let i = 0; i < numCurves; i++) {
@@ -621,6 +650,7 @@ export class BGFBReader {
621
650
  case BGFBAccessors.VariantGeometryUnion.tagVectorOfVariantGeometry: {
622
651
  const geometry = [];
623
652
  const offsetToVectorOfVariantGeometry = variant.geometry(new BGFBAccessors.VectorOfVariantGeometry());
653
+ assert(offsetToVectorOfVariantGeometry !== null, "expect defined because VectorOfVariantGeometry is defined by VariantGeometryUnion schema");
624
654
  for (let i = 0; i < offsetToVectorOfVariantGeometry.membersLength(); i++) {
625
655
  const child = offsetToVectorOfVariantGeometry.members(i);
626
656
  if (child !== null) {
@@ -1 +1 @@
1
- {"version":3,"file":"BGFBReader.js","sourceRoot":"","sources":["../../../src/serialization/BGFBReader.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\nimport { flatbuffers } from \"flatbuffers\";\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { AkimaCurve3d, AkimaCurve3dOptions } from \"../bspline/AkimaCurve3d\";\r\nimport { BSplineCurve3d } from \"../bspline/BSplineCurve\";\r\nimport { BSplineCurve3dH } from \"../bspline/BSplineCurve3dH\";\r\nimport { BSplineSurface3d, BSplineSurface3dH, UVSelect } from \"../bspline/BSplineSurface\";\r\nimport { InterpolationCurve3d, InterpolationCurve3dOptions } from \"../bspline/InterpolationCurve3d\";\r\nimport { Arc3d } from \"../curve/Arc3d\";\r\nimport { BagOfCurves, CurveCollection } from \"../curve/CurveCollection\";\r\nimport { CurvePrimitive } from \"../curve/CurvePrimitive\";\r\nimport { GeometryQuery } from \"../curve/GeometryQuery\";\r\nimport { LineSegment3d } from \"../curve/LineSegment3d\";\r\nimport { LineString3d } from \"../curve/LineString3d\";\r\nimport { Loop } from \"../curve/Loop\";\r\nimport { ParityRegion } from \"../curve/ParityRegion\";\r\nimport { Path } from \"../curve/Path\";\r\nimport { PointString3d } from \"../curve/PointString3d\";\r\nimport { DirectSpiral3d } from \"../curve/spiral/DirectSpiral3d\";\r\nimport { IntegratedSpiral3d } from \"../curve/spiral/IntegratedSpiral3d\";\r\nimport { TransitionSpiral3d } from \"../curve/spiral/TransitionSpiral3d\";\r\nimport { UnionRegion } from \"../curve/UnionRegion\";\r\nimport { Geometry } from \"../Geometry\";\r\nimport { Angle } from \"../geometry3d/Angle\";\r\nimport { AngleSweep } from \"../geometry3d/AngleSweep\";\r\nimport { Point3d, Vector3d } from \"../geometry3d/Point3dVector3d\";\r\nimport { NumberArray, Point3dArray } from \"../geometry3d/PointHelpers\";\r\nimport { Ray3d } from \"../geometry3d/Ray3d\";\r\nimport { Segment1d } from \"../geometry3d/Segment1d\";\r\nimport { Transform } from \"../geometry3d/Transform\";\r\nimport { AuxChannel, AuxChannelData, PolyfaceAuxData } from \"../polyface/AuxData\";\r\nimport { IndexedPolyface } from \"../polyface/Polyface\";\r\nimport { TaggedNumericData } from \"../polyface/TaggedNumericData\";\r\nimport { Box } from \"../solid/Box\";\r\nimport { Cone } from \"../solid/Cone\";\r\nimport { LinearSweep } from \"../solid/LinearSweep\";\r\nimport { RotationalSweep } from \"../solid/RotationalSweep\";\r\nimport { RuledSweep } from \"../solid/RuledSweep\";\r\nimport { SolidPrimitive } from \"../solid/SolidPrimitive\";\r\nimport { Sphere } from \"../solid/Sphere\";\r\nimport { TorusPipe } from \"../solid/TorusPipe\";\r\nimport { BGFBAccessors } from \"./BGFBAccessors\";\r\nimport { SerializationHelpers } from \"./SerializationHelpers\";\r\n\r\n/** * Context to write to a flatbuffer blob.\r\n * * This class is internal.\r\n * * Public access is through BentleyGeometryFlatBuffer.geometryToBytes()\r\n * @internal\r\n */\r\nexport class BGFBReader {\r\n public constructor() {\r\n }\r\n /**\r\n * Extract a bspline surface\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readBSplineSurfaceFromVariant(variantHeader: BGFBAccessors.VariantGeometry): BSplineSurface3d | BSplineSurface3dH | undefined {\r\n let newSurface: BSplineSurface3d | BSplineSurface3dH | undefined;\r\n const geometryType = variantHeader.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineSurface) {\r\n const bsurfHeader = variantHeader.geometry(new BGFBAccessors.BsplineSurface());\r\n if (bsurfHeader !== null) {\r\n const orderU = bsurfHeader.orderU();\r\n const orderV = bsurfHeader.orderV();\r\n const numPolesU = bsurfHeader.numPolesU();\r\n const numPolesV = bsurfHeader.numPolesV();\r\n const xyzArray = bsurfHeader.polesArray();\r\n const knotArrayU = bsurfHeader.knotsUArray();\r\n const knotArrayV = bsurfHeader.knotsVArray();\r\n const weightArray = bsurfHeader.weightsArray();\r\n const closedU = bsurfHeader.closedU();\r\n const closedV = bsurfHeader.closedV();\r\n\r\n if (xyzArray !== null && knotArrayU !== null && knotArrayV !== null) {\r\n const myData = SerializationHelpers.createBSplineSurfaceData(xyzArray, 3, knotArrayU, numPolesU, orderU, knotArrayV, numPolesV, orderV);\r\n if (weightArray !== null)\r\n myData.weights = weightArray;\r\n if (closedU)\r\n myData.uParams.closed = true;\r\n if (closedV)\r\n myData.vParams.closed = true;\r\n\r\n if (SerializationHelpers.Import.prepareBSplineSurfaceData(myData, { jsonPoles: false })) {\r\n if (undefined === myData.weights)\r\n newSurface = BSplineSurface3d.create(myData.poles as Float64Array, myData.uParams.numPoles, myData.uParams.order, myData.uParams.knots, myData.vParams.numPoles, myData.vParams.order, myData.vParams.knots);\r\n else\r\n newSurface = BSplineSurface3dH.create(myData.poles as Float64Array, myData.weights as Float64Array, myData.uParams.numPoles, myData.uParams.order, myData.uParams.knots, myData.vParams.numPoles, myData.vParams.order, myData.vParams.knots);\r\n\r\n if (undefined !== newSurface) {\r\n if (undefined !== myData.uParams.wrapMode)\r\n newSurface.setWrappable(UVSelect.uDirection, myData.uParams.wrapMode);\r\n if (undefined !== myData.vParams.wrapMode)\r\n newSurface.setWrappable(UVSelect.vDirection, myData.vParams.wrapMode);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n return newSurface;\r\n }\r\n\r\n /**\r\n * Extract an interpolating curve\r\n * @param header read position in the flat buffer.\r\n */\r\n public readInterpolationCurve3d(header: BGFBAccessors.InterpolationCurve): InterpolationCurve3d | undefined {\r\n const xyzArray = header.fitPointsArray();\r\n if (xyzArray instanceof Float64Array) {\r\n const knots = header.knotsArray();\r\n const options = new InterpolationCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray), knots ? NumberArray.create(knots) : undefined);\r\n const startTangent = header.startTangent();\r\n const endTangent = header.endTangent();\r\n options.captureOptionalProps(\r\n header.order(),\r\n header.closed(),\r\n header.isChordLenKnots(),\r\n header.isColinearTangents(),\r\n header.isChordLenTangents(),\r\n header.isNaturalTangents(),\r\n startTangent !== null ? Vector3d.create(startTangent.x(), startTangent.y(), startTangent.z()) : undefined,\r\n endTangent !== null ? Vector3d.create(endTangent.x(), endTangent.y(), endTangent.z()) : undefined);\r\n return InterpolationCurve3d.createCapture(options);\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Extract an akima curve\r\n * @param header read position in the flat buffer.\r\n */\r\n public readAkimaCurve3d(header: BGFBAccessors.AkimaCurve): AkimaCurve3d | undefined {\r\n const xyzArray = header.pointsArray();\r\n if (xyzArray instanceof Float64Array) {\r\n const options = new AkimaCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray));\r\n return AkimaCurve3d.createCapture(options);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a bspline curve\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readBSplineCurve(header: BGFBAccessors.BsplineCurve): BSplineCurve3d | BSplineCurve3dH | undefined {\r\n let newCurve: BSplineCurve3d | BSplineCurve3dH | undefined;\r\n const order = header.order();\r\n const xyzArray = header.polesArray();\r\n const knots = header.knotsArray();\r\n const weightsArray = header.weightsArray();\r\n const closed = header.closed();\r\n\r\n if (xyzArray !== null && knots !== null) {\r\n const numPoles = Math.floor(xyzArray.length / 3);\r\n const myData = SerializationHelpers.createBSplineCurveData(xyzArray, 3, knots, numPoles, order);\r\n if (closed)\r\n myData.params.closed = true;\r\n\r\n if (weightsArray === null) {\r\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData))\r\n newCurve = BSplineCurve3d.create(myData.poles, myData.params.knots, myData.params.order);\r\n } else {\r\n myData.weights = weightsArray;\r\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData, { jsonPoles: false }))\r\n newCurve = BSplineCurve3dH.create({ xyz: myData.poles as Float64Array, weights: myData.weights }, myData.params.knots, myData.params.order);\r\n }\r\n\r\n if (undefined !== newCurve) {\r\n if (undefined !== myData.params.wrapMode)\r\n newCurve.setWrappable(myData.params.wrapMode);\r\n }\r\n }\r\n return newCurve;\r\n }\r\n /**\r\n * Extract a bspline curve\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readTransitionSpiral(header: BGFBAccessors.TransitionSpiral): TransitionSpiral3d | undefined {\r\n const detailHeader = header.detail();\r\n if (detailHeader) {\r\n const directDetailHeader = header.directDetail();\r\n const _extraDataArray = header.extraDataArray();\r\n const spiralTypeName = DgnSpiralTypeQueries.typeCodeToString(detailHeader.spiralType());\r\n const curvature0 = detailHeader.curvature0();\r\n const curvature1 = detailHeader.curvature1();\r\n const bearing0Radians = detailHeader.bearing0Radians();\r\n const bearing1Radians = detailHeader.bearing1Radians();\r\n const fbTransform = detailHeader.transform();\r\n const localToWorld = fbTransform ? Transform.createRowValues(\r\n fbTransform.axx(), fbTransform.axy(), fbTransform.axz(), fbTransform.axw(),\r\n fbTransform.ayx(), fbTransform.ayy(), fbTransform.ayz(), fbTransform.ayw(),\r\n fbTransform.azx(), fbTransform.azy(), fbTransform.azz(), fbTransform.azw()) :\r\n Transform.createIdentity();\r\n\r\n const activeFractionInterval = Segment1d.create(detailHeader.fractionA(),\r\n detailHeader.fractionB());\r\n if (!directDetailHeader) {\r\n const integratedSpiral = IntegratedSpiral3d.createRadiusRadiusBearingBearing(\r\n Segment1d.create(IntegratedSpiral3d.curvatureToRadius(curvature0), IntegratedSpiral3d.curvatureToRadius(curvature1)),\r\n AngleSweep.createStartEndRadians(bearing0Radians, bearing1Radians),\r\n activeFractionInterval, localToWorld, spiralTypeName);\r\n if (integratedSpiral)\r\n return integratedSpiral;\r\n const radius0 = TransitionSpiral3d.curvatureToRadius(curvature0);\r\n const radius1 = TransitionSpiral3d.curvatureToRadius(curvature1);\r\n const arcLength = TransitionSpiral3d.radiusRadiusSweepRadiansToArcLength(radius0, radius1,\r\n bearing1Radians - bearing0Radians);\r\n const directSpiral = DirectSpiral3d.createFromLengthAndRadius(\r\n spiralTypeName!,\r\n radius0, radius1,\r\n Angle.createRadians(bearing0Radians),\r\n Angle.createRadians(bearing1Radians),\r\n arcLength,\r\n activeFractionInterval,\r\n localToWorld);\r\n if (directSpiral)\r\n return directSpiral;\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve primitive\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readCurvePrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): CurvePrimitive | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineSegment) {\r\n const offsetToLineSegment = variant.geometry(new BGFBAccessors.LineSegment());\r\n const offsetToCoordinates = offsetToLineSegment!.segment();\r\n return LineSegment3d.createXYZXYZ(\r\n offsetToCoordinates!.point0X(), offsetToCoordinates!.point0Y(), offsetToCoordinates!.point0Z(),\r\n offsetToCoordinates!.point1X(), offsetToCoordinates!.point1Y(), offsetToCoordinates!.point1Z());\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagEllipticArc) {\r\n const offsetToEllipticArc = variant.geometry(new BGFBAccessors.EllipticArc());\r\n const offsetToCoordinates = offsetToEllipticArc!.arc()!;\r\n return Arc3d.createXYZXYZXYZ(\r\n offsetToCoordinates.centerX(), offsetToCoordinates.centerY(), offsetToCoordinates.centerZ(),\r\n offsetToCoordinates.vector0X(), offsetToCoordinates.vector0Y(), offsetToCoordinates.vector0Z(),\r\n offsetToCoordinates.vector90X(), offsetToCoordinates.vector90Y(), offsetToCoordinates.vector90Z(),\r\n AngleSweep.createStartSweepRadians(offsetToCoordinates.startRadians(), offsetToCoordinates?.sweepRadians()));\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineString) {\r\n const offsetToLineString = variant.geometry(new BGFBAccessors.LineString())!;\r\n const numCoordinates = offsetToLineString.pointsLength();\r\n const result = LineString3d.create();\r\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\r\n result.packedPoints.pushXYZ(offsetToLineString.points(i)!, offsetToLineString.points(i + 1)!, offsetToLineString.points(i + 2)!);\r\n }\r\n return result;\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineCurve) {\r\n const offsetToBCurve = variant.geometry(new BGFBAccessors.BsplineCurve());\r\n if (offsetToBCurve !== null)\r\n return this.readBSplineCurve(offsetToBCurve);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral) {\r\n const offsetToTransitionSpiralTable = variant.geometry(new BGFBAccessors.TransitionSpiral());\r\n if (offsetToTransitionSpiralTable !== null)\r\n return this.readTransitionSpiral(offsetToTransitionSpiralTable);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve) {\r\n const offsetToInterpolationCurveTable = variant.geometry(new BGFBAccessors.InterpolationCurve());\r\n if (offsetToInterpolationCurveTable !== null)\r\n return this.readInterpolationCurve3d(offsetToInterpolationCurveTable);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagAkimaCurve) {\r\n const offsetToAkimaCurveTable = variant.geometry(new BGFBAccessors.AkimaCurve());\r\n if (offsetToAkimaCurveTable !== null)\r\n return this.readAkimaCurve3d(offsetToAkimaCurveTable);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve primitive\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readPointStringFromVariant(variant: BGFBAccessors.VariantGeometry): PointString3d | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPointString) {\r\n const offsetToLineString = variant.geometry(new BGFBAccessors.PointString())!;\r\n const numCoordinates = offsetToLineString.pointsLength();\r\n const result = PointString3d.create();\r\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\r\n result.points.push(Point3d.create(offsetToLineString.points(i)!, offsetToLineString.points(i + 1)!, offsetToLineString.points(i + 2)!));\r\n }\r\n return result;\r\n }\r\n return undefined;\r\n }\r\n /** Extract auxData channel data for a mesh */\r\n public readPolyfaceAuxChannelData(channelDataHeader: BGFBAccessors.PolyfaceAuxChannelData | null): AuxChannelData | undefined {\r\n if (channelDataHeader !== null) {\r\n const input = channelDataHeader.input();\r\n const values = channelDataHeader.valuesArray();\r\n if (values !== null)\r\n return new AuxChannelData(input, values);\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Extract auxData channel for a mesh */\r\n public readPolyfaceAuxChannel(channelHeader: BGFBAccessors.PolyfaceAuxChannel | null): AuxChannel | undefined {\r\n if (channelHeader) {\r\n const dataType = channelHeader.dataType();\r\n const dataLength = channelHeader.dataLength();\r\n const channelDataArray: AuxChannelData[] = [];\r\n const name = channelHeader.name();\r\n const inputName = channelHeader.inputName();\r\n for (let i = 0; i < dataLength; i++) {\r\n const channelData = this.readPolyfaceAuxChannelData(channelHeader.data(i));\r\n if (channelData)\r\n channelDataArray.push(channelData);\r\n }\r\n return new AuxChannel(channelDataArray, dataType, name ? name : undefined, inputName ? inputName : undefined);\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Compute the number of logical entries in every flat data array in the AuxData */\r\n private static channelDataLength(fbAuxData: BGFBAccessors.PolyfaceAuxData): number {\r\n if (fbAuxData.channelsLength() <= 0)\r\n return 0;\r\n\r\n const fbChannel0 = nullToUndefined<BGFBAccessors.PolyfaceAuxChannel>(fbAuxData.channels(0));\r\n if (!fbChannel0)\r\n return 0;\r\n\r\n const numChannel0Data = fbChannel0.dataLength();\r\n if (numChannel0Data <= 0)\r\n return 0;\r\n\r\n const fbChannel0Data0 = nullToUndefined<BGFBAccessors.PolyfaceAuxChannelData>(fbChannel0.data(0));\r\n if (!fbChannel0Data0)\r\n return 0;\r\n\r\n const numChannelDataValues = fbChannel0Data0.valuesLength();\r\n if (numChannelDataValues <= 0)\r\n return 0;\r\n\r\n return numChannelDataValues / AuxChannel.entriesPerValue(fbChannel0.dataType());\r\n }\r\n\r\n /** Examine int array for range and zero count */\r\n private countIntArray(ints: Int32Array): { min: number, max: number, numZeroes: number } {\r\n let min = Infinity;\r\n let max = -Infinity;\r\n let numZeroes = 0;\r\n for (const i of ints) {\r\n if (min > i)\r\n min = i;\r\n if (max < i)\r\n max = i;\r\n if (0 === i)\r\n ++numZeroes;\r\n }\r\n return { min, max, numZeroes };\r\n }\r\n\r\n /**\r\n * Extract auxData for a mesh.\r\n * Typescript object format for Polyface/PolyfaceAuxData indices is 0-based, unterminated.\r\n * FlatBuffer format for Polyface/PolyfaceAuxData indices is 1-based, 0-terminated/padded.\r\n * Typescript API previously wrote FlatBuffer PolyfaceAuxData indices as 0-based, unterminated;\r\n * heuristics are used herein to identify this legacy format so it can still be read.\r\n */\r\n public readPolyfaceAuxData(fbPolyface: BGFBAccessors.Polyface | null, fbAuxData: BGFBAccessors.PolyfaceAuxData | null): PolyfaceAuxData | undefined {\r\n if (!fbPolyface || !fbAuxData)\r\n return undefined;\r\n\r\n const fbPointIndices = nullToUndefined<Int32Array>(fbPolyface.pointIndexArray());\r\n const fbAuxIndices = nullToUndefined<Int32Array>(fbAuxData.indicesArray());\r\n const numChannels = fbAuxData.channelsLength();\r\n const fbNumData = BGFBReader.channelDataLength(fbAuxData);\r\n if (!fbPointIndices || !fbPointIndices.length || !fbAuxIndices || !fbAuxIndices.length || numChannels <= 0 || fbNumData <= 0)\r\n return undefined;\r\n\r\n const numPerFace = fbPolyface.numPerFace();\r\n\r\n // HEURISTICS to detect legacy AuxData indices, previously mistakenly serialized by BGFBWriter.writePolyfaceAsFBVariantGeometry as 0-based unblocked indices\r\n let isLegacy = false;\r\n const pointIndicesPadCount = fbPointIndices.filter((index) => index === 0).length;\r\n if (numPerFace > 1) {\r\n const auxIndexCounts = this.countIntArray(fbAuxIndices);\r\n if (auxIndexCounts.max > fbNumData) // auxIndices invalid\r\n return undefined;\r\n if (auxIndexCounts.max === fbNumData) // auxIndices 1-based\r\n isLegacy = false;\r\n else if (auxIndexCounts.max <= 0 || auxIndexCounts.min < 0) // auxIndices 1-based (signed)\r\n isLegacy = false;\r\n else if (auxIndexCounts.min === 0) // auxIndices likely legacy 0-based index, but could be modern with padding\r\n isLegacy = pointIndicesPadCount !== auxIndexCounts.numZeroes;\r\n else if (auxIndexCounts.min > 0) // auxIndices likely modern without padding, but could be legacy if first datum not indexed\r\n isLegacy = pointIndicesPadCount > 0;\r\n } else {\r\n isLegacy = (fbAuxIndices.length < fbPointIndices.length) && (fbAuxIndices.length + pointIndicesPadCount === fbPointIndices.length);\r\n }\r\n if (!isLegacy && fbAuxIndices.length !== fbPointIndices.length)\r\n return undefined; // auxIndices invalid\r\n\r\n const indices: number[] = [];\r\n if (isLegacy)\r\n SerializationHelpers.announceZeroBasedIndicesWithExternalBlocking(fbAuxIndices, fbPointIndices, numPerFace, (i0: number) => { indices.push(i0); });\r\n else\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(fbAuxIndices, numPerFace, (i0: number) => { indices.push(i0); });\r\n if (indices.length + pointIndicesPadCount !== fbPointIndices.length)\r\n return undefined;\r\n const maxIndex = Math.max(...indices);\r\n\r\n const channels: AuxChannel[] = [];\r\n for (let i = 0; i < numChannels; i++) {\r\n const channelHeader = fbAuxData.channels(i);\r\n const channelContent = this.readPolyfaceAuxChannel(channelHeader);\r\n if (channelContent) {\r\n if (maxIndex >= channelContent.valueCount)\r\n return undefined; // invalid index\r\n channels.push(channelContent);\r\n }\r\n }\r\n if (!channels.length)\r\n return undefined;\r\n\r\n return new PolyfaceAuxData(channels, indices);\r\n }\r\n\r\n /** Extract tagged numeric data for a mesh */\r\n public readTaggedNumericData(accessor: BGFBAccessors.TaggedNumericData | undefined): TaggedNumericData | undefined {\r\n if (accessor) {\r\n const taggedNumericData = new TaggedNumericData(accessor.tagA(), accessor.tagB());\r\n const intDataArray = nullToUndefined<Int32Array>(accessor.intDataArray());\r\n const doubleDataArray = nullToUndefined<Float64Array>(accessor.doubleDataArray());\r\n if (intDataArray) {\r\n taggedNumericData.intData = [];\r\n for (const c of intDataArray)\r\n taggedNumericData.intData.push(c);\r\n\r\n }\r\n if (doubleDataArray) {\r\n taggedNumericData.doubleData = [];\r\n for (const c of doubleDataArray)\r\n taggedNumericData.doubleData.push(c);\r\n }\r\n return taggedNumericData;\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Extract a mesh\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readPolyfaceFromVariant(variant: BGFBAccessors.VariantGeometry): IndexedPolyface | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPolyface) {\r\n const polyfaceHeader = variant.geometry(new BGFBAccessors.Polyface());\r\n if (polyfaceHeader) {\r\n const twoSided = polyfaceHeader.twoSided();\r\n const expectedClosure = polyfaceHeader.expectedClosure();\r\n const meshStyle = polyfaceHeader.meshStyle();\r\n const numPerFace = polyfaceHeader.numPerFace();\r\n\r\n const pointF64 = nullToUndefined<Float64Array>(polyfaceHeader.pointArray());\r\n const paramF64 = nullToUndefined<Float64Array>(polyfaceHeader.paramArray());\r\n const normalF64 = nullToUndefined<Float64Array>(polyfaceHeader.normalArray());\r\n const intColorU32 = nullToUndefined<Uint32Array>(polyfaceHeader.intColorArray());\r\n\r\n const pointIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.pointIndexArray());\r\n const paramIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.paramIndexArray());\r\n const normalIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.normalIndexArray());\r\n const colorIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.colorIndexArray());\r\n const edgeMateIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.edgeMateIndexArray());\r\n const taggedNumericDataOffset = polyfaceHeader.taggedNumericData();\r\n\r\n // FB polyfaces are always indexed face loop style, but we recognize both variable and fixed-size face loops.\r\n // (BGFBWriter only writes variable-sized face loops, but native FBWriter can write both.)\r\n assert(meshStyle === 1, \"Unrecognized flatbuffer mesh style\");\r\n\r\n if (meshStyle === 1 && pointF64 && pointIndexI32) {\r\n const polyface = IndexedPolyface.create();\r\n polyface.twoSided = twoSided;\r\n polyface.expectedClosure = expectedClosure;\r\n\r\n // Flatbuffer parallel index array values are:\r\n // * signed 1-based index into the respective data array\r\n // * 0 indicates variable-sized face loop terminator (numPerFace < 2)\r\n // * 0 indicates fixed-sized face loop padding (numPerFace >= 2)\r\n // Native format is the same as flatbuffer.\r\n // TypeScript format is 0-based indices sans terminator/padding\r\n if (normalF64 && normalIndexI32) {\r\n for (let i = 0; i + 2 < normalF64.length; i += 3)\r\n polyface.addNormalXYZ(normalF64[i], normalF64[i + 1], normalF64[i + 2]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(normalIndexI32, numPerFace,\r\n (i: number) => { polyface.addNormalIndex(i); });\r\n }\r\n if (paramF64 && paramIndexI32) {\r\n for (let i = 0; i + 1 < paramF64.length; i += 2)\r\n polyface.addParamUV(paramF64[i], paramF64[i + 1]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(paramIndexI32, numPerFace,\r\n (i: number) => { polyface.addParamIndex(i); });\r\n }\r\n if (intColorU32 && colorIndexI32) {\r\n for (const c of intColorU32)\r\n polyface.addColor(c);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(colorIndexI32, numPerFace,\r\n (i: number) => { polyface.addColorIndex(i); });\r\n }\r\n\r\n // the second callback below builds up the facetStart array as we process the main point index array\r\n for (let i = 0; i + 2 < pointF64.length; i += 3)\r\n polyface.addPointXYZ(pointF64[i], pointF64[i + 1], pointF64[i + 2]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(pointIndexI32, numPerFace,\r\n (i: number, v?: boolean) => { polyface.addPointIndex(i, v); },\r\n () => { polyface.terminateFacet(false); });\r\n\r\n // FB/JSON/native edgeMateIndex array format:\r\n // 0-based edgeMate indices into the parallel Polyface index arrays (and edgeMateIndex!),\r\n // -1 terminator/pad, not present in TypeScript,\r\n // -2 for \"no edgeMate\", maps to `undefined` in TypeScript\r\n if (edgeMateIndexI32) {\r\n const edgeMateIndex: Array<number | undefined> = [];\r\n if (SerializationHelpers.announceCompressedZeroBasedReflexiveIndices(edgeMateIndexI32, numPerFace,\r\n SerializationHelpers.EdgeMateIndex.BlockSeparator, SerializationHelpers.EdgeMateIndex.NoEdgeMate,\r\n (i: number | undefined) => edgeMateIndex.push(i),\r\n )) {\r\n polyface.data.edgeMateIndex = edgeMateIndex;\r\n }\r\n }\r\n\r\n if (!polyface.validateAllIndices())\r\n return undefined;\r\n\r\n polyface.data.auxData = this.readPolyfaceAuxData(polyfaceHeader, polyfaceHeader.auxData());\r\n\r\n if (taggedNumericDataOffset) {\r\n const taggedNumericDataAccessor = nullToUndefined<BGFBAccessors.TaggedNumericData>(taggedNumericDataOffset);\r\n if (taggedNumericDataAccessor !== undefined) {\r\n const taggedNumericData = this.readTaggedNumericData(taggedNumericDataAccessor);\r\n if (taggedNumericData !== undefined)\r\n polyface.data.setTaggedNumericData(taggedNumericData);\r\n }\r\n }\r\n\r\n // NOTE: faceData is ignored\r\n return polyface;\r\n }\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n public readCurveCollectionFromCurveVectorTable(cvTable: BGFBAccessors.CurveVector): CurveCollection {\r\n const numChildren = cvTable.curvesLength();\r\n const collectionType = cvTable.type();\r\n const collection = createTypedCurveCollection(collectionType);\r\n for (let i = 0; i < numChildren; i++) {\r\n const childOffset = cvTable.curves(i);\r\n if (childOffset !== null) {\r\n const child = this.readCurvePrimitiveFromVariant(childOffset);\r\n if (child)\r\n collection.tryAddChild(child);\r\n else {\r\n const childCollection = this.readCurveCollectionFromVariantGeometry(childOffset);\r\n if (childCollection)\r\n collection.tryAddChild(childCollection);\r\n }\r\n }\r\n }\r\n return collection;\r\n }\r\n /**\r\n * Extract a curve collection\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readCurveCollectionFromVariantGeometry(variant: BGFBAccessors.VariantGeometry): CurveCollection | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagCurveVector) {\r\n const cvTable = variant.geometry(new BGFBAccessors.CurveVector())!;\r\n return this.readCurveCollectionFromCurveVectorTable(cvTable);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve collection\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readSolidPrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): SolidPrimitive | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnBox) {\r\n const header = variant.geometry(new BGFBAccessors.DgnBox());\r\n const detail = header!.detail()!;\r\n return Box.createDgnBox(\r\n Point3d.create(detail.baseOriginX(), detail.baseOriginY(), detail.baseOriginZ()),\r\n Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ()),\r\n Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ()),\r\n Point3d.create(detail.topOriginX(), detail.topOriginY(), detail.topOriginZ()),\r\n detail.baseX(), detail.baseY(), detail.topX(), detail.topY(),\r\n detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnSphere) {\r\n const header = variant.geometry(new BGFBAccessors.DgnSphere());\r\n const detail = header!.detail()!;\r\n const lToWDetail = detail.localToWorld()!;\r\n const localToWorld = Transform.createRowValues(\r\n lToWDetail.axx(), lToWDetail.axy(), lToWDetail.axz(), lToWDetail.axw(),\r\n lToWDetail.ayx(), lToWDetail.ayy(), lToWDetail.ayz(), lToWDetail.ayw(),\r\n lToWDetail.azx(), lToWDetail.azy(), lToWDetail.azz(), lToWDetail.azw());\r\n return Sphere.createEllipsoid(localToWorld,\r\n AngleSweep.createStartSweepRadians(detail.startLatitudeRadians(), detail.latitudeSweepRadians()),\r\n detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnCone) {\r\n const header = variant.geometry(new BGFBAccessors.DgnCone());\r\n const detail = header!.detail()!;\r\n const centerA = Point3d.create(detail.centerAX(), detail.centerAY(), detail.centerAZ());\r\n const centerB = Point3d.create(detail.centerBX(), detail.centerBY(), detail.centerBZ());\r\n const vector0 = Vector3d.create(detail.vector0X(), detail.vector0Y(), detail.vector0Z());\r\n const vector90 = Vector3d.create(detail.vector90X(), detail.vector90Y(), detail.vector90Z());\r\n const radiusA = detail.radiusA();\r\n const radiusB = detail.radiusB();\r\n return Cone.createBaseAndTarget(centerA, centerB, vector0, vector90, radiusA, radiusB, detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe) {\r\n const header = variant.geometry(new BGFBAccessors.DgnTorusPipe())!;\r\n const detail = header.detail()!;\r\n const center = Point3d.create(detail.centerX(), detail.centerY(), detail.centerZ());\r\n const vectorX = Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ());\r\n const vectorY = Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ());\r\n const sweepRadians = detail.sweepRadians();\r\n const majorRadius = detail.majorRadius();\r\n const minorRadius = detail.minorRadius();\r\n return TorusPipe.createDgnTorusPipe(center, vectorX, vectorY, majorRadius, minorRadius, Angle.createRadians(sweepRadians), detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion) {\r\n const header = variant.geometry(new BGFBAccessors.DgnExtrusion())!;\r\n const dVector = new BGFBAccessors.DVector3d();\r\n header.extrusionVector(dVector);\r\n const extrusionVector = Vector3d.create(dVector.x(), dVector.y(), dVector.z());\r\n const baseCurve = header.baseCurve();\r\n if (baseCurve !== null) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\r\n return LinearSweep.create(contour, extrusionVector, header.capped());\r\n }\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep) {\r\n const header = variant.geometry(new BGFBAccessors.DgnRotationalSweep())!;\r\n const dAxis = new BGFBAccessors.DRay3d();\r\n header.axis(dAxis);\r\n const axis = Ray3d.createXYZUVW(dAxis.x(), dAxis.y(), dAxis.z(), dAxis.ux(), dAxis.uy(), dAxis.uz());\r\n const sweepAngle = Angle.createRadians(header.sweepRadians());\r\n // const numVRules = header.numVRules();\r\n const baseCurve = header.baseCurve();\r\n if (baseCurve !== null) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\r\n return RotationalSweep.create(contour, axis, sweepAngle, header.capped());\r\n }\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep) {\r\n const header = variant.geometry(new BGFBAccessors.DgnRuledSweep())!;\r\n const numCurves = header.curvesLength();\r\n const contours: CurveCollection[] = [];\r\n for (let i = 0; i < numCurves; i++) {\r\n const contourTable = header.curves(i);\r\n if (contourTable) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(contourTable);\r\n if (contour)\r\n contours.push(contour);\r\n }\r\n }\r\n if (contours.length > 0) {\r\n return RuledSweep.create(contours, header.capped());\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract any geometry type or array of geometry.\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readGeometryQueryFromVariant(variant: BGFBAccessors.VariantGeometry): GeometryQuery | GeometryQuery[] | undefined {\r\n const rootType = variant.geometryType();\r\n switch (rootType) {\r\n case BGFBAccessors.VariantGeometryUnion.tagLineSegment:\r\n case BGFBAccessors.VariantGeometryUnion.tagLineString:\r\n case BGFBAccessors.VariantGeometryUnion.tagEllipticArc:\r\n case BGFBAccessors.VariantGeometryUnion.tagBsplineCurve:\r\n case BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral:\r\n case BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve:\r\n case BGFBAccessors.VariantGeometryUnion.tagAkimaCurve: {\r\n return this.readCurvePrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagCurveVector: {\r\n return this.readCurveCollectionFromVariantGeometry(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagPolyface: {\r\n return this.readPolyfaceFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnBox:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnCone:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnSphere:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep: {\r\n return this.readSolidPrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagVectorOfVariantGeometry: {\r\n const geometry: GeometryQuery[] = [];\r\n const offsetToVectorOfVariantGeometry = variant.geometry(new BGFBAccessors.VectorOfVariantGeometry());\r\n for (let i = 0; i < offsetToVectorOfVariantGeometry!.membersLength(); i++) {\r\n const child = offsetToVectorOfVariantGeometry!.members(i);\r\n if (child !== null) {\r\n const childGeometry = this.readGeometryQueryFromVariant(child);\r\n if (childGeometry instanceof GeometryQuery) {\r\n geometry.push(childGeometry);\r\n } else if (Array.isArray(childGeometry)) {\r\n geometry.push(...childGeometry);\r\n }\r\n }\r\n }\r\n return geometry;\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagBsplineSurface: {\r\n return this.readBSplineSurfaceFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagPointString: {\r\n return this.readPointStringFromVariant(variant);\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Deserialize bytes from a flatbuffer.\r\n * @param justTheBytes FlatBuffer bytes as created by BGFBWriter.createFlatBuffer (g);\r\n */\r\n public static bytesToGeometry(theBytes: Uint8Array, signature?: Uint8Array): GeometryQuery | GeometryQuery[] | undefined {\r\n const newByteBuffer = new flatbuffers.ByteBuffer(theBytes);\r\n if (signature) {\r\n if (theBytes.length < signature.length)\r\n return undefined;\r\n for (let i = 0; i < signature.length; i++)\r\n if (theBytes[i] !== signature[i])\r\n return undefined;\r\n newByteBuffer.setPosition(signature.length);\r\n }\r\n const root = BGFBAccessors.VariantGeometry.getRootAsVariantGeometry(newByteBuffer);\r\n const reader = new BGFBReader();\r\n return reader.readGeometryQueryFromVariant(root);\r\n }\r\n\r\n}\r\n/**\r\n * if data is \"null\" (the deprecated javascript idiom!) return undefined. Otherwise return the data as its own type.\r\n * @param data\r\n */\r\nfunction nullToUndefined<T>(data: any): T | undefined {\r\n if (data === null)\r\n return undefined;\r\n return data;\r\n}\r\n\r\nfunction createTypedCurveCollection(collectionType: number): CurveCollection {\r\n if (collectionType === 1) return new Path();\r\n if (collectionType === 2 || collectionType === 3) return new Loop();\r\n if (collectionType === 4) return new ParityRegion();\r\n if (collectionType === 5) return new UnionRegion();\r\n return new BagOfCurves();\r\n}\r\n/**\r\n * mappings between typescript spiral type strings and native integers.\r\n * @internal\r\n */\r\nexport class DgnSpiralTypeQueries {\r\n // remark: this is the full list based on native DSpiral2dBase.h.\r\n // This does not guarantee all types are supported.\r\n private static spiralTypeCodeMap = [\r\n [10, \"clothoid\"],\r\n [11, \"bloss\"],\r\n [12, \"biquadratic\"],\r\n [13, \"cosine\"],\r\n [14, \"sine\"],\r\n [15, \"Viennese\"],\r\n [16, \"weightedViennese\"],\r\n\r\n [50, \"WesternAustralian\"],\r\n [51, \"Czech\"],\r\n [52, \"AustralianRailCorp\"],\r\n [53, \"Italian\"],\r\n [54, \"PolishCubic\"],\r\n [55, \"Arema\"],\r\n [56, \"MXCubicAlongArc\"],\r\n [57, \"MXCubicAlongTangent\"],\r\n [58, \"ChineseCubic\"],\r\n [60, \"HalfCosine\"],\r\n [61, \"JapaneseCubic\"],\r\n ];\r\n /** Convert native integer type (e.g. from flatbuffer) to typescript string */\r\n public static typeCodeToString(typeCode: number): string | undefined {\r\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\r\n if (entry[0] === typeCode)\r\n return entry[1] as string;\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Convert typescript string to native integer type */\r\n public static stringToTypeCode(s: string, defaultToClothoid: boolean = true): number | undefined {\r\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\r\n if (Geometry.equalStringNoCase(s, entry[1] as string))\r\n return entry[0] as number;\r\n }\r\n return defaultToClothoid ? 10 : undefined;\r\n }\r\n /** Ask if the indicated type code is a \"direct\" spiral */\r\n public static isDirectSpiralType(typeCode: number): boolean {\r\n return typeCode >= 50;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"BGFBReader.js","sourceRoot":"","sources":["../../../src/serialization/BGFBReader.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\nimport { flatbuffers } from \"flatbuffers\";\r\nimport { assert } from \"@itwin/core-bentley\";\r\nimport { AkimaCurve3d, AkimaCurve3dOptions } from \"../bspline/AkimaCurve3d\";\r\nimport { BSplineCurve3d } from \"../bspline/BSplineCurve\";\r\nimport { BSplineCurve3dH } from \"../bspline/BSplineCurve3dH\";\r\nimport { BSplineSurface3d, BSplineSurface3dH, UVSelect } from \"../bspline/BSplineSurface\";\r\nimport { InterpolationCurve3d, InterpolationCurve3dOptions } from \"../bspline/InterpolationCurve3d\";\r\nimport { Arc3d } from \"../curve/Arc3d\";\r\nimport { BagOfCurves, CurveCollection } from \"../curve/CurveCollection\";\r\nimport { CurvePrimitive } from \"../curve/CurvePrimitive\";\r\nimport { GeometryQuery } from \"../curve/GeometryQuery\";\r\nimport { LineSegment3d } from \"../curve/LineSegment3d\";\r\nimport { LineString3d } from \"../curve/LineString3d\";\r\nimport { Loop } from \"../curve/Loop\";\r\nimport { ParityRegion } from \"../curve/ParityRegion\";\r\nimport { Path } from \"../curve/Path\";\r\nimport { PointString3d } from \"../curve/PointString3d\";\r\nimport { DirectSpiral3d } from \"../curve/spiral/DirectSpiral3d\";\r\nimport { IntegratedSpiral3d } from \"../curve/spiral/IntegratedSpiral3d\";\r\nimport { TransitionSpiral3d } from \"../curve/spiral/TransitionSpiral3d\";\r\nimport { UnionRegion } from \"../curve/UnionRegion\";\r\nimport { Geometry } from \"../Geometry\";\r\nimport { Angle } from \"../geometry3d/Angle\";\r\nimport { AngleSweep } from \"../geometry3d/AngleSweep\";\r\nimport { Point3d, Vector3d } from \"../geometry3d/Point3dVector3d\";\r\nimport { NumberArray, Point3dArray } from \"../geometry3d/PointHelpers\";\r\nimport { Ray3d } from \"../geometry3d/Ray3d\";\r\nimport { Segment1d } from \"../geometry3d/Segment1d\";\r\nimport { Transform } from \"../geometry3d/Transform\";\r\nimport { AuxChannel, AuxChannelData, PolyfaceAuxData } from \"../polyface/AuxData\";\r\nimport { IndexedPolyface } from \"../polyface/Polyface\";\r\nimport { TaggedNumericData } from \"../polyface/TaggedNumericData\";\r\nimport { Box } from \"../solid/Box\";\r\nimport { Cone } from \"../solid/Cone\";\r\nimport { LinearSweep } from \"../solid/LinearSweep\";\r\nimport { RotationalSweep } from \"../solid/RotationalSweep\";\r\nimport { RuledSweep } from \"../solid/RuledSweep\";\r\nimport { SolidPrimitive } from \"../solid/SolidPrimitive\";\r\nimport { Sphere } from \"../solid/Sphere\";\r\nimport { TorusPipe } from \"../solid/TorusPipe\";\r\nimport { BGFBAccessors } from \"./BGFBAccessors\";\r\nimport { SerializationHelpers } from \"./SerializationHelpers\";\r\n\r\n/** * Context to write to a flatbuffer blob.\r\n * * This class is internal.\r\n * * Public access is through BentleyGeometryFlatBuffer.geometryToBytes()\r\n * @internal\r\n */\r\nexport class BGFBReader {\r\n public constructor() {\r\n }\r\n /**\r\n * Extract a bspline surface\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readBSplineSurfaceFromVariant(variantHeader: BGFBAccessors.VariantGeometry): BSplineSurface3d | BSplineSurface3dH | undefined {\r\n let newSurface: BSplineSurface3d | BSplineSurface3dH | undefined;\r\n const geometryType = variantHeader.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineSurface) {\r\n const bsurfHeader = variantHeader.geometry(new BGFBAccessors.BsplineSurface());\r\n if (bsurfHeader !== null) {\r\n const orderU = bsurfHeader.orderU();\r\n const orderV = bsurfHeader.orderV();\r\n const numPolesU = bsurfHeader.numPolesU();\r\n const numPolesV = bsurfHeader.numPolesV();\r\n const xyzArray = bsurfHeader.polesArray();\r\n const knotArrayU = bsurfHeader.knotsUArray();\r\n const knotArrayV = bsurfHeader.knotsVArray();\r\n const weightArray = bsurfHeader.weightsArray();\r\n const closedU = bsurfHeader.closedU();\r\n const closedV = bsurfHeader.closedV();\r\n\r\n if (xyzArray !== null && knotArrayU !== null && knotArrayV !== null) {\r\n const myData = SerializationHelpers.createBSplineSurfaceData(xyzArray, 3, knotArrayU, numPolesU, orderU, knotArrayV, numPolesV, orderV);\r\n if (weightArray !== null)\r\n myData.weights = weightArray;\r\n if (closedU)\r\n myData.uParams.closed = true;\r\n if (closedV)\r\n myData.vParams.closed = true;\r\n\r\n if (SerializationHelpers.Import.prepareBSplineSurfaceData(myData, { jsonPoles: false })) {\r\n if (undefined === myData.weights)\r\n newSurface = BSplineSurface3d.create(myData.poles as Float64Array, myData.uParams.numPoles, myData.uParams.order, myData.uParams.knots, myData.vParams.numPoles, myData.vParams.order, myData.vParams.knots);\r\n else\r\n newSurface = BSplineSurface3dH.create(myData.poles as Float64Array, myData.weights as Float64Array, myData.uParams.numPoles, myData.uParams.order, myData.uParams.knots, myData.vParams.numPoles, myData.vParams.order, myData.vParams.knots);\r\n\r\n if (undefined !== newSurface) {\r\n if (undefined !== myData.uParams.wrapMode)\r\n newSurface.setWrappable(UVSelect.uDirection, myData.uParams.wrapMode);\r\n if (undefined !== myData.vParams.wrapMode)\r\n newSurface.setWrappable(UVSelect.vDirection, myData.vParams.wrapMode);\r\n }\r\n }\r\n }\r\n }\r\n }\r\n return newSurface;\r\n }\r\n\r\n /**\r\n * Extract an interpolating curve\r\n * @param header read position in the flat buffer.\r\n */\r\n public readInterpolationCurve3d(header: BGFBAccessors.InterpolationCurve): InterpolationCurve3d | undefined {\r\n const xyzArray = header.fitPointsArray();\r\n if (xyzArray instanceof Float64Array) {\r\n const knots = header.knotsArray();\r\n const options = new InterpolationCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray), knots ? NumberArray.create(knots) : undefined);\r\n const startTangent = header.startTangent();\r\n const endTangent = header.endTangent();\r\n options.captureOptionalProps(\r\n header.order(),\r\n header.closed(),\r\n header.isChordLenKnots(),\r\n header.isColinearTangents(),\r\n header.isChordLenTangents(),\r\n header.isNaturalTangents(),\r\n startTangent !== null ? Vector3d.create(startTangent.x(), startTangent.y(), startTangent.z()) : undefined,\r\n endTangent !== null ? Vector3d.create(endTangent.x(), endTangent.y(), endTangent.z()) : undefined);\r\n return InterpolationCurve3d.createCapture(options);\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Extract an akima curve\r\n * @param header read position in the flat buffer.\r\n */\r\n public readAkimaCurve3d(header: BGFBAccessors.AkimaCurve): AkimaCurve3d | undefined {\r\n const xyzArray = header.pointsArray();\r\n if (xyzArray instanceof Float64Array) {\r\n const options = new AkimaCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray));\r\n return AkimaCurve3d.createCapture(options);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a bspline curve\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readBSplineCurve(header: BGFBAccessors.BsplineCurve): BSplineCurve3d | BSplineCurve3dH | undefined {\r\n let newCurve: BSplineCurve3d | BSplineCurve3dH | undefined;\r\n const order = header.order();\r\n const xyzArray = header.polesArray();\r\n const knots = header.knotsArray();\r\n const weightsArray = header.weightsArray();\r\n const closed = header.closed();\r\n\r\n if (xyzArray !== null && knots !== null) {\r\n const numPoles = Math.floor(xyzArray.length / 3);\r\n const myData = SerializationHelpers.createBSplineCurveData(xyzArray, 3, knots, numPoles, order);\r\n if (closed)\r\n myData.params.closed = true;\r\n\r\n if (weightsArray === null) {\r\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData))\r\n newCurve = BSplineCurve3d.create(myData.poles, myData.params.knots, myData.params.order);\r\n } else {\r\n myData.weights = weightsArray;\r\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData, { jsonPoles: false }))\r\n newCurve = BSplineCurve3dH.create({ xyz: myData.poles as Float64Array, weights: myData.weights }, myData.params.knots, myData.params.order);\r\n }\r\n\r\n if (undefined !== newCurve) {\r\n if (undefined !== myData.params.wrapMode)\r\n newCurve.setWrappable(myData.params.wrapMode);\r\n }\r\n }\r\n return newCurve;\r\n }\r\n /**\r\n * Extract a bspline curve\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readTransitionSpiral(header: BGFBAccessors.TransitionSpiral): TransitionSpiral3d | undefined {\r\n const detailHeader = header.detail();\r\n if (detailHeader) {\r\n const directDetailHeader = header.directDetail(); // unpersisted but repopulated\r\n // const extraDataArray = header.extraDataArray(); // unpersisted and ignored\r\n const spiralTypeName = DgnSpiralTypeQueries.typeCodeToString(detailHeader.spiralType());\r\n if (!spiralTypeName)\r\n return undefined;\r\n const curvature0 = detailHeader.curvature0();\r\n const curvature1 = detailHeader.curvature1();\r\n const bearing0Radians = detailHeader.bearing0Radians();\r\n const bearing1Radians = detailHeader.bearing1Radians();\r\n const fbTransform = detailHeader.transform();\r\n const localToWorld = fbTransform ? Transform.createRowValues(\r\n fbTransform.axx(), fbTransform.axy(), fbTransform.axz(), fbTransform.axw(),\r\n fbTransform.ayx(), fbTransform.ayy(), fbTransform.ayz(), fbTransform.ayw(),\r\n fbTransform.azx(), fbTransform.azy(), fbTransform.azz(), fbTransform.azw()) :\r\n Transform.createIdentity();\r\n\r\n const activeFractionInterval = Segment1d.create(detailHeader.fractionA(),\r\n detailHeader.fractionB());\r\n if (!directDetailHeader) {\r\n const integratedSpiral = IntegratedSpiral3d.createRadiusRadiusBearingBearing(\r\n Segment1d.create(IntegratedSpiral3d.curvatureToRadius(curvature0), IntegratedSpiral3d.curvatureToRadius(curvature1)),\r\n AngleSweep.createStartEndRadians(bearing0Radians, bearing1Radians),\r\n activeFractionInterval, localToWorld, spiralTypeName);\r\n if (integratedSpiral)\r\n return integratedSpiral;\r\n const radius0 = TransitionSpiral3d.curvatureToRadius(curvature0);\r\n const radius1 = TransitionSpiral3d.curvatureToRadius(curvature1);\r\n const arcLength = TransitionSpiral3d.radiusRadiusSweepRadiansToArcLength(radius0, radius1,\r\n bearing1Radians - bearing0Radians);\r\n const directSpiral = DirectSpiral3d.createFromLengthAndRadius(\r\n spiralTypeName,\r\n radius0, radius1,\r\n Angle.createRadians(bearing0Radians),\r\n Angle.createRadians(bearing1Radians),\r\n arcLength,\r\n activeFractionInterval,\r\n localToWorld);\r\n if (directSpiral)\r\n return directSpiral;\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve primitive\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readCurvePrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): CurvePrimitive | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineSegment) {\r\n const offsetToLineSegment = variant.geometry(new BGFBAccessors.LineSegment());\r\n assert(offsetToLineSegment !== null, \"expect defined because LineSegment is defined by VariantGeometryUnion schema\");\r\n const offsetToCoordinates = offsetToLineSegment.segment();\r\n assert(offsetToCoordinates !== null, \"expect defined because `segment` is defined by LineSegment schema\");\r\n return LineSegment3d.createXYZXYZ(\r\n offsetToCoordinates.point0X(), offsetToCoordinates.point0Y(), offsetToCoordinates.point0Z(),\r\n offsetToCoordinates.point1X(), offsetToCoordinates.point1Y(), offsetToCoordinates.point1Z());\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagEllipticArc) {\r\n const offsetToEllipticArc = variant.geometry(new BGFBAccessors.EllipticArc());\r\n assert(offsetToEllipticArc !== null, \"expect defined because EllipticArc is defined by VariantGeometryUnion schema\");\r\n const offsetToCoordinates = offsetToEllipticArc.arc();\r\n assert(offsetToCoordinates !== null, \"expect defined because `arc` is defined by EllipticArc schema\");\r\n return Arc3d.createXYZXYZXYZ(\r\n offsetToCoordinates.centerX(), offsetToCoordinates.centerY(), offsetToCoordinates.centerZ(),\r\n offsetToCoordinates.vector0X(), offsetToCoordinates.vector0Y(), offsetToCoordinates.vector0Z(),\r\n offsetToCoordinates.vector90X(), offsetToCoordinates.vector90Y(), offsetToCoordinates.vector90Z(),\r\n AngleSweep.createStartSweepRadians(offsetToCoordinates.startRadians(), offsetToCoordinates.sweepRadians()));\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineString) {\r\n const offsetToLineString = variant.geometry(new BGFBAccessors.LineString());\r\n assert(offsetToLineString !== null, \"expect defined because LineString is defined by VariantGeometryUnion schema\");\r\n const numCoordinates = offsetToLineString.pointsLength();\r\n const result = LineString3d.create();\r\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\r\n const p0 = offsetToLineString.points(i);\r\n const p1 = offsetToLineString.points(i + 1);\r\n const p2 = offsetToLineString.points(i + 2);\r\n assert(p0 !== null && p1 !== null && p2 !== null, \"expect defined because `points` is defined by LineString schema and indices are valid\");\r\n result.packedPoints.pushXYZ(p0, p1, p2);\r\n }\r\n return result;\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineCurve) {\r\n const offsetToBCurve = variant.geometry(new BGFBAccessors.BsplineCurve());\r\n if (offsetToBCurve !== null)\r\n return this.readBSplineCurve(offsetToBCurve);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral) {\r\n const offsetToTransitionSpiralTable = variant.geometry(new BGFBAccessors.TransitionSpiral());\r\n if (offsetToTransitionSpiralTable !== null)\r\n return this.readTransitionSpiral(offsetToTransitionSpiralTable);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve) {\r\n const offsetToInterpolationCurveTable = variant.geometry(new BGFBAccessors.InterpolationCurve());\r\n if (offsetToInterpolationCurveTable !== null)\r\n return this.readInterpolationCurve3d(offsetToInterpolationCurveTable);\r\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagAkimaCurve) {\r\n const offsetToAkimaCurveTable = variant.geometry(new BGFBAccessors.AkimaCurve());\r\n if (offsetToAkimaCurveTable !== null)\r\n return this.readAkimaCurve3d(offsetToAkimaCurveTable);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve primitive\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readPointStringFromVariant(variant: BGFBAccessors.VariantGeometry): PointString3d | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPointString) {\r\n const offsetToLineString = variant.geometry(new BGFBAccessors.PointString());\r\n assert(offsetToLineString !== null, \"expect defined because PointString is defined by VariantGeometryUnion schema\");\r\n const numCoordinates = offsetToLineString.pointsLength();\r\n const result = PointString3d.create();\r\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\r\n const p0 = offsetToLineString.points(i);\r\n const p1 = offsetToLineString.points(i + 1);\r\n const p2 = offsetToLineString.points(i + 2);\r\n assert(p0 !== null && p1 !== null && p2 !== null, \"expect defined because `points` is defined by PointString schema and indices are valid\");\r\n result.points.push(Point3d.create(p0, p1, p2));\r\n }\r\n return result;\r\n }\r\n return undefined;\r\n }\r\n /** Extract auxData channel data for a mesh */\r\n public readPolyfaceAuxChannelData(channelDataHeader: BGFBAccessors.PolyfaceAuxChannelData | null): AuxChannelData | undefined {\r\n if (channelDataHeader !== null) {\r\n const input = channelDataHeader.input();\r\n const values = channelDataHeader.valuesArray();\r\n if (values !== null)\r\n return new AuxChannelData(input, values);\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Extract auxData channel for a mesh */\r\n public readPolyfaceAuxChannel(channelHeader: BGFBAccessors.PolyfaceAuxChannel | null): AuxChannel | undefined {\r\n if (channelHeader) {\r\n const dataType = channelHeader.dataType();\r\n const dataLength = channelHeader.dataLength();\r\n const channelDataArray: AuxChannelData[] = [];\r\n const name = channelHeader.name();\r\n const inputName = channelHeader.inputName();\r\n for (let i = 0; i < dataLength; i++) {\r\n const channelData = this.readPolyfaceAuxChannelData(channelHeader.data(i));\r\n if (channelData)\r\n channelDataArray.push(channelData);\r\n }\r\n return new AuxChannel(channelDataArray, dataType, name ? name : undefined, inputName ? inputName : undefined);\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Compute the number of logical entries in every flat data array in the AuxData */\r\n private static channelDataLength(fbAuxData: BGFBAccessors.PolyfaceAuxData): number {\r\n if (fbAuxData.channelsLength() <= 0)\r\n return 0;\r\n\r\n const fbChannel0 = nullToUndefined<BGFBAccessors.PolyfaceAuxChannel>(fbAuxData.channels(0));\r\n if (!fbChannel0)\r\n return 0;\r\n\r\n const numChannel0Data = fbChannel0.dataLength();\r\n if (numChannel0Data <= 0)\r\n return 0;\r\n\r\n const fbChannel0Data0 = nullToUndefined<BGFBAccessors.PolyfaceAuxChannelData>(fbChannel0.data(0));\r\n if (!fbChannel0Data0)\r\n return 0;\r\n\r\n const numChannelDataValues = fbChannel0Data0.valuesLength();\r\n if (numChannelDataValues <= 0)\r\n return 0;\r\n\r\n return numChannelDataValues / AuxChannel.entriesPerValue(fbChannel0.dataType());\r\n }\r\n\r\n /** Examine int array for range and zero count */\r\n private countIntArray(ints: Int32Array): { min: number, max: number, numZeroes: number } {\r\n let min = Infinity;\r\n let max = -Infinity;\r\n let numZeroes = 0;\r\n for (const i of ints) {\r\n if (min > i)\r\n min = i;\r\n if (max < i)\r\n max = i;\r\n if (0 === i)\r\n ++numZeroes;\r\n }\r\n return { min, max, numZeroes };\r\n }\r\n\r\n /**\r\n * Extract auxData for a mesh.\r\n * Typescript object format for Polyface/PolyfaceAuxData indices is 0-based, unterminated.\r\n * FlatBuffer format for Polyface/PolyfaceAuxData indices is 1-based, 0-terminated/padded.\r\n * Typescript API previously wrote FlatBuffer PolyfaceAuxData indices as 0-based, unterminated;\r\n * heuristics are used herein to identify this legacy format so it can still be read.\r\n */\r\n public readPolyfaceAuxData(fbPolyface: BGFBAccessors.Polyface | null, fbAuxData: BGFBAccessors.PolyfaceAuxData | null): PolyfaceAuxData | undefined {\r\n if (!fbPolyface || !fbAuxData)\r\n return undefined;\r\n\r\n const fbPointIndices = nullToUndefined<Int32Array>(fbPolyface.pointIndexArray());\r\n const fbAuxIndices = nullToUndefined<Int32Array>(fbAuxData.indicesArray());\r\n const numChannels = fbAuxData.channelsLength();\r\n const fbNumData = BGFBReader.channelDataLength(fbAuxData);\r\n if (!fbPointIndices || !fbPointIndices.length || !fbAuxIndices || !fbAuxIndices.length || numChannels <= 0 || fbNumData <= 0)\r\n return undefined;\r\n\r\n const numPerFace = fbPolyface.numPerFace();\r\n\r\n // HEURISTICS to detect legacy AuxData indices, previously mistakenly serialized by BGFBWriter.writePolyfaceAsFBVariantGeometry as 0-based unblocked indices\r\n let isLegacy = false;\r\n const pointIndicesPadCount = fbPointIndices.filter((index) => index === 0).length;\r\n if (numPerFace > 1) {\r\n const auxIndexCounts = this.countIntArray(fbAuxIndices);\r\n if (auxIndexCounts.max > fbNumData) // auxIndices invalid\r\n return undefined;\r\n if (auxIndexCounts.max === fbNumData) // auxIndices 1-based\r\n isLegacy = false;\r\n else if (auxIndexCounts.max <= 0 || auxIndexCounts.min < 0) // auxIndices 1-based (signed)\r\n isLegacy = false;\r\n else if (auxIndexCounts.min === 0) // auxIndices likely legacy 0-based index, but could be modern with padding\r\n isLegacy = pointIndicesPadCount !== auxIndexCounts.numZeroes;\r\n else if (auxIndexCounts.min > 0) // auxIndices likely modern without padding, but could be legacy if first datum not indexed\r\n isLegacy = pointIndicesPadCount > 0;\r\n } else {\r\n isLegacy = (fbAuxIndices.length < fbPointIndices.length) && (fbAuxIndices.length + pointIndicesPadCount === fbPointIndices.length);\r\n }\r\n if (!isLegacy && fbAuxIndices.length !== fbPointIndices.length)\r\n return undefined; // auxIndices invalid\r\n\r\n const indices: number[] = [];\r\n if (isLegacy)\r\n SerializationHelpers.announceZeroBasedIndicesWithExternalBlocking(fbAuxIndices, fbPointIndices, numPerFace, (i0: number) => { indices.push(i0); });\r\n else\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(fbAuxIndices, numPerFace, (i0: number) => { indices.push(i0); });\r\n if (indices.length + pointIndicesPadCount !== fbPointIndices.length)\r\n return undefined;\r\n const maxIndex = Math.max(...indices);\r\n\r\n const channels: AuxChannel[] = [];\r\n for (let i = 0; i < numChannels; i++) {\r\n const channelHeader = fbAuxData.channels(i);\r\n const channelContent = this.readPolyfaceAuxChannel(channelHeader);\r\n if (channelContent) {\r\n if (maxIndex >= channelContent.valueCount)\r\n return undefined; // invalid index\r\n channels.push(channelContent);\r\n }\r\n }\r\n if (!channels.length)\r\n return undefined;\r\n\r\n return new PolyfaceAuxData(channels, indices);\r\n }\r\n\r\n /** Extract tagged numeric data for a mesh */\r\n public readTaggedNumericData(accessor: BGFBAccessors.TaggedNumericData | undefined): TaggedNumericData | undefined {\r\n if (accessor) {\r\n const taggedNumericData = new TaggedNumericData(accessor.tagA(), accessor.tagB());\r\n const intDataArray = nullToUndefined<Int32Array>(accessor.intDataArray());\r\n const doubleDataArray = nullToUndefined<Float64Array>(accessor.doubleDataArray());\r\n if (intDataArray) {\r\n taggedNumericData.intData = [];\r\n for (const c of intDataArray)\r\n taggedNumericData.intData.push(c);\r\n\r\n }\r\n if (doubleDataArray) {\r\n taggedNumericData.doubleData = [];\r\n for (const c of doubleDataArray)\r\n taggedNumericData.doubleData.push(c);\r\n }\r\n return taggedNumericData;\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Extract a mesh\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readPolyfaceFromVariant(variant: BGFBAccessors.VariantGeometry): IndexedPolyface | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPolyface) {\r\n const polyfaceHeader = variant.geometry(new BGFBAccessors.Polyface());\r\n if (polyfaceHeader) {\r\n const twoSided = polyfaceHeader.twoSided();\r\n const expectedClosure = polyfaceHeader.expectedClosure();\r\n const meshStyle = polyfaceHeader.meshStyle();\r\n const numPerFace = polyfaceHeader.numPerFace();\r\n\r\n const pointF64 = nullToUndefined<Float64Array>(polyfaceHeader.pointArray());\r\n const paramF64 = nullToUndefined<Float64Array>(polyfaceHeader.paramArray());\r\n const normalF64 = nullToUndefined<Float64Array>(polyfaceHeader.normalArray());\r\n const intColorU32 = nullToUndefined<Uint32Array>(polyfaceHeader.intColorArray());\r\n\r\n const pointIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.pointIndexArray());\r\n const paramIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.paramIndexArray());\r\n const normalIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.normalIndexArray());\r\n const colorIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.colorIndexArray());\r\n const edgeMateIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.edgeMateIndexArray());\r\n const taggedNumericDataOffset = polyfaceHeader.taggedNumericData();\r\n\r\n // FB polyfaces are always indexed face loop style, but we recognize both variable and fixed-size face loops.\r\n // (BGFBWriter only writes variable-sized face loops, but native FBWriter can write both.)\r\n assert(meshStyle === 1, \"Unrecognized flatbuffer mesh style\");\r\n\r\n if (meshStyle === 1 && pointF64 && pointIndexI32) {\r\n const polyface = IndexedPolyface.create();\r\n polyface.twoSided = twoSided;\r\n polyface.expectedClosure = expectedClosure;\r\n\r\n // Flatbuffer parallel index array values are:\r\n // * signed 1-based index into the respective data array\r\n // * 0 indicates variable-sized face loop terminator (numPerFace < 2)\r\n // * 0 indicates fixed-sized face loop padding (numPerFace >= 2)\r\n // Native format is the same as flatbuffer.\r\n // TypeScript format is 0-based indices sans terminator/padding\r\n if (normalF64 && normalIndexI32) {\r\n for (let i = 0; i + 2 < normalF64.length; i += 3)\r\n polyface.addNormalXYZ(normalF64[i], normalF64[i + 1], normalF64[i + 2]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(normalIndexI32, numPerFace,\r\n (i: number) => { polyface.addNormalIndex(i); });\r\n }\r\n if (paramF64 && paramIndexI32) {\r\n for (let i = 0; i + 1 < paramF64.length; i += 2)\r\n polyface.addParamUV(paramF64[i], paramF64[i + 1]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(paramIndexI32, numPerFace,\r\n (i: number) => { polyface.addParamIndex(i); });\r\n }\r\n if (intColorU32 && colorIndexI32) {\r\n for (const c of intColorU32)\r\n polyface.addColor(c);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(colorIndexI32, numPerFace,\r\n (i: number) => { polyface.addColorIndex(i); });\r\n }\r\n\r\n // the second callback below builds up the facetStart array as we process the main point index array\r\n for (let i = 0; i + 2 < pointF64.length; i += 3)\r\n polyface.addPointXYZ(pointF64[i], pointF64[i + 1], pointF64[i + 2]);\r\n SerializationHelpers.announceZeroBasedIndicesFromSignedOneBasedIndices(pointIndexI32, numPerFace,\r\n (i: number, v?: boolean) => { polyface.addPointIndex(i, v); },\r\n () => { polyface.terminateFacet(false); });\r\n\r\n // FB/JSON/native edgeMateIndex array format:\r\n // 0-based edgeMate indices into the parallel Polyface index arrays (and edgeMateIndex!),\r\n // -1 terminator/pad, not present in TypeScript,\r\n // -2 for \"no edgeMate\", maps to `undefined` in TypeScript\r\n if (edgeMateIndexI32) {\r\n const edgeMateIndex: Array<number | undefined> = [];\r\n if (SerializationHelpers.announceCompressedZeroBasedReflexiveIndices(edgeMateIndexI32, numPerFace,\r\n SerializationHelpers.EdgeMateIndex.BlockSeparator, SerializationHelpers.EdgeMateIndex.NoEdgeMate,\r\n (i: number | undefined) => edgeMateIndex.push(i),\r\n )) {\r\n polyface.data.edgeMateIndex = edgeMateIndex;\r\n }\r\n }\r\n\r\n if (!polyface.validateAllIndices())\r\n return undefined;\r\n\r\n polyface.data.auxData = this.readPolyfaceAuxData(polyfaceHeader, polyfaceHeader.auxData());\r\n\r\n if (taggedNumericDataOffset) {\r\n const taggedNumericDataAccessor = nullToUndefined<BGFBAccessors.TaggedNumericData>(taggedNumericDataOffset);\r\n if (taggedNumericDataAccessor !== undefined) {\r\n const taggedNumericData = this.readTaggedNumericData(taggedNumericDataAccessor);\r\n if (taggedNumericData !== undefined)\r\n polyface.data.setTaggedNumericData(taggedNumericData);\r\n }\r\n }\r\n\r\n // NOTE: faceData is ignored\r\n return polyface;\r\n }\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n public readCurveCollectionFromCurveVectorTable(cvTable: BGFBAccessors.CurveVector): CurveCollection {\r\n const numChildren = cvTable.curvesLength();\r\n const collectionType = cvTable.type();\r\n const collection = createTypedCurveCollection(collectionType);\r\n for (let i = 0; i < numChildren; i++) {\r\n const childOffset = cvTable.curves(i);\r\n if (childOffset !== null) {\r\n const child = this.readCurvePrimitiveFromVariant(childOffset);\r\n if (child)\r\n collection.tryAddChild(child);\r\n else {\r\n const childCollection = this.readCurveCollectionFromVariantGeometry(childOffset);\r\n if (childCollection)\r\n collection.tryAddChild(childCollection);\r\n }\r\n }\r\n }\r\n return collection;\r\n }\r\n /**\r\n * Extract a curve collection\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readCurveCollectionFromVariantGeometry(variant: BGFBAccessors.VariantGeometry): CurveCollection | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagCurveVector) {\r\n const cvTable = variant.geometry(new BGFBAccessors.CurveVector());\r\n assert(cvTable !== null, \"expect defined because CurveVector is defined by VariantGeometryUnion schema\");\r\n return this.readCurveCollectionFromCurveVectorTable(cvTable);\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract a curve collection\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readSolidPrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): SolidPrimitive | undefined {\r\n const geometryType = variant.geometryType();\r\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnBox) {\r\n const header = variant.geometry(new BGFBAccessors.DgnBox());\r\n assert(header !== null, \"expect defined because DgnBox is defined by VariantGeometryUnion schema\");\r\n const detail = header.detail();\r\n assert(detail !== null, \"expect defined because `detail` is defined by DgnBox schema\");\r\n return Box.createDgnBox(\r\n Point3d.create(detail.baseOriginX(), detail.baseOriginY(), detail.baseOriginZ()),\r\n Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ()),\r\n Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ()),\r\n Point3d.create(detail.topOriginX(), detail.topOriginY(), detail.topOriginZ()),\r\n detail.baseX(), detail.baseY(), detail.topX(), detail.topY(),\r\n detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnSphere) {\r\n const header = variant.geometry(new BGFBAccessors.DgnSphere());\r\n assert(header !== null, \"expect defined because DgnSphere is defined by VariantGeometryUnion schema\");\r\n const detail = header.detail();\r\n assert(detail !== null, \"expect defined because `detail` is defined by DgnSphere schema\");\r\n const dLocalToWorld = detail.localToWorld();\r\n assert(dLocalToWorld !== null, \"expect defined because `localToWorld` is defined by DgnSphereDetail schema\");\r\n const localToWorld = Transform.createRowValues(\r\n dLocalToWorld.axx(), dLocalToWorld.axy(), dLocalToWorld.axz(), dLocalToWorld.axw(),\r\n dLocalToWorld.ayx(), dLocalToWorld.ayy(), dLocalToWorld.ayz(), dLocalToWorld.ayw(),\r\n dLocalToWorld.azx(), dLocalToWorld.azy(), dLocalToWorld.azz(), dLocalToWorld.azw());\r\n return Sphere.createEllipsoid(localToWorld,\r\n AngleSweep.createStartSweepRadians(detail.startLatitudeRadians(), detail.latitudeSweepRadians()),\r\n detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnCone) {\r\n const header = variant.geometry(new BGFBAccessors.DgnCone());\r\n assert(header !== null, \"expect defined because DgnCone is defined by VariantGeometryUnion schema\");\r\n const detail = header.detail();\r\n assert(detail !== null, \"expect defined because `detail` is defined by DgnCone schema\");\r\n const centerA = Point3d.create(detail.centerAX(), detail.centerAY(), detail.centerAZ());\r\n const centerB = Point3d.create(detail.centerBX(), detail.centerBY(), detail.centerBZ());\r\n const vector0 = Vector3d.create(detail.vector0X(), detail.vector0Y(), detail.vector0Z());\r\n const vector90 = Vector3d.create(detail.vector90X(), detail.vector90Y(), detail.vector90Z());\r\n const radiusA = detail.radiusA();\r\n const radiusB = detail.radiusB();\r\n return Cone.createBaseAndTarget(centerA, centerB, vector0, vector90, radiusA, radiusB, detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe) {\r\n const header = variant.geometry(new BGFBAccessors.DgnTorusPipe());\r\n assert(header !== null, \"expect defined because DgnTorusPipe is defined by VariantGeometryUnion schema\");\r\n const detail = header.detail();\r\n assert(detail !== null, \"expect defined because `detail` is defined by DgnTorusPipe schema\");\r\n const center = Point3d.create(detail.centerX(), detail.centerY(), detail.centerZ());\r\n const vectorX = Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ());\r\n const vectorY = Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ());\r\n const sweepRadians = detail.sweepRadians();\r\n const majorRadius = detail.majorRadius();\r\n const minorRadius = detail.minorRadius();\r\n return TorusPipe.createDgnTorusPipe(center, vectorX, vectorY, majorRadius, minorRadius, Angle.createRadians(sweepRadians), detail.capped());\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion) {\r\n const header = variant.geometry(new BGFBAccessors.DgnExtrusion());\r\n assert(header !== null, \"expect defined because DgnExtrusion is defined by VariantGeometryUnion schema\");\r\n const dVector = new BGFBAccessors.DVector3d();\r\n header.extrusionVector(dVector);\r\n const extrusionVector = Vector3d.create(dVector.x(), dVector.y(), dVector.z());\r\n const baseCurve = header.baseCurve();\r\n if (baseCurve !== null) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\r\n return LinearSweep.create(contour, extrusionVector, header.capped());\r\n }\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep) {\r\n const header = variant.geometry(new BGFBAccessors.DgnRotationalSweep());\r\n assert(header !== null, \"expect defined because DgnRotationalSweep is defined by VariantGeometryUnion schema\");\r\n const dAxis = new BGFBAccessors.DRay3d();\r\n header.axis(dAxis);\r\n const axis = Ray3d.createXYZUVW(dAxis.x(), dAxis.y(), dAxis.z(), dAxis.ux(), dAxis.uy(), dAxis.uz());\r\n const sweepAngle = Angle.createRadians(header.sweepRadians());\r\n // const numVRules = header.numVRules();\r\n const baseCurve = header.baseCurve();\r\n if (baseCurve !== null) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\r\n return RotationalSweep.create(contour, axis, sweepAngle, header.capped());\r\n }\r\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep) {\r\n const header = variant.geometry(new BGFBAccessors.DgnRuledSweep());\r\n assert(header !== null, \"expect defined because DgnRuledSweep is defined by VariantGeometryUnion schema\");\r\n const numCurves = header.curvesLength();\r\n const contours: CurveCollection[] = [];\r\n for (let i = 0; i < numCurves; i++) {\r\n const contourTable = header.curves(i);\r\n if (contourTable) {\r\n const contour = this.readCurveCollectionFromCurveVectorTable(contourTable);\r\n if (contour)\r\n contours.push(contour);\r\n }\r\n }\r\n if (contours.length > 0) {\r\n return RuledSweep.create(contours, header.capped());\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Extract any geometry type or array of geometry.\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readGeometryQueryFromVariant(variant: BGFBAccessors.VariantGeometry): GeometryQuery | GeometryQuery[] | undefined {\r\n const rootType = variant.geometryType();\r\n switch (rootType) {\r\n case BGFBAccessors.VariantGeometryUnion.tagLineSegment:\r\n case BGFBAccessors.VariantGeometryUnion.tagLineString:\r\n case BGFBAccessors.VariantGeometryUnion.tagEllipticArc:\r\n case BGFBAccessors.VariantGeometryUnion.tagBsplineCurve:\r\n case BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral:\r\n case BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve:\r\n case BGFBAccessors.VariantGeometryUnion.tagAkimaCurve: {\r\n return this.readCurvePrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagCurveVector: {\r\n return this.readCurveCollectionFromVariantGeometry(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagPolyface: {\r\n return this.readPolyfaceFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnBox:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnCone:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnSphere:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep:\r\n case BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep: {\r\n return this.readSolidPrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagVectorOfVariantGeometry: {\r\n const geometry: GeometryQuery[] = [];\r\n const offsetToVectorOfVariantGeometry = variant.geometry(new BGFBAccessors.VectorOfVariantGeometry());\r\n assert(offsetToVectorOfVariantGeometry !== null, \"expect defined because VectorOfVariantGeometry is defined by VariantGeometryUnion schema\");\r\n for (let i = 0; i < offsetToVectorOfVariantGeometry.membersLength(); i++) {\r\n const child = offsetToVectorOfVariantGeometry.members(i);\r\n if (child !== null) {\r\n const childGeometry = this.readGeometryQueryFromVariant(child);\r\n if (childGeometry instanceof GeometryQuery) {\r\n geometry.push(childGeometry);\r\n } else if (Array.isArray(childGeometry)) {\r\n geometry.push(...childGeometry);\r\n }\r\n }\r\n }\r\n return geometry;\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagBsplineSurface: {\r\n return this.readBSplineSurfaceFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagPointString: {\r\n return this.readPointStringFromVariant(variant);\r\n }\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Deserialize bytes from a flatbuffer.\r\n * @param justTheBytes FlatBuffer bytes as created by BGFBWriter.createFlatBuffer (g);\r\n */\r\n public static bytesToGeometry(theBytes: Uint8Array, signature?: Uint8Array): GeometryQuery | GeometryQuery[] | undefined {\r\n const newByteBuffer = new flatbuffers.ByteBuffer(theBytes);\r\n if (signature) {\r\n if (theBytes.length < signature.length)\r\n return undefined;\r\n for (let i = 0; i < signature.length; i++)\r\n if (theBytes[i] !== signature[i])\r\n return undefined;\r\n newByteBuffer.setPosition(signature.length);\r\n }\r\n const root = BGFBAccessors.VariantGeometry.getRootAsVariantGeometry(newByteBuffer);\r\n const reader = new BGFBReader();\r\n return reader.readGeometryQueryFromVariant(root);\r\n }\r\n\r\n}\r\n/**\r\n * if data is \"null\" (the deprecated javascript idiom!) return undefined. Otherwise return the data as its own type.\r\n * @param data\r\n */\r\nfunction nullToUndefined<T>(data: any): T | undefined {\r\n if (data === null)\r\n return undefined;\r\n return data;\r\n}\r\n\r\nfunction createTypedCurveCollection(collectionType: number): CurveCollection {\r\n if (collectionType === 1) return new Path();\r\n if (collectionType === 2 || collectionType === 3) return new Loop();\r\n if (collectionType === 4) return new ParityRegion();\r\n if (collectionType === 5) return new UnionRegion();\r\n return new BagOfCurves();\r\n}\r\n/**\r\n * mappings between typescript spiral type strings and native integers.\r\n * @internal\r\n */\r\nexport class DgnSpiralTypeQueries {\r\n // remark: this is the full list based on native DSpiral2dBase.h.\r\n // This does not guarantee all types are supported.\r\n private static spiralTypeCodeMap = [\r\n [10, \"clothoid\"],\r\n [11, \"bloss\"],\r\n [12, \"biquadratic\"],\r\n [13, \"cosine\"],\r\n [14, \"sine\"],\r\n [15, \"Viennese\"],\r\n [16, \"weightedViennese\"],\r\n\r\n [50, \"WesternAustralian\"],\r\n [51, \"Czech\"],\r\n [52, \"AustralianRailCorp\"],\r\n [53, \"Italian\"],\r\n [54, \"PolishCubic\"],\r\n [55, \"Arema\"],\r\n [56, \"MXCubicAlongArc\"],\r\n [57, \"MXCubicAlongTangent\"],\r\n [58, \"ChineseCubic\"],\r\n [60, \"HalfCosine\"],\r\n [61, \"JapaneseCubic\"],\r\n ];\r\n /** Convert native integer type (e.g. from flatbuffer) to typescript string */\r\n public static typeCodeToString(typeCode: number): string | undefined {\r\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\r\n if (entry[0] === typeCode)\r\n return entry[1] as string;\r\n }\r\n return undefined;\r\n }\r\n\r\n /** Convert typescript string to native integer type */\r\n public static stringToTypeCode(s: string, defaultToClothoid: boolean = true): number | undefined {\r\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\r\n if (Geometry.equalStringNoCase(s, entry[1] as string))\r\n return entry[0] as number;\r\n }\r\n return defaultToClothoid ? 10 : undefined;\r\n }\r\n /** Ask if the indicated type code is a \"direct\" spiral */\r\n public static isDirectSpiralType(typeCode: number): boolean {\r\n return typeCode >= 50;\r\n }\r\n}\r\n"]}
@@ -43,7 +43,7 @@ export declare class BGFBWriter {
43
43
  * The data is output as a flat array of 3*data.length numbers.
44
44
  */
45
45
  writePackedYZArray(data: XYZ[] | undefined): number;
46
- writeCurveCollectionAsFBCurveVector(cv: CurveCollection): number | undefined;
46
+ writeCurveCollectionAsFBCurveVector(cv: CurveCollection): number;
47
47
  writeCurveCollectionAsFBVariantGeometry(cv: CurveCollection): number | undefined;
48
48
  writeInterpolationCurve3dAsFBVariantGeometry(curve: InterpolationCurve3d): number | undefined;
49
49
  writeAkimaCurve3dAsFBVariantGeometry(curve: AkimaCurve3d): number | undefined;
@@ -53,9 +53,9 @@ export declare class BGFBWriter {
53
53
  writeCurvePrimitiveAsFBVariantGeometry(curvePrimitive: CurvePrimitive): number | undefined;
54
54
  writePointString3dAsFBVariantGeometry(pointString: PointString3d): number | undefined;
55
55
  writeSolidPrimitiveAsFBVariantGeometry(solid: SolidPrimitive): number | undefined;
56
- writePolyfaceAuxChannelDataAsFBVariantGeometry(channelData: AuxChannelData): number | undefined;
57
- writePolyfaceAuxChannelAsFBVariantGeometry(channel: AuxChannel): number | undefined;
58
- writePolyfaceAuxDataAsFBVariantGeometry(mesh: IndexedPolyface, data: PolyfaceAuxData): number | undefined;
56
+ writePolyfaceAuxChannelDataAsFBVariantGeometry(channelData: AuxChannelData): number;
57
+ writePolyfaceAuxChannelAsFBVariantGeometry(channel: AuxChannel): number;
58
+ writePolyfaceAuxDataAsFBVariantGeometry(mesh: IndexedPolyface, data: PolyfaceAuxData): number;
59
59
  writeTaggedNumericDataArray(data: TaggedNumericData | undefined): number;
60
60
  writePolyfaceAsFBVariantGeometry(mesh: IndexedPolyface): number | undefined;
61
61
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"BGFBWriter.d.ts","sourceRoot":"","sources":["../../../src/serialization/BGFBWriter.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BGFBWriter.d.ts","sourceRoot":"","sources":["../../../src/serialization/BGFBWriter.ts"],"names":[],"mappings":"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"}