@itwin/core-geometry 4.4.0-dev.9 → 4.5.0-dev.0

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 (655) hide show
  1. package/CHANGELOG.md +6 -1
  2. package/lib/cjs/Constant.js.map +1 -1
  3. package/lib/cjs/Geometry.d.ts +17 -0
  4. package/lib/cjs/Geometry.d.ts.map +1 -1
  5. package/lib/cjs/Geometry.js +14 -0
  6. package/lib/cjs/Geometry.js.map +1 -1
  7. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  8. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  9. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  10. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  11. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  12. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  13. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  14. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  15. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  16. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  17. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  18. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  19. package/lib/cjs/bspline/SurfaceLocationDetail.js.map +1 -1
  20. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  21. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  22. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  23. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  24. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  25. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  26. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  27. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  28. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  29. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  30. package/lib/cjs/core-geometry.d.ts +3 -2
  31. package/lib/cjs/core-geometry.d.ts.map +1 -1
  32. package/lib/cjs/core-geometry.js +3 -2
  33. package/lib/cjs/core-geometry.js.map +1 -1
  34. package/lib/cjs/curve/Arc3d.js.map +1 -1
  35. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  36. package/lib/cjs/curve/CoordinateXYZ.js.map +1 -1
  37. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts +2 -2
  38. package/lib/cjs/curve/CurveChainWithDistanceIndex.js +3 -3
  39. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  40. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  41. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  42. package/lib/cjs/curve/CurveExtendMode.d.ts +7 -6
  43. package/lib/cjs/curve/CurveExtendMode.d.ts.map +1 -1
  44. package/lib/cjs/curve/CurveExtendMode.js +7 -6
  45. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  46. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  47. package/lib/cjs/curve/CurveLocationDetail.d.ts.map +1 -1
  48. package/lib/cjs/curve/CurveLocationDetail.js +23 -18
  49. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  50. package/lib/cjs/curve/CurveOps.js.map +1 -1
  51. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  52. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  53. package/lib/cjs/curve/CurveTypes.js.map +1 -1
  54. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  55. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  56. package/lib/cjs/curve/LineSegment3d.d.ts +14 -4
  57. package/lib/cjs/curve/LineSegment3d.d.ts.map +1 -1
  58. package/lib/cjs/curve/LineSegment3d.js +107 -2
  59. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  60. package/lib/cjs/curve/LineString3d.d.ts +41 -8
  61. package/lib/cjs/curve/LineString3d.d.ts.map +1 -1
  62. package/lib/cjs/curve/LineString3d.js +53 -15
  63. package/lib/cjs/curve/LineString3d.js.map +1 -1
  64. package/lib/cjs/curve/Loop.js +1 -1
  65. package/lib/cjs/curve/Loop.js.map +1 -1
  66. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  67. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  68. package/lib/cjs/curve/Path.js.map +1 -1
  69. package/lib/cjs/curve/PointString3d.js.map +1 -1
  70. package/lib/cjs/curve/ProxyCurve.js.map +1 -1
  71. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  72. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  73. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  74. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  75. package/lib/cjs/curve/Query/PlanarSubdivision.d.ts +2 -2
  76. package/lib/cjs/curve/Query/PlanarSubdivision.js +2 -2
  77. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  78. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  79. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  80. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  81. package/lib/cjs/curve/RegionOps.d.ts +1 -2
  82. package/lib/cjs/curve/RegionOps.d.ts.map +1 -1
  83. package/lib/cjs/curve/RegionOps.js.map +1 -1
  84. package/lib/cjs/curve/RegionOpsClassificationSweeps.d.ts +5 -8
  85. package/lib/cjs/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  86. package/lib/cjs/curve/RegionOpsClassificationSweeps.js +12 -12
  87. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  88. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  89. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  90. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  91. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  92. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  93. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  94. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  95. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  96. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  97. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  98. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  99. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  100. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  101. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  102. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  103. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  104. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  105. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  106. package/lib/cjs/curve/internalContexts/SumLengthsContext.js.map +1 -1
  107. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  108. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  109. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  110. package/lib/cjs/curve/spiral/CubicEvaluator.js.map +1 -1
  111. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  112. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  113. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  114. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  115. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  116. package/lib/cjs/curve/spiral/NormalizedTransition.js.map +1 -1
  117. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  118. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  119. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  120. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  121. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  122. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  123. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  124. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  125. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  126. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  127. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  128. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  129. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  130. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  131. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  132. package/lib/cjs/geometry3d/GrowableXYArray.d.ts +2 -2
  133. package/lib/cjs/geometry3d/GrowableXYArray.d.ts.map +1 -1
  134. package/lib/cjs/geometry3d/GrowableXYArray.js +1 -1
  135. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  136. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts +2 -3
  137. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  138. package/lib/cjs/geometry3d/GrowableXYZArray.js +1 -1
  139. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  140. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  141. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  142. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts +18 -1
  143. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  144. package/lib/cjs/geometry3d/IndexedXYZCollection.js +13 -0
  145. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  146. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  147. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  148. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  149. package/lib/cjs/geometry3d/Plane3d.js.map +1 -1
  150. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  151. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  152. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  153. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  154. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  155. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  156. package/lib/cjs/geometry3d/PointHelpers.d.ts +1 -2
  157. package/lib/cjs/geometry3d/PointHelpers.d.ts.map +1 -1
  158. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  159. package/lib/cjs/geometry3d/PointStreaming.d.ts +1 -1
  160. package/lib/cjs/geometry3d/PointStreaming.d.ts.map +1 -1
  161. package/lib/cjs/geometry3d/PointStreaming.js +3 -1
  162. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  163. package/lib/cjs/geometry3d/PolygonOps.d.ts +68 -1
  164. package/lib/cjs/geometry3d/PolygonOps.d.ts.map +1 -1
  165. package/lib/cjs/geometry3d/PolygonOps.js +152 -4
  166. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  167. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  168. package/lib/cjs/geometry3d/PolylineOps.d.ts +23 -1
  169. package/lib/cjs/geometry3d/PolylineOps.d.ts.map +1 -1
  170. package/lib/cjs/geometry3d/PolylineOps.js +73 -1
  171. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  172. package/lib/cjs/geometry3d/Range.d.ts +1 -1
  173. package/lib/cjs/geometry3d/Range.d.ts.map +1 -1
  174. package/lib/cjs/geometry3d/Range.js.map +1 -1
  175. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  176. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  177. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  178. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  179. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  180. package/lib/cjs/geometry3d/Transform.js +1 -1
  181. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  182. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  183. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  184. package/lib/cjs/geometry3d/YawPitchRollAngles.d.ts +7 -5
  185. package/lib/cjs/geometry3d/YawPitchRollAngles.d.ts.map +1 -1
  186. package/lib/cjs/geometry3d/YawPitchRollAngles.js +8 -6
  187. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  188. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  189. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  190. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  191. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  192. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  193. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  194. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  195. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  196. package/lib/cjs/numerics/Complex.js.map +1 -1
  197. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  198. package/lib/cjs/numerics/Newton.js.map +1 -1
  199. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  200. package/lib/cjs/numerics/PolarData.js.map +1 -1
  201. package/lib/cjs/numerics/Polynomials.d.ts +13 -1
  202. package/lib/cjs/numerics/Polynomials.d.ts.map +1 -1
  203. package/lib/cjs/numerics/Polynomials.js +13 -1
  204. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  205. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  206. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  207. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  208. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  209. package/lib/cjs/numerics/UsageSums.js.map +1 -1
  210. package/lib/cjs/polyface/AuxData.js.map +1 -1
  211. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  212. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  213. package/lib/cjs/polyface/FacetLocationDetail.d.ts +28 -5
  214. package/lib/cjs/polyface/FacetLocationDetail.d.ts.map +1 -1
  215. package/lib/cjs/polyface/FacetLocationDetail.js +50 -15
  216. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  217. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  218. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  219. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  220. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  221. package/lib/cjs/polyface/Polyface.d.ts +1 -1
  222. package/lib/cjs/polyface/Polyface.d.ts.map +1 -1
  223. package/lib/cjs/polyface/Polyface.js.map +1 -1
  224. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  225. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  226. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  227. package/lib/cjs/polyface/PolyfaceQuery.d.ts +7 -3
  228. package/lib/cjs/polyface/PolyfaceQuery.d.ts.map +1 -1
  229. package/lib/cjs/polyface/PolyfaceQuery.js +23 -0
  230. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  231. package/lib/cjs/polyface/RangeLengthData.js.map +1 -1
  232. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.d.ts +52 -0
  233. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.d.ts.map +1 -0
  234. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js +78 -0
  235. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -0
  236. package/lib/cjs/polyface/RangeTree/MinimumValueTester.d.ts +60 -0
  237. package/lib/cjs/polyface/RangeTree/MinimumValueTester.d.ts.map +1 -0
  238. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js +96 -0
  239. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js.map +1 -0
  240. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.d.ts +57 -0
  241. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.d.ts.map +1 -0
  242. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js +73 -0
  243. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -0
  244. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.d.ts +57 -0
  245. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.d.ts.map +1 -0
  246. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js +84 -0
  247. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -0
  248. package/lib/cjs/polyface/RangeTree/RangeTreeNode.d.ts +274 -0
  249. package/lib/cjs/polyface/RangeTree/RangeTreeNode.d.ts.map +1 -0
  250. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js +505 -0
  251. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -0
  252. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.d.ts +204 -0
  253. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.d.ts.map +1 -0
  254. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js +383 -0
  255. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -0
  256. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  257. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  258. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  259. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  260. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  261. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  262. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  263. package/lib/cjs/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  264. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  265. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  266. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  267. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  268. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  269. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  270. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  271. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  272. package/lib/cjs/serialization/GeometrySamples.d.ts +36 -3
  273. package/lib/cjs/serialization/GeometrySamples.d.ts.map +1 -1
  274. package/lib/cjs/serialization/GeometrySamples.js +93 -4
  275. package/lib/cjs/serialization/GeometrySamples.js.map +1 -1
  276. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  277. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  278. package/lib/cjs/solid/Box.js.map +1 -1
  279. package/lib/cjs/solid/Cone.js.map +1 -1
  280. package/lib/cjs/solid/LinearSweep.d.ts +1 -1
  281. package/lib/cjs/solid/LinearSweep.js +1 -1
  282. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  283. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  284. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  285. package/lib/cjs/solid/SolidPrimitive.js.map +1 -1
  286. package/lib/cjs/solid/Sphere.js.map +1 -1
  287. package/lib/cjs/solid/SweepContour.d.ts +2 -2
  288. package/lib/cjs/solid/SweepContour.d.ts.map +1 -1
  289. package/lib/cjs/solid/SweepContour.js.map +1 -1
  290. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  291. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  292. package/lib/cjs/topology/Graph.d.ts +5 -6
  293. package/lib/cjs/topology/Graph.d.ts.map +1 -1
  294. package/lib/cjs/topology/Graph.js +7 -6
  295. package/lib/cjs/topology/Graph.js.map +1 -1
  296. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.d.ts +4 -4
  297. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js +5 -5
  298. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  299. package/lib/cjs/topology/HalfEdgeGraphSearch.d.ts +108 -71
  300. package/lib/cjs/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  301. package/lib/cjs/topology/HalfEdgeGraphSearch.js +223 -109
  302. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  303. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  304. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  305. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  306. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  307. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  308. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  309. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  310. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  311. package/lib/cjs/topology/MaskManager.js.map +1 -1
  312. package/lib/cjs/topology/Merging.d.ts +1 -1
  313. package/lib/cjs/topology/Merging.d.ts.map +1 -1
  314. package/lib/cjs/topology/Merging.js.map +1 -1
  315. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  316. package/lib/cjs/topology/SignedDataSummary.d.ts +13 -13
  317. package/lib/cjs/topology/SignedDataSummary.d.ts.map +1 -1
  318. package/lib/cjs/topology/SignedDataSummary.js +3 -3
  319. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  320. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  321. package/lib/cjs/topology/Triangulation.d.ts +1 -12
  322. package/lib/cjs/topology/Triangulation.d.ts.map +1 -1
  323. package/lib/cjs/topology/Triangulation.js.map +1 -1
  324. package/lib/cjs/topology/XYParitySearchContext.d.ts +27 -21
  325. package/lib/cjs/topology/XYParitySearchContext.d.ts.map +1 -1
  326. package/lib/cjs/topology/XYParitySearchContext.js +73 -71
  327. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  328. package/lib/esm/Constant.js.map +1 -1
  329. package/lib/esm/Geometry.d.ts +17 -0
  330. package/lib/esm/Geometry.d.ts.map +1 -1
  331. package/lib/esm/Geometry.js +14 -0
  332. package/lib/esm/Geometry.js.map +1 -1
  333. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  334. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  335. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  336. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  337. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  338. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  339. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  340. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  341. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  342. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  343. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  344. package/lib/esm/bspline/KnotVector.js.map +1 -1
  345. package/lib/esm/bspline/SurfaceLocationDetail.js.map +1 -1
  346. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  347. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  348. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  349. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  350. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  351. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  352. package/lib/esm/clipping/ClipVector.js.map +1 -1
  353. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  354. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  355. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  356. package/lib/esm/core-geometry.d.ts +3 -2
  357. package/lib/esm/core-geometry.d.ts.map +1 -1
  358. package/lib/esm/core-geometry.js +3 -2
  359. package/lib/esm/core-geometry.js.map +1 -1
  360. package/lib/esm/curve/Arc3d.js.map +1 -1
  361. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  362. package/lib/esm/curve/CoordinateXYZ.js.map +1 -1
  363. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts +2 -2
  364. package/lib/esm/curve/CurveChainWithDistanceIndex.js +3 -3
  365. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  366. package/lib/esm/curve/CurveCollection.js.map +1 -1
  367. package/lib/esm/curve/CurveCurve.js.map +1 -1
  368. package/lib/esm/curve/CurveExtendMode.d.ts +7 -6
  369. package/lib/esm/curve/CurveExtendMode.d.ts.map +1 -1
  370. package/lib/esm/curve/CurveExtendMode.js +7 -6
  371. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  372. package/lib/esm/curve/CurveFactory.js.map +1 -1
  373. package/lib/esm/curve/CurveLocationDetail.d.ts.map +1 -1
  374. package/lib/esm/curve/CurveLocationDetail.js +23 -18
  375. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  376. package/lib/esm/curve/CurveOps.js.map +1 -1
  377. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  378. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  379. package/lib/esm/curve/CurveTypes.js.map +1 -1
  380. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  381. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  382. package/lib/esm/curve/LineSegment3d.d.ts +14 -4
  383. package/lib/esm/curve/LineSegment3d.d.ts.map +1 -1
  384. package/lib/esm/curve/LineSegment3d.js +108 -3
  385. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  386. package/lib/esm/curve/LineString3d.d.ts +41 -8
  387. package/lib/esm/curve/LineString3d.d.ts.map +1 -1
  388. package/lib/esm/curve/LineString3d.js +53 -15
  389. package/lib/esm/curve/LineString3d.js.map +1 -1
  390. package/lib/esm/curve/Loop.js +1 -1
  391. package/lib/esm/curve/Loop.js.map +1 -1
  392. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  393. package/lib/esm/curve/ParityRegion.js.map +1 -1
  394. package/lib/esm/curve/Path.js.map +1 -1
  395. package/lib/esm/curve/PointString3d.js.map +1 -1
  396. package/lib/esm/curve/ProxyCurve.js.map +1 -1
  397. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  398. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  399. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  400. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  401. package/lib/esm/curve/Query/PlanarSubdivision.d.ts +2 -2
  402. package/lib/esm/curve/Query/PlanarSubdivision.js +2 -2
  403. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  404. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  405. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  406. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  407. package/lib/esm/curve/RegionOps.d.ts +1 -2
  408. package/lib/esm/curve/RegionOps.d.ts.map +1 -1
  409. package/lib/esm/curve/RegionOps.js +1 -1
  410. package/lib/esm/curve/RegionOps.js.map +1 -1
  411. package/lib/esm/curve/RegionOpsClassificationSweeps.d.ts +5 -8
  412. package/lib/esm/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  413. package/lib/esm/curve/RegionOpsClassificationSweeps.js +12 -12
  414. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  415. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  416. package/lib/esm/curve/UnionRegion.js.map +1 -1
  417. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  418. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  419. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  420. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  421. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  422. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  423. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  424. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  425. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  426. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  427. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  428. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  429. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  430. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  431. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  432. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  433. package/lib/esm/curve/internalContexts/SumLengthsContext.js.map +1 -1
  434. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  435. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  436. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  437. package/lib/esm/curve/spiral/CubicEvaluator.js.map +1 -1
  438. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  439. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  440. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  441. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  442. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  443. package/lib/esm/curve/spiral/NormalizedTransition.js.map +1 -1
  444. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  445. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  446. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  447. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  448. package/lib/esm/geometry3d/Angle.js.map +1 -1
  449. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  450. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  451. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  452. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  453. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  454. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  455. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  456. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  457. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  458. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  459. package/lib/esm/geometry3d/GrowableXYArray.d.ts +2 -2
  460. package/lib/esm/geometry3d/GrowableXYArray.d.ts.map +1 -1
  461. package/lib/esm/geometry3d/GrowableXYArray.js +1 -1
  462. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  463. package/lib/esm/geometry3d/GrowableXYZArray.d.ts +2 -3
  464. package/lib/esm/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  465. package/lib/esm/geometry3d/GrowableXYZArray.js +1 -1
  466. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  467. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  468. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  469. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts +18 -1
  470. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  471. package/lib/esm/geometry3d/IndexedXYZCollection.js +13 -0
  472. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  473. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  474. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  475. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  476. package/lib/esm/geometry3d/Plane3d.js.map +1 -1
  477. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  478. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  479. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  480. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  481. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  482. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  483. package/lib/esm/geometry3d/PointHelpers.d.ts +1 -2
  484. package/lib/esm/geometry3d/PointHelpers.d.ts.map +1 -1
  485. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  486. package/lib/esm/geometry3d/PointStreaming.d.ts +1 -1
  487. package/lib/esm/geometry3d/PointStreaming.d.ts.map +1 -1
  488. package/lib/esm/geometry3d/PointStreaming.js +3 -1
  489. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  490. package/lib/esm/geometry3d/PolygonOps.d.ts +68 -1
  491. package/lib/esm/geometry3d/PolygonOps.d.ts.map +1 -1
  492. package/lib/esm/geometry3d/PolygonOps.js +150 -3
  493. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  494. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  495. package/lib/esm/geometry3d/PolylineOps.d.ts +23 -1
  496. package/lib/esm/geometry3d/PolylineOps.d.ts.map +1 -1
  497. package/lib/esm/geometry3d/PolylineOps.js +73 -1
  498. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  499. package/lib/esm/geometry3d/Range.d.ts +1 -1
  500. package/lib/esm/geometry3d/Range.d.ts.map +1 -1
  501. package/lib/esm/geometry3d/Range.js.map +1 -1
  502. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  503. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  504. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  505. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  506. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  507. package/lib/esm/geometry3d/Transform.js +1 -1
  508. package/lib/esm/geometry3d/Transform.js.map +1 -1
  509. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  510. package/lib/esm/geometry3d/XYZProps.js.map +1 -1
  511. package/lib/esm/geometry3d/YawPitchRollAngles.d.ts +7 -5
  512. package/lib/esm/geometry3d/YawPitchRollAngles.d.ts.map +1 -1
  513. package/lib/esm/geometry3d/YawPitchRollAngles.js +8 -6
  514. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  515. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  516. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  517. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  518. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  519. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  520. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  521. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  522. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  523. package/lib/esm/numerics/Complex.js.map +1 -1
  524. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  525. package/lib/esm/numerics/Newton.js.map +1 -1
  526. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  527. package/lib/esm/numerics/PolarData.js.map +1 -1
  528. package/lib/esm/numerics/Polynomials.d.ts +13 -1
  529. package/lib/esm/numerics/Polynomials.d.ts.map +1 -1
  530. package/lib/esm/numerics/Polynomials.js +13 -1
  531. package/lib/esm/numerics/Polynomials.js.map +1 -1
  532. package/lib/esm/numerics/Quadrature.js.map +1 -1
  533. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  534. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  535. package/lib/esm/numerics/UnionFind.js.map +1 -1
  536. package/lib/esm/numerics/UsageSums.js.map +1 -1
  537. package/lib/esm/polyface/AuxData.js.map +1 -1
  538. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  539. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  540. package/lib/esm/polyface/FacetLocationDetail.d.ts +28 -5
  541. package/lib/esm/polyface/FacetLocationDetail.d.ts.map +1 -1
  542. package/lib/esm/polyface/FacetLocationDetail.js +48 -14
  543. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  544. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  545. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  546. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  547. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  548. package/lib/esm/polyface/Polyface.d.ts +1 -1
  549. package/lib/esm/polyface/Polyface.d.ts.map +1 -1
  550. package/lib/esm/polyface/Polyface.js.map +1 -1
  551. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  552. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  553. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  554. package/lib/esm/polyface/PolyfaceQuery.d.ts +7 -3
  555. package/lib/esm/polyface/PolyfaceQuery.d.ts.map +1 -1
  556. package/lib/esm/polyface/PolyfaceQuery.js +23 -0
  557. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  558. package/lib/esm/polyface/RangeLengthData.js.map +1 -1
  559. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.d.ts +52 -0
  560. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.d.ts.map +1 -0
  561. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js +74 -0
  562. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -0
  563. package/lib/esm/polyface/RangeTree/MinimumValueTester.d.ts +60 -0
  564. package/lib/esm/polyface/RangeTree/MinimumValueTester.d.ts.map +1 -0
  565. package/lib/esm/polyface/RangeTree/MinimumValueTester.js +92 -0
  566. package/lib/esm/polyface/RangeTree/MinimumValueTester.js.map +1 -0
  567. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.d.ts +57 -0
  568. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.d.ts.map +1 -0
  569. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js +69 -0
  570. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -0
  571. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.d.ts +57 -0
  572. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.d.ts.map +1 -0
  573. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js +80 -0
  574. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -0
  575. package/lib/esm/polyface/RangeTree/RangeTreeNode.d.ts +274 -0
  576. package/lib/esm/polyface/RangeTree/RangeTreeNode.d.ts.map +1 -0
  577. package/lib/esm/polyface/RangeTree/RangeTreeNode.js +497 -0
  578. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -0
  579. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.d.ts +204 -0
  580. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.d.ts.map +1 -0
  581. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js +374 -0
  582. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -0
  583. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  584. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  585. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  586. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  587. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  588. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  589. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  590. package/lib/esm/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  591. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  592. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  593. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  594. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  595. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  596. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  597. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  598. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  599. package/lib/esm/serialization/GeometrySamples.d.ts +36 -3
  600. package/lib/esm/serialization/GeometrySamples.d.ts.map +1 -1
  601. package/lib/esm/serialization/GeometrySamples.js +93 -4
  602. package/lib/esm/serialization/GeometrySamples.js.map +1 -1
  603. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  604. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  605. package/lib/esm/solid/Box.js.map +1 -1
  606. package/lib/esm/solid/Cone.js.map +1 -1
  607. package/lib/esm/solid/LinearSweep.d.ts +1 -1
  608. package/lib/esm/solid/LinearSweep.js +1 -1
  609. package/lib/esm/solid/LinearSweep.js.map +1 -1
  610. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  611. package/lib/esm/solid/RuledSweep.js.map +1 -1
  612. package/lib/esm/solid/SolidPrimitive.js.map +1 -1
  613. package/lib/esm/solid/Sphere.js.map +1 -1
  614. package/lib/esm/solid/SweepContour.d.ts +2 -2
  615. package/lib/esm/solid/SweepContour.d.ts.map +1 -1
  616. package/lib/esm/solid/SweepContour.js.map +1 -1
  617. package/lib/esm/solid/TorusPipe.js.map +1 -1
  618. package/lib/esm/topology/ChainMerge.js.map +1 -1
  619. package/lib/esm/topology/Graph.d.ts +5 -6
  620. package/lib/esm/topology/Graph.d.ts.map +1 -1
  621. package/lib/esm/topology/Graph.js +7 -6
  622. package/lib/esm/topology/Graph.js.map +1 -1
  623. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.d.ts +4 -4
  624. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js +5 -5
  625. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  626. package/lib/esm/topology/HalfEdgeGraphSearch.d.ts +108 -71
  627. package/lib/esm/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  628. package/lib/esm/topology/HalfEdgeGraphSearch.js +223 -109
  629. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  630. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  631. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  632. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  633. package/lib/esm/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  634. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  635. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  636. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  637. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  638. package/lib/esm/topology/MaskManager.js.map +1 -1
  639. package/lib/esm/topology/Merging.d.ts +1 -1
  640. package/lib/esm/topology/Merging.d.ts.map +1 -1
  641. package/lib/esm/topology/Merging.js.map +1 -1
  642. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  643. package/lib/esm/topology/SignedDataSummary.d.ts +13 -13
  644. package/lib/esm/topology/SignedDataSummary.d.ts.map +1 -1
  645. package/lib/esm/topology/SignedDataSummary.js +3 -3
  646. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  647. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  648. package/lib/esm/topology/Triangulation.d.ts +1 -12
  649. package/lib/esm/topology/Triangulation.d.ts.map +1 -1
  650. package/lib/esm/topology/Triangulation.js.map +1 -1
  651. package/lib/esm/topology/XYParitySearchContext.d.ts +27 -21
  652. package/lib/esm/topology/XYParitySearchContext.d.ts.map +1 -1
  653. package/lib/esm/topology/XYParitySearchContext.js +73 -71
  654. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  655. package/package.json +3 -3
