@itwin/core-common 4.0.0-dev.60 → 4.0.0-dev.61
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.
- package/lib/cjs/AmbientOcclusion.js.map +1 -1
- package/lib/cjs/AnalysisStyle.js.map +1 -1
- package/lib/cjs/AuthorizationClient.js.map +1 -1
- package/lib/cjs/BackendTypes.js.map +1 -1
- package/lib/cjs/BackgroundMapProvider.js.map +1 -1
- package/lib/cjs/BackgroundMapSettings.js.map +1 -1
- package/lib/cjs/Base64EncodedString.js.map +1 -1
- package/lib/cjs/BlobReader.js.map +1 -1
- package/lib/cjs/BriefcaseTypes.js.map +1 -1
- package/lib/cjs/Camera.js.map +1 -1
- package/lib/cjs/ChangedElements.js.map +1 -1
- package/lib/cjs/ChangedEntities.js.map +1 -1
- package/lib/cjs/ChangesetProps.js.map +1 -1
- package/lib/cjs/ClipStyle.js.map +1 -1
- package/lib/cjs/Code.js.map +1 -1
- package/lib/cjs/ColorByName.js.map +1 -1
- package/lib/cjs/ColorDef.js.map +1 -1
- package/lib/cjs/CommonLoggerCategory.js.map +1 -1
- package/lib/cjs/ConcurrentQuery.js.map +1 -1
- package/lib/cjs/ContextRealityModel.js.map +1 -1
- package/lib/cjs/DisplayStyleSettings.js.map +1 -1
- package/lib/cjs/ECSchemaProps.js.map +1 -1
- package/lib/cjs/ECSqlReader.js.map +1 -1
- package/lib/cjs/ECSqlTypes.js.map +1 -1
- package/lib/cjs/ElementMesh.js.map +1 -1
- package/lib/cjs/ElementProps.js.map +1 -1
- package/lib/cjs/EmphasizeElementsProps.js.map +1 -1
- package/lib/cjs/EntityProps.js.map +1 -1
- package/lib/cjs/EntityReference.js.map +1 -1
- package/lib/cjs/Environment.js.map +1 -1
- package/lib/cjs/FeatureIndex.js.map +1 -1
- package/lib/cjs/FeatureSymbology.js.map +1 -1
- package/lib/cjs/FeatureTable.js.map +1 -1
- package/lib/cjs/Fonts.js.map +1 -1
- package/lib/cjs/Frustum.js.map +1 -1
- package/lib/cjs/GeoCoordinateServices.js.map +1 -1
- package/lib/cjs/GeometryContainment.js.map +1 -1
- package/lib/cjs/GeometryParams.js.map +1 -1
- package/lib/cjs/GeometrySummary.js.map +1 -1
- package/lib/cjs/Gradient.js.map +1 -1
- package/lib/cjs/GraphicParams.js.map +1 -1
- package/lib/cjs/GroundPlane.js.map +1 -1
- package/lib/cjs/HSLColor.js.map +1 -1
- package/lib/cjs/HSVColor.js.map +1 -1
- package/lib/cjs/HiddenLine.js.map +1 -1
- package/lib/cjs/Hilite.js.map +1 -1
- package/lib/cjs/IModel.js.map +1 -1
- package/lib/cjs/IModelError.js.map +1 -1
- package/lib/cjs/IModelVersion.js.map +1 -1
- package/lib/cjs/Image.js.map +1 -1
- package/lib/cjs/IpcAppProps.js.map +1 -1
- package/lib/cjs/LightSettings.js.map +1 -1
- package/lib/cjs/LinePixels.js.map +1 -1
- package/lib/cjs/Localization.js.map +1 -1
- package/lib/cjs/MapImagerySettings.js.map +1 -1
- package/lib/cjs/MapLayerSettings.js.map +1 -1
- package/lib/cjs/MassProperties.js.map +1 -1
- package/lib/cjs/MaterialProps.js.map +1 -1
- package/lib/cjs/ModelClipGroup.js.map +1 -1
- package/lib/cjs/ModelGeometryChanges.js.map +1 -1
- package/lib/cjs/ModelProps.js.map +1 -1
- package/lib/cjs/NativeAppProps.js.map +1 -1
- package/lib/cjs/OctEncodedNormal.js.map +1 -1
- package/lib/cjs/PlanProjectionSettings.js.map +1 -1
- package/lib/cjs/PlanarClipMask.js.map +1 -1
- package/lib/cjs/QPoint.js.map +1 -1
- package/lib/cjs/RealityDataAccessProps.js.map +1 -1
- package/lib/cjs/RealityModelDisplaySettings.js.map +1 -1
- package/lib/cjs/Render.js.map +1 -1
- package/lib/cjs/RenderMaterial.js.map +1 -1
- package/lib/cjs/RenderTexture.js.map +1 -1
- package/lib/cjs/RgbColor.js.map +1 -1
- package/lib/cjs/RpcInterface.js.map +1 -1
- package/lib/cjs/RpcManager.js.map +1 -1
- package/lib/cjs/SessionProps.js.map +1 -1
- package/lib/cjs/SkyBox.js.map +1 -1
- package/lib/cjs/Snapping.js.map +1 -1
- package/lib/cjs/SolarCalculate.js.map +1 -1
- package/lib/cjs/SolarShadows.js.map +1 -1
- package/lib/cjs/SpatialClassification.js.map +1 -1
- package/lib/cjs/SubCategoryAppearance.js.map +1 -1
- package/lib/cjs/SubCategoryOverride.js.map +1 -1
- package/lib/cjs/TerrainSettings.js.map +1 -1
- package/lib/cjs/TextureMapping.js.map +1 -1
- package/lib/cjs/TextureProps.js.map +1 -1
- package/lib/cjs/ThematicDisplay.js.map +1 -1
- package/lib/cjs/Thumbnail.js.map +1 -1
- package/lib/cjs/TileProps.js.map +1 -1
- package/lib/cjs/Tween.js.map +1 -1
- package/lib/cjs/TxnAction.js.map +1 -1
- package/lib/cjs/ViewDetails.js.map +1 -1
- package/lib/cjs/ViewFlags.js.map +1 -1
- package/lib/cjs/ViewProps.js.map +1 -1
- package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
- package/lib/cjs/core-common.js.map +1 -1
- package/lib/cjs/domains/FunctionalElementProps.js.map +1 -1
- package/lib/cjs/domains/GenericElementProps.js.map +1 -1
- package/lib/cjs/geometry/AdditionalTransform.js.map +1 -1
- package/lib/cjs/geometry/AreaPattern.js.map +1 -1
- package/lib/cjs/geometry/BoundingSphere.js.map +1 -1
- package/lib/cjs/geometry/Cartographic.js.map +1 -1
- package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
- package/lib/cjs/geometry/ElementGeometry.js.map +1 -1
- package/lib/cjs/geometry/ElementGeometryFB.js.map +1 -1
- package/lib/cjs/geometry/FrustumPlanes.js.map +1 -1
- package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
- package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
- package/lib/cjs/geometry/GeometryStream.js.map +1 -1
- package/lib/cjs/geometry/ImageGraphic.js.map +1 -1
- package/lib/cjs/geometry/LineStyle.js.map +1 -1
- package/lib/cjs/geometry/Placement.js.map +1 -1
- package/lib/cjs/geometry/Projection.js.map +1 -1
- package/lib/cjs/geometry/TextString.js.map +1 -1
- package/lib/cjs/ipc/IpcSession.js.map +1 -1
- package/lib/cjs/ipc/IpcSocket.js.map +1 -1
- package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
- package/lib/cjs/ipc/IpcWebSocketTransport.js.map +1 -1
- package/lib/cjs/rpc/DevToolsRpcInterface.js.map +1 -1
- package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
- package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
- package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
- package/lib/cjs/rpc/TestRpcManager.js.map +1 -1
- package/lib/cjs/rpc/WipRpcInterface.js.map +1 -1
- package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
- package/lib/cjs/rpc/core/RpcConstants.js.map +1 -1
- package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
- package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
- package/lib/cjs/rpc/core/RpcMarshaling.js.map +1 -1
- package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
- package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
- package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
- package/lib/cjs/rpc/core/RpcPush.js.map +1 -1
- package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
- package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
- package/lib/cjs/rpc/core/RpcRequestContext.js.map +1 -1
- package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
- package/lib/cjs/rpc/core/RpcSessionInvocation.js.map +1 -1
- package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
- package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
- package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
- package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
- package/lib/cjs/rpc/web/WebAppRpcLogging.js.map +1 -1
- package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
- package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
- package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
- package/lib/cjs/tile/B3dmTileIO.js.map +1 -1
- package/lib/cjs/tile/CompositeTileIO.js.map +1 -1
- package/lib/cjs/tile/ElementGraphics.js.map +1 -1
- package/lib/cjs/tile/GltfTileIO.js.map +1 -1
- package/lib/cjs/tile/I3dmTileIO.js.map +1 -1
- package/lib/cjs/tile/IModelTileIO.js.map +1 -1
- package/lib/cjs/tile/PntsTileIO.js.map +1 -1
- package/lib/cjs/tile/TileIO.js.map +1 -1
- package/lib/cjs/tile/TileMetadata.js.map +1 -1
- package/lib/cjs/tile/Tileset3dSchema.js.map +1 -1
- package/lib/esm/AmbientOcclusion.js.map +1 -1
- package/lib/esm/AnalysisStyle.js.map +1 -1
- package/lib/esm/AuthorizationClient.js.map +1 -1
- package/lib/esm/BackendTypes.js.map +1 -1
- package/lib/esm/BackgroundMapProvider.js.map +1 -1
- package/lib/esm/BackgroundMapSettings.js.map +1 -1
- package/lib/esm/Base64EncodedString.js.map +1 -1
- package/lib/esm/BlobReader.js.map +1 -1
- package/lib/esm/BriefcaseTypes.js.map +1 -1
- package/lib/esm/Camera.js.map +1 -1
- package/lib/esm/ChangedElements.js.map +1 -1
- package/lib/esm/ChangedEntities.js.map +1 -1
- package/lib/esm/ChangesetProps.js.map +1 -1
- package/lib/esm/ClipStyle.js.map +1 -1
- package/lib/esm/Code.js.map +1 -1
- package/lib/esm/ColorByName.js.map +1 -1
- package/lib/esm/ColorDef.js.map +1 -1
- package/lib/esm/CommonLoggerCategory.js.map +1 -1
- package/lib/esm/ConcurrentQuery.js.map +1 -1
- package/lib/esm/ContextRealityModel.js.map +1 -1
- package/lib/esm/DisplayStyleSettings.js.map +1 -1
- package/lib/esm/ECSchemaProps.js.map +1 -1
- package/lib/esm/ECSqlReader.js.map +1 -1
- package/lib/esm/ECSqlTypes.js.map +1 -1
- package/lib/esm/ElementMesh.js.map +1 -1
- package/lib/esm/ElementProps.js.map +1 -1
- package/lib/esm/EmphasizeElementsProps.js.map +1 -1
- package/lib/esm/EntityProps.js.map +1 -1
- package/lib/esm/EntityReference.js.map +1 -1
- package/lib/esm/Environment.js.map +1 -1
- package/lib/esm/FeatureIndex.js.map +1 -1
- package/lib/esm/FeatureSymbology.js.map +1 -1
- package/lib/esm/FeatureTable.js.map +1 -1
- package/lib/esm/Fonts.js.map +1 -1
- package/lib/esm/Frustum.js.map +1 -1
- package/lib/esm/GeoCoordinateServices.js.map +1 -1
- package/lib/esm/GeometryContainment.js.map +1 -1
- package/lib/esm/GeometryParams.js.map +1 -1
- package/lib/esm/GeometrySummary.js.map +1 -1
- package/lib/esm/Gradient.js.map +1 -1
- package/lib/esm/GraphicParams.js.map +1 -1
- package/lib/esm/GroundPlane.js.map +1 -1
- package/lib/esm/HSLColor.js.map +1 -1
- package/lib/esm/HSVColor.js.map +1 -1
- package/lib/esm/HiddenLine.js.map +1 -1
- package/lib/esm/Hilite.js.map +1 -1
- package/lib/esm/IModel.js.map +1 -1
- package/lib/esm/IModelError.js.map +1 -1
- package/lib/esm/IModelVersion.js.map +1 -1
- package/lib/esm/Image.js.map +1 -1
- package/lib/esm/IpcAppProps.js.map +1 -1
- package/lib/esm/LightSettings.js.map +1 -1
- package/lib/esm/LinePixels.js.map +1 -1
- package/lib/esm/Localization.js.map +1 -1
- package/lib/esm/MapImagerySettings.js.map +1 -1
- package/lib/esm/MapLayerSettings.js.map +1 -1
- package/lib/esm/MassProperties.js.map +1 -1
- package/lib/esm/MaterialProps.js.map +1 -1
- package/lib/esm/ModelClipGroup.js.map +1 -1
- package/lib/esm/ModelGeometryChanges.js.map +1 -1
- package/lib/esm/ModelProps.js.map +1 -1
- package/lib/esm/NativeAppProps.js.map +1 -1
- package/lib/esm/OctEncodedNormal.js.map +1 -1
- package/lib/esm/PlanProjectionSettings.js.map +1 -1
- package/lib/esm/PlanarClipMask.js.map +1 -1
- package/lib/esm/QPoint.js.map +1 -1
- package/lib/esm/RealityDataAccessProps.js.map +1 -1
- package/lib/esm/RealityModelDisplaySettings.js.map +1 -1
- package/lib/esm/Render.js.map +1 -1
- package/lib/esm/RenderMaterial.js.map +1 -1
- package/lib/esm/RenderTexture.js.map +1 -1
- package/lib/esm/RgbColor.js.map +1 -1
- package/lib/esm/RpcInterface.js.map +1 -1
- package/lib/esm/RpcManager.js.map +1 -1
- package/lib/esm/SessionProps.js.map +1 -1
- package/lib/esm/SkyBox.js.map +1 -1
- package/lib/esm/Snapping.js.map +1 -1
- package/lib/esm/SolarCalculate.js.map +1 -1
- package/lib/esm/SolarShadows.js.map +1 -1
- package/lib/esm/SpatialClassification.js.map +1 -1
- package/lib/esm/SubCategoryAppearance.js.map +1 -1
- package/lib/esm/SubCategoryOverride.js.map +1 -1
- package/lib/esm/TerrainSettings.js.map +1 -1
- package/lib/esm/TextureMapping.js.map +1 -1
- package/lib/esm/TextureProps.js.map +1 -1
- package/lib/esm/ThematicDisplay.js.map +1 -1
- package/lib/esm/Thumbnail.js.map +1 -1
- package/lib/esm/TileProps.js.map +1 -1
- package/lib/esm/Tween.js.map +1 -1
- package/lib/esm/TxnAction.js.map +1 -1
- package/lib/esm/ViewDetails.js.map +1 -1
- package/lib/esm/ViewFlags.js.map +1 -1
- package/lib/esm/ViewProps.js.map +1 -1
- package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
- package/lib/esm/core-common.js.map +1 -1
- package/lib/esm/domains/FunctionalElementProps.js.map +1 -1
- package/lib/esm/domains/GenericElementProps.js.map +1 -1
- package/lib/esm/geometry/AdditionalTransform.js.map +1 -1
- package/lib/esm/geometry/AreaPattern.js.map +1 -1
- package/lib/esm/geometry/BoundingSphere.js.map +1 -1
- package/lib/esm/geometry/Cartographic.js.map +1 -1
- package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
- package/lib/esm/geometry/ElementGeometry.js.map +1 -1
- package/lib/esm/geometry/ElementGeometryFB.js.map +1 -1
- package/lib/esm/geometry/FrustumPlanes.js.map +1 -1
- package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
- package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
- package/lib/esm/geometry/GeometryStream.js.map +1 -1
- package/lib/esm/geometry/ImageGraphic.js.map +1 -1
- package/lib/esm/geometry/LineStyle.js.map +1 -1
- package/lib/esm/geometry/Placement.js.map +1 -1
- package/lib/esm/geometry/Projection.js.map +1 -1
- package/lib/esm/geometry/TextString.js.map +1 -1
- package/lib/esm/ipc/IpcSession.js.map +1 -1
- package/lib/esm/ipc/IpcSocket.js.map +1 -1
- package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
- package/lib/esm/ipc/IpcWebSocketTransport.js.map +1 -1
- package/lib/esm/rpc/DevToolsRpcInterface.js.map +1 -1
- package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
- package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
- package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
- package/lib/esm/rpc/TestRpcManager.js.map +1 -1
- package/lib/esm/rpc/WipRpcInterface.js.map +1 -1
- package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
- package/lib/esm/rpc/core/RpcConstants.js.map +1 -1
- package/lib/esm/rpc/core/RpcControl.js.map +1 -1
- package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
- package/lib/esm/rpc/core/RpcMarshaling.js.map +1 -1
- package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
- package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
- package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
- package/lib/esm/rpc/core/RpcPush.js.map +1 -1
- package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
- package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
- package/lib/esm/rpc/core/RpcRequestContext.js.map +1 -1
- package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
- package/lib/esm/rpc/core/RpcSessionInvocation.js.map +1 -1
- package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
- package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
- package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
- package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
- package/lib/esm/rpc/web/WebAppRpcLogging.js.map +1 -1
- package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
- package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
- package/lib/esm/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
- package/lib/esm/tile/B3dmTileIO.js.map +1 -1
- package/lib/esm/tile/CompositeTileIO.js.map +1 -1
- package/lib/esm/tile/ElementGraphics.js.map +1 -1
- package/lib/esm/tile/GltfTileIO.js.map +1 -1
- package/lib/esm/tile/I3dmTileIO.js.map +1 -1
- package/lib/esm/tile/IModelTileIO.js.map +1 -1
- package/lib/esm/tile/PntsTileIO.js.map +1 -1
- package/lib/esm/tile/TileIO.js.map +1 -1
- package/lib/esm/tile/TileMetadata.js.map +1 -1
- package/lib/esm/tile/Tileset3dSchema.js.map +1 -1
- package/package.json +6 -6
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FrustumPlanes.js","sourceRoot":"","sources":["../../../src/geometry/FrustumPlanes.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*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Geometry\n */\n\nimport { ClipPlane, Point3d, Vector3d } from \"@itwin/core-geometry\";\nimport { Frustum } from \"../Frustum\";\nimport { BoundingSphere } from \"./BoundingSphere\";\n\nconst planePointIndices = [\n [1, 3, 5], // right\n [0, 4, 2], // left\n [2, 6, 3], // top\n [0, 1, 4], // bottom\n [0, 2, 1], // back\n [4, 5, 6], // front\n];\n\nfunction computeFrustumPlanes(frustum: Frustum): ClipPlane[] {\n const planes = [];\n const points = frustum.points;\n const expandPlaneDistance = 1e-6;\n\n for (const indices of planePointIndices) {\n const i0 = indices[0], i1 = indices[1], i2 = indices[2];\n const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);\n normal.normalizeInPlace();\n\n const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);\n if (!plane)\n return [];\n\n planes.push(plane);\n }\n\n return planes;\n}\n\n// Scratch variable used by FrustumPlanes.computeContainment.\nconst planesContainingSphere = [false, false, false, false, false, false];\n\n/** Represents a the planes of a [[Frustum]] for testing containment and intersection.\n * A valid frustum produces six planes. A degenerate frustum produces zero planes.\n * @public\n * @extensions\n */\nexport class FrustumPlanes {\n private _planes: ClipPlane[];\n\n private constructor(planes: ClipPlane[]) {\n this._planes = planes;\n }\n\n /** Compute the six planes of the specified frustum.\n * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.\n * @see [[isValid]] to test this condition.\n */\n public static fromFrustum(frustum: Frustum): FrustumPlanes {\n const planes = computeFrustumPlanes(frustum);\n return new FrustumPlanes(planes);\n }\n\n /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -\n * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.\n */\n public static createEmpty(): FrustumPlanes {\n return new FrustumPlanes([]);\n }\n\n /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created\n * via [[createEmpty]] - in either case, [[planes]] will be an empty array.\n */\n public get isValid(): boolean {\n return this._planes.length === 6;\n }\n\n /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as\n * right, left, top, bottom, back, front. Otherwise, it will be empty.\n */\n public get planes(): ClipPlane[] {\n return this._planes;\n }\n\n /** Recompute the planes from the specified frustum.\n * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.\n */\n public init(frustum: Frustum): boolean {\n this._planes = computeFrustumPlanes(frustum);\n return this.isValid;\n }\n\n /** Compute to what degree a [[Frustum]] is contained with these frustum planes.\n * @param box The frustum to test for containment.\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\n * @returns the degree to which `box` is contained within the clipping planes.\n */\n public computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment {\n return this.computeContainment(box.points, sphere);\n }\n\n /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.\n * @param box The frustum to test for containment.\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\n * @returns true if `box` is not entirely outside of the clipping planes.\n */\n public intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean {\n return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);\n }\n\n /** Determines whether a point is contained within these frustum planes.\n * @param point The point to test for containment.\n * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered \"contained\".\n * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.\n */\n public containsPoint(point: Point3d, tolerance: number = 1.0e-8): boolean {\n return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);\n }\n\n /** Compute the degree to which a set of points is contained within these frustum planes.\n * @param points The points to test for containment.\n * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.\n * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered \"contained\".\n * @returns the degree to which all of the points are contained within the clipping planes.\n */\n public computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance: number = 1.0e-8): FrustumPlanes.Containment {\n if (undefined === this._planes)\n return FrustumPlanes.Containment.Outside;\n\n // Do the cheap test against bounding sphere first.\n if (sphere) {\n for (let i = 0; i < this._planes.length; i++) {\n const plane = this._planes[i];\n const centerDistance = plane.altitude(sphere.center);\n const tolerancePlusRadius = tolerance + sphere.radius;\n if (centerDistance < -tolerancePlusRadius)\n return FrustumPlanes.Containment.Outside;\n\n planesContainingSphere[i] = centerDistance > tolerancePlusRadius;\n }\n }\n\n // Test against points.\n let allInside = true;\n for (let i = 0; i < this._planes.length; i++) {\n if (sphere && planesContainingSphere[i])\n continue;\n\n const plane = this._planes[i];\n let nOutside = 0;\n for (const point of points) {\n if (plane.altitude(point) + tolerance < 0) {\n ++nOutside;\n allInside = false;\n }\n }\n\n if (nOutside === points.length)\n return FrustumPlanes.Containment.Outside;\n }\n\n return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;\n }\n\n /** Computes whether a ray intersects these clipping planes.\n * @param origin The origin of the ray.\n * @param direction The direction of the ray.\n * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.\n */\n public intersectsRay(origin: Point3d, direction: Vector3d): boolean {\n if (undefined === this._planes) {\n return false;\n }\n\n let tFar = 1e37;\n let tNear = -tFar;\n\n for (const plane of this._planes) {\n const vD = plane.velocity(direction);\n const vN = plane.altitude(origin);\n if (0.0 === vD) {\n // ray is parallel... no need to continue testing if outside halfspace.\n if (vN < 0.0) {\n return false;\n }\n } else {\n const rayDistance = -vN / vD;\n if (vD < 0.0) {\n tFar = Math.min(rayDistance, tFar);\n } else {\n tNear = Math.max(rayDistance, tNear);\n }\n }\n }\n\n return tNear <= tFar;\n }\n}\n\n/** @public @extensions */\nexport namespace FrustumPlanes { // eslint-disable-line no-redeclare\n /** Describes the degree to which an object is contained within the planes of a [[Frustum]].\n * @see [[FrustumPlanes.computeContainment]], for example.\n */\n export enum Containment {\n /** The object is entirely outside of the frustum, intersecting none of its planes. */\n Outside = 0,\n /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */\n Partial = 1,\n /** The object is entirely inside of the frustum, intersecting none of its planes. */\n Inside = 2,\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"FrustumPlanes.js","sourceRoot":"","sources":["../../../src/geometry/FrustumPlanes.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\n/** @packageDocumentation\r\n * @module Geometry\r\n */\r\n\r\nimport { ClipPlane, Point3d, Vector3d } from \"@itwin/core-geometry\";\r\nimport { Frustum } from \"../Frustum\";\r\nimport { BoundingSphere } from \"./BoundingSphere\";\r\n\r\nconst planePointIndices = [\r\n [1, 3, 5], // right\r\n [0, 4, 2], // left\r\n [2, 6, 3], // top\r\n [0, 1, 4], // bottom\r\n [0, 2, 1], // back\r\n [4, 5, 6], // front\r\n];\r\n\r\nfunction computeFrustumPlanes(frustum: Frustum): ClipPlane[] {\r\n const planes = [];\r\n const points = frustum.points;\r\n const expandPlaneDistance = 1e-6;\r\n\r\n for (const indices of planePointIndices) {\r\n const i0 = indices[0], i1 = indices[1], i2 = indices[2];\r\n const normal = Vector3d.createCrossProductToPoints(points[i2], points[i1], points[i0]);\r\n normal.normalizeInPlace();\r\n\r\n const plane = ClipPlane.createNormalAndDistance(normal, normal.dotProduct(points[i0]) - expandPlaneDistance);\r\n if (!plane)\r\n return [];\r\n\r\n planes.push(plane);\r\n }\r\n\r\n return planes;\r\n}\r\n\r\n// Scratch variable used by FrustumPlanes.computeContainment.\r\nconst planesContainingSphere = [false, false, false, false, false, false];\r\n\r\n/** Represents a the planes of a [[Frustum]] for testing containment and intersection.\r\n * A valid frustum produces six planes. A degenerate frustum produces zero planes.\r\n * @public\r\n * @extensions\r\n */\r\nexport class FrustumPlanes {\r\n private _planes: ClipPlane[];\r\n\r\n private constructor(planes: ClipPlane[]) {\r\n this._planes = planes;\r\n }\r\n\r\n /** Compute the six planes of the specified frustum.\r\n * If the frustum is degenerate - that is, its points do not represent a truncated pyramid - then the returned `FrustumPlanes` will contain zero planes.\r\n * @see [[isValid]] to test this condition.\r\n */\r\n public static fromFrustum(frustum: Frustum): FrustumPlanes {\r\n const planes = computeFrustumPlanes(frustum);\r\n return new FrustumPlanes(planes);\r\n }\r\n\r\n /** Create an empty set of frustum planes. [[isValid]] will be `true`. This can be useful when you want to create a `FrustumPlanes` object and initialize it later via [[init]] -\r\n * for example, if you intend to use the same object repeatedly with different [[Frustum]]s.\r\n */\r\n public static createEmpty(): FrustumPlanes {\r\n return new FrustumPlanes([]);\r\n }\r\n\r\n /** Returns true if [[planes]] consists of six planes. This may return `false` if a degenerate [[Frustum]] was supplied to [[fromFrustum]], or if this object was created\r\n * via [[createEmpty]] - in either case, [[planes]] will be an empty array.\r\n */\r\n public get isValid(): boolean {\r\n return this._planes.length === 6;\r\n }\r\n\r\n /** Obtain the list of planes defining the frustum. If [[isValid]] is `true`, it will have a length of six, with the planes ordered as\r\n * right, left, top, bottom, back, front. Otherwise, it will be empty.\r\n */\r\n public get planes(): ClipPlane[] {\r\n return this._planes;\r\n }\r\n\r\n /** Recompute the planes from the specified frustum.\r\n * @returns true upon success, or false if the input frustum was degenerate, in which case [[isValid]] will be `false`.\r\n */\r\n public init(frustum: Frustum): boolean {\r\n this._planes = computeFrustumPlanes(frustum);\r\n return this.isValid;\r\n }\r\n\r\n /** Compute to what degree a [[Frustum]] is contained with these frustum planes.\r\n * @param box The frustum to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\r\n * @returns the degree to which `box` is contained within the clipping planes.\r\n */\r\n public computeFrustumContainment(box: Frustum, sphere?: BoundingSphere): FrustumPlanes.Containment {\r\n return this.computeContainment(box.points, sphere);\r\n }\r\n\r\n /** Determines whether a [[Frustum]] intersects with or is fully contained within these frustum planes.\r\n * @param box The frustum to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing `box`. If supplied, this can reduce the amount of computation required.\r\n * @returns true if `box` is not entirely outside of the clipping planes.\r\n */\r\n public intersectsFrustum(box: Frustum, sphere?: BoundingSphere): boolean {\r\n return FrustumPlanes.Containment.Outside !== this.computeFrustumContainment(box, sphere);\r\n }\r\n\r\n /** Determines whether a point is contained within these frustum planes.\r\n * @param point The point to test for containment.\r\n * @param tolerance The maximum distance from the interior of the frustum planes that will still be considered \"contained\".\r\n * @returns true if `point` is no further than `tolerance` meters outside of the clipping planes.\r\n */\r\n public containsPoint(point: Point3d, tolerance: number = 1.0e-8): boolean {\r\n return FrustumPlanes.Containment.Outside !== this.computeContainment([point], undefined, tolerance);\r\n }\r\n\r\n /** Compute the degree to which a set of points is contained within these frustum planes.\r\n * @param points The points to test for containment.\r\n * @param sphere An optional spherical bounding volume fully containing all of the points. If supplied, this can reduce the amount of computation required.\r\n * @param tolerance The maximum distance from the interior of the frustum planes a point must be to be considered \"contained\".\r\n * @returns the degree to which all of the points are contained within the clipping planes.\r\n */\r\n public computeContainment(points: Point3d[], sphere?: BoundingSphere, tolerance: number = 1.0e-8): FrustumPlanes.Containment {\r\n if (undefined === this._planes)\r\n return FrustumPlanes.Containment.Outside;\r\n\r\n // Do the cheap test against bounding sphere first.\r\n if (sphere) {\r\n for (let i = 0; i < this._planes.length; i++) {\r\n const plane = this._planes[i];\r\n const centerDistance = plane.altitude(sphere.center);\r\n const tolerancePlusRadius = tolerance + sphere.radius;\r\n if (centerDistance < -tolerancePlusRadius)\r\n return FrustumPlanes.Containment.Outside;\r\n\r\n planesContainingSphere[i] = centerDistance > tolerancePlusRadius;\r\n }\r\n }\r\n\r\n // Test against points.\r\n let allInside = true;\r\n for (let i = 0; i < this._planes.length; i++) {\r\n if (sphere && planesContainingSphere[i])\r\n continue;\r\n\r\n const plane = this._planes[i];\r\n let nOutside = 0;\r\n for (const point of points) {\r\n if (plane.altitude(point) + tolerance < 0) {\r\n ++nOutside;\r\n allInside = false;\r\n }\r\n }\r\n\r\n if (nOutside === points.length)\r\n return FrustumPlanes.Containment.Outside;\r\n }\r\n\r\n return allInside ? FrustumPlanes.Containment.Inside : FrustumPlanes.Containment.Partial;\r\n }\r\n\r\n /** Computes whether a ray intersects these clipping planes.\r\n * @param origin The origin of the ray.\r\n * @param direction The direction of the ray.\r\n * @returns true if the ray extending from `origin` in the specified `direction` intersects at least one of the clipping planes.\r\n */\r\n public intersectsRay(origin: Point3d, direction: Vector3d): boolean {\r\n if (undefined === this._planes) {\r\n return false;\r\n }\r\n\r\n let tFar = 1e37;\r\n let tNear = -tFar;\r\n\r\n for (const plane of this._planes) {\r\n const vD = plane.velocity(direction);\r\n const vN = plane.altitude(origin);\r\n if (0.0 === vD) {\r\n // ray is parallel... no need to continue testing if outside halfspace.\r\n if (vN < 0.0) {\r\n return false;\r\n }\r\n } else {\r\n const rayDistance = -vN / vD;\r\n if (vD < 0.0) {\r\n tFar = Math.min(rayDistance, tFar);\r\n } else {\r\n tNear = Math.max(rayDistance, tNear);\r\n }\r\n }\r\n }\r\n\r\n return tNear <= tFar;\r\n }\r\n}\r\n\r\n/** @public @extensions */\r\nexport namespace FrustumPlanes { // eslint-disable-line no-redeclare\r\n /** Describes the degree to which an object is contained within the planes of a [[Frustum]].\r\n * @see [[FrustumPlanes.computeContainment]], for example.\r\n */\r\n export enum Containment {\r\n /** The object is entirely outside of the frustum, intersecting none of its planes. */\r\n Outside = 0,\r\n /** The object intersects at least one of the frustum planes. placing it partially inside of the frustum. */\r\n Partial = 1,\r\n /** The object is entirely inside of the frustum, intersecting none of its planes. */\r\n Inside = 2,\r\n }\r\n}\r\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GeodeticDatum.js","sourceRoot":"","sources":["../../../src/geometry/GeodeticDatum.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*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Geometry\n */\n// cspell:ignore JSONXYZ, ETRF, OSGB, DHDN, NADCON, GEOCN\n\nimport { Geometry, Vector3d, XYAndZ } from \"@itwin/core-geometry\";\nimport { GeodeticEllipsoid, GeodeticEllipsoidProps } from \"./GeodeticEllipsoid\";\n\n/** Holds 3 components of a Positional Vector rotation definition in arc seconds\n * @public\n * @extensions\n */\nexport interface XyzRotationProps {\n /** X rotation component in arc second */\n x: number;\n /** Y rotation component in arc second*/\n y: number;\n /** Z rotation component in arc second*/\n z: number;\n}\n\n/** Hold 3 components data of a Positional Vector rotation definition in arc seconds\n * @public\n */\nexport class XyzRotation implements XyzRotationProps {\n /** X rotation component in arc second */\n public readonly x!: number;\n /** Y rotation component in arc second*/\n public readonly y!: number;\n /** Z rotation component in arc second*/\n public readonly z!: number;\n\n public constructor(data?: XyzRotationProps) {\n if (data) {\n this.x = data.x;\n this.y = data.y;\n this.z = data.z;\n }\n }\n\n /** Creates a Rotations object from JSON representation.\n * @public */\n public static fromJSON(data: XyzRotationProps): XyzRotation {\n return new XyzRotation(data);\n }\n\n /** Creates a JSON from the Rotations definition\n * @public */\n public toJSON(): XyzRotationProps {\n return { x: this.x, y: this.y, z: this.z };\n }\n\n /** Compares two geodetic rotations. It applies a minuscule angular tolerance\n * @public */\n public equals(other: XyzRotation): boolean {\n return (Math.abs(this.x - other.x) < Geometry.smallAngleSeconds &&\n Math.abs(this.y - other.y) < Geometry.smallAngleSeconds &&\n Math.abs(this.z - other.z) < Geometry.smallAngleSeconds);\n }\n}\n\n/** Type indicating the geodetic transformation method\n * @public\n * @extensions\n */\nexport type GeodeticTransformMethod =\n \"None\" |\n \"Geocentric\" |\n \"PositionalVector\" |\n \"GridFiles\" |\n \"MultipleRegression\" |\n \"Undefined\";\n\n/** This interface represents a geocentric (three parameters) geodetic transformation.\n * @public\n * @extensions\n */\nexport interface GeocentricTransformProps {\n /** The frame translation components in meters */\n delta: XYAndZ;\n}\n\n/** This class represents a geocentric (three parameters) geodetic transformation.\n * @public\n */\nexport class GeocentricTransform implements GeocentricTransformProps {\n /** The frame translation components in meters */\n public readonly delta: Vector3d;\n\n public constructor(data?: GeocentricTransformProps) {\n this.delta = data ? Vector3d.fromJSON(data.delta) : new Vector3d();\n }\n\n /** Creates a Geocentric Transform from JSON representation.\n * @public */\n public static fromJSON(data: GeocentricTransformProps): GeocentricTransform {\n return new GeocentricTransform(data);\n }\n\n /** Creates a JSON from the Geodetic GeocentricTransform definition\n * @public */\n public toJSON(): GeocentricTransformProps {\n return { delta: { x: this.delta.x, y: this.delta.y, z: this.delta.z } };\n }\n\n /** Compares two geodetic transforms. It applies a minuscule tolerance.\n * @public */\n public equals(other: GeocentricTransform): boolean {\n return (Math.abs(this.delta.x - other.delta.x) < Geometry.smallMetricDistance &&\n Math.abs(this.delta.y - other.delta.y) < Geometry.smallMetricDistance &&\n Math.abs(this.delta.z - other.delta.z) < Geometry.smallMetricDistance);\n }\n}\n\n/** This interface represents a positional vector (seven parameters) geodetic transformation corresponding to\n * EPSG operation 9606. Beware that the convention relative to rotation direction is different\n * from the Coordinate Frame operation (epsg 9607).\n * @public\n * @extensions\n */\nexport interface PositionalVectorTransformProps {\n /** The frame translation components in meters */\n delta: XYAndZ;\n /** The frame rotation components in arc seconds. The rotation sign convention is the one associated with\n * the operation EPSG:9606 following recommendation of ISO 19111 specifications */\n rotation: XyzRotationProps;\n /** Scale in parts per million. The scale effectively applied will be 1 plus scale divided by 1 000 000. */\n scalePPM: number;\n}\n\n/** This class represents a positional vector (seven parameters) geodetic transformation corresponding to\n * EPSG operation 9606. Beware that the convention relative to rotation direction is different\n * from the Coordinate Frame operation (epsg 9607).\n * @public\n */\nexport class PositionalVectorTransform implements PositionalVectorTransformProps {\n /** The frame translation components in meters */\n public readonly delta!: Vector3d;\n /** The frame rotation components in arc seconds. The rotation sign convention is the one associated with\n * the operation EPSG:9606 following recommendation of ISO 19111 specifications */\n public readonly rotation!: XyzRotation;\n /** Scale in parts per million. The scale effectively applied will be 1 plus scale divided by 1 000 000. */\n public readonly scalePPM!: number;\n\n public constructor(data?: PositionalVectorTransformProps) {\n if (data) {\n this.delta = data.delta ? Vector3d.fromJSON(data.delta) : new Vector3d();\n this.rotation = data.rotation ? XyzRotation.fromJSON(data.rotation) : new XyzRotation();\n this.scalePPM = data.scalePPM;\n }\n }\n\n /** Creates a Positional Vector Transform from JSON representation.\n * @public */\n public static fromJSON(data: PositionalVectorTransformProps): PositionalVectorTransform {\n return new PositionalVectorTransform(data);\n }\n\n /** Creates a JSON from the Positional Vector Transform definition\n * @public */\n public toJSON(): PositionalVectorTransformProps {\n return {\n delta: { x: this.delta.x, y: this.delta.y, z: this.delta.z },\n rotation: this.rotation.toJSON(),\n scalePPM: this.scalePPM,\n };\n }\n\n /** Compares two Positional Vector Transforms. It applies a minuscule tolerance to number compares.\n * @public */\n public equals(other: PositionalVectorTransform): boolean {\n if (Math.abs(this.delta.x - other.delta.x) > Geometry.smallMetricDistance ||\n Math.abs(this.delta.y - other.delta.y) > Geometry.smallMetricDistance ||\n Math.abs(this.delta.z - other.delta.z) > Geometry.smallMetricDistance ||\n Math.abs(this.scalePPM - other.scalePPM) > Geometry.smallFraction)\n return false;\n\n return this.rotation.equals(other.rotation);\n }\n}\n\n/** Type indicating the file format of the grid files.\n * @public\n * @extensions\n */\nexport type GridFileFormat =\n \"NONE\" |\n \"NTv1\" |\n \"NTv2\" |\n \"NADCON\" |\n \"FRENCH\" |\n \"JAPAN\" |\n \"ATS77\" |\n \"GEOCN\" |\n \"OSTN02\" |\n \"OSTN15\";\n\n/** type to indicate the grid file application direction.\n * @public\n * @extensions\n */\nexport type GridFileDirection = \"Direct\" | \"Inverse\";\n\n/** Grid file definition containing name of the file, the format and the direction it should be applied\n * @public\n * @extensions\n */\nexport interface GridFileDefinitionProps {\n /** Name of the grid shift file. This name is relative to the expected dictionary root document.\n * Typical grid shift file name will contain first the country name it applies to then possibly some sub path.\n * Example of existing grid files:\n * Germany/BETA2007.gsb or Brazil/SAD69_003.GSB but sometimes longer paths USA/NADCON/conus.l*s\n * Note that the file name can contain wildcards when the format requires more than one file. For example\n * the NADCON format makes use of a different file for latitude and longitude shifts thus the .l*s extension in the\n * file name above.\n * Forward slash is always used to separate the path components.\n */\n fileName: string;\n /** The grid file format */\n format: GridFileFormat;\n /** The grid file application direction */\n direction: GridFileDirection;\n}\n\n/** Grid file definition containing name of the file, the format and the direction it should be applied\n * @public\n */\nexport class GridFileDefinition implements GridFileDefinitionProps {\n /** Name of the grid shift file. This name is relative to the expected dictionary root document.\n * Typical grid shift file name will contain first the country name it applies to then possibly some sub path.\n * Example of existing grid files:\n * Germany/BETA2007.gsb or Brazil/SAD69_003.GSB but sometimes longer paths USA/NADCON/conus.l*s\n * Note that the file name can contain wildcards when the format requires more than one file. For example\n * the NADCON format makes use of a different file for latitude and longitude shifts thus the .l*s extension in the\n * file name above.\n * Forward slash is always used to separate the path components.\n */\n public readonly fileName: string;\n /** The grid file format */\n public readonly format: GridFileFormat;\n /** The grid file application direction */\n public readonly direction: GridFileDirection;\n\n public constructor(data?: GridFileDefinitionProps) {\n this.fileName = data ? data.fileName : \"\";\n this.format = data ? data.format : \"NTv2\";\n this.direction = data ? data.direction : \"Direct\";\n }\n\n /** Creates a Grid File Definition from JSON representation.\n * @public */\n public static fromJSON(data: GridFileDefinitionProps): GridFileDefinition {\n return new GridFileDefinition(data);\n }\n\n /** Creates a JSON from the Grid File Definition\n * @public */\n public toJSON(): GridFileDefinitionProps {\n return { fileName: this.fileName, format: this.format, direction: this.direction };\n }\n\n /** Compares two grid file definition. It is a strict compare operation not an equivalence test.\n * @public */\n public equals(other: GridFileDefinition): boolean {\n return (this.fileName === other.fileName && this.direction === other.direction && this.format === other.format);\n }\n}\n\n/** This interface represents a grid files based geodetic transformation.\n * @public\n * @extensions\n */\nexport interface GridFileTransformProps {\n /** The list of grid files. The order of file is meaningful, the first encountered that covers the extent of coordinate\n * transformation will be used. */\n files: GridFileDefinitionProps[];\n /** The positional vector fallback transformation used for extents not covered by the grid files */\n fallback?: PositionalVectorTransformProps;\n}\n\n/** This class represents a grid files based geodetic transformation.\n * @public\n */\nexport class GridFileTransform implements GridFileTransformProps {\n /** The list of grid files. The order of file is meaningful, the first encountered that covers the extent of coordinate\n * transformation will be used. */\n public readonly files: GridFileDefinition[];\n /** The positional vector fallback transformation used for extents not covered by the grid files */\n public readonly fallback?: PositionalVectorTransform;\n\n public constructor(data?: GridFileTransformProps) {\n this.files = [];\n if (data) {\n this.fallback = data.fallback ? PositionalVectorTransform.fromJSON(data.fallback) : undefined;\n if (Array.isArray(data.files)) {\n this.files = [];\n for (const item of data.files)\n this.files.push(GridFileDefinition.fromJSON(item));\n }\n }\n }\n\n /** Creates a Grid File Transform from JSON representation.\n * @public */\n public static fromJSON(data: GridFileTransformProps): GridFileTransform {\n return new GridFileTransform(data);\n }\n\n /** Creates a JSON from the Grid File Transform definition\n * @public */\n public toJSON(): GridFileTransformProps {\n const data: GridFileTransformProps = { files: [] };\n data.fallback = this.fallback ? this.fallback.toJSON() : undefined;\n if (Array.isArray(this.files)) {\n for (const item of this.files)\n data.files.push(item.toJSON());\n }\n return data;\n }\n\n /** Compares two Grid File Transforms. It is a strict compare operation not an equivalence test.\n * @public */\n public equals(other: GridFileTransform): boolean {\n if (this.files.length !== other.files.length)\n return false;\n\n for (let idx = 0; idx < this.files.length; ++idx)\n if (!this.files[idx].equals(other.files[idx]))\n return false;\n\n if ((this.fallback === undefined) !== (other.fallback === undefined))\n return false;\n\n if (this.fallback && !this.fallback.equals(other.fallback!))\n return false;\n\n return true;\n }\n}\n\n/** This interface represents a geodetic transformation that enables transforming longitude/latitude coordinates\n * from one datum to another.\n * @public\n * @extensions\n */\nexport interface GeodeticTransformProps {\n /** The method used by the geodetic transform */\n method: GeodeticTransformMethod;\n /** The complete definition of the source geodetic ellipsoid referred to by ellipsoidId.\n * The source ellipsoid identifier enables obtaining the shape of the Earth mathematical model\n * for the purpose of performing the transformation.\n */\n sourceEllipsoid?: GeodeticEllipsoidProps;\n /** The complete definition of the target geodetic ellipsoid referred to by ellipsoidId.\n * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model\n * for the purpose of performing the transformation.*/\n targetEllipsoid?: GeodeticEllipsoidProps;\n /** The id of the source datum. */\n sourceDatumId?: string;\n /** The id of the target datum. This id is useful to seach within a geodetic transform path for\n * a shortcut to another included datum.\n */\n targetDatumId?: string;\n /** When method is Geocentric this property contains the geocentric parameters */\n geocentric?: GeocentricTransformProps;\n /** When method is PositionalVector this property contains the positional vector parameters */\n positionalVector?: PositionalVectorTransformProps;\n /** When method is GridFiles this property contains the grid files parameters */\n gridFile?: GridFileTransformProps;\n}\n\n/** This class represents a geodetic transformation that enables transforming longitude/latitude coordinates\n * from one datum to another.\n * @public\n */\nexport class GeodeticTransform implements GeodeticTransformProps {\n /** The method used by the geodetic transform */\n public readonly method: GeodeticTransformMethod;\n /** The identifier of the source geodetic datum as stored in the dictionary or the service database.\n * This identifier is optional and informational only.\n */\n public readonly sourceEllipsoid?: GeodeticEllipsoid;\n /** The complete definition of the target geodetic ellipsoid referred to by ellipsoidId.\n * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model\n * for the purpose of performing the transformation.*/\n public readonly targetEllipsoid?: GeodeticEllipsoid;\n /** The id of the source datum. */\n public readonly sourceDatumId?: string;\n /** The id of the target datum. This id is useful to seach within a geodetic transform path for\n * a shortcut to another included datum.\n */\n public readonly targetDatumId?: string;\n /** When method is Geocentric this property contains the geocentric parameters */\n public readonly geocentric?: GeocentricTransform;\n /** When method is PositionalVector this property contains the positional vector parameters */\n public readonly positionalVector?: PositionalVectorTransform;\n /** When method is GridFiles this property contains the grid files parameters */\n public readonly gridFile?: GridFileTransform;\n\n public constructor(data?: GeodeticTransformProps) {\n this.method = \"None\";\n if (data) {\n this.method = data.method;\n this.sourceEllipsoid = data.sourceEllipsoid ? GeodeticEllipsoid.fromJSON(data.sourceEllipsoid) : undefined;\n this.targetEllipsoid = data.targetEllipsoid ? GeodeticEllipsoid.fromJSON(data.targetEllipsoid) : undefined;\n this.sourceDatumId = data.sourceDatumId;\n this.targetDatumId = data.targetDatumId;\n this.geocentric = data.geocentric ? GeocentricTransform.fromJSON(data.geocentric) : undefined;\n this.positionalVector = data.positionalVector ? PositionalVectorTransform.fromJSON(data.positionalVector) : undefined;\n this.gridFile = data.gridFile ? GridFileTransform.fromJSON(data.gridFile) : undefined;\n }\n }\n\n /** Creates a Geodetic Transform from JSON representation.\n * @public */\n public static fromJSON(data: GeodeticTransformProps): GeodeticTransform {\n return new GeodeticTransform(data);\n }\n\n /** Creates a JSON from the Geodetic Transform definition\n * @public */\n public toJSON(): GeodeticTransformProps {\n const data: GeodeticTransformProps = { method: this.method };\n data.sourceEllipsoid = this.sourceEllipsoid ? this.sourceEllipsoid.toJSON() : undefined;\n data.targetEllipsoid = this.targetEllipsoid ? this.targetEllipsoid.toJSON() : undefined;\n data.sourceDatumId = this.sourceDatumId;\n data.targetDatumId = this.targetDatumId;\n data.geocentric = this.geocentric ? this.geocentric.toJSON() : undefined;\n data.positionalVector = this.positionalVector ? this.positionalVector.toJSON() : undefined;\n data.gridFile = this.gridFile ? this.gridFile.toJSON() : undefined;\n return data;\n }\n\n /** Compares two geodetic Transforms. It is not an equivalence test since\n * descriptive information is strictly compared. A minuscule tolerance is applied to number compares.\n * @public */\n public equals(other: GeodeticTransform): boolean {\n if (this.method !== other.method)\n return false;\n\n if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)\n return false;\n\n if ((this.sourceEllipsoid === undefined) !== (other.sourceEllipsoid === undefined))\n return false;\n if (this.sourceEllipsoid && !this.sourceEllipsoid.equals(other.sourceEllipsoid!))\n return false;\n\n if ((this.targetEllipsoid === undefined) !== (other.targetEllipsoid === undefined))\n return false;\n if (this.targetEllipsoid && !this.targetEllipsoid.equals(other.targetEllipsoid!))\n return false;\n\n if ((this.geocentric === undefined) !== (other.geocentric === undefined))\n return false;\n if (this.geocentric && !this.geocentric.equals(other.geocentric!))\n return false;\n\n if ((this.positionalVector === undefined) !== (other.positionalVector === undefined))\n return false;\n if (this.positionalVector && !this.positionalVector.equals(other.positionalVector!))\n return false;\n\n if ((this.gridFile === undefined) !== (other.gridFile === undefined))\n return false;\n if (this.gridFile && !this.gridFile.equals(other.gridFile!))\n return false;\n\n return true;\n }\n}\n\n/** This interface represents a geodetic datum transform path. It contains a list of transforms linking\n * a source to a target geodetic datum.\n * @public\n */\nexport interface GeodeticTransformPathProps {\n /** Source geodetic datum key name */\n sourceDatumId?: string;\n /** Target geodetic datum key name */\n targetDatumId?: string;\n /** The transformation path from source datum to target datum.\n */\n transforms?: GeodeticTransformProps[];\n}\n\n/** This class represents a geodetic datum transform path. It contains a list of transforms linking\n * a source to a target geodetic datum.\n * @public\n */\nexport class GeodeticTransformPath implements GeodeticTransformPathProps {\n /** Source geodetic datum key name */\n public readonly sourceDatumId?: string;\n /** Target geodetic datum key name */\n public readonly targetDatumId?: string;\n /** The transformation path from source datum to target datum.\n */\n public readonly transforms?: GeodeticTransform[];\n\n public constructor(_data?: GeodeticTransformPathProps) {\n if (_data) {\n this.sourceDatumId = _data.sourceDatumId;\n this.targetDatumId = _data.targetDatumId;\n if (Array.isArray(_data.transforms)) {\n this.transforms = [];\n for (const item of _data.transforms)\n this.transforms.push(GeodeticTransform.fromJSON(item));\n }\n }\n }\n\n /** Creates a Geodetic transform path from JSON representation.\n * @public */\n public static fromJSON(data: GeodeticTransformPathProps): GeodeticTransformPath {\n return new GeodeticTransformPath(data);\n }\n\n /** Creates a JSON from the Geodetic transform path definition\n * @public */\n public toJSON(): GeodeticTransformPathProps {\n const data: GeodeticTransformPathProps = {};\n data.sourceDatumId = this.sourceDatumId;\n data.targetDatumId = this.targetDatumId;\n if (Array.isArray(this.transforms)) {\n data.transforms = [];\n for (const item of this.transforms)\n data.transforms.push(item.toJSON());\n }\n return data;\n }\n\n /** Compares two Geodetic Transform Paths. It is a strict compare operation not an equivalence test.\n * It takes into account descriptive properties not only mathematical definition properties.\n * @public */\n public equals(other: GeodeticTransformPath): boolean {\n if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)\n return false;\n\n if ((this.transforms === undefined) !== (other.transforms === undefined))\n return false;\n\n if (this.transforms && other.transforms) {\n if (this.transforms.length !== other.transforms.length)\n return false;\n\n for (let idx = 0; idx < this.transforms.length; ++idx)\n if (!this.transforms[idx].equals(other.transforms[idx]))\n return false;\n }\n return true;\n }\n}\n\n/** This interface represents a geodetic datum. Geodetic datums are based on an ellipsoid.\n * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.\n * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying\n * the transformation to the common base WGS84 (or local equivalent). The transforms property can contain the\n * definition of the transformation path to WGS84.\n * Sometimes there exists transformation paths direct from one non-WGS84 datum to another non-WGS84. The current model\n * does not allow specifications of these special paths at the moment.\n * @public\n * @extensions\n */\nexport interface GeodeticDatumProps {\n /** GeodeticDatum key name */\n id?: string;\n /** Description */\n description?: string;\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\n ** If false or undefined then the definition is not deprecated.\n */\n deprecated?: boolean;\n /** A textual description of the source of the geodetic datum definition. */\n source?: string;\n /** The EPSG code of the geodetic datum. If undefined then there is no EPSG code associated. */\n epsg?: number;\n /** The key name to the base Ellipsoid. */\n ellipsoidId?: string;\n /** The full definition of the geodetic ellipsoid associated to the datum. If undefined then the ellipsoidId must be used to fetch the definition from the dictionary, geographic coordinate system service or the backend */\n ellipsoid?: GeodeticEllipsoidProps;\n /** The transformation to WGS84. If null then there is no known transformation to WGS84. Although\n * this is rare it occurs in a few cases where the country charges for obtaining and using\n * the transformation and its parameters, or if the transformation is maintained secret for military reasons.\n * In this case the recommendation is to considered the geodetic datum to be coincident to WGS84 keeping\n * in mind imported global data such as Google Map or Bing Map data may be approximately located.\n * The list of transforms contains normally a single transform but there can be a sequence of transformations\n * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.\n */\n transforms?: GeodeticTransformProps[];\n /** The optional list of transformation paths to other datum. These should only be used if the path to\n * these datum is not included in the transforms property definition of the transformation to WGS84.\n * It should not be used either if the transformation to the datum can be infered from the concatenation\n * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is\n * inherent to the nature of the datum. As an example it is required to represent the transformation\n * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path\n * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related\n * to the available paths to WGS84.\n */\n additionalTransformPaths?: GeodeticTransformPathProps[];\n}\n\n/** This class represents a geodetic datum. Geodetic datums are based on an ellipsoid.\n * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.\n * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying\n * the transformation to the common base WGS84 (or local equivalent). The transforms property can contain the\n * definition of the transformation path to WGS84.\n * Sometimes there exists transformation paths direct from one non-WGS84 datum to another non-WGS84. The current model\n * does not allow specifications of these special paths at the moment.\n * @public\n */\nexport class GeodeticDatum implements GeodeticDatumProps {\n /** GeodeticDatum key name */\n public readonly id?: string;\n /** Description */\n public readonly description?: string;\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\n * If false then the definition is not deprecated. Default is false.\n */\n public readonly deprecated: boolean;\n /** A textual description of the source of the geodetic datum definition. */\n public readonly source?: string;\n /** The EPSG code of the geodetic datum. If undefined then there is no EPSG code associated. */\n public readonly epsg?: number;\n /** The key name to the base Ellipsoid. */\n public readonly ellipsoidId?: string;\n /** The full definition of the geodetic ellipsoid associated to the datum. If undefined then the ellipsoidId must\n * be used to fetch the definition from the dictionary, geographic coordinate system service or the backend\n */\n public readonly ellipsoid?: GeodeticEllipsoid;\n /** The transformation to WGS84. If null then there is no known transformation to WGS84. Although\n * this is rare it occurs in a few cases where the country charges for obtaining and using\n * the transformation and its parameters, or if the transformation is maintained secret for military reasons.\n * In this case the recommendation is to considered the geodetic datum to be coincident to WGS84 keeping\n * in mind imported global data such as Google Map or Bing Map data may be approximately located.\n * The list of transforms contains normally a single transform but there can be a sequence of transformations\n * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.\n */\n public readonly transforms?: GeodeticTransform[];\n /** The optional list of transformation paths to other datum. These should only be used if the path to\n * these datum is not included in the transforms property definition of the transformation to WGS84.\n * It should not be used either if the transformation to the datum can be infered from the concatenation\n * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is\n * inherent to the nature of the datum. As an example it is required to represent the transformation\n * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path\n * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related\n * to the available paths to WGS84.\n */\n public readonly additionalTransformPaths?: GeodeticTransformPath[];\n\n public constructor(_data?: GeodeticDatumProps) {\n this.deprecated = false;\n if (_data) {\n this.id = _data.id;\n this.description = _data.description;\n this.deprecated = _data.deprecated ?? false;\n this.source = _data.source;\n this.epsg = _data.epsg;\n this.ellipsoidId = _data.ellipsoidId;\n this.ellipsoid = _data.ellipsoid ? GeodeticEllipsoid.fromJSON(_data.ellipsoid) : undefined;\n if (Array.isArray(_data.transforms)) {\n this.transforms = [];\n for (const item of _data.transforms)\n this.transforms.push(GeodeticTransform.fromJSON(item));\n }\n if (Array.isArray(_data.additionalTransformPaths)) {\n this.additionalTransformPaths = [];\n for (const item of _data.additionalTransformPaths)\n this.additionalTransformPaths.push(GeodeticTransformPath.fromJSON(item));\n }\n }\n }\n\n /** Creates a Geodetic Datum from JSON representation.\n * @public */\n public static fromJSON(data: GeodeticDatumProps): GeodeticDatum {\n return new GeodeticDatum(data);\n }\n\n /** Creates a JSON from the Geodetic Datum definition\n * @public */\n public toJSON(): GeodeticDatumProps {\n const data: GeodeticDatumProps = {};\n data.id = this.id;\n data.description = this.description;\n /* We prefer to use the default undef instead of false value for deprecated value in Json */\n data.deprecated = (this.deprecated === false ? undefined : true);\n data.source = this.source;\n data.epsg = this.epsg;\n data.ellipsoidId = this.ellipsoidId;\n data.ellipsoid = this.ellipsoid ? this.ellipsoid.toJSON() : undefined;\n if (Array.isArray(this.transforms)) {\n data.transforms = [];\n for (const item of this.transforms)\n data.transforms.push(item.toJSON());\n }\n if (Array.isArray(this.additionalTransformPaths)) {\n data.additionalTransformPaths = [];\n for (const item of this.additionalTransformPaths)\n data.additionalTransformPaths.push(item.toJSON());\n }\n return data;\n }\n\n /** Compares two Geodetic Datums. It is a strict compare operation not an equivalence test.\n * It takes into account descriptive properties not only mathematical definition properties.\n * @public */\n public equals(other: GeodeticDatum): boolean {\n if (this.id !== other.id ||\n this.description !== other.description ||\n this.deprecated !== other.deprecated ||\n this.source !== other.source ||\n this.epsg !== other.epsg ||\n this.ellipsoidId !== other.ellipsoidId)\n return false;\n\n if ((this.ellipsoid === undefined) !== (other.ellipsoid === undefined))\n return false;\n\n if (this.ellipsoid && !this.ellipsoid.equals(other.ellipsoid!))\n return false;\n\n if ((this.transforms === undefined) !== (other.transforms === undefined))\n return false;\n\n if (this.transforms && other.transforms) {\n if (this.transforms.length !== other.transforms.length)\n return false;\n\n for (let idx = 0; idx < this.transforms.length; ++idx)\n if (!this.transforms[idx].equals(other.transforms[idx]))\n return false;\n }\n\n if ((this.additionalTransformPaths === undefined) !== (other.additionalTransformPaths === undefined))\n return false;\n\n if (this.additionalTransformPaths && other.additionalTransformPaths) {\n if (this.additionalTransformPaths.length !== other.additionalTransformPaths.length)\n return false;\n\n for (let idx = 0; idx < this.additionalTransformPaths.length; ++idx)\n if (!this.additionalTransformPaths[idx].equals(other.additionalTransformPaths[idx]))\n return false;\n }\n return true;\n }\n}\n\n"]}
|
|
1
|
+
{"version":3,"file":"GeodeticDatum.js","sourceRoot":"","sources":["../../../src/geometry/GeodeticDatum.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\n/** @packageDocumentation\r\n * @module Geometry\r\n */\r\n// cspell:ignore JSONXYZ, ETRF, OSGB, DHDN, NADCON, GEOCN\r\n\r\nimport { Geometry, Vector3d, XYAndZ } from \"@itwin/core-geometry\";\r\nimport { GeodeticEllipsoid, GeodeticEllipsoidProps } from \"./GeodeticEllipsoid\";\r\n\r\n/** Holds 3 components of a Positional Vector rotation definition in arc seconds\r\n * @public\r\n * @extensions\r\n */\r\nexport interface XyzRotationProps {\r\n /** X rotation component in arc second */\r\n x: number;\r\n /** Y rotation component in arc second*/\r\n y: number;\r\n /** Z rotation component in arc second*/\r\n z: number;\r\n}\r\n\r\n/** Hold 3 components data of a Positional Vector rotation definition in arc seconds\r\n * @public\r\n */\r\nexport class XyzRotation implements XyzRotationProps {\r\n /** X rotation component in arc second */\r\n public readonly x!: number;\r\n /** Y rotation component in arc second*/\r\n public readonly y!: number;\r\n /** Z rotation component in arc second*/\r\n public readonly z!: number;\r\n\r\n public constructor(data?: XyzRotationProps) {\r\n if (data) {\r\n this.x = data.x;\r\n this.y = data.y;\r\n this.z = data.z;\r\n }\r\n }\r\n\r\n /** Creates a Rotations object from JSON representation.\r\n * @public */\r\n public static fromJSON(data: XyzRotationProps): XyzRotation {\r\n return new XyzRotation(data);\r\n }\r\n\r\n /** Creates a JSON from the Rotations definition\r\n * @public */\r\n public toJSON(): XyzRotationProps {\r\n return { x: this.x, y: this.y, z: this.z };\r\n }\r\n\r\n /** Compares two geodetic rotations. It applies a minuscule angular tolerance\r\n * @public */\r\n public equals(other: XyzRotation): boolean {\r\n return (Math.abs(this.x - other.x) < Geometry.smallAngleSeconds &&\r\n Math.abs(this.y - other.y) < Geometry.smallAngleSeconds &&\r\n Math.abs(this.z - other.z) < Geometry.smallAngleSeconds);\r\n }\r\n}\r\n\r\n/** Type indicating the geodetic transformation method\r\n * @public\r\n * @extensions\r\n */\r\nexport type GeodeticTransformMethod =\r\n \"None\" |\r\n \"Geocentric\" |\r\n \"PositionalVector\" |\r\n \"GridFiles\" |\r\n \"MultipleRegression\" |\r\n \"Undefined\";\r\n\r\n/** This interface represents a geocentric (three parameters) geodetic transformation.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeocentricTransformProps {\r\n /** The frame translation components in meters */\r\n delta: XYAndZ;\r\n}\r\n\r\n/** This class represents a geocentric (three parameters) geodetic transformation.\r\n * @public\r\n */\r\nexport class GeocentricTransform implements GeocentricTransformProps {\r\n /** The frame translation components in meters */\r\n public readonly delta: Vector3d;\r\n\r\n public constructor(data?: GeocentricTransformProps) {\r\n this.delta = data ? Vector3d.fromJSON(data.delta) : new Vector3d();\r\n }\r\n\r\n /** Creates a Geocentric Transform from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeocentricTransformProps): GeocentricTransform {\r\n return new GeocentricTransform(data);\r\n }\r\n\r\n /** Creates a JSON from the Geodetic GeocentricTransform definition\r\n * @public */\r\n public toJSON(): GeocentricTransformProps {\r\n return { delta: { x: this.delta.x, y: this.delta.y, z: this.delta.z } };\r\n }\r\n\r\n /** Compares two geodetic transforms. It applies a minuscule tolerance.\r\n * @public */\r\n public equals(other: GeocentricTransform): boolean {\r\n return (Math.abs(this.delta.x - other.delta.x) < Geometry.smallMetricDistance &&\r\n Math.abs(this.delta.y - other.delta.y) < Geometry.smallMetricDistance &&\r\n Math.abs(this.delta.z - other.delta.z) < Geometry.smallMetricDistance);\r\n }\r\n}\r\n\r\n/** This interface represents a positional vector (seven parameters) geodetic transformation corresponding to\r\n * EPSG operation 9606. Beware that the convention relative to rotation direction is different\r\n * from the Coordinate Frame operation (epsg 9607).\r\n * @public\r\n * @extensions\r\n */\r\nexport interface PositionalVectorTransformProps {\r\n /** The frame translation components in meters */\r\n delta: XYAndZ;\r\n /** The frame rotation components in arc seconds. The rotation sign convention is the one associated with\r\n * the operation EPSG:9606 following recommendation of ISO 19111 specifications */\r\n rotation: XyzRotationProps;\r\n /** Scale in parts per million. The scale effectively applied will be 1 plus scale divided by 1 000 000. */\r\n scalePPM: number;\r\n}\r\n\r\n/** This class represents a positional vector (seven parameters) geodetic transformation corresponding to\r\n * EPSG operation 9606. Beware that the convention relative to rotation direction is different\r\n * from the Coordinate Frame operation (epsg 9607).\r\n * @public\r\n */\r\nexport class PositionalVectorTransform implements PositionalVectorTransformProps {\r\n /** The frame translation components in meters */\r\n public readonly delta!: Vector3d;\r\n /** The frame rotation components in arc seconds. The rotation sign convention is the one associated with\r\n * the operation EPSG:9606 following recommendation of ISO 19111 specifications */\r\n public readonly rotation!: XyzRotation;\r\n /** Scale in parts per million. The scale effectively applied will be 1 plus scale divided by 1 000 000. */\r\n public readonly scalePPM!: number;\r\n\r\n public constructor(data?: PositionalVectorTransformProps) {\r\n if (data) {\r\n this.delta = data.delta ? Vector3d.fromJSON(data.delta) : new Vector3d();\r\n this.rotation = data.rotation ? XyzRotation.fromJSON(data.rotation) : new XyzRotation();\r\n this.scalePPM = data.scalePPM;\r\n }\r\n }\r\n\r\n /** Creates a Positional Vector Transform from JSON representation.\r\n * @public */\r\n public static fromJSON(data: PositionalVectorTransformProps): PositionalVectorTransform {\r\n return new PositionalVectorTransform(data);\r\n }\r\n\r\n /** Creates a JSON from the Positional Vector Transform definition\r\n * @public */\r\n public toJSON(): PositionalVectorTransformProps {\r\n return {\r\n delta: { x: this.delta.x, y: this.delta.y, z: this.delta.z },\r\n rotation: this.rotation.toJSON(),\r\n scalePPM: this.scalePPM,\r\n };\r\n }\r\n\r\n /** Compares two Positional Vector Transforms. It applies a minuscule tolerance to number compares.\r\n * @public */\r\n public equals(other: PositionalVectorTransform): boolean {\r\n if (Math.abs(this.delta.x - other.delta.x) > Geometry.smallMetricDistance ||\r\n Math.abs(this.delta.y - other.delta.y) > Geometry.smallMetricDistance ||\r\n Math.abs(this.delta.z - other.delta.z) > Geometry.smallMetricDistance ||\r\n Math.abs(this.scalePPM - other.scalePPM) > Geometry.smallFraction)\r\n return false;\r\n\r\n return this.rotation.equals(other.rotation);\r\n }\r\n}\r\n\r\n/** Type indicating the file format of the grid files.\r\n * @public\r\n * @extensions\r\n */\r\nexport type GridFileFormat =\r\n \"NONE\" |\r\n \"NTv1\" |\r\n \"NTv2\" |\r\n \"NADCON\" |\r\n \"FRENCH\" |\r\n \"JAPAN\" |\r\n \"ATS77\" |\r\n \"GEOCN\" |\r\n \"OSTN02\" |\r\n \"OSTN15\";\r\n\r\n/** type to indicate the grid file application direction.\r\n * @public\r\n * @extensions\r\n */\r\nexport type GridFileDirection = \"Direct\" | \"Inverse\";\r\n\r\n/** Grid file definition containing name of the file, the format and the direction it should be applied\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GridFileDefinitionProps {\r\n /** Name of the grid shift file. This name is relative to the expected dictionary root document.\r\n * Typical grid shift file name will contain first the country name it applies to then possibly some sub path.\r\n * Example of existing grid files:\r\n * Germany/BETA2007.gsb or Brazil/SAD69_003.GSB but sometimes longer paths USA/NADCON/conus.l*s\r\n * Note that the file name can contain wildcards when the format requires more than one file. For example\r\n * the NADCON format makes use of a different file for latitude and longitude shifts thus the .l*s extension in the\r\n * file name above.\r\n * Forward slash is always used to separate the path components.\r\n */\r\n fileName: string;\r\n /** The grid file format */\r\n format: GridFileFormat;\r\n /** The grid file application direction */\r\n direction: GridFileDirection;\r\n}\r\n\r\n/** Grid file definition containing name of the file, the format and the direction it should be applied\r\n * @public\r\n */\r\nexport class GridFileDefinition implements GridFileDefinitionProps {\r\n /** Name of the grid shift file. This name is relative to the expected dictionary root document.\r\n * Typical grid shift file name will contain first the country name it applies to then possibly some sub path.\r\n * Example of existing grid files:\r\n * Germany/BETA2007.gsb or Brazil/SAD69_003.GSB but sometimes longer paths USA/NADCON/conus.l*s\r\n * Note that the file name can contain wildcards when the format requires more than one file. For example\r\n * the NADCON format makes use of a different file for latitude and longitude shifts thus the .l*s extension in the\r\n * file name above.\r\n * Forward slash is always used to separate the path components.\r\n */\r\n public readonly fileName: string;\r\n /** The grid file format */\r\n public readonly format: GridFileFormat;\r\n /** The grid file application direction */\r\n public readonly direction: GridFileDirection;\r\n\r\n public constructor(data?: GridFileDefinitionProps) {\r\n this.fileName = data ? data.fileName : \"\";\r\n this.format = data ? data.format : \"NTv2\";\r\n this.direction = data ? data.direction : \"Direct\";\r\n }\r\n\r\n /** Creates a Grid File Definition from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GridFileDefinitionProps): GridFileDefinition {\r\n return new GridFileDefinition(data);\r\n }\r\n\r\n /** Creates a JSON from the Grid File Definition\r\n * @public */\r\n public toJSON(): GridFileDefinitionProps {\r\n return { fileName: this.fileName, format: this.format, direction: this.direction };\r\n }\r\n\r\n /** Compares two grid file definition. It is a strict compare operation not an equivalence test.\r\n * @public */\r\n public equals(other: GridFileDefinition): boolean {\r\n return (this.fileName === other.fileName && this.direction === other.direction && this.format === other.format);\r\n }\r\n}\r\n\r\n/** This interface represents a grid files based geodetic transformation.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GridFileTransformProps {\r\n /** The list of grid files. The order of file is meaningful, the first encountered that covers the extent of coordinate\r\n * transformation will be used. */\r\n files: GridFileDefinitionProps[];\r\n /** The positional vector fallback transformation used for extents not covered by the grid files */\r\n fallback?: PositionalVectorTransformProps;\r\n}\r\n\r\n/** This class represents a grid files based geodetic transformation.\r\n * @public\r\n */\r\nexport class GridFileTransform implements GridFileTransformProps {\r\n /** The list of grid files. The order of file is meaningful, the first encountered that covers the extent of coordinate\r\n * transformation will be used. */\r\n public readonly files: GridFileDefinition[];\r\n /** The positional vector fallback transformation used for extents not covered by the grid files */\r\n public readonly fallback?: PositionalVectorTransform;\r\n\r\n public constructor(data?: GridFileTransformProps) {\r\n this.files = [];\r\n if (data) {\r\n this.fallback = data.fallback ? PositionalVectorTransform.fromJSON(data.fallback) : undefined;\r\n if (Array.isArray(data.files)) {\r\n this.files = [];\r\n for (const item of data.files)\r\n this.files.push(GridFileDefinition.fromJSON(item));\r\n }\r\n }\r\n }\r\n\r\n /** Creates a Grid File Transform from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GridFileTransformProps): GridFileTransform {\r\n return new GridFileTransform(data);\r\n }\r\n\r\n /** Creates a JSON from the Grid File Transform definition\r\n * @public */\r\n public toJSON(): GridFileTransformProps {\r\n const data: GridFileTransformProps = { files: [] };\r\n data.fallback = this.fallback ? this.fallback.toJSON() : undefined;\r\n if (Array.isArray(this.files)) {\r\n for (const item of this.files)\r\n data.files.push(item.toJSON());\r\n }\r\n return data;\r\n }\r\n\r\n /** Compares two Grid File Transforms. It is a strict compare operation not an equivalence test.\r\n * @public */\r\n public equals(other: GridFileTransform): boolean {\r\n if (this.files.length !== other.files.length)\r\n return false;\r\n\r\n for (let idx = 0; idx < this.files.length; ++idx)\r\n if (!this.files[idx].equals(other.files[idx]))\r\n return false;\r\n\r\n if ((this.fallback === undefined) !== (other.fallback === undefined))\r\n return false;\r\n\r\n if (this.fallback && !this.fallback.equals(other.fallback!))\r\n return false;\r\n\r\n return true;\r\n }\r\n}\r\n\r\n/** This interface represents a geodetic transformation that enables transforming longitude/latitude coordinates\r\n * from one datum to another.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeodeticTransformProps {\r\n /** The method used by the geodetic transform */\r\n method: GeodeticTransformMethod;\r\n /** The complete definition of the source geodetic ellipsoid referred to by ellipsoidId.\r\n * The source ellipsoid identifier enables obtaining the shape of the Earth mathematical model\r\n * for the purpose of performing the transformation.\r\n */\r\n sourceEllipsoid?: GeodeticEllipsoidProps;\r\n /** The complete definition of the target geodetic ellipsoid referred to by ellipsoidId.\r\n * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model\r\n * for the purpose of performing the transformation.*/\r\n targetEllipsoid?: GeodeticEllipsoidProps;\r\n /** The id of the source datum. */\r\n sourceDatumId?: string;\r\n /** The id of the target datum. This id is useful to seach within a geodetic transform path for\r\n * a shortcut to another included datum.\r\n */\r\n targetDatumId?: string;\r\n /** When method is Geocentric this property contains the geocentric parameters */\r\n geocentric?: GeocentricTransformProps;\r\n /** When method is PositionalVector this property contains the positional vector parameters */\r\n positionalVector?: PositionalVectorTransformProps;\r\n /** When method is GridFiles this property contains the grid files parameters */\r\n gridFile?: GridFileTransformProps;\r\n}\r\n\r\n/** This class represents a geodetic transformation that enables transforming longitude/latitude coordinates\r\n * from one datum to another.\r\n * @public\r\n */\r\nexport class GeodeticTransform implements GeodeticTransformProps {\r\n /** The method used by the geodetic transform */\r\n public readonly method: GeodeticTransformMethod;\r\n /** The identifier of the source geodetic datum as stored in the dictionary or the service database.\r\n * This identifier is optional and informational only.\r\n */\r\n public readonly sourceEllipsoid?: GeodeticEllipsoid;\r\n /** The complete definition of the target geodetic ellipsoid referred to by ellipsoidId.\r\n * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model\r\n * for the purpose of performing the transformation.*/\r\n public readonly targetEllipsoid?: GeodeticEllipsoid;\r\n /** The id of the source datum. */\r\n public readonly sourceDatumId?: string;\r\n /** The id of the target datum. This id is useful to seach within a geodetic transform path for\r\n * a shortcut to another included datum.\r\n */\r\n public readonly targetDatumId?: string;\r\n /** When method is Geocentric this property contains the geocentric parameters */\r\n public readonly geocentric?: GeocentricTransform;\r\n /** When method is PositionalVector this property contains the positional vector parameters */\r\n public readonly positionalVector?: PositionalVectorTransform;\r\n /** When method is GridFiles this property contains the grid files parameters */\r\n public readonly gridFile?: GridFileTransform;\r\n\r\n public constructor(data?: GeodeticTransformProps) {\r\n this.method = \"None\";\r\n if (data) {\r\n this.method = data.method;\r\n this.sourceEllipsoid = data.sourceEllipsoid ? GeodeticEllipsoid.fromJSON(data.sourceEllipsoid) : undefined;\r\n this.targetEllipsoid = data.targetEllipsoid ? GeodeticEllipsoid.fromJSON(data.targetEllipsoid) : undefined;\r\n this.sourceDatumId = data.sourceDatumId;\r\n this.targetDatumId = data.targetDatumId;\r\n this.geocentric = data.geocentric ? GeocentricTransform.fromJSON(data.geocentric) : undefined;\r\n this.positionalVector = data.positionalVector ? PositionalVectorTransform.fromJSON(data.positionalVector) : undefined;\r\n this.gridFile = data.gridFile ? GridFileTransform.fromJSON(data.gridFile) : undefined;\r\n }\r\n }\r\n\r\n /** Creates a Geodetic Transform from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeodeticTransformProps): GeodeticTransform {\r\n return new GeodeticTransform(data);\r\n }\r\n\r\n /** Creates a JSON from the Geodetic Transform definition\r\n * @public */\r\n public toJSON(): GeodeticTransformProps {\r\n const data: GeodeticTransformProps = { method: this.method };\r\n data.sourceEllipsoid = this.sourceEllipsoid ? this.sourceEllipsoid.toJSON() : undefined;\r\n data.targetEllipsoid = this.targetEllipsoid ? this.targetEllipsoid.toJSON() : undefined;\r\n data.sourceDatumId = this.sourceDatumId;\r\n data.targetDatumId = this.targetDatumId;\r\n data.geocentric = this.geocentric ? this.geocentric.toJSON() : undefined;\r\n data.positionalVector = this.positionalVector ? this.positionalVector.toJSON() : undefined;\r\n data.gridFile = this.gridFile ? this.gridFile.toJSON() : undefined;\r\n return data;\r\n }\r\n\r\n /** Compares two geodetic Transforms. It is not an equivalence test since\r\n * descriptive information is strictly compared. A minuscule tolerance is applied to number compares.\r\n * @public */\r\n public equals(other: GeodeticTransform): boolean {\r\n if (this.method !== other.method)\r\n return false;\r\n\r\n if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)\r\n return false;\r\n\r\n if ((this.sourceEllipsoid === undefined) !== (other.sourceEllipsoid === undefined))\r\n return false;\r\n if (this.sourceEllipsoid && !this.sourceEllipsoid.equals(other.sourceEllipsoid!))\r\n return false;\r\n\r\n if ((this.targetEllipsoid === undefined) !== (other.targetEllipsoid === undefined))\r\n return false;\r\n if (this.targetEllipsoid && !this.targetEllipsoid.equals(other.targetEllipsoid!))\r\n return false;\r\n\r\n if ((this.geocentric === undefined) !== (other.geocentric === undefined))\r\n return false;\r\n if (this.geocentric && !this.geocentric.equals(other.geocentric!))\r\n return false;\r\n\r\n if ((this.positionalVector === undefined) !== (other.positionalVector === undefined))\r\n return false;\r\n if (this.positionalVector && !this.positionalVector.equals(other.positionalVector!))\r\n return false;\r\n\r\n if ((this.gridFile === undefined) !== (other.gridFile === undefined))\r\n return false;\r\n if (this.gridFile && !this.gridFile.equals(other.gridFile!))\r\n return false;\r\n\r\n return true;\r\n }\r\n}\r\n\r\n/** This interface represents a geodetic datum transform path. It contains a list of transforms linking\r\n * a source to a target geodetic datum.\r\n * @public\r\n */\r\nexport interface GeodeticTransformPathProps {\r\n /** Source geodetic datum key name */\r\n sourceDatumId?: string;\r\n /** Target geodetic datum key name */\r\n targetDatumId?: string;\r\n /** The transformation path from source datum to target datum.\r\n */\r\n transforms?: GeodeticTransformProps[];\r\n}\r\n\r\n/** This class represents a geodetic datum transform path. It contains a list of transforms linking\r\n * a source to a target geodetic datum.\r\n * @public\r\n */\r\nexport class GeodeticTransformPath implements GeodeticTransformPathProps {\r\n /** Source geodetic datum key name */\r\n public readonly sourceDatumId?: string;\r\n /** Target geodetic datum key name */\r\n public readonly targetDatumId?: string;\r\n /** The transformation path from source datum to target datum.\r\n */\r\n public readonly transforms?: GeodeticTransform[];\r\n\r\n public constructor(_data?: GeodeticTransformPathProps) {\r\n if (_data) {\r\n this.sourceDatumId = _data.sourceDatumId;\r\n this.targetDatumId = _data.targetDatumId;\r\n if (Array.isArray(_data.transforms)) {\r\n this.transforms = [];\r\n for (const item of _data.transforms)\r\n this.transforms.push(GeodeticTransform.fromJSON(item));\r\n }\r\n }\r\n }\r\n\r\n /** Creates a Geodetic transform path from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeodeticTransformPathProps): GeodeticTransformPath {\r\n return new GeodeticTransformPath(data);\r\n }\r\n\r\n /** Creates a JSON from the Geodetic transform path definition\r\n * @public */\r\n public toJSON(): GeodeticTransformPathProps {\r\n const data: GeodeticTransformPathProps = {};\r\n data.sourceDatumId = this.sourceDatumId;\r\n data.targetDatumId = this.targetDatumId;\r\n if (Array.isArray(this.transforms)) {\r\n data.transforms = [];\r\n for (const item of this.transforms)\r\n data.transforms.push(item.toJSON());\r\n }\r\n return data;\r\n }\r\n\r\n /** Compares two Geodetic Transform Paths. It is a strict compare operation not an equivalence test.\r\n * It takes into account descriptive properties not only mathematical definition properties.\r\n * @public */\r\n public equals(other: GeodeticTransformPath): boolean {\r\n if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)\r\n return false;\r\n\r\n if ((this.transforms === undefined) !== (other.transforms === undefined))\r\n return false;\r\n\r\n if (this.transforms && other.transforms) {\r\n if (this.transforms.length !== other.transforms.length)\r\n return false;\r\n\r\n for (let idx = 0; idx < this.transforms.length; ++idx)\r\n if (!this.transforms[idx].equals(other.transforms[idx]))\r\n return false;\r\n }\r\n return true;\r\n }\r\n}\r\n\r\n/** This interface represents a geodetic datum. Geodetic datums are based on an ellipsoid.\r\n * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.\r\n * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying\r\n * the transformation to the common base WGS84 (or local equivalent). The transforms property can contain the\r\n * definition of the transformation path to WGS84.\r\n * Sometimes there exists transformation paths direct from one non-WGS84 datum to another non-WGS84. The current model\r\n * does not allow specifications of these special paths at the moment.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeodeticDatumProps {\r\n /** GeodeticDatum key name */\r\n id?: string;\r\n /** Description */\r\n description?: string;\r\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\r\n ** If false or undefined then the definition is not deprecated.\r\n */\r\n deprecated?: boolean;\r\n /** A textual description of the source of the geodetic datum definition. */\r\n source?: string;\r\n /** The EPSG code of the geodetic datum. If undefined then there is no EPSG code associated. */\r\n epsg?: number;\r\n /** The key name to the base Ellipsoid. */\r\n ellipsoidId?: string;\r\n /** The full definition of the geodetic ellipsoid associated to the datum. If undefined then the ellipsoidId must be used to fetch the definition from the dictionary, geographic coordinate system service or the backend */\r\n ellipsoid?: GeodeticEllipsoidProps;\r\n /** The transformation to WGS84. If null then there is no known transformation to WGS84. Although\r\n * this is rare it occurs in a few cases where the country charges for obtaining and using\r\n * the transformation and its parameters, or if the transformation is maintained secret for military reasons.\r\n * In this case the recommendation is to considered the geodetic datum to be coincident to WGS84 keeping\r\n * in mind imported global data such as Google Map or Bing Map data may be approximately located.\r\n * The list of transforms contains normally a single transform but there can be a sequence of transformations\r\n * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.\r\n */\r\n transforms?: GeodeticTransformProps[];\r\n /** The optional list of transformation paths to other datum. These should only be used if the path to\r\n * these datum is not included in the transforms property definition of the transformation to WGS84.\r\n * It should not be used either if the transformation to the datum can be infered from the concatenation\r\n * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is\r\n * inherent to the nature of the datum. As an example it is required to represent the transformation\r\n * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path\r\n * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related\r\n * to the available paths to WGS84.\r\n */\r\n additionalTransformPaths?: GeodeticTransformPathProps[];\r\n}\r\n\r\n/** This class represents a geodetic datum. Geodetic datums are based on an ellipsoid.\r\n * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.\r\n * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying\r\n * the transformation to the common base WGS84 (or local equivalent). The transforms property can contain the\r\n * definition of the transformation path to WGS84.\r\n * Sometimes there exists transformation paths direct from one non-WGS84 datum to another non-WGS84. The current model\r\n * does not allow specifications of these special paths at the moment.\r\n * @public\r\n */\r\nexport class GeodeticDatum implements GeodeticDatumProps {\r\n /** GeodeticDatum key name */\r\n public readonly id?: string;\r\n /** Description */\r\n public readonly description?: string;\r\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\r\n * If false then the definition is not deprecated. Default is false.\r\n */\r\n public readonly deprecated: boolean;\r\n /** A textual description of the source of the geodetic datum definition. */\r\n public readonly source?: string;\r\n /** The EPSG code of the geodetic datum. If undefined then there is no EPSG code associated. */\r\n public readonly epsg?: number;\r\n /** The key name to the base Ellipsoid. */\r\n public readonly ellipsoidId?: string;\r\n /** The full definition of the geodetic ellipsoid associated to the datum. If undefined then the ellipsoidId must\r\n * be used to fetch the definition from the dictionary, geographic coordinate system service or the backend\r\n */\r\n public readonly ellipsoid?: GeodeticEllipsoid;\r\n /** The transformation to WGS84. If null then there is no known transformation to WGS84. Although\r\n * this is rare it occurs in a few cases where the country charges for obtaining and using\r\n * the transformation and its parameters, or if the transformation is maintained secret for military reasons.\r\n * In this case the recommendation is to considered the geodetic datum to be coincident to WGS84 keeping\r\n * in mind imported global data such as Google Map or Bing Map data may be approximately located.\r\n * The list of transforms contains normally a single transform but there can be a sequence of transformations\r\n * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.\r\n */\r\n public readonly transforms?: GeodeticTransform[];\r\n /** The optional list of transformation paths to other datum. These should only be used if the path to\r\n * these datum is not included in the transforms property definition of the transformation to WGS84.\r\n * It should not be used either if the transformation to the datum can be infered from the concatenation\r\n * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is\r\n * inherent to the nature of the datum. As an example it is required to represent the transformation\r\n * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path\r\n * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related\r\n * to the available paths to WGS84.\r\n */\r\n public readonly additionalTransformPaths?: GeodeticTransformPath[];\r\n\r\n public constructor(_data?: GeodeticDatumProps) {\r\n this.deprecated = false;\r\n if (_data) {\r\n this.id = _data.id;\r\n this.description = _data.description;\r\n this.deprecated = _data.deprecated ?? false;\r\n this.source = _data.source;\r\n this.epsg = _data.epsg;\r\n this.ellipsoidId = _data.ellipsoidId;\r\n this.ellipsoid = _data.ellipsoid ? GeodeticEllipsoid.fromJSON(_data.ellipsoid) : undefined;\r\n if (Array.isArray(_data.transforms)) {\r\n this.transforms = [];\r\n for (const item of _data.transforms)\r\n this.transforms.push(GeodeticTransform.fromJSON(item));\r\n }\r\n if (Array.isArray(_data.additionalTransformPaths)) {\r\n this.additionalTransformPaths = [];\r\n for (const item of _data.additionalTransformPaths)\r\n this.additionalTransformPaths.push(GeodeticTransformPath.fromJSON(item));\r\n }\r\n }\r\n }\r\n\r\n /** Creates a Geodetic Datum from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeodeticDatumProps): GeodeticDatum {\r\n return new GeodeticDatum(data);\r\n }\r\n\r\n /** Creates a JSON from the Geodetic Datum definition\r\n * @public */\r\n public toJSON(): GeodeticDatumProps {\r\n const data: GeodeticDatumProps = {};\r\n data.id = this.id;\r\n data.description = this.description;\r\n /* We prefer to use the default undef instead of false value for deprecated value in Json */\r\n data.deprecated = (this.deprecated === false ? undefined : true);\r\n data.source = this.source;\r\n data.epsg = this.epsg;\r\n data.ellipsoidId = this.ellipsoidId;\r\n data.ellipsoid = this.ellipsoid ? this.ellipsoid.toJSON() : undefined;\r\n if (Array.isArray(this.transforms)) {\r\n data.transforms = [];\r\n for (const item of this.transforms)\r\n data.transforms.push(item.toJSON());\r\n }\r\n if (Array.isArray(this.additionalTransformPaths)) {\r\n data.additionalTransformPaths = [];\r\n for (const item of this.additionalTransformPaths)\r\n data.additionalTransformPaths.push(item.toJSON());\r\n }\r\n return data;\r\n }\r\n\r\n /** Compares two Geodetic Datums. It is a strict compare operation not an equivalence test.\r\n * It takes into account descriptive properties not only mathematical definition properties.\r\n * @public */\r\n public equals(other: GeodeticDatum): boolean {\r\n if (this.id !== other.id ||\r\n this.description !== other.description ||\r\n this.deprecated !== other.deprecated ||\r\n this.source !== other.source ||\r\n this.epsg !== other.epsg ||\r\n this.ellipsoidId !== other.ellipsoidId)\r\n return false;\r\n\r\n if ((this.ellipsoid === undefined) !== (other.ellipsoid === undefined))\r\n return false;\r\n\r\n if (this.ellipsoid && !this.ellipsoid.equals(other.ellipsoid!))\r\n return false;\r\n\r\n if ((this.transforms === undefined) !== (other.transforms === undefined))\r\n return false;\r\n\r\n if (this.transforms && other.transforms) {\r\n if (this.transforms.length !== other.transforms.length)\r\n return false;\r\n\r\n for (let idx = 0; idx < this.transforms.length; ++idx)\r\n if (!this.transforms[idx].equals(other.transforms[idx]))\r\n return false;\r\n }\r\n\r\n if ((this.additionalTransformPaths === undefined) !== (other.additionalTransformPaths === undefined))\r\n return false;\r\n\r\n if (this.additionalTransformPaths && other.additionalTransformPaths) {\r\n if (this.additionalTransformPaths.length !== other.additionalTransformPaths.length)\r\n return false;\r\n\r\n for (let idx = 0; idx < this.additionalTransformPaths.length; ++idx)\r\n if (!this.additionalTransformPaths[idx].equals(other.additionalTransformPaths[idx]))\r\n return false;\r\n }\r\n return true;\r\n }\r\n}\r\n\r\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GeodeticEllipsoid.js","sourceRoot":"","sources":["../../../src/geometry/GeodeticEllipsoid.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AA6BhD;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,iBAAiB;IAkB5B,YAAmB,IAA6B;QAC9C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;YAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;YACpC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,KAAK,CAAC;YAC3C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;YACtB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;SACrC;IACH,CAAC;IAED;iBACa;IACN,MAAM,CAAC,QAAQ,CAAC,IAA4B;QACjD,OAAO,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;iBACa;IACN,MAAM;QACX,MAAM,IAAI,GAA2B,EAAE,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;QAChH,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,sFAAsF;QACtF,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;kBAGc;IACP,MAAM,CAAC,KAAwB;QACpC,OAAO,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE;YACzB,IAAI,CAAC,WAAW,KAAK,KAAK,CAAC,WAAW;YACtC,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU;YACpC,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM;YAC5B,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI;YACxB,QAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EAAE,QAAQ,CAAC,mBAAmB,CAAC;YAC3G,QAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,mBAAmB,CAAC,CAAC;IACtG,CAAC;CACF","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*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Geometry\n */\n\nimport { Geometry } from \"@itwin/core-geometry\";\n\n/** This interface defines the mathematical model of the Earth shape in the form of an ellipsoid.\n * There are various ways to define an ellipsoid but we have retained the definition based on the polar and equatorial radiuses.\n * The other ellipsoid properties, such as flattening and inverse flattening, can be obtained using\n * the simple equations that are defined at:\n * https://en.wikipedia.org/wiki/Flattening and https://en.wikipedia.org/wiki/Earth_ellipsoid.\n * @public\n * @extensions\n */\nexport interface GeodeticEllipsoidProps {\n /** Ellipsoid key name */\n id?: string;\n /** Description of the ellipsoid */\n description?: string;\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\n * If false or undefined then the definition is not deprecated.\n */\n deprecated?: boolean;\n /** The textual description of the source of the ellipsoid definition. */\n source?: string;\n /** The EPSG code of the ellipsoid. If undefined then there is no EPSG code associated. */\n epsg?: number;\n /** The equatorial radius of the ellipsoid in meters */\n equatorialRadius?: number;\n /** The polar radius of the ellipsoid in meters*/\n polarRadius?: number;\n}\n\n/** This class defines the mathematical model of the Earth shape in the form of an ellipsoid.\n * There are various ways to define an ellipsoid but we have retained the definition based on the polar and equatorial radiuses.\n * The other ellipsoid properties, such as flattening and inverse flattening, can be obtained using\n * the simple equations that are defined at:\n * https://en.wikipedia.org/wiki/Flattening and https://en.wikipedia.org/wiki/Earth_ellipsoid.\n * The present class only implements the definition of the ellipsoid. No processing is performed here. If ellipsoid based computation\n * are required refer to [[Ellipsoid]] in core/geometry package.\n * The class only serves to describe a geodetic ellipsoid and can be partially or fully defined.\n * For a lot of purposes simply setting the id property is sufficient to describe the ellipsoid in most cases\n * as the mathematical properties (equatorial and polar radiuses) will be often extracted from the dictionary\n * of commonly known ellipsoids by the reprojection engine used.\n * @public\n */\nexport class GeodeticEllipsoid implements GeodeticEllipsoidProps {\n /** Ellipsoid key name */\n public readonly id?: string;\n /** Description of the ellipsoid */\n public readonly description?: string;\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\n * If false then the definition is not deprecated. Default is false.\n */\n public readonly deprecated: boolean;\n /** The textual description of the source of the ellipsoid definition. */\n public readonly source?: string;\n /** The EPSG code of the ellipsoid. If undefined then there is no EPSG code associated. */\n public readonly epsg?: number;\n /** The equatorial radius of the ellipsoid in meters. */\n public readonly equatorialRadius?: number;\n /** The polar radius of the ellipsoid in meters. */\n public readonly polarRadius?: number;\n\n public constructor(data?: GeodeticEllipsoidProps) {\n this.deprecated = false;\n if (data) {\n this.id = data.id;\n this.description = data.description;\n this.deprecated = data.deprecated ?? false;\n this.source = data.source;\n this.epsg = data.epsg;\n this.equatorialRadius = data.equatorialRadius;\n this.polarRadius = data.polarRadius;\n }\n }\n\n /** Creates a Geodetic Ellipsoid from JSON representation.\n * @public */\n public static fromJSON(data: GeodeticEllipsoidProps): GeodeticEllipsoid {\n return new GeodeticEllipsoid(data);\n }\n\n /** Creates a JSON from the Geodetic Ellipsoid definition\n * @public */\n public toJSON(): GeodeticEllipsoidProps {\n const data: GeodeticEllipsoidProps = { equatorialRadius: this.equatorialRadius, polarRadius: this.polarRadius };\n data.id = this.id;\n data.description = this.description;\n /* We prefer to use the default undef instead of false value for deprecated in Json */\n data.deprecated = (this.deprecated === false ? undefined : true);\n data.source = this.source;\n data.epsg = this.epsg;\n data.equatorialRadius = this.equatorialRadius;\n data.polarRadius = this.polarRadius;\n return data;\n }\n\n /** Compares two Geodetic Ellipsoid. It is a strict compare operation not an equivalence test\n * but it applies a minuscule tolerance for floating point compares.\n * It takes into account descriptive properties not only mathematical definition properties.\n * @public */\n public equals(other: GeodeticEllipsoid): boolean {\n return this.id === other.id &&\n this.description === other.description &&\n this.deprecated === other.deprecated &&\n this.source === other.source &&\n this.epsg === other.epsg &&\n Geometry.isAlmostEqualOptional(this.equatorialRadius, other.equatorialRadius, Geometry.smallMetricDistance) &&\n Geometry.isAlmostEqualOptional(this.polarRadius, other.polarRadius, Geometry.smallMetricDistance);\n }\n}\n\n"]}
|
|
1
|
+
{"version":3,"file":"GeodeticEllipsoid.js","sourceRoot":"","sources":["../../../src/geometry/GeodeticEllipsoid.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AA6BhD;;;;;;;;;;;;GAYG;AACH,MAAM,OAAO,iBAAiB;IAkB5B,YAAmB,IAA6B;QAC9C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;YAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;YACpC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,KAAK,CAAC;YAC3C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;YACtB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;SACrC;IACH,CAAC;IAED;iBACa;IACN,MAAM,CAAC,QAAQ,CAAC,IAA4B;QACjD,OAAO,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;iBACa;IACN,MAAM;QACX,MAAM,IAAI,GAA2B,EAAE,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;QAChH,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,sFAAsF;QACtF,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QACpC,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;kBAGc;IACP,MAAM,CAAC,KAAwB;QACpC,OAAO,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE;YACzB,IAAI,CAAC,WAAW,KAAK,KAAK,CAAC,WAAW;YACtC,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU;YACpC,IAAI,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM;YAC5B,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI;YACxB,QAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EAAE,QAAQ,CAAC,mBAAmB,CAAC;YAC3G,QAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,QAAQ,CAAC,mBAAmB,CAAC,CAAC;IACtG,CAAC;CACF","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\n/** @packageDocumentation\r\n * @module Geometry\r\n */\r\n\r\nimport { Geometry } from \"@itwin/core-geometry\";\r\n\r\n/** This interface defines the mathematical model of the Earth shape in the form of an ellipsoid.\r\n * There are various ways to define an ellipsoid but we have retained the definition based on the polar and equatorial radiuses.\r\n * The other ellipsoid properties, such as flattening and inverse flattening, can be obtained using\r\n * the simple equations that are defined at:\r\n * https://en.wikipedia.org/wiki/Flattening and https://en.wikipedia.org/wiki/Earth_ellipsoid.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeodeticEllipsoidProps {\r\n /** Ellipsoid key name */\r\n id?: string;\r\n /** Description of the ellipsoid */\r\n description?: string;\r\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\r\n * If false or undefined then the definition is not deprecated.\r\n */\r\n deprecated?: boolean;\r\n /** The textual description of the source of the ellipsoid definition. */\r\n source?: string;\r\n /** The EPSG code of the ellipsoid. If undefined then there is no EPSG code associated. */\r\n epsg?: number;\r\n /** The equatorial radius of the ellipsoid in meters */\r\n equatorialRadius?: number;\r\n /** The polar radius of the ellipsoid in meters*/\r\n polarRadius?: number;\r\n}\r\n\r\n/** This class defines the mathematical model of the Earth shape in the form of an ellipsoid.\r\n * There are various ways to define an ellipsoid but we have retained the definition based on the polar and equatorial radiuses.\r\n * The other ellipsoid properties, such as flattening and inverse flattening, can be obtained using\r\n * the simple equations that are defined at:\r\n * https://en.wikipedia.org/wiki/Flattening and https://en.wikipedia.org/wiki/Earth_ellipsoid.\r\n * The present class only implements the definition of the ellipsoid. No processing is performed here. If ellipsoid based computation\r\n * are required refer to [[Ellipsoid]] in core/geometry package.\r\n * The class only serves to describe a geodetic ellipsoid and can be partially or fully defined.\r\n * For a lot of purposes simply setting the id property is sufficient to describe the ellipsoid in most cases\r\n * as the mathematical properties (equatorial and polar radiuses) will be often extracted from the dictionary\r\n * of commonly known ellipsoids by the reprojection engine used.\r\n * @public\r\n */\r\nexport class GeodeticEllipsoid implements GeodeticEllipsoidProps {\r\n /** Ellipsoid key name */\r\n public readonly id?: string;\r\n /** Description of the ellipsoid */\r\n public readonly description?: string;\r\n /** If true then indicates the definition is deprecated. It should then be used for backward compatibility only.\r\n * If false then the definition is not deprecated. Default is false.\r\n */\r\n public readonly deprecated: boolean;\r\n /** The textual description of the source of the ellipsoid definition. */\r\n public readonly source?: string;\r\n /** The EPSG code of the ellipsoid. If undefined then there is no EPSG code associated. */\r\n public readonly epsg?: number;\r\n /** The equatorial radius of the ellipsoid in meters. */\r\n public readonly equatorialRadius?: number;\r\n /** The polar radius of the ellipsoid in meters. */\r\n public readonly polarRadius?: number;\r\n\r\n public constructor(data?: GeodeticEllipsoidProps) {\r\n this.deprecated = false;\r\n if (data) {\r\n this.id = data.id;\r\n this.description = data.description;\r\n this.deprecated = data.deprecated ?? false;\r\n this.source = data.source;\r\n this.epsg = data.epsg;\r\n this.equatorialRadius = data.equatorialRadius;\r\n this.polarRadius = data.polarRadius;\r\n }\r\n }\r\n\r\n /** Creates a Geodetic Ellipsoid from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeodeticEllipsoidProps): GeodeticEllipsoid {\r\n return new GeodeticEllipsoid(data);\r\n }\r\n\r\n /** Creates a JSON from the Geodetic Ellipsoid definition\r\n * @public */\r\n public toJSON(): GeodeticEllipsoidProps {\r\n const data: GeodeticEllipsoidProps = { equatorialRadius: this.equatorialRadius, polarRadius: this.polarRadius };\r\n data.id = this.id;\r\n data.description = this.description;\r\n /* We prefer to use the default undef instead of false value for deprecated in Json */\r\n data.deprecated = (this.deprecated === false ? undefined : true);\r\n data.source = this.source;\r\n data.epsg = this.epsg;\r\n data.equatorialRadius = this.equatorialRadius;\r\n data.polarRadius = this.polarRadius;\r\n return data;\r\n }\r\n\r\n /** Compares two Geodetic Ellipsoid. It is a strict compare operation not an equivalence test\r\n * but it applies a minuscule tolerance for floating point compares.\r\n * It takes into account descriptive properties not only mathematical definition properties.\r\n * @public */\r\n public equals(other: GeodeticEllipsoid): boolean {\r\n return this.id === other.id &&\r\n this.description === other.description &&\r\n this.deprecated === other.deprecated &&\r\n this.source === other.source &&\r\n this.epsg === other.epsg &&\r\n Geometry.isAlmostEqualOptional(this.equatorialRadius, other.equatorialRadius, Geometry.smallMetricDistance) &&\r\n Geometry.isAlmostEqualOptional(this.polarRadius, other.polarRadius, Geometry.smallMetricDistance);\r\n }\r\n}\r\n\r\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GeometryStream.js","sourceRoot":"","sources":["../../../src/geometry/GeometryStream.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*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Geometry\n */\n\nimport { Id64, Id64String, IModelStatus } from \"@itwin/core-bentley\";\nimport {\n Angle, AnyGeometryQuery, GeometryQuery, IModelJson as GeomJson, LowAndHighXYZ, Matrix3d, Point2d, Point3d, Range3d, Transform, TransformProps,\n Vector3d, XYZProps, YawPitchRollAngles, YawPitchRollProps,\n} from \"@itwin/core-geometry\";\nimport { ColorDef, ColorDefProps } from \"../ColorDef\";\nimport { GeometricElement2dProps, GeometricElement3dProps, GeometryPartProps, isPlacement2dProps, PlacementProps } from \"../ElementProps\";\nimport { BackgroundFill, FillDisplay, GeometryClass, GeometryParams } from \"../GeometryParams\";\nimport { Gradient } from \"../Gradient\";\nimport { IModelError } from \"../IModelError\";\nimport { AreaPattern } from \"./AreaPattern\";\nimport { ImageGraphic, ImageGraphicProps } from \"./ImageGraphic\";\nimport { LineStyle } from \"./LineStyle\";\nimport { TextString, TextStringProps } from \"./TextString\";\nimport { Base64EncodedString } from \"../Base64EncodedString\";\nimport { Placement2d, Placement3d } from \"./Placement\";\n\n/** Establish a non-default [[SubCategory]] or to override [[SubCategoryAppearance]] for the geometry that follows.\n * A GeometryAppearanceProps always signifies a reset to the [[SubCategoryAppearance]] for subsequent [[GeometryStreamProps]] entries for undefined values.\n * @see [[GeometryStreamEntryProps]]\n * @public\n * @extensions\n */\nexport interface GeometryAppearanceProps {\n /** Optional [[SubCategory]] id for subsequent geometry. Use to create a GeometryStream with geometry that is not on the default [[SubCategory]] for the element's [[Category]] or is has geometry on multiple subCategories. */\n subCategory?: Id64String;\n /** Optional color to override [[SubCategoryAppearance.color]] for subsequent geometry. */\n color?: ColorDefProps;\n /** Optional weight to override [[SubCategoryAppearance.weight]] for subsequent geometry. */\n weight?: number;\n /** Optional style to override [[SubCategoryAppearance.styleId]] for subsequent geometry. */\n style?: Id64String;\n /** Optional transparency, 0.0 if undefined. Effective transparency is a combination of this value and [[SubCategoryAppearance.color]]. */\n transparency?: number;\n /** Optional display priority (2d only), 0 if undefined. Effective display priority is a combination of this value and [[SubCategoryAppearance.priority]]. */\n displayPriority?: number;\n /** Optional GeometryClass (for DGN compatibility, subCategories preferred), [[GeometryClass.Primary]] if undefined. */\n geometryClass?: GeometryClass;\n}\n\n/** Add a [[gradient]], [[backgroundFill]], or solid [[color]] fill to subsequent planar regions (or meshes).\n * Only one value among [[gradient]], [[backgroundFill]], and [[color]] should be set.\n * @see [[GeometryStreamEntryProps]]\n * @public\n * @extensions\n */\nexport interface AreaFillProps {\n /** Fill display type, must be set to something other than [[FillDisplay.Never]] to display fill */\n display: FillDisplay;\n /** Optional fill transparency, will be the same as outline transparency if undefined. Allows for different fill and outline transparencies */\n transparency?: number;\n /** Set fill color to view background color. Use [[BackgroundFill.Solid]] for an opaque fill and [[BackgroundFill.Outline]] to display an outline using the line color */\n backgroundFill?: BackgroundFill;\n /** Set fill color to a specific color. If the fill color the same as the line color, it is an opaque fill, otherwise it is an outline fill */\n color?: ColorDefProps;\n /** Set fill using gradient properties. */\n gradient?: Gradient.SymbProps;\n}\n\n/** Override [[SubCategoryAppearance.materialId]] for subsequent surface and solid geometry.\n * @see [[GeometryStreamEntryProps]]\n * @public\n * @extensions\n */\nexport interface MaterialProps {\n /** Material id to use, specify an invalid [[Id64]] to override [[SubCategoryAppearance.materialId]] with no material. */\n materialId?: Id64String;\n /** @internal */\n origin?: XYZProps;\n /** @internal */\n size?: XYZProps;\n /** @internal */\n rotation?: YawPitchRollProps;\n}\n\n/** JSON representation of a brep GeometryStream entry.\n * @public\n */\nexport namespace BRepEntity {\n /** Enum for type of solid kernel entity this represents */\n export enum Type {\n /** Body consisting of at least one solid region */\n Solid = 0,\n /** Body consisting of connected sets of faces having edges that are shared by a maximum of two faces */\n Sheet = 1,\n /** Body consisting of connected sets of edges having vertices that are shared by a maximum of two edges */\n Wire = 2,\n }\n\n /** Optional symbology that can be assigned to individual faces of a solid or sheet body */\n export interface FaceSymbologyProps {\n /** Optional color override for face */\n color?: ColorDefProps;\n /** Optional transparency override for face */\n transparency?: number;\n /** Optional material override for face */\n materialId?: Id64String;\n }\n\n /** Geometry entry representing raw brep data.\n * @see [[GeometryStreamEntryProps]]\n */\n export interface DataProps {\n /** data as Base64 encoded string. Must be specifically requested using [[ElementLoadProps.wantBRepData]]. */\n data?: Base64EncodedString;\n /** body type, default is Solid */\n type?: Type;\n /** body transform, default is identity */\n transform?: TransformProps;\n /** body face attachments */\n faceSymbology?: FaceSymbologyProps[];\n }\n}\n\n/** Add a reference to a [[GeometryPart]] from the GeometryStream of a [[GeometricElement]].\n * @see [[GeometryStreamEntryProps]]\n * @public\n * @extensions\n */\nexport interface GeometryPartInstanceProps {\n /** GeometryPart id */\n part: Id64String;\n /** Optional translation relative to element's placement, 0.0,0.0,0.0 if undefined. For a 2d element/translation, supply non-zero x and y only */\n origin?: XYZProps;\n /** Optional rotation relative to element's placement, 0.0,0.0,0.0 if undefined. For a 2d element/rotation, supply a non-zero yaw angle only */\n rotation?: YawPitchRollProps;\n /** Optional scale to apply to part, 1.0 if undefined */\n scale?: number;\n}\n\n/** Flags applied to the entire contents of a [[GeometryStreamProps]].\n * @see GeometryStreamHeaderProps\n * @public\n * @extensions\n */\nexport enum GeometryStreamFlags {\n /** No flags. */\n None = 0,\n /** When the geometry is displayed, it is always oriented to face the viewer. The placement origin of the element associated with the geometry is used as the rotation point.\n * If the placement origin is outside of the view, the geometry will not necessarily be displayed, even if rotating it to face the viewer would cause its range to intersect the viewed volume.\n */\n ViewIndependent = 1 << 0,\n}\n\n/** An entry in a [[GeometryStreamProps]] containing [[GeometryStreamFlags]] that apply to the geometry stream as a whole.\n * If this entry exists in the [[GeometryStreamProps]] array, it will always be the *first* entry.\n * @public\n * @extensions\n */\nexport interface GeometryStreamHeaderProps {\n /** The flags applied to the geometry stream. */\n flags: GeometryStreamFlags;\n}\n\n/** Allowed GeometryStream entries - should only set one value.\n * @see [GeometryStream]($docs/learning/common/geometrystream.md)\n * @public\n * @extensions\n */\nexport interface GeometryStreamEntryProps extends GeomJson.GeometryProps {\n header?: GeometryStreamHeaderProps;\n appearance?: GeometryAppearanceProps;\n styleMod?: LineStyle.ModifierProps;\n fill?: AreaFillProps;\n pattern?: AreaPattern.ParamsProps;\n material?: MaterialProps;\n geomPart?: GeometryPartInstanceProps;\n textString?: TextStringProps;\n brep?: BRepEntity.DataProps;\n image?: ImageGraphicProps;\n subRange?: LowAndHighXYZ;\n}\n\n/** A [[GeometricElement]]'s GeometryStream is represented by an array of [[GeometryStreamEntryProps]].\n * @public\n * @extensions\n */\nexport type GeometryStreamProps = GeometryStreamEntryProps[];\n\n/** GeometryStreamBuilder is a helper class for populating the [[GeometryStreamProps]] array needed to create a [[GeometricElement]] or [[GeometryPart]].\n * @public\n */\nexport class GeometryStreamBuilder {\n /** Current inverse placement transform, used for converting world coordinate input to be placement relative */\n private _worldToLocal?: Transform;\n /** GeometryStream entries */\n public readonly geometryStream: GeometryStreamProps = [];\n\n /** Supply optional local to world transform. Used to transform world coordinate input relative to element placement.\n * For a [[GeometricElement]]'s placement to be meaningful, world coordinate geometry should never be appended to an element with an identity placement.\n * Can be called with undefined or identity transform to start appending geometry supplied in local coordinates again.\n */\n public setLocalToWorld(localToWorld?: Transform) {\n this._worldToLocal = (undefined === localToWorld || localToWorld.isIdentity ? undefined : localToWorld.inverse());\n }\n\n /** Supply local to world transform from a Point3d and optional YawPitchRollAngles.\n * @see [[Placement3d]]\n */\n public setLocalToWorld3d(origin: Point3d, angles: YawPitchRollAngles = YawPitchRollAngles.createDegrees(0.0, 0.0, 0.0)) {\n this.setLocalToWorld(Transform.createOriginAndMatrix(origin, angles.toMatrix3d()));\n }\n\n /** Supply local to world transform from a Point2d and optional Angle.\n * @see [[Placement2d]]\n */\n public setLocalToWorld2d(origin: Point2d, angle: Angle = Angle.createDegrees(0.0)) {\n this.setLocalToWorld(Transform.createOriginAndMatrix(Point3d.createFrom(origin), Matrix3d.createRotationAroundVector(Vector3d.unitZ(), angle)));\n }\n\n /** Supply local to world transform from a PlacementProps2d or PlacementProps3d.\n * @see [[PlacementProps]]\n */\n public setLocalToWorldFromPlacement(props: PlacementProps) {\n const placement = isPlacement2dProps(props) ? Placement2d.fromJSON(props) : Placement3d.fromJSON(props);\n this.setLocalToWorld(placement.transform);\n }\n\n /** Store local ranges in GeometryStream for all subsequent geometry appended. Can improve performance of range testing for elements with a GeometryStream\n * containing more than one [[GeometryQuery]] differentiable by range. Not useful for a single [[GeometryQuery]] as its range and that of the [[GeometricElement]] are the same.\n * Ignored when defining a [[GeometryPart]] and not needed when only appending [[GeometryPart]] instances to a [[GeometricElement]] as these store their own range.\n */\n public appendGeometryRanges() {\n this.geometryStream.push({ subRange: Range3d.createNull() });\n }\n\n /** Change [[SubCategory]] or reset to [[SubCategoryAppearance]] for subsequent geometry.\n * An invalid sub-category id can be supplied to force a reset to the current [[SubCategoryAppearance]].\n * It is not valid to change the sub-category when defining a [[GeometryPart]]. A [[GeometryPart]] inherit the symbology of their instance for anything not explicitly overridden.\n */\n public appendSubCategoryChange(subCategoryId: Id64String): boolean {\n this.geometryStream.push({ appearance: { subCategory: subCategoryId } });\n return true;\n }\n\n /** Change [[GeometryParams]] for subsequent geometry.\n * It is not valid to change the sub-category when defining a [[GeometryPart]]. A [[GeometryPart]] inherits the symbology of their instance for anything not explicitly overridden.\n */\n public appendGeometryParamsChange(geomParams: GeometryParams): boolean {\n const appearance: GeometryAppearanceProps = {\n subCategory: geomParams.subCategoryId,\n color: geomParams.lineColor?.toJSON(),\n weight: geomParams.weight,\n style: geomParams.styleInfo?.styleId,\n transparency: geomParams.elmTransparency,\n displayPriority: geomParams.elmPriority,\n geometryClass: geomParams.geometryClass,\n };\n this.geometryStream.push({ appearance });\n\n if (undefined !== geomParams.materialId)\n this.geometryStream.push({ material: { materialId: geomParams.materialId } });\n\n if (undefined !== geomParams.fillDisplay && FillDisplay.Never !== geomParams.fillDisplay) {\n const fill: AreaFillProps = {\n display: geomParams.fillDisplay,\n transparency: geomParams.fillTransparency,\n };\n if (undefined !== geomParams.gradient && Gradient.Mode.None !== geomParams.gradient.mode)\n fill.gradient = geomParams.gradient?.toJSON();\n else if (undefined !== geomParams.backgroundFill && BackgroundFill.None !== geomParams.backgroundFill)\n fill.backgroundFill = geomParams.backgroundFill;\n else if (undefined !== geomParams.fillColor)\n fill.color = geomParams.fillColor.toJSON();\n this.geometryStream.push({ fill });\n }\n\n if (undefined !== geomParams.pattern) {\n const localPattern = this._worldToLocal ? geomParams.pattern.clone() : geomParams.pattern;\n if (undefined !== this._worldToLocal && !localPattern.applyTransform(this._worldToLocal))\n return false;\n\n this.geometryStream.push({ pattern: localPattern.toJSON() });\n }\n\n if (undefined !== geomParams.styleInfo && undefined !== geomParams.styleInfo.styleMod) {\n const localStyleMod = new LineStyle.Modifier(geomParams.styleInfo.styleMod);\n if (undefined !== this._worldToLocal && !localStyleMod.applyTransform(this._worldToLocal))\n return false;\n this.geometryStream.push({ styleMod: localStyleMod });\n }\n\n return true;\n }\n\n /** Append a [[GeometryPart]] instance with relative position, orientation, and scale to a [[GeometryStreamProps]] array for creating a [[GeometricElement3d]].\n * Not valid when defining a [[GeometryPart]] as nesting of parts is not supported.\n */\n public appendGeometryPart3d(partId: Id64String, instanceOrigin?: Point3d, instanceRotation?: YawPitchRollAngles, instanceScale?: number): boolean {\n if (undefined === this._worldToLocal) {\n this.geometryStream.push({ geomPart: { part: partId, origin: instanceOrigin, rotation: instanceRotation, scale: instanceScale } });\n return true;\n }\n const partTrans = Transform.createOriginAndMatrix(instanceOrigin, instanceRotation ? instanceRotation.toMatrix3d() : Matrix3d.createIdentity());\n if (undefined !== instanceScale)\n partTrans.matrix.scaleColumnsInPlace(instanceScale, instanceScale, instanceScale);\n const resultTrans = this._worldToLocal.multiplyTransformTransform(partTrans);\n const scales = new Vector3d();\n if (!resultTrans.matrix.normalizeColumnsInPlace(scales))\n return false;\n const newRotation = YawPitchRollAngles.createFromMatrix3d(resultTrans.matrix);\n if (undefined === newRotation)\n return false;\n this.geometryStream.push({ geomPart: { part: partId, origin: resultTrans.getOrigin(), rotation: newRotation, scale: scales.x } });\n return true;\n }\n\n /** Append a [[GeometryPart]] instance with relative position, orientation, and scale to a [[GeometryStreamProps]] array for creating a [[GeometricElement2d]].\n * Not valid when defining a [[GeometryPart]] as nesting of parts is not supported.\n */\n public appendGeometryPart2d(partId: Id64String, instanceOrigin?: Point2d, instanceRotation?: Angle, instanceScale?: number): boolean {\n return this.appendGeometryPart3d(partId, instanceOrigin ? Point3d.createFrom(instanceOrigin) : undefined, instanceRotation ? new YawPitchRollAngles(instanceRotation) : undefined, instanceScale);\n }\n\n /** Append a [[TextString]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array */\n public appendTextString(textString: TextString): boolean {\n if (undefined === this._worldToLocal) {\n this.geometryStream.push({ textString });\n return true;\n }\n const localTextString = new TextString(textString);\n if (!localTextString.transformInPlace(this._worldToLocal))\n return false;\n this.geometryStream.push({ textString: localTextString });\n return true;\n }\n\n /** Append an [[ImageGraphic]] supplied in either local or world coordinates. */\n public appendImage(image: ImageGraphic): boolean {\n if (undefined !== this._worldToLocal)\n image = image.cloneTransformed(this._worldToLocal);\n\n this.geometryStream.push({ image: image.toJSON() });\n return true;\n }\n\n /** Append a [[GeometryQuery]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array */\n public appendGeometry(geometry: GeometryQuery): boolean {\n if (undefined === this._worldToLocal) {\n const geomData = GeomJson.Writer.toIModelJson(geometry);\n if (undefined === geomData)\n return false;\n this.geometryStream.push(geomData);\n return true;\n }\n const localGeometry = geometry.cloneTransformed(this._worldToLocal);\n if (undefined === localGeometry)\n return false;\n const localGeomData = GeomJson.Writer.toIModelJson(localGeometry);\n if (undefined === localGeomData)\n return false;\n this.geometryStream.push(localGeomData);\n return true;\n }\n\n /** Append [[BRepEntity.DataProps]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array\n * @beta\n */\n public appendBRepData(brep: BRepEntity.DataProps): boolean {\n if (undefined === this._worldToLocal) {\n this.geometryStream.push({ brep });\n return true;\n }\n const entityTrans = Transform.fromJSON(brep.transform);\n const localTrans = entityTrans.multiplyTransformTransform(this._worldToLocal);\n const localBrep: BRepEntity.DataProps = {\n data: brep.data,\n type: brep.type,\n transform: localTrans.isIdentity ? undefined : localTrans.toJSON(),\n faceSymbology: brep.faceSymbology,\n };\n this.geometryStream.push({ brep: localBrep });\n return true;\n }\n\n /** @internal */\n public getHeader(): GeometryStreamHeaderProps | undefined {\n return 0 < this.geometryStream.length ? this.geometryStream[0].header : undefined;\n }\n\n /** @internal */\n public obtainHeader(): GeometryStreamHeaderProps {\n const hdr = this.getHeader();\n if (undefined !== hdr)\n return hdr;\n\n const entry = { header: { flags: GeometryStreamFlags.None } };\n this.geometryStream.unshift(entry);\n return entry.header;\n }\n\n /** Controls whether or not the geometry in the stream should be displayed as view-independent.\n * When view-independent geometry is displayed, it is always oriented to face the viewer, using the placement origin of the element as the rotation point.\n * If the placement origin is outside of the view, the geometry will not necessarily be displayed, even if rotating it to face the viewer would cause its range to intersect the viewed volume\n * @public\n */\n public get isViewIndependent(): boolean {\n const hdr = this.getHeader();\n return undefined !== hdr && GeometryStreamFlags.None !== (hdr.flags & GeometryStreamFlags.ViewIndependent);\n }\n public set isViewIndependent(viewIndependent: boolean) {\n if (viewIndependent === this.isViewIndependent)\n return;\n\n const hdr = this.obtainHeader();\n if (viewIndependent)\n hdr.flags |= GeometryStreamFlags.ViewIndependent;\n else\n hdr.flags &= ~GeometryStreamFlags.ViewIndependent;\n }\n}\n\n/** Represents a text string within a GeometryStream.\n * @public\n * @extensions\n */\nexport interface TextStringPrimitive {\n type: \"textString\";\n readonly textString: TextString;\n}\n\n/** Represents an image within a GeometryStream.\n * @public\n * @extensions\n */\nexport interface ImagePrimitive {\n type: \"image\";\n readonly image: ImageGraphic;\n}\n\n/** Represents a reference to a GeometryPart within a GeometryStream.\n * @public\n * @extensions\n */\nexport interface PartReference {\n type: \"partReference\";\n part: {\n id: Id64String;\n readonly toLocal?: Transform;\n };\n}\n\n/** Represents a BRep within a GeometryStream.\n * @public\n * @extensions\n */\nexport interface BRepPrimitive {\n type: \"brep\";\n /** @beta */\n readonly brep: BRepEntity.DataProps;\n}\n\n/** Represents one of a variety of GeometryQuery objects within a GeometryStream.\n * @public\n * @extensions\n */\nexport interface GeometryPrimitive {\n type: \"geometryQuery\";\n readonly geometry: AnyGeometryQuery;\n}\n\n/** Union of all possible geometric primitive types that may appear within a GeometryStream.\n * @public\n * @extensions\n */\nexport type GeometryStreamPrimitive = TextStringPrimitive | PartReference | BRepPrimitive | GeometryPrimitive | ImagePrimitive;\n\n/** Holds current state information for [[GeometryStreamIterator]]. Each entry represents exactly one geometry primitive in the stream.\n * @public\n * @extensions\n */\nexport interface GeometryStreamIteratorEntry {\n /** A [[GeometryParams]] representing the appearance of the current geometric entry */\n readonly geomParams: GeometryParams;\n /** Placement transform, used for converting placement relative, local coordinate entries to world */\n readonly localToWorld?: Transform;\n /** Optional stored local range for the current geometric entry */\n readonly localRange?: Range3d;\n /** Returns the geometric primitive represented by this entry. */\n readonly primitive: GeometryStreamPrimitive;\n}\n\nclass IteratorEntry implements GeometryStreamIteratorEntry {\n private _primitive?: GeometryStreamPrimitive;\n public readonly geomParams: GeometryParams;\n public readonly localToWorld?: Transform;\n public localRange?: Range3d;\n\n public constructor(appearance: Id64String | GeometryParams, localToWorld?: Transform) {\n this.geomParams = typeof appearance === \"string\" ? new GeometryParams(appearance) : appearance;\n this.localToWorld = localToWorld;\n }\n\n public get primitive() { return this._primitive!; }\n public set primitive(primitive: GeometryStreamPrimitive) { this._primitive = primitive; }\n\n public setGeometryQuery(geometry: AnyGeometryQuery) { this._primitive = { type: \"geometryQuery\", geometry }; }\n public setTextString(textString: TextString) { this._primitive = { type: \"textString\", textString }; }\n public setBRep(brep: BRepEntity.DataProps) { this._primitive = { type: \"brep\", brep }; }\n public setImage(image: ImageGraphic) { this._primitive = { type: \"image\", image }; }\n public setPartReference(id: Id64String, toLocal?: Transform) {\n this._primitive = {\n type: \"partReference\",\n part: { id, toLocal },\n };\n }\n}\n\n/** GeometryStreamIterator is a helper class for iterating a [[GeometryStreamProps]].\n * A [[GeometricElement]]'s GeometryStream must be specifically requested using [[ElementLoadProps.wantGeometry]].\n * Each [[GeometryStreamIteratorEntry]] returned by the iterator represents exactly one geometric primitive in the stream.\n * @public\n */\nexport class GeometryStreamIterator implements IterableIterator<GeometryStreamIteratorEntry> {\n /** GeometryStream entries */\n public geometryStream: GeometryStreamProps;\n /** Flags applied to the entire geometry stream. */\n public readonly flags: GeometryStreamFlags;\n /** Current entry position */\n private _index = 0;\n /** Allocated on first call to next() and reused thereafter. */\n private _entry?: IteratorEntry;\n /** Used to initialize this._entry. */\n private readonly _appearance: Id64String | GeometryParams;\n private readonly _localToWorld?: Transform;\n\n /** Construct a new GeometryStreamIterator given a [[GeometryStreamProps]] from either a [[GeometricElement3d]], [[GeometricElement2d]], or [[GeometryPart]].\n * Supply the [[GeometricElement]]'s category to initialize the appearance information for each geometric entry.\n */\n public constructor(geometryStream: GeometryStreamProps, categoryOrGeometryParams?: Id64String | GeometryParams, localToWorld?: Transform) {\n this.geometryStream = geometryStream;\n this._appearance = categoryOrGeometryParams ?? Id64.invalid;\n this._localToWorld = localToWorld;\n if (0 < geometryStream.length && undefined !== geometryStream[0].header) {\n this.flags = geometryStream[0].header.flags;\n ++this._index;\n } else {\n this.flags = GeometryStreamFlags.None;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/naming-convention\n private get entry() {\n if (undefined === this._entry)\n this._entry = new IteratorEntry(this._appearance, this._localToWorld);\n\n return this._entry;\n }\n\n /** Create a new GeometryStream iterator for a [[GeometricElement3d]].\n * If [[GeometricElement3dProps.placement]] is not undefined, placement relative entries will be returned transformed to world coordinates.\n * @throws [[IModelError]] if element.geom is undefined.\n */\n public static fromGeometricElement3d(element: Pick<GeometricElement3dProps, \"geom\" | \"placement\" | \"category\">) {\n if (element.geom === undefined)\n throw new IModelError(IModelStatus.NoGeometry, \"GeometricElement has no geometry or geometry wasn't requested\");\n\n let transform;\n if (element.placement !== undefined)\n transform = Transform.createOriginAndMatrix(Point3d.fromJSON(element.placement.origin), YawPitchRollAngles.fromJSON(element.placement.angles).toMatrix3d());\n\n return new GeometryStreamIterator(element.geom, element.category, transform);\n }\n\n /** Create a new GeometryStream iterator for a [[GeometricElement2d]].\n * If [[GeometricElement2dProps.placement]] is not undefined, placement relative entries will be returned transformed to world coordinates.\n * @throws [[IModelError]] if element.geom is undefined.\n */\n public static fromGeometricElement2d(element: Pick<GeometricElement2dProps, \"geom\" | \"placement\" | \"category\">) {\n if (element.geom === undefined)\n throw new IModelError(IModelStatus.NoGeometry, \"GeometricElement has no geometry or geometry wasn't requested\");\n\n let transform;\n if (element.placement !== undefined) {\n const origin = Point3d.createFrom(Point2d.fromJSON(element.placement.origin));\n const matrix = Matrix3d.createRotationAroundVector(Vector3d.unitZ(), Angle.fromJSON(element.placement.angle))!;\n transform = Transform.createOriginAndMatrix(origin, matrix);\n }\n\n return new GeometryStreamIterator(element.geom, element.category, transform);\n }\n\n /** Create a new GeometryStream iterator for a [[GeometryPart]].\n * To iterate a part's GeometryStream in the context of a part instance found for a [[GeometricElement]], provide the optional [[GeometryParams]] and Transform from the [[GeometricElement]]'s [[GeometryStreamIterator]].\n * Supply the [[GeometryParams]] to return appearance information as inherited from the [[GeometricElement]].\n * Supply the partToWorld transform to return the part geometry in world coordinates.\n * Supply the partToLocal transform to return the part geometry relative to the [[GeometricElement]]'s placement.\n * @throws [[IModelError]] if geomPart.geom is undefined.\n */\n public static fromGeometryPart(geomPart: Pick<GeometryPartProps, \"geom\">, geomParams?: GeometryParams, partTransform?: Transform) {\n if (geomPart.geom === undefined)\n throw new IModelError(IModelStatus.NoGeometry, \"GeometryPart has no geometry or geometry wasn't requested\");\n\n return new GeometryStreamIterator(geomPart.geom, geomParams?.clone(), partTransform);\n }\n\n /** Get the transform that if applied to a [[GeometryPart]]'s GeometryStream entries would return them in world coordinates. */\n public partToWorld(): Transform | undefined {\n if (undefined === this._entry)\n return this._localToWorld;\n\n const partToLocal = \"partReference\" === this._entry.primitive.type ? this._entry.primitive.part.toLocal : undefined;\n if (this._entry.localToWorld === undefined || partToLocal === undefined)\n return this._entry.localToWorld;\n\n return this._entry.localToWorld.multiplyTransformTransform(partToLocal);\n }\n\n /** Advance to next displayable geometric entry while updating the current [[GeometryParams]] from appearance related entries.\n * Geometric entries are [[TextString]], [[GeometryQuery]], [[GeometryPart]], [[ImageGraphic]], and [[BRepEntity.DataProps]].\n */\n public next(): IteratorResult<GeometryStreamIteratorEntry> {\n // NOTE: localRange remains valid until we encounter either a new subRange entry or a geometry part reference.\n while (this._index < this.geometryStream.length) {\n const entry = this.geometryStream[this._index++];\n if (entry.appearance) {\n this.entry.geomParams.resetAppearance();\n if (entry.appearance.subCategory)\n this.entry.geomParams.subCategoryId = Id64.fromJSON(entry.appearance.subCategory);\n if (undefined !== entry.appearance.color)\n this.entry.geomParams.lineColor = ColorDef.fromJSON(entry.appearance.color);\n if (undefined !== entry.appearance.weight)\n this.entry.geomParams.weight = entry.appearance.weight;\n if (undefined !== entry.appearance.style)\n this.entry.geomParams.styleInfo = new LineStyle.Info(Id64.fromJSON(entry.appearance.style));\n if (undefined !== entry.appearance.transparency)\n this.entry.geomParams.elmTransparency = entry.appearance.transparency;\n if (undefined !== entry.appearance.displayPriority)\n this.entry.geomParams.elmPriority = entry.appearance.displayPriority;\n if (undefined !== entry.appearance.geometryClass)\n this.entry.geomParams.geometryClass = entry.appearance.geometryClass;\n } else if (entry.styleMod) {\n if (this.entry.geomParams.styleInfo === undefined)\n continue;\n\n const styleMod = new LineStyle.Modifier(entry.styleMod);\n if (this.entry.localToWorld !== undefined)\n styleMod.applyTransform(this.entry.localToWorld);\n\n this.entry.geomParams.styleInfo = new LineStyle.Info(this.entry.geomParams.styleInfo.styleId, styleMod);\n } else if (entry.fill) {\n if (entry.fill.display)\n this.entry.geomParams.fillDisplay = entry.fill.display;\n if (entry.fill.transparency)\n this.entry.geomParams.fillTransparency = entry.fill.transparency;\n if (entry.fill.gradient)\n this.entry.geomParams.gradient = Gradient.Symb.fromJSON(entry.fill.gradient);\n else if (entry.fill.backgroundFill)\n this.entry.geomParams.backgroundFill = entry.fill.backgroundFill;\n else if (entry.fill.color)\n this.entry.geomParams.fillColor = ColorDef.fromJSON(entry.fill.color);\n } else if (entry.pattern) {\n const params = AreaPattern.Params.fromJSON(entry.pattern);\n if (this.entry.localToWorld !== undefined)\n params.applyTransform(this.entry.localToWorld);\n\n this.entry.geomParams.pattern = params;\n } else if (entry.material) {\n if (entry.material.materialId)\n this.entry.geomParams.materialId = Id64.fromJSON(entry.material.materialId);\n } else if (entry.subRange) {\n this.entry.localRange = Range3d.fromJSON(entry.subRange);\n } else if (entry.geomPart) {\n let transform;\n if (entry.geomPart.origin !== undefined || entry.geomPart.rotation !== undefined || entry.geomPart.scale !== undefined) {\n const origin = entry.geomPart.origin ? Point3d.fromJSON(entry.geomPart.origin) : Point3d.createZero();\n const rotation = entry.geomPart.rotation ? YawPitchRollAngles.fromJSON(entry.geomPart.rotation).toMatrix3d() : Matrix3d.createIdentity();\n transform = Transform.createRefs(origin, rotation);\n if (entry.geomPart.scale)\n transform.multiplyTransformTransform(Transform.createRefs(Point3d.createZero(), Matrix3d.createUniformScale(entry.geomPart.scale)), transform);\n }\n\n // Subgraphic range doesn't apply to parts. A sane geometry stream (i.e., any that has been through the native layers or GeometryStreamBuilder)\n // will have a new subgraphic range for any geometric primitive following the part.\n this.entry.localRange = undefined;\n this.entry.setPartReference(Id64.fromJSON(entry.geomPart.part), transform);\n return { value: this.entry, done: false };\n } else if (entry.textString) {\n const textString = new TextString(entry.textString);\n if (this.entry.localToWorld !== undefined)\n textString.transformInPlace(this.entry.localToWorld);\n\n this.entry.setTextString(textString);\n return { value: this.entry, done: false };\n } else if (entry.image) {\n const image = ImageGraphic.fromJSON(entry.image);\n if (undefined !== this.entry.localToWorld)\n image.transformInPlace(this.entry.localToWorld);\n\n this.entry.setImage(image);\n return { value: this.entry, done: false };\n } else if (entry.brep) {\n if (this.entry.localToWorld !== undefined) {\n const entityTrans = Transform.fromJSON(entry.brep.transform);\n entry.brep.transform = entityTrans.multiplyTransformTransform(this.entry.localToWorld).toJSON();\n }\n\n this.entry.setBRep(entry.brep);\n return { value: this.entry, done: false };\n } else {\n const geometryQuery = GeomJson.Reader.parse(entry);\n if (!(geometryQuery instanceof GeometryQuery))\n continue;\n\n if (this.entry.localToWorld !== undefined)\n geometryQuery.tryTransformInPlace(this.entry.localToWorld);\n\n this.entry.setGeometryQuery(geometryQuery);\n return { value: this.entry, done: false };\n }\n }\n\n return { value: this.entry, done: true };\n }\n\n public [Symbol.iterator](): IterableIterator<GeometryStreamIteratorEntry> {\n return this;\n }\n\n /** @internal */\n public get isViewIndependent(): boolean { return GeometryStreamFlags.None !== (this.flags & GeometryStreamFlags.ViewIndependent); }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"GeometryStream.js","sourceRoot":"","sources":["../../../src/geometry/GeometryStream.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\n/** @packageDocumentation\r\n * @module Geometry\r\n */\r\n\r\nimport { Id64, Id64String, IModelStatus } from \"@itwin/core-bentley\";\r\nimport {\r\n Angle, AnyGeometryQuery, GeometryQuery, IModelJson as GeomJson, LowAndHighXYZ, Matrix3d, Point2d, Point3d, Range3d, Transform, TransformProps,\r\n Vector3d, XYZProps, YawPitchRollAngles, YawPitchRollProps,\r\n} from \"@itwin/core-geometry\";\r\nimport { ColorDef, ColorDefProps } from \"../ColorDef\";\r\nimport { GeometricElement2dProps, GeometricElement3dProps, GeometryPartProps, isPlacement2dProps, PlacementProps } from \"../ElementProps\";\r\nimport { BackgroundFill, FillDisplay, GeometryClass, GeometryParams } from \"../GeometryParams\";\r\nimport { Gradient } from \"../Gradient\";\r\nimport { IModelError } from \"../IModelError\";\r\nimport { AreaPattern } from \"./AreaPattern\";\r\nimport { ImageGraphic, ImageGraphicProps } from \"./ImageGraphic\";\r\nimport { LineStyle } from \"./LineStyle\";\r\nimport { TextString, TextStringProps } from \"./TextString\";\r\nimport { Base64EncodedString } from \"../Base64EncodedString\";\r\nimport { Placement2d, Placement3d } from \"./Placement\";\r\n\r\n/** Establish a non-default [[SubCategory]] or to override [[SubCategoryAppearance]] for the geometry that follows.\r\n * A GeometryAppearanceProps always signifies a reset to the [[SubCategoryAppearance]] for subsequent [[GeometryStreamProps]] entries for undefined values.\r\n * @see [[GeometryStreamEntryProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryAppearanceProps {\r\n /** Optional [[SubCategory]] id for subsequent geometry. Use to create a GeometryStream with geometry that is not on the default [[SubCategory]] for the element's [[Category]] or is has geometry on multiple subCategories. */\r\n subCategory?: Id64String;\r\n /** Optional color to override [[SubCategoryAppearance.color]] for subsequent geometry. */\r\n color?: ColorDefProps;\r\n /** Optional weight to override [[SubCategoryAppearance.weight]] for subsequent geometry. */\r\n weight?: number;\r\n /** Optional style to override [[SubCategoryAppearance.styleId]] for subsequent geometry. */\r\n style?: Id64String;\r\n /** Optional transparency, 0.0 if undefined. Effective transparency is a combination of this value and [[SubCategoryAppearance.color]]. */\r\n transparency?: number;\r\n /** Optional display priority (2d only), 0 if undefined. Effective display priority is a combination of this value and [[SubCategoryAppearance.priority]]. */\r\n displayPriority?: number;\r\n /** Optional GeometryClass (for DGN compatibility, subCategories preferred), [[GeometryClass.Primary]] if undefined. */\r\n geometryClass?: GeometryClass;\r\n}\r\n\r\n/** Add a [[gradient]], [[backgroundFill]], or solid [[color]] fill to subsequent planar regions (or meshes).\r\n * Only one value among [[gradient]], [[backgroundFill]], and [[color]] should be set.\r\n * @see [[GeometryStreamEntryProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface AreaFillProps {\r\n /** Fill display type, must be set to something other than [[FillDisplay.Never]] to display fill */\r\n display: FillDisplay;\r\n /** Optional fill transparency, will be the same as outline transparency if undefined. Allows for different fill and outline transparencies */\r\n transparency?: number;\r\n /** Set fill color to view background color. Use [[BackgroundFill.Solid]] for an opaque fill and [[BackgroundFill.Outline]] to display an outline using the line color */\r\n backgroundFill?: BackgroundFill;\r\n /** Set fill color to a specific color. If the fill color the same as the line color, it is an opaque fill, otherwise it is an outline fill */\r\n color?: ColorDefProps;\r\n /** Set fill using gradient properties. */\r\n gradient?: Gradient.SymbProps;\r\n}\r\n\r\n/** Override [[SubCategoryAppearance.materialId]] for subsequent surface and solid geometry.\r\n * @see [[GeometryStreamEntryProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface MaterialProps {\r\n /** Material id to use, specify an invalid [[Id64]] to override [[SubCategoryAppearance.materialId]] with no material. */\r\n materialId?: Id64String;\r\n /** @internal */\r\n origin?: XYZProps;\r\n /** @internal */\r\n size?: XYZProps;\r\n /** @internal */\r\n rotation?: YawPitchRollProps;\r\n}\r\n\r\n/** JSON representation of a brep GeometryStream entry.\r\n * @public\r\n */\r\nexport namespace BRepEntity {\r\n /** Enum for type of solid kernel entity this represents */\r\n export enum Type {\r\n /** Body consisting of at least one solid region */\r\n Solid = 0,\r\n /** Body consisting of connected sets of faces having edges that are shared by a maximum of two faces */\r\n Sheet = 1,\r\n /** Body consisting of connected sets of edges having vertices that are shared by a maximum of two edges */\r\n Wire = 2,\r\n }\r\n\r\n /** Optional symbology that can be assigned to individual faces of a solid or sheet body */\r\n export interface FaceSymbologyProps {\r\n /** Optional color override for face */\r\n color?: ColorDefProps;\r\n /** Optional transparency override for face */\r\n transparency?: number;\r\n /** Optional material override for face */\r\n materialId?: Id64String;\r\n }\r\n\r\n /** Geometry entry representing raw brep data.\r\n * @see [[GeometryStreamEntryProps]]\r\n */\r\n export interface DataProps {\r\n /** data as Base64 encoded string. Must be specifically requested using [[ElementLoadProps.wantBRepData]]. */\r\n data?: Base64EncodedString;\r\n /** body type, default is Solid */\r\n type?: Type;\r\n /** body transform, default is identity */\r\n transform?: TransformProps;\r\n /** body face attachments */\r\n faceSymbology?: FaceSymbologyProps[];\r\n }\r\n}\r\n\r\n/** Add a reference to a [[GeometryPart]] from the GeometryStream of a [[GeometricElement]].\r\n * @see [[GeometryStreamEntryProps]]\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryPartInstanceProps {\r\n /** GeometryPart id */\r\n part: Id64String;\r\n /** Optional translation relative to element's placement, 0.0,0.0,0.0 if undefined. For a 2d element/translation, supply non-zero x and y only */\r\n origin?: XYZProps;\r\n /** Optional rotation relative to element's placement, 0.0,0.0,0.0 if undefined. For a 2d element/rotation, supply a non-zero yaw angle only */\r\n rotation?: YawPitchRollProps;\r\n /** Optional scale to apply to part, 1.0 if undefined */\r\n scale?: number;\r\n}\r\n\r\n/** Flags applied to the entire contents of a [[GeometryStreamProps]].\r\n * @see GeometryStreamHeaderProps\r\n * @public\r\n * @extensions\r\n */\r\nexport enum GeometryStreamFlags {\r\n /** No flags. */\r\n None = 0,\r\n /** When the geometry is displayed, it is always oriented to face the viewer. The placement origin of the element associated with the geometry is used as the rotation point.\r\n * If the placement origin is outside of the view, the geometry will not necessarily be displayed, even if rotating it to face the viewer would cause its range to intersect the viewed volume.\r\n */\r\n ViewIndependent = 1 << 0,\r\n}\r\n\r\n/** An entry in a [[GeometryStreamProps]] containing [[GeometryStreamFlags]] that apply to the geometry stream as a whole.\r\n * If this entry exists in the [[GeometryStreamProps]] array, it will always be the *first* entry.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryStreamHeaderProps {\r\n /** The flags applied to the geometry stream. */\r\n flags: GeometryStreamFlags;\r\n}\r\n\r\n/** Allowed GeometryStream entries - should only set one value.\r\n * @see [GeometryStream]($docs/learning/common/geometrystream.md)\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryStreamEntryProps extends GeomJson.GeometryProps {\r\n header?: GeometryStreamHeaderProps;\r\n appearance?: GeometryAppearanceProps;\r\n styleMod?: LineStyle.ModifierProps;\r\n fill?: AreaFillProps;\r\n pattern?: AreaPattern.ParamsProps;\r\n material?: MaterialProps;\r\n geomPart?: GeometryPartInstanceProps;\r\n textString?: TextStringProps;\r\n brep?: BRepEntity.DataProps;\r\n image?: ImageGraphicProps;\r\n subRange?: LowAndHighXYZ;\r\n}\r\n\r\n/** A [[GeometricElement]]'s GeometryStream is represented by an array of [[GeometryStreamEntryProps]].\r\n * @public\r\n * @extensions\r\n */\r\nexport type GeometryStreamProps = GeometryStreamEntryProps[];\r\n\r\n/** GeometryStreamBuilder is a helper class for populating the [[GeometryStreamProps]] array needed to create a [[GeometricElement]] or [[GeometryPart]].\r\n * @public\r\n */\r\nexport class GeometryStreamBuilder {\r\n /** Current inverse placement transform, used for converting world coordinate input to be placement relative */\r\n private _worldToLocal?: Transform;\r\n /** GeometryStream entries */\r\n public readonly geometryStream: GeometryStreamProps = [];\r\n\r\n /** Supply optional local to world transform. Used to transform world coordinate input relative to element placement.\r\n * For a [[GeometricElement]]'s placement to be meaningful, world coordinate geometry should never be appended to an element with an identity placement.\r\n * Can be called with undefined or identity transform to start appending geometry supplied in local coordinates again.\r\n */\r\n public setLocalToWorld(localToWorld?: Transform) {\r\n this._worldToLocal = (undefined === localToWorld || localToWorld.isIdentity ? undefined : localToWorld.inverse());\r\n }\r\n\r\n /** Supply local to world transform from a Point3d and optional YawPitchRollAngles.\r\n * @see [[Placement3d]]\r\n */\r\n public setLocalToWorld3d(origin: Point3d, angles: YawPitchRollAngles = YawPitchRollAngles.createDegrees(0.0, 0.0, 0.0)) {\r\n this.setLocalToWorld(Transform.createOriginAndMatrix(origin, angles.toMatrix3d()));\r\n }\r\n\r\n /** Supply local to world transform from a Point2d and optional Angle.\r\n * @see [[Placement2d]]\r\n */\r\n public setLocalToWorld2d(origin: Point2d, angle: Angle = Angle.createDegrees(0.0)) {\r\n this.setLocalToWorld(Transform.createOriginAndMatrix(Point3d.createFrom(origin), Matrix3d.createRotationAroundVector(Vector3d.unitZ(), angle)));\r\n }\r\n\r\n /** Supply local to world transform from a PlacementProps2d or PlacementProps3d.\r\n * @see [[PlacementProps]]\r\n */\r\n public setLocalToWorldFromPlacement(props: PlacementProps) {\r\n const placement = isPlacement2dProps(props) ? Placement2d.fromJSON(props) : Placement3d.fromJSON(props);\r\n this.setLocalToWorld(placement.transform);\r\n }\r\n\r\n /** Store local ranges in GeometryStream for all subsequent geometry appended. Can improve performance of range testing for elements with a GeometryStream\r\n * containing more than one [[GeometryQuery]] differentiable by range. Not useful for a single [[GeometryQuery]] as its range and that of the [[GeometricElement]] are the same.\r\n * Ignored when defining a [[GeometryPart]] and not needed when only appending [[GeometryPart]] instances to a [[GeometricElement]] as these store their own range.\r\n */\r\n public appendGeometryRanges() {\r\n this.geometryStream.push({ subRange: Range3d.createNull() });\r\n }\r\n\r\n /** Change [[SubCategory]] or reset to [[SubCategoryAppearance]] for subsequent geometry.\r\n * An invalid sub-category id can be supplied to force a reset to the current [[SubCategoryAppearance]].\r\n * It is not valid to change the sub-category when defining a [[GeometryPart]]. A [[GeometryPart]] inherit the symbology of their instance for anything not explicitly overridden.\r\n */\r\n public appendSubCategoryChange(subCategoryId: Id64String): boolean {\r\n this.geometryStream.push({ appearance: { subCategory: subCategoryId } });\r\n return true;\r\n }\r\n\r\n /** Change [[GeometryParams]] for subsequent geometry.\r\n * It is not valid to change the sub-category when defining a [[GeometryPart]]. A [[GeometryPart]] inherits the symbology of their instance for anything not explicitly overridden.\r\n */\r\n public appendGeometryParamsChange(geomParams: GeometryParams): boolean {\r\n const appearance: GeometryAppearanceProps = {\r\n subCategory: geomParams.subCategoryId,\r\n color: geomParams.lineColor?.toJSON(),\r\n weight: geomParams.weight,\r\n style: geomParams.styleInfo?.styleId,\r\n transparency: geomParams.elmTransparency,\r\n displayPriority: geomParams.elmPriority,\r\n geometryClass: geomParams.geometryClass,\r\n };\r\n this.geometryStream.push({ appearance });\r\n\r\n if (undefined !== geomParams.materialId)\r\n this.geometryStream.push({ material: { materialId: geomParams.materialId } });\r\n\r\n if (undefined !== geomParams.fillDisplay && FillDisplay.Never !== geomParams.fillDisplay) {\r\n const fill: AreaFillProps = {\r\n display: geomParams.fillDisplay,\r\n transparency: geomParams.fillTransparency,\r\n };\r\n if (undefined !== geomParams.gradient && Gradient.Mode.None !== geomParams.gradient.mode)\r\n fill.gradient = geomParams.gradient?.toJSON();\r\n else if (undefined !== geomParams.backgroundFill && BackgroundFill.None !== geomParams.backgroundFill)\r\n fill.backgroundFill = geomParams.backgroundFill;\r\n else if (undefined !== geomParams.fillColor)\r\n fill.color = geomParams.fillColor.toJSON();\r\n this.geometryStream.push({ fill });\r\n }\r\n\r\n if (undefined !== geomParams.pattern) {\r\n const localPattern = this._worldToLocal ? geomParams.pattern.clone() : geomParams.pattern;\r\n if (undefined !== this._worldToLocal && !localPattern.applyTransform(this._worldToLocal))\r\n return false;\r\n\r\n this.geometryStream.push({ pattern: localPattern.toJSON() });\r\n }\r\n\r\n if (undefined !== geomParams.styleInfo && undefined !== geomParams.styleInfo.styleMod) {\r\n const localStyleMod = new LineStyle.Modifier(geomParams.styleInfo.styleMod);\r\n if (undefined !== this._worldToLocal && !localStyleMod.applyTransform(this._worldToLocal))\r\n return false;\r\n this.geometryStream.push({ styleMod: localStyleMod });\r\n }\r\n\r\n return true;\r\n }\r\n\r\n /** Append a [[GeometryPart]] instance with relative position, orientation, and scale to a [[GeometryStreamProps]] array for creating a [[GeometricElement3d]].\r\n * Not valid when defining a [[GeometryPart]] as nesting of parts is not supported.\r\n */\r\n public appendGeometryPart3d(partId: Id64String, instanceOrigin?: Point3d, instanceRotation?: YawPitchRollAngles, instanceScale?: number): boolean {\r\n if (undefined === this._worldToLocal) {\r\n this.geometryStream.push({ geomPart: { part: partId, origin: instanceOrigin, rotation: instanceRotation, scale: instanceScale } });\r\n return true;\r\n }\r\n const partTrans = Transform.createOriginAndMatrix(instanceOrigin, instanceRotation ? instanceRotation.toMatrix3d() : Matrix3d.createIdentity());\r\n if (undefined !== instanceScale)\r\n partTrans.matrix.scaleColumnsInPlace(instanceScale, instanceScale, instanceScale);\r\n const resultTrans = this._worldToLocal.multiplyTransformTransform(partTrans);\r\n const scales = new Vector3d();\r\n if (!resultTrans.matrix.normalizeColumnsInPlace(scales))\r\n return false;\r\n const newRotation = YawPitchRollAngles.createFromMatrix3d(resultTrans.matrix);\r\n if (undefined === newRotation)\r\n return false;\r\n this.geometryStream.push({ geomPart: { part: partId, origin: resultTrans.getOrigin(), rotation: newRotation, scale: scales.x } });\r\n return true;\r\n }\r\n\r\n /** Append a [[GeometryPart]] instance with relative position, orientation, and scale to a [[GeometryStreamProps]] array for creating a [[GeometricElement2d]].\r\n * Not valid when defining a [[GeometryPart]] as nesting of parts is not supported.\r\n */\r\n public appendGeometryPart2d(partId: Id64String, instanceOrigin?: Point2d, instanceRotation?: Angle, instanceScale?: number): boolean {\r\n return this.appendGeometryPart3d(partId, instanceOrigin ? Point3d.createFrom(instanceOrigin) : undefined, instanceRotation ? new YawPitchRollAngles(instanceRotation) : undefined, instanceScale);\r\n }\r\n\r\n /** Append a [[TextString]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array */\r\n public appendTextString(textString: TextString): boolean {\r\n if (undefined === this._worldToLocal) {\r\n this.geometryStream.push({ textString });\r\n return true;\r\n }\r\n const localTextString = new TextString(textString);\r\n if (!localTextString.transformInPlace(this._worldToLocal))\r\n return false;\r\n this.geometryStream.push({ textString: localTextString });\r\n return true;\r\n }\r\n\r\n /** Append an [[ImageGraphic]] supplied in either local or world coordinates. */\r\n public appendImage(image: ImageGraphic): boolean {\r\n if (undefined !== this._worldToLocal)\r\n image = image.cloneTransformed(this._worldToLocal);\r\n\r\n this.geometryStream.push({ image: image.toJSON() });\r\n return true;\r\n }\r\n\r\n /** Append a [[GeometryQuery]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array */\r\n public appendGeometry(geometry: GeometryQuery): boolean {\r\n if (undefined === this._worldToLocal) {\r\n const geomData = GeomJson.Writer.toIModelJson(geometry);\r\n if (undefined === geomData)\r\n return false;\r\n this.geometryStream.push(geomData);\r\n return true;\r\n }\r\n const localGeometry = geometry.cloneTransformed(this._worldToLocal);\r\n if (undefined === localGeometry)\r\n return false;\r\n const localGeomData = GeomJson.Writer.toIModelJson(localGeometry);\r\n if (undefined === localGeomData)\r\n return false;\r\n this.geometryStream.push(localGeomData);\r\n return true;\r\n }\r\n\r\n /** Append [[BRepEntity.DataProps]] supplied in either local or world coordinates to the [[GeometryStreamProps]] array\r\n * @beta\r\n */\r\n public appendBRepData(brep: BRepEntity.DataProps): boolean {\r\n if (undefined === this._worldToLocal) {\r\n this.geometryStream.push({ brep });\r\n return true;\r\n }\r\n const entityTrans = Transform.fromJSON(brep.transform);\r\n const localTrans = entityTrans.multiplyTransformTransform(this._worldToLocal);\r\n const localBrep: BRepEntity.DataProps = {\r\n data: brep.data,\r\n type: brep.type,\r\n transform: localTrans.isIdentity ? undefined : localTrans.toJSON(),\r\n faceSymbology: brep.faceSymbology,\r\n };\r\n this.geometryStream.push({ brep: localBrep });\r\n return true;\r\n }\r\n\r\n /** @internal */\r\n public getHeader(): GeometryStreamHeaderProps | undefined {\r\n return 0 < this.geometryStream.length ? this.geometryStream[0].header : undefined;\r\n }\r\n\r\n /** @internal */\r\n public obtainHeader(): GeometryStreamHeaderProps {\r\n const hdr = this.getHeader();\r\n if (undefined !== hdr)\r\n return hdr;\r\n\r\n const entry = { header: { flags: GeometryStreamFlags.None } };\r\n this.geometryStream.unshift(entry);\r\n return entry.header;\r\n }\r\n\r\n /** Controls whether or not the geometry in the stream should be displayed as view-independent.\r\n * When view-independent geometry is displayed, it is always oriented to face the viewer, using the placement origin of the element as the rotation point.\r\n * If the placement origin is outside of the view, the geometry will not necessarily be displayed, even if rotating it to face the viewer would cause its range to intersect the viewed volume\r\n * @public\r\n */\r\n public get isViewIndependent(): boolean {\r\n const hdr = this.getHeader();\r\n return undefined !== hdr && GeometryStreamFlags.None !== (hdr.flags & GeometryStreamFlags.ViewIndependent);\r\n }\r\n public set isViewIndependent(viewIndependent: boolean) {\r\n if (viewIndependent === this.isViewIndependent)\r\n return;\r\n\r\n const hdr = this.obtainHeader();\r\n if (viewIndependent)\r\n hdr.flags |= GeometryStreamFlags.ViewIndependent;\r\n else\r\n hdr.flags &= ~GeometryStreamFlags.ViewIndependent;\r\n }\r\n}\r\n\r\n/** Represents a text string within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface TextStringPrimitive {\r\n type: \"textString\";\r\n readonly textString: TextString;\r\n}\r\n\r\n/** Represents an image within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface ImagePrimitive {\r\n type: \"image\";\r\n readonly image: ImageGraphic;\r\n}\r\n\r\n/** Represents a reference to a GeometryPart within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface PartReference {\r\n type: \"partReference\";\r\n part: {\r\n id: Id64String;\r\n readonly toLocal?: Transform;\r\n };\r\n}\r\n\r\n/** Represents a BRep within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface BRepPrimitive {\r\n type: \"brep\";\r\n /** @beta */\r\n readonly brep: BRepEntity.DataProps;\r\n}\r\n\r\n/** Represents one of a variety of GeometryQuery objects within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryPrimitive {\r\n type: \"geometryQuery\";\r\n readonly geometry: AnyGeometryQuery;\r\n}\r\n\r\n/** Union of all possible geometric primitive types that may appear within a GeometryStream.\r\n * @public\r\n * @extensions\r\n */\r\nexport type GeometryStreamPrimitive = TextStringPrimitive | PartReference | BRepPrimitive | GeometryPrimitive | ImagePrimitive;\r\n\r\n/** Holds current state information for [[GeometryStreamIterator]]. Each entry represents exactly one geometry primitive in the stream.\r\n * @public\r\n * @extensions\r\n */\r\nexport interface GeometryStreamIteratorEntry {\r\n /** A [[GeometryParams]] representing the appearance of the current geometric entry */\r\n readonly geomParams: GeometryParams;\r\n /** Placement transform, used for converting placement relative, local coordinate entries to world */\r\n readonly localToWorld?: Transform;\r\n /** Optional stored local range for the current geometric entry */\r\n readonly localRange?: Range3d;\r\n /** Returns the geometric primitive represented by this entry. */\r\n readonly primitive: GeometryStreamPrimitive;\r\n}\r\n\r\nclass IteratorEntry implements GeometryStreamIteratorEntry {\r\n private _primitive?: GeometryStreamPrimitive;\r\n public readonly geomParams: GeometryParams;\r\n public readonly localToWorld?: Transform;\r\n public localRange?: Range3d;\r\n\r\n public constructor(appearance: Id64String | GeometryParams, localToWorld?: Transform) {\r\n this.geomParams = typeof appearance === \"string\" ? new GeometryParams(appearance) : appearance;\r\n this.localToWorld = localToWorld;\r\n }\r\n\r\n public get primitive() { return this._primitive!; }\r\n public set primitive(primitive: GeometryStreamPrimitive) { this._primitive = primitive; }\r\n\r\n public setGeometryQuery(geometry: AnyGeometryQuery) { this._primitive = { type: \"geometryQuery\", geometry }; }\r\n public setTextString(textString: TextString) { this._primitive = { type: \"textString\", textString }; }\r\n public setBRep(brep: BRepEntity.DataProps) { this._primitive = { type: \"brep\", brep }; }\r\n public setImage(image: ImageGraphic) { this._primitive = { type: \"image\", image }; }\r\n public setPartReference(id: Id64String, toLocal?: Transform) {\r\n this._primitive = {\r\n type: \"partReference\",\r\n part: { id, toLocal },\r\n };\r\n }\r\n}\r\n\r\n/** GeometryStreamIterator is a helper class for iterating a [[GeometryStreamProps]].\r\n * A [[GeometricElement]]'s GeometryStream must be specifically requested using [[ElementLoadProps.wantGeometry]].\r\n * Each [[GeometryStreamIteratorEntry]] returned by the iterator represents exactly one geometric primitive in the stream.\r\n * @public\r\n */\r\nexport class GeometryStreamIterator implements IterableIterator<GeometryStreamIteratorEntry> {\r\n /** GeometryStream entries */\r\n public geometryStream: GeometryStreamProps;\r\n /** Flags applied to the entire geometry stream. */\r\n public readonly flags: GeometryStreamFlags;\r\n /** Current entry position */\r\n private _index = 0;\r\n /** Allocated on first call to next() and reused thereafter. */\r\n private _entry?: IteratorEntry;\r\n /** Used to initialize this._entry. */\r\n private readonly _appearance: Id64String | GeometryParams;\r\n private readonly _localToWorld?: Transform;\r\n\r\n /** Construct a new GeometryStreamIterator given a [[GeometryStreamProps]] from either a [[GeometricElement3d]], [[GeometricElement2d]], or [[GeometryPart]].\r\n * Supply the [[GeometricElement]]'s category to initialize the appearance information for each geometric entry.\r\n */\r\n public constructor(geometryStream: GeometryStreamProps, categoryOrGeometryParams?: Id64String | GeometryParams, localToWorld?: Transform) {\r\n this.geometryStream = geometryStream;\r\n this._appearance = categoryOrGeometryParams ?? Id64.invalid;\r\n this._localToWorld = localToWorld;\r\n if (0 < geometryStream.length && undefined !== geometryStream[0].header) {\r\n this.flags = geometryStream[0].header.flags;\r\n ++this._index;\r\n } else {\r\n this.flags = GeometryStreamFlags.None;\r\n }\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/naming-convention\r\n private get entry() {\r\n if (undefined === this._entry)\r\n this._entry = new IteratorEntry(this._appearance, this._localToWorld);\r\n\r\n return this._entry;\r\n }\r\n\r\n /** Create a new GeometryStream iterator for a [[GeometricElement3d]].\r\n * If [[GeometricElement3dProps.placement]] is not undefined, placement relative entries will be returned transformed to world coordinates.\r\n * @throws [[IModelError]] if element.geom is undefined.\r\n */\r\n public static fromGeometricElement3d(element: Pick<GeometricElement3dProps, \"geom\" | \"placement\" | \"category\">) {\r\n if (element.geom === undefined)\r\n throw new IModelError(IModelStatus.NoGeometry, \"GeometricElement has no geometry or geometry wasn't requested\");\r\n\r\n let transform;\r\n if (element.placement !== undefined)\r\n transform = Transform.createOriginAndMatrix(Point3d.fromJSON(element.placement.origin), YawPitchRollAngles.fromJSON(element.placement.angles).toMatrix3d());\r\n\r\n return new GeometryStreamIterator(element.geom, element.category, transform);\r\n }\r\n\r\n /** Create a new GeometryStream iterator for a [[GeometricElement2d]].\r\n * If [[GeometricElement2dProps.placement]] is not undefined, placement relative entries will be returned transformed to world coordinates.\r\n * @throws [[IModelError]] if element.geom is undefined.\r\n */\r\n public static fromGeometricElement2d(element: Pick<GeometricElement2dProps, \"geom\" | \"placement\" | \"category\">) {\r\n if (element.geom === undefined)\r\n throw new IModelError(IModelStatus.NoGeometry, \"GeometricElement has no geometry or geometry wasn't requested\");\r\n\r\n let transform;\r\n if (element.placement !== undefined) {\r\n const origin = Point3d.createFrom(Point2d.fromJSON(element.placement.origin));\r\n const matrix = Matrix3d.createRotationAroundVector(Vector3d.unitZ(), Angle.fromJSON(element.placement.angle))!;\r\n transform = Transform.createOriginAndMatrix(origin, matrix);\r\n }\r\n\r\n return new GeometryStreamIterator(element.geom, element.category, transform);\r\n }\r\n\r\n /** Create a new GeometryStream iterator for a [[GeometryPart]].\r\n * To iterate a part's GeometryStream in the context of a part instance found for a [[GeometricElement]], provide the optional [[GeometryParams]] and Transform from the [[GeometricElement]]'s [[GeometryStreamIterator]].\r\n * Supply the [[GeometryParams]] to return appearance information as inherited from the [[GeometricElement]].\r\n * Supply the partToWorld transform to return the part geometry in world coordinates.\r\n * Supply the partToLocal transform to return the part geometry relative to the [[GeometricElement]]'s placement.\r\n * @throws [[IModelError]] if geomPart.geom is undefined.\r\n */\r\n public static fromGeometryPart(geomPart: Pick<GeometryPartProps, \"geom\">, geomParams?: GeometryParams, partTransform?: Transform) {\r\n if (geomPart.geom === undefined)\r\n throw new IModelError(IModelStatus.NoGeometry, \"GeometryPart has no geometry or geometry wasn't requested\");\r\n\r\n return new GeometryStreamIterator(geomPart.geom, geomParams?.clone(), partTransform);\r\n }\r\n\r\n /** Get the transform that if applied to a [[GeometryPart]]'s GeometryStream entries would return them in world coordinates. */\r\n public partToWorld(): Transform | undefined {\r\n if (undefined === this._entry)\r\n return this._localToWorld;\r\n\r\n const partToLocal = \"partReference\" === this._entry.primitive.type ? this._entry.primitive.part.toLocal : undefined;\r\n if (this._entry.localToWorld === undefined || partToLocal === undefined)\r\n return this._entry.localToWorld;\r\n\r\n return this._entry.localToWorld.multiplyTransformTransform(partToLocal);\r\n }\r\n\r\n /** Advance to next displayable geometric entry while updating the current [[GeometryParams]] from appearance related entries.\r\n * Geometric entries are [[TextString]], [[GeometryQuery]], [[GeometryPart]], [[ImageGraphic]], and [[BRepEntity.DataProps]].\r\n */\r\n public next(): IteratorResult<GeometryStreamIteratorEntry> {\r\n // NOTE: localRange remains valid until we encounter either a new subRange entry or a geometry part reference.\r\n while (this._index < this.geometryStream.length) {\r\n const entry = this.geometryStream[this._index++];\r\n if (entry.appearance) {\r\n this.entry.geomParams.resetAppearance();\r\n if (entry.appearance.subCategory)\r\n this.entry.geomParams.subCategoryId = Id64.fromJSON(entry.appearance.subCategory);\r\n if (undefined !== entry.appearance.color)\r\n this.entry.geomParams.lineColor = ColorDef.fromJSON(entry.appearance.color);\r\n if (undefined !== entry.appearance.weight)\r\n this.entry.geomParams.weight = entry.appearance.weight;\r\n if (undefined !== entry.appearance.style)\r\n this.entry.geomParams.styleInfo = new LineStyle.Info(Id64.fromJSON(entry.appearance.style));\r\n if (undefined !== entry.appearance.transparency)\r\n this.entry.geomParams.elmTransparency = entry.appearance.transparency;\r\n if (undefined !== entry.appearance.displayPriority)\r\n this.entry.geomParams.elmPriority = entry.appearance.displayPriority;\r\n if (undefined !== entry.appearance.geometryClass)\r\n this.entry.geomParams.geometryClass = entry.appearance.geometryClass;\r\n } else if (entry.styleMod) {\r\n if (this.entry.geomParams.styleInfo === undefined)\r\n continue;\r\n\r\n const styleMod = new LineStyle.Modifier(entry.styleMod);\r\n if (this.entry.localToWorld !== undefined)\r\n styleMod.applyTransform(this.entry.localToWorld);\r\n\r\n this.entry.geomParams.styleInfo = new LineStyle.Info(this.entry.geomParams.styleInfo.styleId, styleMod);\r\n } else if (entry.fill) {\r\n if (entry.fill.display)\r\n this.entry.geomParams.fillDisplay = entry.fill.display;\r\n if (entry.fill.transparency)\r\n this.entry.geomParams.fillTransparency = entry.fill.transparency;\r\n if (entry.fill.gradient)\r\n this.entry.geomParams.gradient = Gradient.Symb.fromJSON(entry.fill.gradient);\r\n else if (entry.fill.backgroundFill)\r\n this.entry.geomParams.backgroundFill = entry.fill.backgroundFill;\r\n else if (entry.fill.color)\r\n this.entry.geomParams.fillColor = ColorDef.fromJSON(entry.fill.color);\r\n } else if (entry.pattern) {\r\n const params = AreaPattern.Params.fromJSON(entry.pattern);\r\n if (this.entry.localToWorld !== undefined)\r\n params.applyTransform(this.entry.localToWorld);\r\n\r\n this.entry.geomParams.pattern = params;\r\n } else if (entry.material) {\r\n if (entry.material.materialId)\r\n this.entry.geomParams.materialId = Id64.fromJSON(entry.material.materialId);\r\n } else if (entry.subRange) {\r\n this.entry.localRange = Range3d.fromJSON(entry.subRange);\r\n } else if (entry.geomPart) {\r\n let transform;\r\n if (entry.geomPart.origin !== undefined || entry.geomPart.rotation !== undefined || entry.geomPart.scale !== undefined) {\r\n const origin = entry.geomPart.origin ? Point3d.fromJSON(entry.geomPart.origin) : Point3d.createZero();\r\n const rotation = entry.geomPart.rotation ? YawPitchRollAngles.fromJSON(entry.geomPart.rotation).toMatrix3d() : Matrix3d.createIdentity();\r\n transform = Transform.createRefs(origin, rotation);\r\n if (entry.geomPart.scale)\r\n transform.multiplyTransformTransform(Transform.createRefs(Point3d.createZero(), Matrix3d.createUniformScale(entry.geomPart.scale)), transform);\r\n }\r\n\r\n // Subgraphic range doesn't apply to parts. A sane geometry stream (i.e., any that has been through the native layers or GeometryStreamBuilder)\r\n // will have a new subgraphic range for any geometric primitive following the part.\r\n this.entry.localRange = undefined;\r\n this.entry.setPartReference(Id64.fromJSON(entry.geomPart.part), transform);\r\n return { value: this.entry, done: false };\r\n } else if (entry.textString) {\r\n const textString = new TextString(entry.textString);\r\n if (this.entry.localToWorld !== undefined)\r\n textString.transformInPlace(this.entry.localToWorld);\r\n\r\n this.entry.setTextString(textString);\r\n return { value: this.entry, done: false };\r\n } else if (entry.image) {\r\n const image = ImageGraphic.fromJSON(entry.image);\r\n if (undefined !== this.entry.localToWorld)\r\n image.transformInPlace(this.entry.localToWorld);\r\n\r\n this.entry.setImage(image);\r\n return { value: this.entry, done: false };\r\n } else if (entry.brep) {\r\n if (this.entry.localToWorld !== undefined) {\r\n const entityTrans = Transform.fromJSON(entry.brep.transform);\r\n entry.brep.transform = entityTrans.multiplyTransformTransform(this.entry.localToWorld).toJSON();\r\n }\r\n\r\n this.entry.setBRep(entry.brep);\r\n return { value: this.entry, done: false };\r\n } else {\r\n const geometryQuery = GeomJson.Reader.parse(entry);\r\n if (!(geometryQuery instanceof GeometryQuery))\r\n continue;\r\n\r\n if (this.entry.localToWorld !== undefined)\r\n geometryQuery.tryTransformInPlace(this.entry.localToWorld);\r\n\r\n this.entry.setGeometryQuery(geometryQuery);\r\n return { value: this.entry, done: false };\r\n }\r\n }\r\n\r\n return { value: this.entry, done: true };\r\n }\r\n\r\n public [Symbol.iterator](): IterableIterator<GeometryStreamIteratorEntry> {\r\n return this;\r\n }\r\n\r\n /** @internal */\r\n public get isViewIndependent(): boolean { return GeometryStreamFlags.None !== (this.flags & GeometryStreamFlags.ViewIndependent); }\r\n}\r\n"]}
|