@@ -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 { 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 variant 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 variant 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\nreturn 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 /**\r\n * Extract auxData for a mesh\r\n * @param variant read position in the flat buffer.\r\n */\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 /**\r\n * Extract auxData for a mesh\r\n * @param variant read position in the flat buffer.\r\n */\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 * Extract auxData for a mesh\r\n * @param variant read position in the flat buffer.\r\n */\r\n public readPolyfaceAuxData(auxDataHeader: BGFBAccessors.PolyfaceAuxData | null): PolyfaceAuxData | undefined {\r\n if (auxDataHeader) {\r\n const channelsLength = auxDataHeader.channelsLength();\r\n const indicesArray = auxDataHeader.indicesArray();\r\n const indices: number[] = [];\r\n const channels: AuxChannel[] = [];\r\n if (null !== indicesArray) {\r\n for (const i of indicesArray)\r\n indices.push(i);\r\n }\r\n if (0 !== channelsLength) {\r\n for (let i = 0; i < channelsLength; i++) {\r\n const channelHeader = auxDataHeader.channels(i);\r\n const channelContent = this.readPolyfaceAuxChannel(channelHeader);\r\n if (channelContent)\r\n channels.push(channelContent);\r\n }\r\n }\r\n return new PolyfaceAuxData(channels, indices);\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Extract auxData for a mesh\r\n * @param variant read position in the flat buffer.\r\n */\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 * 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 taggedNumericDataOffset = polyfaceHeader.taggedNumericData();\r\n if (meshStyle === 1 && pointF64 && pointIndexI32) {\r\n const polyface = IndexedPolyface.create(normalF64 !== undefined, paramF64 !== undefined, intColorU32 !== undefined, twoSided);\r\n polyface.expectedClosure = expectedClosure;\r\n for (let i = 0; i + 2 < pointF64?.length; i += 3)\r\n polyface.data.point.pushXYZ(pointF64[i], pointF64[i + 1], pointF64[i + 2]);\r\n if (paramF64) {\r\n for (let i = 0; i + 1 < paramF64?.length; i += 2)\r\n polyface.data.param!.pushXY(paramF64[i], paramF64[i + 1]);\r\n }\r\n if (normalF64) {\r\n for (let i = 0; i + 2 < normalF64?.length; i += 3)\r\n polyface.data.normal!.pushXYZ(normalF64[i], normalF64[i + 1], normalF64[i + 2]);\r\n }\r\n if (intColorU32) {\r\n for (const c of intColorU32)\r\n polyface.data.color!.push(c);\r\n }\r\n // The flatbuffer data is one based.\r\n // If numPerFace is less than 2, facets are variable size and zero terminated\r\n // If numPerFace is 2 or more, indices are blocked\r\n const numIndex = pointIndexI32.length;\r\n const addIndicesInBlock = (k0: number, k1: number) => {\r\n for (let k = k0; k < k1; k++) {\r\n const q = pointIndexI32[k];\r\n polyface.addPointIndex(Math.abs(q) - 1, q > 0);\r\n if (normalF64 && normalIndexI32) {\r\n polyface.addNormalIndex(Math.abs(normalIndexI32[k]) - 1);\r\n }\r\n if (paramF64 && paramIndexI32) {\r\n polyface.addParamIndex(Math.abs(paramIndexI32[k]) - 1);\r\n }\r\n if (intColorU32 && colorIndexI32) {\r\n polyface.addColorIndex(Math.abs(colorIndexI32[k]) - 1);\r\n }\r\n }\r\n };\r\n\r\n if (numPerFace > 1) {\r\n for (let i0 = 0; i0 + numPerFace <= numIndex; i0 += numPerFace){\r\n addIndicesInBlock(i0, i0 + numPerFace);\r\n polyface.terminateFacet(true);\r\n }\r\n } else {\r\n let i0 = 0;\r\n for (let i1 = i0; i1 < numIndex; i1++) {\r\n if (pointIndexI32[i1] === 0) {\r\n addIndicesInBlock(i0, i1);\r\n polyface.terminateFacet(true);\r\n i0 = i1 + 1;\r\n }\r\n }\r\n }\r\n\r\n polyface.data.auxData = this.readPolyfaceAuxData(polyfaceHeader.auxData());\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 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 {\r\n return this.readCurvePrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagCurveVector:\r\n {\r\n return this.readCurveCollectionFromVariantGeometry(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagPolyface:\r\n {\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 {\r\n return this.readSolidPrimitiveFromVariant(variant);\r\n }\r\n case BGFBAccessors.VariantGeometryUnion.tagVectorOfVariantGeometry:\r\n {\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 {\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":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\nimport { flatbuffers } from \"flatbuffers\";\nimport { AkimaCurve3d, AkimaCurve3dOptions } from \"../bspline/AkimaCurve3d\";\nimport { BSplineCurve3d } from \"../bspline/BSplineCurve\";\nimport { BSplineCurve3dH } from \"../bspline/BSplineCurve3dH\";\nimport { BSplineSurface3d, BSplineSurface3dH, UVSelect } from \"../bspline/BSplineSurface\";\nimport { InterpolationCurve3d, InterpolationCurve3dOptions } from \"../bspline/InterpolationCurve3d\";\nimport { Arc3d } from \"../curve/Arc3d\";\nimport { BagOfCurves, CurveCollection } from \"../curve/CurveCollection\";\nimport { CurvePrimitive } from \"../curve/CurvePrimitive\";\nimport { GeometryQuery } from \"../curve/GeometryQuery\";\nimport { LineSegment3d } from \"../curve/LineSegment3d\";\nimport { LineString3d } from \"../curve/LineString3d\";\nimport { Loop } from \"../curve/Loop\";\nimport { ParityRegion } from \"../curve/ParityRegion\";\nimport { Path } from \"../curve/Path\";\nimport { PointString3d } from \"../curve/PointString3d\";\nimport { DirectSpiral3d } from \"../curve/spiral/DirectSpiral3d\";\nimport { IntegratedSpiral3d } from \"../curve/spiral/IntegratedSpiral3d\";\nimport { TransitionSpiral3d } from \"../curve/spiral/TransitionSpiral3d\";\nimport { UnionRegion } from \"../curve/UnionRegion\";\nimport { Geometry } from \"../Geometry\";\nimport { Angle } from \"../geometry3d/Angle\";\nimport { AngleSweep } from \"../geometry3d/AngleSweep\";\nimport { Point3d, Vector3d } from \"../geometry3d/Point3dVector3d\";\nimport { NumberArray, Point3dArray } from \"../geometry3d/PointHelpers\";\nimport { Ray3d } from \"../geometry3d/Ray3d\";\nimport { Segment1d } from \"../geometry3d/Segment1d\";\nimport { Transform } from \"../geometry3d/Transform\";\nimport { AuxChannel, AuxChannelData, PolyfaceAuxData } from \"../polyface/AuxData\";\nimport { IndexedPolyface } from \"../polyface/Polyface\";\nimport { TaggedNumericData } from \"../polyface/TaggedNumericData\";\nimport { Box } from \"../solid/Box\";\nimport { Cone } from \"../solid/Cone\";\nimport { LinearSweep } from \"../solid/LinearSweep\";\nimport { RotationalSweep } from \"../solid/RotationalSweep\";\nimport { RuledSweep } from \"../solid/RuledSweep\";\nimport { SolidPrimitive } from \"../solid/SolidPrimitive\";\nimport { Sphere } from \"../solid/Sphere\";\nimport { TorusPipe } from \"../solid/TorusPipe\";\nimport { BGFBAccessors } from \"./BGFBAccessors\";\nimport { SerializationHelpers } from \"./SerializationHelpers\";\n\n/** * Context to write to a flatbuffer blob.\n * * This class is internal.\n * * Public access is through BentleyGeometryFlatBuffer.geometryToBytes()\n * @internal\n */\nexport class BGFBReader {\n public constructor() {\n }\n /**\n * Extract a bspline surface\n * @param variant read position in the flat buffer.\n */\n public readBSplineSurfaceFromVariant(variantHeader: BGFBAccessors.VariantGeometry): BSplineSurface3d | BSplineSurface3dH | undefined {\n let newSurface: BSplineSurface3d | BSplineSurface3dH | undefined;\n const geometryType = variantHeader.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineSurface) {\n const bsurfHeader = variantHeader.geometry(new BGFBAccessors.BsplineSurface());\n if (bsurfHeader !== null) {\n const orderU = bsurfHeader.orderU();\n const orderV = bsurfHeader.orderV();\n const numPolesU = bsurfHeader.numPolesU();\n const numPolesV = bsurfHeader.numPolesV();\n const xyzArray = bsurfHeader.polesArray();\n const knotArrayU = bsurfHeader.knotsUArray();\n const knotArrayV = bsurfHeader.knotsVArray();\n const weightArray = bsurfHeader.weightsArray();\n const closedU = bsurfHeader.closedU();\n const closedV = bsurfHeader.closedV();\n\n if (xyzArray !== null && knotArrayU !== null && knotArrayV !== null) {\n const myData = SerializationHelpers.createBSplineSurfaceData(xyzArray, 3, knotArrayU, numPolesU, orderU, knotArrayV, numPolesV, orderV);\n if (weightArray !== null)\n myData.weights = weightArray;\n if (closedU)\n myData.uParams.closed = true;\n if (closedV)\n myData.vParams.closed = true;\n\n if (SerializationHelpers.Import.prepareBSplineSurfaceData(myData, {jsonPoles: false})) {\n if (undefined === myData.weights)\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);\n else\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);\n\n if (undefined !== newSurface) {\n if (undefined !== myData.uParams.wrapMode)\n newSurface.setWrappable(UVSelect.uDirection, myData.uParams.wrapMode);\n if (undefined !== myData.vParams.wrapMode)\n newSurface.setWrappable(UVSelect.vDirection, myData.vParams.wrapMode);\n }\n }\n }\n }\n }\n return newSurface;\n }\n\n /**\n * Extract an interpolating curve\n * @param variant read position in the flat buffer.\n */\n public readInterpolationCurve3d(header: BGFBAccessors.InterpolationCurve): InterpolationCurve3d | undefined {\n const xyzArray = header.fitPointsArray();\n if (xyzArray instanceof Float64Array){\n const knots = header.knotsArray();\n const options = new InterpolationCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray), knots ? NumberArray.create(knots) : undefined);\n const startTangent = header.startTangent();\n const endTangent = header.endTangent();\n options.captureOptionalProps(\n header.order(),\n header.closed(),\n header.isChordLenKnots(),\n header.isColinearTangents(),\n header.isChordLenTangents(),\n header.isNaturalTangents (),\n startTangent !== null ? Vector3d.create(startTangent.x(), startTangent.y(), startTangent.z()) : undefined,\n endTangent !== null ? Vector3d.create(endTangent.x(), endTangent.y(), endTangent.z()) : undefined);\n return InterpolationCurve3d.createCapture(options);\n }\n return undefined;\n}\n\n/**\n * Extract an akima curve\n * @param variant read position in the flat buffer.\n */\n public readAkimaCurve3d(header: BGFBAccessors.AkimaCurve): AkimaCurve3d | undefined {\n const xyzArray = header.pointsArray();\n if (xyzArray instanceof Float64Array){\n const options = new AkimaCurve3dOptions(Point3dArray.clonePoint3dArray(xyzArray));\n return AkimaCurve3d.createCapture(options);\n }\nreturn undefined;\n}\n/**\n * Extract a bspline curve\n * @param variant read position in the flat buffer.\n */\n public readBSplineCurve(header: BGFBAccessors.BsplineCurve): BSplineCurve3d | BSplineCurve3dH | undefined {\n let newCurve: BSplineCurve3d | BSplineCurve3dH | undefined;\n const order = header.order();\n const xyzArray = header.polesArray();\n const knots = header.knotsArray();\n const weightsArray = header.weightsArray();\n const closed = header.closed();\n\n if (xyzArray !== null && knots !== null) {\n const numPoles = Math.floor(xyzArray.length / 3);\n const myData = SerializationHelpers.createBSplineCurveData(xyzArray, 3, knots, numPoles, order);\n if (closed)\n myData.params.closed = true;\n\n if (weightsArray === null) {\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData))\n newCurve = BSplineCurve3d.create(myData.poles, myData.params.knots, myData.params.order);\n } else {\n myData.weights = weightsArray;\n if (SerializationHelpers.Import.prepareBSplineCurveData(myData, {jsonPoles: false}))\n newCurve = BSplineCurve3dH.create({ xyz: myData.poles as Float64Array, weights: myData.weights }, myData.params.knots, myData.params.order);\n }\n\n if (undefined !== newCurve) {\n if (undefined !== myData.params.wrapMode)\n newCurve.setWrappable(myData.params.wrapMode);\n }\n }\n return newCurve;\n }\n /**\n * Extract a bspline curve\n * @param variant read position in the flat buffer.\n */\n public readTransitionSpiral(header: BGFBAccessors.TransitionSpiral): TransitionSpiral3d | undefined {\n const detailHeader = header.detail();\n if (detailHeader) {\n const directDetailHeader = header.directDetail();\n const _extraDataArray = header.extraDataArray();\n const spiralTypeName = DgnSpiralTypeQueries.typeCodeToString(detailHeader.spiralType());\n const curvature0 = detailHeader.curvature0();\n const curvature1 = detailHeader.curvature1();\n const bearing0Radians = detailHeader.bearing0Radians();\n const bearing1Radians = detailHeader.bearing1Radians();\n const fbTransform = detailHeader.transform();\n const localToWorld = fbTransform ? Transform.createRowValues(\n fbTransform.axx(), fbTransform.axy(), fbTransform.axz(), fbTransform.axw(),\n fbTransform.ayx(), fbTransform.ayy(), fbTransform.ayz(), fbTransform.ayw(),\n fbTransform.azx(), fbTransform.azy(), fbTransform.azz(), fbTransform.azw()) :\n Transform.createIdentity();\n\n const activeFractionInterval = Segment1d.create(detailHeader.fractionA(),\n detailHeader.fractionB());\n if (!directDetailHeader) {\n const integratedSpiral = IntegratedSpiral3d.createRadiusRadiusBearingBearing(\n Segment1d.create(IntegratedSpiral3d.curvatureToRadius(curvature0), IntegratedSpiral3d.curvatureToRadius(curvature1)),\n AngleSweep.createStartEndRadians(bearing0Radians, bearing1Radians),\n activeFractionInterval, localToWorld, spiralTypeName);\n if (integratedSpiral)\n return integratedSpiral;\n const radius0 = TransitionSpiral3d.curvatureToRadius(curvature0);\n const radius1 = TransitionSpiral3d.curvatureToRadius(curvature1);\n const arcLength = TransitionSpiral3d.radiusRadiusSweepRadiansToArcLength(radius0, radius1,\n bearing1Radians - bearing0Radians);\n const directSpiral = DirectSpiral3d.createFromLengthAndRadius(\n spiralTypeName!,\n radius0, radius1,\n Angle.createRadians(bearing0Radians),\n Angle.createRadians (bearing1Radians),\n arcLength,\n activeFractionInterval,\n localToWorld);\n if (directSpiral)\n return directSpiral;\n }\n }\n return undefined;\n }\n /**\n * Extract a curve primitive\n * @param variant read position in the flat buffer.\n */\n public readCurvePrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): CurvePrimitive | undefined {\n const geometryType = variant.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineSegment) {\n const offsetToLineSegment = variant.geometry(new BGFBAccessors.LineSegment());\n const offsetToCoordinates = offsetToLineSegment!.segment();\n return LineSegment3d.createXYZXYZ(\n offsetToCoordinates!.point0X(), offsetToCoordinates!.point0Y(), offsetToCoordinates!.point0Z(),\n offsetToCoordinates!.point1X(), offsetToCoordinates!.point1Y(), offsetToCoordinates!.point1Z());\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagEllipticArc) {\n const offsetToEllipticArc = variant.geometry(new BGFBAccessors.EllipticArc());\n const offsetToCoordinates = offsetToEllipticArc!.arc()!;\n return Arc3d.createXYZXYZXYZ(\n offsetToCoordinates.centerX(), offsetToCoordinates.centerY(), offsetToCoordinates.centerZ(),\n offsetToCoordinates.vector0X(), offsetToCoordinates.vector0Y(), offsetToCoordinates.vector0Z(),\n offsetToCoordinates.vector90X(), offsetToCoordinates.vector90Y(), offsetToCoordinates.vector90Z(),\n AngleSweep.createStartSweepRadians(offsetToCoordinates.startRadians(), offsetToCoordinates?.sweepRadians()));\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagLineString) {\n const offsetToLineString = variant.geometry(new BGFBAccessors.LineString())!;\n const numCoordinates = offsetToLineString.pointsLength();\n const result = LineString3d.create();\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\n result.packedPoints.pushXYZ(offsetToLineString.points(i)!, offsetToLineString.points(i + 1)!, offsetToLineString.points(i + 2)!);\n }\n return result;\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagBsplineCurve) {\n const offsetToBCurve = variant.geometry(new BGFBAccessors.BsplineCurve());\n if (offsetToBCurve !== null)\n return this.readBSplineCurve(offsetToBCurve);\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral) {\n const offsetToTransitionSpiralTable = variant.geometry(new BGFBAccessors.TransitionSpiral());\n if (offsetToTransitionSpiralTable !== null)\n return this.readTransitionSpiral(offsetToTransitionSpiralTable);\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve) {\n const offsetToInterpolationCurveTable = variant.geometry(new BGFBAccessors.InterpolationCurve());\n if (offsetToInterpolationCurveTable !== null)\n return this.readInterpolationCurve3d(offsetToInterpolationCurveTable);\n } else if (geometryType === BGFBAccessors.VariantGeometryUnion.tagAkimaCurve) {\n const offsetToAkimaCurveTable = variant.geometry(new BGFBAccessors.AkimaCurve());\n if (offsetToAkimaCurveTable !== null)\n return this.readAkimaCurve3d(offsetToAkimaCurveTable);\n }\n return undefined;\n }\n /**\n * Extract a curve primitive\n * @param variant read position in the flat buffer.\n */\n public readPointStringFromVariant(variant: BGFBAccessors.VariantGeometry): PointString3d | undefined {\n const geometryType = variant.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPointString) {\n const offsetToLineString = variant.geometry(new BGFBAccessors.PointString())!;\n const numCoordinates = offsetToLineString.pointsLength();\n const result = PointString3d.create();\n for (let i = 0; i + 2 < numCoordinates; i += 3) {\n result.points.push(Point3d.create(offsetToLineString.points(i)!, offsetToLineString.points(i + 1)!, offsetToLineString.points(i + 2)!));\n }\n return result;\n }\n return undefined;\n }\n /**\n * Extract auxData for a mesh\n * @param variant read position in the flat buffer.\n */\n public readPolyfaceAuxChannelData(channelDataHeader: BGFBAccessors.PolyfaceAuxChannelData | null): AuxChannelData | undefined {\n if (channelDataHeader !== null) {\n const input = channelDataHeader.input();\n const values = channelDataHeader.valuesArray();\n if (values !== null)\n return new AuxChannelData(input, values);\n }\n return undefined;\n }\n\n /**\n * Extract auxData for a mesh\n * @param variant read position in the flat buffer.\n */\n public readPolyfaceAuxChannel(channelHeader: BGFBAccessors.PolyfaceAuxChannel | null): AuxChannel | undefined {\n if (channelHeader) {\n const dataType = channelHeader.dataType();\n const dataLength = channelHeader.dataLength();\n const channelDataArray: AuxChannelData[] = [];\n const name = channelHeader.name();\n const inputName = channelHeader.inputName();\n for (let i = 0; i < dataLength; i++) {\n const channelData = this.readPolyfaceAuxChannelData(channelHeader.data(i));\n if (channelData)\n channelDataArray.push(channelData);\n }\n return new AuxChannel(channelDataArray, dataType, name ? name : undefined, inputName ? inputName : undefined);\n }\n return undefined;\n }\n /**\n * Extract auxData for a mesh\n * @param variant read position in the flat buffer.\n */\n public readPolyfaceAuxData(auxDataHeader: BGFBAccessors.PolyfaceAuxData | null): PolyfaceAuxData | undefined {\n if (auxDataHeader) {\n const channelsLength = auxDataHeader.channelsLength();\n const indicesArray = auxDataHeader.indicesArray();\n const indices: number[] = [];\n const channels: AuxChannel[] = [];\n if (null !== indicesArray) {\n for (const i of indicesArray)\n indices.push(i);\n }\n if (0 !== channelsLength) {\n for (let i = 0; i < channelsLength; i++) {\n const channelHeader = auxDataHeader.channels(i);\n const channelContent = this.readPolyfaceAuxChannel(channelHeader);\n if (channelContent)\n channels.push(channelContent);\n }\n }\n return new PolyfaceAuxData(channels, indices);\n }\n return undefined;\n }\n\n /**\n * Extract auxData for a mesh\n * @param variant read position in the flat buffer.\n */\n public readTaggedNumericData(accessor: BGFBAccessors.TaggedNumericData | undefined): TaggedNumericData | undefined {\n if (accessor) {\n const taggedNumericData = new TaggedNumericData(accessor.tagA(), accessor.tagB());\n const intDataArray = nullToUndefined<Int32Array>(accessor.intDataArray());\n const doubleDataArray = nullToUndefined<Float64Array>(accessor.doubleDataArray());\n if (intDataArray) {\n taggedNumericData.intData = [];\n for (const c of intDataArray)\n taggedNumericData.intData.push(c);\n\n }\n if (doubleDataArray) {\n taggedNumericData.doubleData = [];\n for (const c of doubleDataArray)\n taggedNumericData.doubleData.push(c);\n }\n return taggedNumericData;\n }\n return undefined;\n }\n /**\n * Extract a mesh\n * @param variant read position in the flat buffer.\n */\n public readPolyfaceFromVariant(variant: BGFBAccessors.VariantGeometry): IndexedPolyface | undefined {\n const geometryType = variant.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagPolyface) {\n const polyfaceHeader = variant.geometry(new BGFBAccessors.Polyface());\n if (polyfaceHeader) {\n const twoSided = polyfaceHeader.twoSided();\n const expectedClosure = polyfaceHeader.expectedClosure();\n const meshStyle = polyfaceHeader.meshStyle();\n const numPerFace = polyfaceHeader.numPerFace();\n\n const pointF64 = nullToUndefined<Float64Array>(polyfaceHeader.pointArray());\n const paramF64 = nullToUndefined<Float64Array>(polyfaceHeader.paramArray());\n const normalF64 = nullToUndefined<Float64Array>(polyfaceHeader.normalArray());\n const intColorU32 = nullToUndefined<Uint32Array>(polyfaceHeader.intColorArray());\n\n const pointIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.pointIndexArray());\n const paramIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.paramIndexArray());\n const normalIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.normalIndexArray());\n const colorIndexI32 = nullToUndefined<Int32Array>(polyfaceHeader.colorIndexArray());\n const taggedNumericDataOffset = polyfaceHeader.taggedNumericData();\n if (meshStyle === 1 && pointF64 && pointIndexI32) {\n const polyface = IndexedPolyface.create(normalF64 !== undefined, paramF64 !== undefined, intColorU32 !== undefined, twoSided);\n polyface.expectedClosure = expectedClosure;\n for (let i = 0; i + 2 < pointF64?.length; i += 3)\n polyface.data.point.pushXYZ(pointF64[i], pointF64[i + 1], pointF64[i + 2]);\n if (paramF64) {\n for (let i = 0; i + 1 < paramF64?.length; i += 2)\n polyface.data.param!.pushXY(paramF64[i], paramF64[i + 1]);\n }\n if (normalF64) {\n for (let i = 0; i + 2 < normalF64?.length; i += 3)\n polyface.data.normal!.pushXYZ(normalF64[i], normalF64[i + 1], normalF64[i + 2]);\n }\n if (intColorU32) {\n for (const c of intColorU32)\n polyface.data.color!.push(c);\n }\n // The flatbuffer data is one based.\n // If numPerFace is less than 2, facets are variable size and zero terminated\n // If numPerFace is 2 or more, indices are blocked\n const numIndex = pointIndexI32.length;\n const addIndicesInBlock = (k0: number, k1: number) => {\n for (let k = k0; k < k1; k++) {\n const q = pointIndexI32[k];\n polyface.addPointIndex(Math.abs(q) - 1, q > 0);\n if (normalF64 && normalIndexI32) {\n polyface.addNormalIndex(Math.abs(normalIndexI32[k]) - 1);\n }\n if (paramF64 && paramIndexI32) {\n polyface.addParamIndex(Math.abs(paramIndexI32[k]) - 1);\n }\n if (intColorU32 && colorIndexI32) {\n polyface.addColorIndex(Math.abs(colorIndexI32[k]) - 1);\n }\n }\n };\n\n if (numPerFace > 1) {\n for (let i0 = 0; i0 + numPerFace <= numIndex; i0 += numPerFace){\n addIndicesInBlock(i0, i0 + numPerFace);\n polyface.terminateFacet(true);\n }\n } else {\n let i0 = 0;\n for (let i1 = i0; i1 < numIndex; i1++) {\n if (pointIndexI32[i1] === 0) {\n addIndicesInBlock(i0, i1);\n polyface.terminateFacet(true);\n i0 = i1 + 1;\n }\n }\n }\n\n polyface.data.auxData = this.readPolyfaceAuxData(polyfaceHeader.auxData());\n if (taggedNumericDataOffset) {\n const taggedNumericDataAccessor = nullToUndefined<BGFBAccessors.TaggedNumericData>(taggedNumericDataOffset);\n if (taggedNumericDataAccessor !== undefined) {\n const taggedNumericData = this.readTaggedNumericData(taggedNumericDataAccessor);\n if (taggedNumericData !== undefined)\n polyface.data.setTaggedNumericData(taggedNumericData);\n }\n }\n return polyface;\n }\n }\n }\n return undefined;\n }\n\n public readCurveCollectionFromCurveVectorTable(cvTable: BGFBAccessors.CurveVector): CurveCollection {\n const numChildren = cvTable.curvesLength();\n const collectionType = cvTable.type();\n const collection = createTypedCurveCollection(collectionType);\n for (let i = 0; i < numChildren; i++) {\n const childOffset = cvTable.curves(i);\n if (childOffset !== null) {\n const child = this.readCurvePrimitiveFromVariant(childOffset);\n if (child)\n collection.tryAddChild(child);\n else {\n const childCollection = this.readCurveCollectionFromVariantGeometry(childOffset);\n if (childCollection)\n collection.tryAddChild(childCollection);\n }\n }\n }\n return collection;\n }\n /**\n * Extract a curve collection\n * @param variant read position in the flat buffer.\n */\n public readCurveCollectionFromVariantGeometry(variant: BGFBAccessors.VariantGeometry): CurveCollection | undefined {\n const geometryType = variant.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagCurveVector) {\n const cvTable = variant.geometry(new BGFBAccessors.CurveVector())!;\n return this.readCurveCollectionFromCurveVectorTable(cvTable);\n }\n return undefined;\n }\n /**\n * Extract a curve collection\n * @param variant read position in the flat buffer.\n */\n public readSolidPrimitiveFromVariant(variant: BGFBAccessors.VariantGeometry): SolidPrimitive | undefined {\n const geometryType = variant.geometryType();\n if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnBox) {\n const header = variant.geometry(new BGFBAccessors.DgnBox());\n const detail = header!.detail()!;\n return Box.createDgnBox(\n Point3d.create(detail.baseOriginX(), detail.baseOriginY(), detail.baseOriginZ()),\n Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ()),\n Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ()),\n Point3d.create(detail.topOriginX(), detail.topOriginY(), detail.topOriginZ()),\n detail.baseX(), detail.baseY(), detail.topX(), detail.topY(),\n detail.capped());\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnSphere) {\n const header = variant.geometry(new BGFBAccessors.DgnSphere());\n const detail = header!.detail()!;\n const lToWDetail = detail.localToWorld()!;\n const localToWorld = Transform.createRowValues(\n lToWDetail.axx(), lToWDetail.axy(), lToWDetail.axz(), lToWDetail.axw(),\n lToWDetail.ayx(), lToWDetail.ayy(), lToWDetail.ayz(), lToWDetail.ayw(),\n lToWDetail.azx(), lToWDetail.azy(), lToWDetail.azz(), lToWDetail.azw());\n return Sphere.createEllipsoid(localToWorld,\n AngleSweep.createStartSweepRadians(detail.startLatitudeRadians(), detail.latitudeSweepRadians()),\n detail.capped());\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnCone) {\n const header = variant.geometry(new BGFBAccessors.DgnCone());\n const detail = header!.detail()!;\n const centerA = Point3d.create(detail.centerAX(), detail.centerAY(), detail.centerAZ());\n const centerB = Point3d.create(detail.centerBX(), detail.centerBY(), detail.centerBZ());\n const vector0 = Vector3d.create(detail.vector0X(), detail.vector0Y(), detail.vector0Z());\n const vector90 = Vector3d.create(detail.vector90X(), detail.vector90Y(), detail.vector90Z());\n const radiusA = detail.radiusA();\n const radiusB = detail.radiusB();\n return Cone.createBaseAndTarget(centerA, centerB, vector0, vector90, radiusA, radiusB, detail.capped());\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe) {\n const header = variant.geometry(new BGFBAccessors.DgnTorusPipe())!;\n const detail = header.detail()!;\n const center = Point3d.create(detail.centerX(), detail.centerY(), detail.centerZ());\n const vectorX = Vector3d.create(detail.vectorXX(), detail.vectorXY(), detail.vectorXZ());\n const vectorY = Vector3d.create(detail.vectorYX(), detail.vectorYY(), detail.vectorYZ());\n const sweepRadians = detail.sweepRadians();\n const majorRadius = detail.majorRadius();\n const minorRadius = detail.minorRadius();\n return TorusPipe.createDgnTorusPipe(center, vectorX, vectorY, majorRadius, minorRadius, Angle.createRadians(sweepRadians), detail.capped());\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion) {\n const header = variant.geometry(new BGFBAccessors.DgnExtrusion())!;\n const dVector = new BGFBAccessors.DVector3d();\n header.extrusionVector(dVector);\n const extrusionVector = Vector3d.create(dVector.x(), dVector.y(), dVector.z());\n const baseCurve = header.baseCurve();\n if (baseCurve !== null) {\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\n return LinearSweep.create(contour, extrusionVector, header.capped());\n }\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep) {\n const header = variant.geometry(new BGFBAccessors.DgnRotationalSweep())!;\n const dAxis = new BGFBAccessors.DRay3d();\n header.axis(dAxis);\n const axis = Ray3d.createXYZUVW(dAxis.x(), dAxis.y(), dAxis.z(), dAxis.ux(), dAxis.uy(), dAxis.uz());\n const sweepAngle = Angle.createRadians(header.sweepRadians());\n // const numVRules = header.numVRules();\n const baseCurve = header.baseCurve();\n if (baseCurve !== null) {\n const contour = this.readCurveCollectionFromCurveVectorTable(baseCurve);\n return RotationalSweep.create(contour, axis, sweepAngle, header.capped());\n }\n } if (geometryType === BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep) {\n const header = variant.geometry(new BGFBAccessors.DgnRuledSweep())!;\n const numCurves = header.curvesLength();\n const contours: CurveCollection[] = [];\n for (let i = 0; i < numCurves; i++) {\n const contourTable = header.curves(i);\n if (contourTable) {\n const contour = this.readCurveCollectionFromCurveVectorTable(contourTable);\n if (contour)\n contours.push(contour);\n }\n }\n if (contours.length > 0) {\n return RuledSweep.create(contours, header.capped());\n }\n }\n return undefined;\n }\n /**\n * Extract any geometry type or array of geometry.\n * @param variant read position in the flat buffer.\n */\n public readGeometryQueryFromVariant(variant: BGFBAccessors.VariantGeometry): GeometryQuery | GeometryQuery[] | undefined {\n const rootType = variant.geometryType();\n switch (rootType) {\n case BGFBAccessors.VariantGeometryUnion.tagLineSegment:\n case BGFBAccessors.VariantGeometryUnion.tagLineString:\n case BGFBAccessors.VariantGeometryUnion.tagEllipticArc:\n case BGFBAccessors.VariantGeometryUnion.tagBsplineCurve:\n case BGFBAccessors.VariantGeometryUnion.tagTransitionSpiral:\n case BGFBAccessors.VariantGeometryUnion.tagInterpolationCurve:\n case BGFBAccessors.VariantGeometryUnion.tagAkimaCurve:\n {\n return this.readCurvePrimitiveFromVariant(variant);\n }\n case BGFBAccessors.VariantGeometryUnion.tagCurveVector:\n {\n return this.readCurveCollectionFromVariantGeometry(variant);\n }\n case BGFBAccessors.VariantGeometryUnion.tagPolyface:\n {\n return this.readPolyfaceFromVariant(variant);\n }\n case BGFBAccessors.VariantGeometryUnion.tagDgnBox:\n case BGFBAccessors.VariantGeometryUnion.tagDgnCone:\n case BGFBAccessors.VariantGeometryUnion.tagDgnTorusPipe:\n case BGFBAccessors.VariantGeometryUnion.tagDgnSphere:\n case BGFBAccessors.VariantGeometryUnion.tagDgnExtrusion:\n case BGFBAccessors.VariantGeometryUnion.tagDgnRotationalSweep:\n case BGFBAccessors.VariantGeometryUnion.tagDgnRuledSweep:\n {\n return this.readSolidPrimitiveFromVariant(variant);\n }\n case BGFBAccessors.VariantGeometryUnion.tagVectorOfVariantGeometry:\n {\n const geometry: GeometryQuery[] = [];\n const offsetToVectorOfVariantGeometry = variant.geometry(new BGFBAccessors.VectorOfVariantGeometry());\n for (let i = 0; i < offsetToVectorOfVariantGeometry!.membersLength(); i++) {\n const child = offsetToVectorOfVariantGeometry!.members(i);\n if (child !== null) {\n const childGeometry = this.readGeometryQueryFromVariant(child);\n if (childGeometry instanceof GeometryQuery) {\n geometry.push(childGeometry);\n } else if (Array.isArray(childGeometry)) {\n geometry.push(...childGeometry);\n }\n }\n }\n return geometry;\n }\n case BGFBAccessors.VariantGeometryUnion.tagBsplineSurface: {\n return this.readBSplineSurfaceFromVariant(variant);\n }\n case BGFBAccessors.VariantGeometryUnion.tagPointString:\n {\n return this.readPointStringFromVariant(variant);\n }\n }\n return undefined;\n }\n /**\n * Deserialize bytes from a flatbuffer.\n * @param justTheBytes FlatBuffer bytes as created by BGFBWriter.createFlatBuffer (g);\n */\n public static bytesToGeometry(theBytes: Uint8Array, signature?: Uint8Array): GeometryQuery | GeometryQuery[] | undefined {\n const newByteBuffer = new flatbuffers.ByteBuffer(theBytes);\n if (signature) {\n if (theBytes.length < signature.length)\n return undefined;\n for (let i = 0; i < signature.length; i++)\n if (theBytes[i] !== signature[i])\n return undefined;\n newByteBuffer.setPosition(signature.length);\n }\n const root = BGFBAccessors.VariantGeometry.getRootAsVariantGeometry(newByteBuffer);\n const reader = new BGFBReader();\n return reader.readGeometryQueryFromVariant(root);\n }\n\n}\n/**\n * if data is \"null\" (the deprecated javascript idiom!) return undefined. Otherwise return the data as its own type.\n * @param data\n */\nfunction nullToUndefined<T>(data: any): T | undefined {\n if (data === null)\n return undefined;\n return data;\n}\n\nfunction createTypedCurveCollection(collectionType: number): CurveCollection {\n if (collectionType === 1) return new Path();\n if (collectionType === 2 || collectionType === 3) return new Loop();\n if (collectionType === 4) return new ParityRegion();\n if (collectionType === 5) return new UnionRegion();\n return new BagOfCurves();\n}\n/**\n * mappings between typescript spiral type strings and native integers.\n * @internal\n */\nexport class DgnSpiralTypeQueries {\n // remark: this is the full list based on native DSpiral2dBase.h.\n // This does not guarantee all types are supported.\n private static spiralTypeCodeMap = [\n [10, \"clothoid\"],\n [11, \"bloss\"],\n [12, \"biquadratic\"],\n [13, \"cosine\"],\n [14, \"sine\"],\n [15, \"Viennese\"],\n [16, \"weightedViennese\"],\n\n [50, \"WesternAustralian\"],\n [51, \"Czech\"],\n [52, \"AustralianRailCorp\"],\n [53, \"Italian\"],\n [54, \"PolishCubic\"],\n [55, \"Arema\"],\n [56, \"MXCubicAlongArc\"],\n [57, \"MXCubicAlongTangent\"],\n [58, \"ChineseCubic\"],\n [60, \"HalfCosine\"],\n [61, \"JapaneseCubic\"],\n ];\n /** Convert native integer type (e.g. from flatbuffer) to typescript string */\n public static typeCodeToString(typeCode: number): string | undefined {\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\n if (entry[0] === typeCode)\n return entry[1] as string;\n }\n return undefined;\n }\n\n /** Convert typescript string to native integer type */\n public static stringToTypeCode(s: string, defaultToClothoid: boolean = true): number | undefined {\n for (const entry of DgnSpiralTypeQueries.spiralTypeCodeMap) {\n if (Geometry.equalStringNoCase(s, entry[1] as string))\n return entry[0] as number;\n }\n return defaultToClothoid ? 10 : undefined;\n }\n /** Ask if the indicated type code is a \"direct\" spiral */\n public static isDirectSpiralType(typeCode: number): boolean {\n return typeCode >= 50;\n }\n}\n"]}