@itwin/core-common 3.0.0-dev.81 → 3.0.0-dev.85

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (155) hide show
  1. package/CHANGELOG.md +1248 -1248
  2. package/README.md +11 -11
  3. package/lib/cjs/AuthorizationClient.js.map +1 -1
  4. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  5. package/lib/cjs/Base64EncodedString.js.map +1 -1
  6. package/lib/cjs/BlobReader.js.map +1 -1
  7. package/lib/cjs/ChangedElements.js.map +1 -1
  8. package/lib/cjs/ChangedEntities.js.map +1 -1
  9. package/lib/cjs/ClipStyle.js.map +1 -1
  10. package/lib/cjs/CloudStorage.js.map +1 -1
  11. package/lib/cjs/CloudStorageTileCache.js.map +1 -1
  12. package/lib/cjs/Code.js.map +1 -1
  13. package/lib/cjs/ConcurrentQuery.js.map +1 -1
  14. package/lib/cjs/ContextRealityModel.js.map +1 -1
  15. package/lib/cjs/DisplayStyleSettings.js.map +1 -1
  16. package/lib/cjs/ECSqlReader.js.map +1 -1
  17. package/lib/cjs/ECSqlTypes.js.map +1 -1
  18. package/lib/cjs/EntityProps.js.map +1 -1
  19. package/lib/cjs/FeatureGates.js.map +1 -1
  20. package/lib/cjs/FeatureIndex.js.map +1 -1
  21. package/lib/cjs/Fonts.js.map +1 -1
  22. package/lib/cjs/Frustum.js.map +1 -1
  23. package/lib/cjs/IModelError.js.map +1 -1
  24. package/lib/cjs/Image.js.map +1 -1
  25. package/lib/cjs/Localization.d.ts +87 -10
  26. package/lib/cjs/Localization.d.ts.map +1 -1
  27. package/lib/cjs/Localization.js +8 -6
  28. package/lib/cjs/Localization.js.map +1 -1
  29. package/lib/cjs/MapImagerySettings.js.map +1 -1
  30. package/lib/cjs/ModelClipGroup.js.map +1 -1
  31. package/lib/cjs/ModelProps.js.map +1 -1
  32. package/lib/cjs/OctEncodedNormal.js.map +1 -1
  33. package/lib/cjs/PlanarClipMask.js.map +1 -1
  34. package/lib/cjs/QPoint.js.map +1 -1
  35. package/lib/cjs/Render.js.map +1 -1
  36. package/lib/cjs/RpcInterface.js.map +1 -1
  37. package/lib/cjs/RpcManager.js.map +1 -1
  38. package/lib/cjs/SpatialClassification.js.map +1 -1
  39. package/lib/cjs/SubCategoryAppearance.js.map +1 -1
  40. package/lib/cjs/Thumbnail.js.map +1 -1
  41. package/lib/cjs/TxnAction.js.map +1 -1
  42. package/lib/cjs/ViewDetails.js.map +1 -1
  43. package/lib/cjs/ViewProps.js.map +1 -1
  44. package/lib/cjs/WhiteOnWhiteReversalSettings.js.map +1 -1
  45. package/lib/cjs/core-common.js.map +1 -1
  46. package/lib/cjs/geometry/AdditionalTransform.js.map +1 -1
  47. package/lib/cjs/geometry/AreaPattern.js.map +1 -1
  48. package/lib/cjs/geometry/Cartographic.js.map +1 -1
  49. package/lib/cjs/geometry/CoordinateReferenceSystem.js.map +1 -1
  50. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  51. package/lib/cjs/geometry/GeodeticEllipsoid.js.map +1 -1
  52. package/lib/cjs/geometry/LineStyle.js.map +1 -1
  53. package/lib/cjs/geometry/Projection.js.map +1 -1
  54. package/lib/cjs/geometry/TextString.js.map +1 -1
  55. package/lib/cjs/ipc/IpcWebSocket.js.map +1 -1
  56. package/lib/cjs/rpc/IModelReadRpcInterface.js.map +1 -1
  57. package/lib/cjs/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  58. package/lib/cjs/rpc/TestRpcManager.js.map +1 -1
  59. package/lib/cjs/rpc/core/RpcConfiguration.js.map +1 -1
  60. package/lib/cjs/rpc/core/RpcConstants.js.map +1 -1
  61. package/lib/cjs/rpc/core/RpcControl.js.map +1 -1
  62. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  63. package/lib/cjs/rpc/core/RpcMarshaling.js.map +1 -1
  64. package/lib/cjs/rpc/core/RpcOperation.js.map +1 -1
  65. package/lib/cjs/rpc/core/RpcPendingQueue.js.map +1 -1
  66. package/lib/cjs/rpc/core/RpcProtocol.js.map +1 -1
  67. package/lib/cjs/rpc/core/RpcRegistry.js.map +1 -1
  68. package/lib/cjs/rpc/core/RpcRequest.js.map +1 -1
  69. package/lib/cjs/rpc/core/RpcRoutingToken.js.map +1 -1
  70. package/lib/cjs/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  71. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  72. package/lib/cjs/rpc/web/OpenAPI.js.map +1 -1
  73. package/lib/cjs/rpc/web/RpcMultipart.js.map +1 -1
  74. package/lib/cjs/rpc/web/WebAppRpcLogging.js.map +1 -1
  75. package/lib/cjs/rpc/web/WebAppRpcProtocol.js.map +1 -1
  76. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  77. package/lib/cjs/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  78. package/lib/cjs/tile/ElementGraphics.js.map +1 -1
  79. package/lib/esm/AuthorizationClient.js.map +1 -1
  80. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  81. package/lib/esm/Base64EncodedString.js.map +1 -1
  82. package/lib/esm/BlobReader.js.map +1 -1
  83. package/lib/esm/ChangedElements.js.map +1 -1
  84. package/lib/esm/ChangedEntities.js.map +1 -1
  85. package/lib/esm/ClipStyle.js.map +1 -1
  86. package/lib/esm/CloudStorage.js.map +1 -1
  87. package/lib/esm/CloudStorageTileCache.js.map +1 -1
  88. package/lib/esm/Code.js.map +1 -1
  89. package/lib/esm/ConcurrentQuery.js.map +1 -1
  90. package/lib/esm/ContextRealityModel.js.map +1 -1
  91. package/lib/esm/DisplayStyleSettings.js.map +1 -1
  92. package/lib/esm/ECSqlReader.js.map +1 -1
  93. package/lib/esm/ECSqlTypes.js.map +1 -1
  94. package/lib/esm/EntityProps.js.map +1 -1
  95. package/lib/esm/FeatureGates.js.map +1 -1
  96. package/lib/esm/FeatureIndex.js.map +1 -1
  97. package/lib/esm/Fonts.js.map +1 -1
  98. package/lib/esm/Frustum.js.map +1 -1
  99. package/lib/esm/IModelError.js.map +1 -1
  100. package/lib/esm/Image.js.map +1 -1
  101. package/lib/esm/Localization.d.ts +87 -10
  102. package/lib/esm/Localization.d.ts.map +1 -1
  103. package/lib/esm/Localization.js +8 -6
  104. package/lib/esm/Localization.js.map +1 -1
  105. package/lib/esm/MapImagerySettings.js.map +1 -1
  106. package/lib/esm/ModelClipGroup.js.map +1 -1
  107. package/lib/esm/ModelProps.js.map +1 -1
  108. package/lib/esm/OctEncodedNormal.js.map +1 -1
  109. package/lib/esm/PlanarClipMask.js.map +1 -1
  110. package/lib/esm/QPoint.js.map +1 -1
  111. package/lib/esm/Render.js.map +1 -1
  112. package/lib/esm/RpcInterface.js.map +1 -1
  113. package/lib/esm/RpcManager.js.map +1 -1
  114. package/lib/esm/SpatialClassification.js.map +1 -1
  115. package/lib/esm/SubCategoryAppearance.js.map +1 -1
  116. package/lib/esm/Thumbnail.js.map +1 -1
  117. package/lib/esm/TxnAction.js.map +1 -1
  118. package/lib/esm/ViewDetails.js.map +1 -1
  119. package/lib/esm/ViewProps.js.map +1 -1
  120. package/lib/esm/WhiteOnWhiteReversalSettings.js.map +1 -1
  121. package/lib/esm/core-common.js.map +1 -1
  122. package/lib/esm/geometry/AdditionalTransform.js.map +1 -1
  123. package/lib/esm/geometry/AreaPattern.js.map +1 -1
  124. package/lib/esm/geometry/Cartographic.js.map +1 -1
  125. package/lib/esm/geometry/CoordinateReferenceSystem.js.map +1 -1
  126. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  127. package/lib/esm/geometry/GeodeticEllipsoid.js.map +1 -1
  128. package/lib/esm/geometry/LineStyle.js.map +1 -1
  129. package/lib/esm/geometry/Projection.js.map +1 -1
  130. package/lib/esm/geometry/TextString.js.map +1 -1
  131. package/lib/esm/ipc/IpcWebSocket.js.map +1 -1
  132. package/lib/esm/rpc/IModelReadRpcInterface.js.map +1 -1
  133. package/lib/esm/rpc/SnapshotIModelRpcInterface.js.map +1 -1
  134. package/lib/esm/rpc/TestRpcManager.js.map +1 -1
  135. package/lib/esm/rpc/core/RpcConfiguration.js.map +1 -1
  136. package/lib/esm/rpc/core/RpcConstants.js.map +1 -1
  137. package/lib/esm/rpc/core/RpcControl.js.map +1 -1
  138. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  139. package/lib/esm/rpc/core/RpcMarshaling.js.map +1 -1
  140. package/lib/esm/rpc/core/RpcOperation.js.map +1 -1
  141. package/lib/esm/rpc/core/RpcPendingQueue.js.map +1 -1
  142. package/lib/esm/rpc/core/RpcProtocol.js.map +1 -1
  143. package/lib/esm/rpc/core/RpcRegistry.js.map +1 -1
  144. package/lib/esm/rpc/core/RpcRequest.js.map +1 -1
  145. package/lib/esm/rpc/core/RpcRoutingToken.js.map +1 -1
  146. package/lib/esm/rpc/web/BentleyCloudRpcManager.js.map +1 -1
  147. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  148. package/lib/esm/rpc/web/OpenAPI.js.map +1 -1
  149. package/lib/esm/rpc/web/RpcMultipart.js.map +1 -1
  150. package/lib/esm/rpc/web/WebAppRpcLogging.js.map +1 -1
  151. package/lib/esm/rpc/web/WebAppRpcProtocol.js.map +1 -1
  152. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  153. package/lib/esm/rpc/web/multipart/RpcMultipartParser.js.map +1 -1
  154. package/lib/esm/tile/ElementGraphics.js.map +1 -1
  155. package/package.json +9 -9
@@ -1 +1 @@
1
- {"version":3,"file":"CoordinateReferenceSystem.js","sourceRoot":"","sources":["../../../src/geometry/CoordinateReferenceSystem.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 NAVD, NGVD\n\nimport { GeodeticDatum, GeodeticDatumProps } from \"./GeodeticDatum\";\nimport { GeodeticEllipsoid, GeodeticEllipsoidProps } from \"./GeodeticEllipsoid\";\nimport { Carto2DDegrees, Carto2DDegreesProps, Projection, ProjectionProps } from \"./Projection\";\nimport { AdditionalTransform, AdditionalTransformProps } from \"./AdditionalTransform\";\n/** This type indicates possible linear and angular units supported.\n * @public\n*/\nexport type UnitType = \"Meter\" | \"InternationalFoot\" | \"USSurveyFoot\" | \"Degree\" | \"Unsupported\";\n\n/** The extent in latitude, longitude bounds where a horizontal CRS is applicable\n * @public\n*/\nexport interface HorizontalCRSExtentProps {\n /** The South West point in latitude and longitude in degrees for the user-defined extent of the CRS */\n southWest: Carto2DDegreesProps;\n /** The North East point in latitude in longitude in degrees for the user-defined extent of the CRS.\n The latitude of the North East must be greater or equal to the latitude of the South West point\n It is possible, however, for the longitude of the South West corner to have greater value than the\n longitude of the North East point such as when the west longitude is located on the other side\n of the -180/180 degree longitude line.*/\n northEast: Carto2DDegreesProps;\n}\n\n/** The extent in latitude, longitude bounds where a horizontal CRS is applicable\n * @public\n */\nexport class HorizontalCRSExtent implements HorizontalCRSExtentProps {\n /** The latitude minimum and maximum for the user-defined extent of the CRS */\n public readonly southWest: Carto2DDegrees;\n /** The North East point in latitude in longitude in degrees for the user-defined extent of the CRS.\n The latitude of the North East must be greater or equal to the latitude of the South West point\n It is possible, however, for the longitude of the South West corner to have greater value than the\n longitude of the North East point such as when the west longitude is located on the other side\n of the -180/180 degree longitude line.*/\n public readonly northEast: Carto2DDegrees;\n\n public constructor(data?: HorizontalCRSExtentProps) {\n if (data) {\n this.southWest = Carto2DDegrees.fromJSON(data.southWest);\n this.northEast = Carto2DDegrees.fromJSON(data.northEast);\n if (this.northEast.latitude < this.southWest.latitude)\n this.northEast.latitude = this.southWest.latitude;\n } else {\n this.southWest = new Carto2DDegrees();\n this.northEast = new Carto2DDegrees();\n }\n }\n\n /** Creates an extent object from JSON representation.\n * @public */\n public static fromJSON(data: HorizontalCRSExtentProps): HorizontalCRSExtent {\n return new HorizontalCRSExtent(data);\n }\n\n /** Creates a JSON from the Extent definition\n * @public */\n public toJSON(): HorizontalCRSExtentProps {\n return { southWest: this.southWest.toJSON(), northEast: this.northEast.toJSON() };\n }\n\n /** Compares two Extents. It applies a minuscule tolerance to comparing numbers.\n * @public */\n public equals(other: HorizontalCRSExtent): boolean {\n return this.southWest.equals(other.southWest) && this.northEast.equals(other.northEast);\n }\n}\n\n/** Horizontal Geographic Coordinate Reference System definition\n * @public\n */\nexport interface HorizontalCRSProps {\n /** The identifier of the horizontal CRS as stored in the dictionary or the service database */\n id?: string;\n /** Used only for user-defined definitions that will typically use a GUID as id. A display name for the CRS that allows\n * a human to understand the nature of the definition\n */\n name?: string;\n /** Description */\n description?: string;\n /** A textual description of the source of the CRS definition. */\n source?: 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 EPSG code of the CRS. If undefined then there is no EPSG code associated. */\n epsg?: number;\n /** The identifier of the geodetic datum as stored in the dictionary or the service database. */\n datumId?: string;\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\n * in either service or dictionary.\n */\n datum?: GeodeticDatumProps;\n /** The identifier of the geodetic ellipsoid as stored in the dictionary or the service database. This property is exclusive\n * of having datumId and datum properties undefined.\n */\n ellipsoidId?: string;\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\n * in either service or dictionary\n */\n ellipsoid?: GeodeticEllipsoidProps;\n /** The text indicating the unit used. */\n unit?: UnitType;\n /** Projection including projection parameters. */\n projection?: ProjectionProps;\n /** Extent representing the domain of application of the CRS. */\n extent?: HorizontalCRSExtentProps;\n}\n\n/** Horizontal Geographic Coordinate reference System implementation.\n * An horizontal CRS defines the portion which is horizontal to the Earth surface (within the deformation brought by the projection process).\n * There are two major classes of Horizontal Coordinate Reference Systems:\n * - The projected CRS which rely on a projection to flatten the coordinate system space into axises using linear\n * units (meter, US Survey Feet, ...) relative to some origin.\n * - The non projected CRS (also named geographic CRS by EPSG nomenclature) that does\n * not require a projection (projection method = None) and horizontal coordinates are expressed\n * as longitude and latitude (see [[Cartographic]])\n * Horizontal Coordinate Systems rely on a projection to flatten the surface of an ellipsoid (see [[GeodeticEllipsoid]]) which is\n * the mathematical model of the Earth surface.\n * Explanations in more details of the various concepts can be obtained from other sources including the page on the subject\n * on itwinJS.org (see https://www.itwinjs.org/learning/geolocation/?term=coordinate+system).\n * A few details are still required to grasp the model. Geographic Coordinate Reference Systems rely on the concept of geodetic datums\n * (see [[GeodeticDatum]]) to convert latitude/longitude from one frame of reference to another. Such geodetic datum will bind the ellipsoid\n * and possibly define transformation steps required to convert from the currently used geodetic datum to the common datum WGS84\n * used for worldwide data (such as most popular imagery data sources). If there are no rules established to convert to WGS84\n * or if those rules are secret then the horizontal CRS can be datum-less and must make direct use of the ellipsoid\n * to define the earth surface.\n * For this purpose either the geodetic datum must be specified using either datumId or datum properties or both. If\n * both these values are undefined then it is possible to define the ellipsoid using properties ellipsoidId or ellipsoid or both.\n * These two pairs of properties are mutually exclusive with datum related properties having precedence. If a datum or datumId is set then\n * ellipsoid properties will automatically be undefined. If datumId or datum is defined then attempts to set ellipsoidId or ellipsoid\n * will fail silently, the values remaining undefined. The ellipsoidId will not be a repeat of the ellipsoidId property part of the\n * geodetic datum definition.\n * @public\n */\nexport class HorizontalCRS implements HorizontalCRSProps {\n /** The identifier of the horizontal CRS as stored in the dictionary or the service database */\n public readonly id?: string;\n /** Used only for user-defined definitions that will typically use a GUID as id. A display name for the CRS that allows\n ** a human to understand the nature of the definition\n */\n public readonly name?: string;\n /** Description */\n public readonly description?: string;\n /** The source of the CRS definition. */\n public readonly source?: 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 EPSG code of the CRS. If undefined then there is no EPSG code associated. */\n public readonly epsg?: number;\n /** The identifier of the geodetic datum as stored in the dictionary or the service database. */\n public readonly datumId?: string;\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\n * in either service or dictionary.\n */\n public readonly datum?: GeodeticDatum;\n\n /** The identifier of the geodetic ellipsoid as stored in the dictionary or the service database. This property is exclusive\n * of having datumId and datum properties undefined.\n */\n public readonly ellipsoidId?: string;\n /** The complete definition of the geodetic ellipsoid referred to by ellipsoidId. It can also be used if the ellipsoid is not stored\n * in either service or dictionary. This property is exclusive\n * of having datumId and datum properties undefined.\n */\n public readonly ellipsoid?: GeodeticEllipsoid;\n /** The text indicating the unit used. */\n public readonly unit?: UnitType;\n /** Projection including projection parameters. */\n public readonly projection?: Projection;\n /** Extent representing the domain of application of the CRS. */\n public readonly extent?: HorizontalCRSExtent;\n\n public constructor(_data?: HorizontalCRSProps) {\n this.deprecated = false;\n if (_data) {\n this.id = _data.id;\n this.description = _data.description;\n this.source = _data.source;\n this.deprecated = _data.deprecated ?? false;\n this.epsg = _data.epsg;\n this.datumId = _data.datumId;\n this.datum = _data.datum ? GeodeticDatum.fromJSON(_data.datum) : undefined;\n if (!this.datumId && !this.datum) {\n this.ellipsoidId = _data.ellipsoidId;\n this.ellipsoid = _data.ellipsoid ? GeodeticEllipsoid.fromJSON(_data.ellipsoid) : undefined;\n }\n this.unit = _data.unit;\n this.projection = _data.projection ? Projection.fromJSON(_data.projection) : undefined;\n this.extent = _data.extent ? HorizontalCRSExtent.fromJSON(_data.extent) : undefined;\n }\n }\n\n /** Creates an Horizontal CRS from JSON representation.\n * @public */\n public static fromJSON(data: HorizontalCRSProps): HorizontalCRS {\n return new HorizontalCRS(data);\n }\n\n /** Creates a JSON from the Horizontal CRS definition\n * @public */\n public toJSON(): HorizontalCRSProps {\n const data: HorizontalCRSProps = {};\n data.id = this.id;\n data.description = this.description;\n data.source = this.source;\n /* We prefer to use the default undef instead of false value for deprecated in Json */\n if (this.deprecated)\n data.deprecated = true;\n\n data.epsg = this.epsg;\n data.datumId = this.datumId;\n if (this.datum)\n data.datum = this.datum.toJSON();\n\n data.ellipsoidId = this.ellipsoidId;\n if (this.ellipsoid)\n data.ellipsoid = this.ellipsoid.toJSON();\n\n data.unit = this.unit;\n if (this.projection)\n data.projection = this.projection.toJSON();\n\n if (this.extent)\n data.extent = this.extent.toJSON();\n\n return data;\n }\n\n /** Compares two horizontal CRS. It is not an equivalence test as descriptive properties are also compared\n * but number compares are applied a minuscule tolerance.\n * @public */\n public equals(other: HorizontalCRS): boolean {\n if (this.id !== other.id ||\n this.description !== other.description ||\n this.source !== other.source ||\n this.deprecated !== other.deprecated ||\n this.epsg !== other.epsg ||\n this.datumId !== other.datumId ||\n this.ellipsoidId !== other.ellipsoidId ||\n this.unit !== other.unit)\n return false;\n\n if ((this.datum === undefined) !== (other.datum === undefined))\n return false;\n\n if (this.datum && !this.datum.equals(other.datum!))\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.projection === undefined) !== (other.projection === undefined))\n return false;\n\n if (this.projection && !this.projection.equals(other.projection!))\n return false;\n\n if ((this.extent === undefined) !== (other.extent === undefined))\n return false;\n\n if (this.extent && !this.extent.equals(other.extent!))\n return false;\n\n return true;\n }\n}\n\n/** Vertical Geographic Coordinate reference System definition\n * @public\n */\nexport interface VerticalCRSProps {\n /** Vertical CRS Key name. */\n id: \"GEOID\" | \"ELLIPSOID\" | \"NGVD29\" | \"NAVD88\";\n}\n\n/** Vertical Coordinate reference System implementation.\n * The VerticalCRS contains currently a single identifier property of string type. Although\n * we currently only support four distinct key values \"GEOID\", \"ELLIPSOID\", \"NAVD88\" and \"NGVD29\"\n * we expect to support a broader set in the future including, eventually, user defined vertical CRS\n * which will require additional parameters to be added.\n * @public\n*/\nexport class VerticalCRS implements VerticalCRSProps {\n /** Vertical CRS Key name. The only supported values are currently \"GEOID\", \"ELLIPSOID\", \"NAVD88\" and \"NGVD29\". The default is ELLIPSOID */\n public readonly id: \"GEOID\" | \"ELLIPSOID\" | \"NGVD29\" | \"NAVD88\";\n\n public constructor(data?: VerticalCRSProps) {\n this.id = \"ELLIPSOID\";\n if (data)\n this.id = data.id;\n }\n\n /** Creates a Vertical CRS from JSON representation.\n * @public */\n public static fromJSON(data: VerticalCRSProps): VerticalCRS {\n return new VerticalCRS(data);\n }\n\n /** Creates a JSON from the Vertical CRS definition\n * @public */\n public toJSON(): VerticalCRSProps {\n return { id: this.id };\n }\n\n /** Compares two vertical CRS.\n * @public */\n public equals(other: VerticalCRS): boolean {\n return (this.id === other.id);\n }\n}\n\n/** Geographic Coordinate Reference System definition that includes both the horizontal and vertical definitions\n * @public\n */\nexport interface GeographicCRSProps {\n /** The horizontal portion of the geographic coordinate reference system. */\n horizontalCRS?: HorizontalCRSProps;\n /** The vertical portion of the geographic coordinate reference system. */\n verticalCRS?: VerticalCRSProps;\n /** The optional additional transform the geographic coordinate reference system. */\n additionalTransform?: AdditionalTransformProps;\n}\n\n/** Geographic Coordinate Reference System implementation. This is the class that indicates the definition of a Geographic\n * coordinate reference system comprised of two components: Horizontal and Vertical.\n * The vertical component (see [[VerticalCRS]]) is the simplest being formed of a simple identifier as a string.\n * The horizontal component contains a list of identification and documentation properties as well as\n * defining details possibly including the projection with method and parameters, the definition of the datum, ellipsoid, extent and so on.\n * The principle of describing a Geographic CRS is that the definition may be incomplete. The whole set of classes related to geographic\n * coordinate reference system classes ([[GeodeticEllipsoid]], [[GeodeticDatum]], [[Projection]], [[GeodeticTransform]], ...) are designed\n * so that they can be parsed from incomplete JSON fragments, or produce incomplete JSON fragments such as would be\n * generated from a request to a REST API to a server when select OData clauses are used.\n * Often GeographicCRS would knowingly be created incomplete but with sufficient information to perform conversion from some\n * reprojection engine (the present set of classes do not provide any GeographicCRS conversion).\n * For example the following definitions are quite sufficient to request conversion to or from by a reprojection engine:\n * { horizontalCRS: {id: \"LL84\"}, verticalCRS: {id:\"GEOID\"}\n * or\n * { horizontalCRS: {datumId: \"WGS84\", projection: {method: \"None\"}}, verticalCRS: \"ELLIPSOID\"}\n * The reprojection engine will use the engine internal dictionary to obtain the details if it can.\n * Some definitions will originate from other sources (a parsed WKT for example) and the reprojection engine will require\n * all mathematical and operational details to perform any conversion (descriptive information are ignored in the conversion process).\n * @note In the absence of the verticalCRS property then ELLIPSOID (Geodetic elevation) will be assumed by reprojection engines.\n * @note see important detailed explanation in the [[HorizontalCRS]] documentation.\n * @note Earth Centered, Earth Fixed coordinate system (ECEF) is a full 3D cartesian system that unambiguously\n * expressed coordinates relative to the Earth Center. Since there is no horizontal portion independent from\n * the vertical portion this system cannot be represented by a GeographicCRS and remains a separate concept.\n * @public\n*/\nexport class GeographicCRS implements GeographicCRSProps {\n /** The horizontal portion of the geographic coordinate reference system. */\n public readonly horizontalCRS?: HorizontalCRS;\n /** The vertical portion of the geographic coordinate reference system. */\n public readonly verticalCRS?: VerticalCRS;\n /** The optional additional transform the geographic coordinate reference system. */\n public readonly additionalTransform?: AdditionalTransform;\n\n public constructor(data?: GeographicCRSProps) {\n if (data) {\n this.horizontalCRS = data.horizontalCRS ? HorizontalCRS.fromJSON(data.horizontalCRS) : undefined;\n this.verticalCRS = data.verticalCRS ? VerticalCRS.fromJSON(data.verticalCRS) : undefined;\n this.additionalTransform = data.additionalTransform ? AdditionalTransform.fromJSON(data.additionalTransform) : undefined;\n }\n }\n\n /** Creates a Geographic CRS from JSON representation.\n * @public */\n public static fromJSON(data: GeographicCRSProps): GeographicCRS {\n return new GeographicCRS(data);\n }\n\n /** Creates a JSON from the Geographic CRS definition\n * @public */\n public toJSON(): GeographicCRSProps {\n const data: GeographicCRSProps = {};\n if (this.horizontalCRS)\n data.horizontalCRS = this.horizontalCRS.toJSON();\n\n if (this.verticalCRS)\n data.verticalCRS = this.verticalCRS.toJSON();\n\n if (this.additionalTransform)\n data.additionalTransform = this.additionalTransform.toJSON();\n\n return data;\n }\n\n /** Compares two Geographic CRS. It is a strict compare operation not an equivalence test though\n * number compares are applied a minuscule tolerance.\n * It takes into account descriptive properties not only mathematical definition properties.\n * @public\n */\n public equals(other: GeographicCRS): boolean {\n if ((this.horizontalCRS === undefined) !== (other.horizontalCRS === undefined))\n return false;\n\n if (this.horizontalCRS && !this.horizontalCRS.equals(other.horizontalCRS!))\n return false;\n\n if ((this.verticalCRS === undefined) !== (other.verticalCRS === undefined))\n return false;\n\n if (this.verticalCRS && !this.verticalCRS.equals(other.verticalCRS!))\n return false;\n\n if ((this.additionalTransform === undefined) !== (other.additionalTransform === undefined))\n return false;\n\n if (this.additionalTransform && !this.additionalTransform.equals(other.additionalTransform!))\n return false;\n\n return true;\n }\n}\n\n"]}
1
+ {"version":3,"file":"CoordinateReferenceSystem.js","sourceRoot":"","sources":["../../../src/geometry/CoordinateReferenceSystem.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 NAVD, NGVD\r\n\r\nimport { GeodeticDatum, GeodeticDatumProps } from \"./GeodeticDatum\";\r\nimport { GeodeticEllipsoid, GeodeticEllipsoidProps } from \"./GeodeticEllipsoid\";\r\nimport { Carto2DDegrees, Carto2DDegreesProps, Projection, ProjectionProps } from \"./Projection\";\r\nimport { AdditionalTransform, AdditionalTransformProps } from \"./AdditionalTransform\";\r\n/** This type indicates possible linear and angular units supported.\r\n * @public\r\n*/\r\nexport type UnitType = \"Meter\" | \"InternationalFoot\" | \"USSurveyFoot\" | \"Degree\" | \"Unsupported\";\r\n\r\n/** The extent in latitude, longitude bounds where a horizontal CRS is applicable\r\n * @public\r\n*/\r\nexport interface HorizontalCRSExtentProps {\r\n /** The South West point in latitude and longitude in degrees for the user-defined extent of the CRS */\r\n southWest: Carto2DDegreesProps;\r\n /** The North East point in latitude in longitude in degrees for the user-defined extent of the CRS.\r\n The latitude of the North East must be greater or equal to the latitude of the South West point\r\n It is possible, however, for the longitude of the South West corner to have greater value than the\r\n longitude of the North East point such as when the west longitude is located on the other side\r\n of the -180/180 degree longitude line.*/\r\n northEast: Carto2DDegreesProps;\r\n}\r\n\r\n/** The extent in latitude, longitude bounds where a horizontal CRS is applicable\r\n * @public\r\n */\r\nexport class HorizontalCRSExtent implements HorizontalCRSExtentProps {\r\n /** The latitude minimum and maximum for the user-defined extent of the CRS */\r\n public readonly southWest: Carto2DDegrees;\r\n /** The North East point in latitude in longitude in degrees for the user-defined extent of the CRS.\r\n The latitude of the North East must be greater or equal to the latitude of the South West point\r\n It is possible, however, for the longitude of the South West corner to have greater value than the\r\n longitude of the North East point such as when the west longitude is located on the other side\r\n of the -180/180 degree longitude line.*/\r\n public readonly northEast: Carto2DDegrees;\r\n\r\n public constructor(data?: HorizontalCRSExtentProps) {\r\n if (data) {\r\n this.southWest = Carto2DDegrees.fromJSON(data.southWest);\r\n this.northEast = Carto2DDegrees.fromJSON(data.northEast);\r\n if (this.northEast.latitude < this.southWest.latitude)\r\n this.northEast.latitude = this.southWest.latitude;\r\n } else {\r\n this.southWest = new Carto2DDegrees();\r\n this.northEast = new Carto2DDegrees();\r\n }\r\n }\r\n\r\n /** Creates an extent object from JSON representation.\r\n * @public */\r\n public static fromJSON(data: HorizontalCRSExtentProps): HorizontalCRSExtent {\r\n return new HorizontalCRSExtent(data);\r\n }\r\n\r\n /** Creates a JSON from the Extent definition\r\n * @public */\r\n public toJSON(): HorizontalCRSExtentProps {\r\n return { southWest: this.southWest.toJSON(), northEast: this.northEast.toJSON() };\r\n }\r\n\r\n /** Compares two Extents. It applies a minuscule tolerance to comparing numbers.\r\n * @public */\r\n public equals(other: HorizontalCRSExtent): boolean {\r\n return this.southWest.equals(other.southWest) && this.northEast.equals(other.northEast);\r\n }\r\n}\r\n\r\n/** Horizontal Geographic Coordinate Reference System definition\r\n * @public\r\n */\r\nexport interface HorizontalCRSProps {\r\n /** The identifier of the horizontal CRS as stored in the dictionary or the service database */\r\n id?: string;\r\n /** Used only for user-defined definitions that will typically use a GUID as id. A display name for the CRS that allows\r\n * a human to understand the nature of the definition\r\n */\r\n name?: string;\r\n /** Description */\r\n description?: string;\r\n /** A textual description of the source of the CRS definition. */\r\n source?: 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 EPSG code of the CRS. If undefined then there is no EPSG code associated. */\r\n epsg?: number;\r\n /** The identifier of the geodetic datum as stored in the dictionary or the service database. */\r\n datumId?: string;\r\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\r\n * in either service or dictionary.\r\n */\r\n datum?: GeodeticDatumProps;\r\n /** The identifier of the geodetic ellipsoid as stored in the dictionary or the service database. This property is exclusive\r\n * of having datumId and datum properties undefined.\r\n */\r\n ellipsoidId?: string;\r\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\r\n * in either service or dictionary\r\n */\r\n ellipsoid?: GeodeticEllipsoidProps;\r\n /** The text indicating the unit used. */\r\n unit?: UnitType;\r\n /** Projection including projection parameters. */\r\n projection?: ProjectionProps;\r\n /** Extent representing the domain of application of the CRS. */\r\n extent?: HorizontalCRSExtentProps;\r\n}\r\n\r\n/** Horizontal Geographic Coordinate reference System implementation.\r\n * An horizontal CRS defines the portion which is horizontal to the Earth surface (within the deformation brought by the projection process).\r\n * There are two major classes of Horizontal Coordinate Reference Systems:\r\n * - The projected CRS which rely on a projection to flatten the coordinate system space into axises using linear\r\n * units (meter, US Survey Feet, ...) relative to some origin.\r\n * - The non projected CRS (also named geographic CRS by EPSG nomenclature) that does\r\n * not require a projection (projection method = None) and horizontal coordinates are expressed\r\n * as longitude and latitude (see [[Cartographic]])\r\n * Horizontal Coordinate Systems rely on a projection to flatten the surface of an ellipsoid (see [[GeodeticEllipsoid]]) which is\r\n * the mathematical model of the Earth surface.\r\n * Explanations in more details of the various concepts can be obtained from other sources including the page on the subject\r\n * on itwinJS.org (see https://www.itwinjs.org/learning/geolocation/?term=coordinate+system).\r\n * A few details are still required to grasp the model. Geographic Coordinate Reference Systems rely on the concept of geodetic datums\r\n * (see [[GeodeticDatum]]) to convert latitude/longitude from one frame of reference to another. Such geodetic datum will bind the ellipsoid\r\n * and possibly define transformation steps required to convert from the currently used geodetic datum to the common datum WGS84\r\n * used for worldwide data (such as most popular imagery data sources). If there are no rules established to convert to WGS84\r\n * or if those rules are secret then the horizontal CRS can be datum-less and must make direct use of the ellipsoid\r\n * to define the earth surface.\r\n * For this purpose either the geodetic datum must be specified using either datumId or datum properties or both. If\r\n * both these values are undefined then it is possible to define the ellipsoid using properties ellipsoidId or ellipsoid or both.\r\n * These two pairs of properties are mutually exclusive with datum related properties having precedence. If a datum or datumId is set then\r\n * ellipsoid properties will automatically be undefined. If datumId or datum is defined then attempts to set ellipsoidId or ellipsoid\r\n * will fail silently, the values remaining undefined. The ellipsoidId will not be a repeat of the ellipsoidId property part of the\r\n * geodetic datum definition.\r\n * @public\r\n */\r\nexport class HorizontalCRS implements HorizontalCRSProps {\r\n /** The identifier of the horizontal CRS as stored in the dictionary or the service database */\r\n public readonly id?: string;\r\n /** Used only for user-defined definitions that will typically use a GUID as id. A display name for the CRS that allows\r\n ** a human to understand the nature of the definition\r\n */\r\n public readonly name?: string;\r\n /** Description */\r\n public readonly description?: string;\r\n /** The source of the CRS definition. */\r\n public readonly source?: 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 EPSG code of the CRS. If undefined then there is no EPSG code associated. */\r\n public readonly epsg?: number;\r\n /** The identifier of the geodetic datum as stored in the dictionary or the service database. */\r\n public readonly datumId?: string;\r\n /** The complete definition of the geodetic datum referred to by datumId. It can also be used if the datum is not stored\r\n * in either service or dictionary.\r\n */\r\n public readonly datum?: GeodeticDatum;\r\n\r\n /** The identifier of the geodetic ellipsoid as stored in the dictionary or the service database. This property is exclusive\r\n * of having datumId and datum properties undefined.\r\n */\r\n public readonly ellipsoidId?: string;\r\n /** The complete definition of the geodetic ellipsoid referred to by ellipsoidId. It can also be used if the ellipsoid is not stored\r\n * in either service or dictionary. This property is exclusive\r\n * of having datumId and datum properties undefined.\r\n */\r\n public readonly ellipsoid?: GeodeticEllipsoid;\r\n /** The text indicating the unit used. */\r\n public readonly unit?: UnitType;\r\n /** Projection including projection parameters. */\r\n public readonly projection?: Projection;\r\n /** Extent representing the domain of application of the CRS. */\r\n public readonly extent?: HorizontalCRSExtent;\r\n\r\n public constructor(_data?: HorizontalCRSProps) {\r\n this.deprecated = false;\r\n if (_data) {\r\n this.id = _data.id;\r\n this.description = _data.description;\r\n this.source = _data.source;\r\n this.deprecated = _data.deprecated ?? false;\r\n this.epsg = _data.epsg;\r\n this.datumId = _data.datumId;\r\n this.datum = _data.datum ? GeodeticDatum.fromJSON(_data.datum) : undefined;\r\n if (!this.datumId && !this.datum) {\r\n this.ellipsoidId = _data.ellipsoidId;\r\n this.ellipsoid = _data.ellipsoid ? GeodeticEllipsoid.fromJSON(_data.ellipsoid) : undefined;\r\n }\r\n this.unit = _data.unit;\r\n this.projection = _data.projection ? Projection.fromJSON(_data.projection) : undefined;\r\n this.extent = _data.extent ? HorizontalCRSExtent.fromJSON(_data.extent) : undefined;\r\n }\r\n }\r\n\r\n /** Creates an Horizontal CRS from JSON representation.\r\n * @public */\r\n public static fromJSON(data: HorizontalCRSProps): HorizontalCRS {\r\n return new HorizontalCRS(data);\r\n }\r\n\r\n /** Creates a JSON from the Horizontal CRS definition\r\n * @public */\r\n public toJSON(): HorizontalCRSProps {\r\n const data: HorizontalCRSProps = {};\r\n data.id = this.id;\r\n data.description = this.description;\r\n data.source = this.source;\r\n /* We prefer to use the default undef instead of false value for deprecated in Json */\r\n if (this.deprecated)\r\n data.deprecated = true;\r\n\r\n data.epsg = this.epsg;\r\n data.datumId = this.datumId;\r\n if (this.datum)\r\n data.datum = this.datum.toJSON();\r\n\r\n data.ellipsoidId = this.ellipsoidId;\r\n if (this.ellipsoid)\r\n data.ellipsoid = this.ellipsoid.toJSON();\r\n\r\n data.unit = this.unit;\r\n if (this.projection)\r\n data.projection = this.projection.toJSON();\r\n\r\n if (this.extent)\r\n data.extent = this.extent.toJSON();\r\n\r\n return data;\r\n }\r\n\r\n /** Compares two horizontal CRS. It is not an equivalence test as descriptive properties are also compared\r\n * but number compares are applied a minuscule tolerance.\r\n * @public */\r\n public equals(other: HorizontalCRS): boolean {\r\n if (this.id !== other.id ||\r\n this.description !== other.description ||\r\n this.source !== other.source ||\r\n this.deprecated !== other.deprecated ||\r\n this.epsg !== other.epsg ||\r\n this.datumId !== other.datumId ||\r\n this.ellipsoidId !== other.ellipsoidId ||\r\n this.unit !== other.unit)\r\n return false;\r\n\r\n if ((this.datum === undefined) !== (other.datum === undefined))\r\n return false;\r\n\r\n if (this.datum && !this.datum.equals(other.datum!))\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.projection === undefined) !== (other.projection === undefined))\r\n return false;\r\n\r\n if (this.projection && !this.projection.equals(other.projection!))\r\n return false;\r\n\r\n if ((this.extent === undefined) !== (other.extent === undefined))\r\n return false;\r\n\r\n if (this.extent && !this.extent.equals(other.extent!))\r\n return false;\r\n\r\n return true;\r\n }\r\n}\r\n\r\n/** Vertical Geographic Coordinate reference System definition\r\n * @public\r\n */\r\nexport interface VerticalCRSProps {\r\n /** Vertical CRS Key name. */\r\n id: \"GEOID\" | \"ELLIPSOID\" | \"NGVD29\" | \"NAVD88\";\r\n}\r\n\r\n/** Vertical Coordinate reference System implementation.\r\n * The VerticalCRS contains currently a single identifier property of string type. Although\r\n * we currently only support four distinct key values \"GEOID\", \"ELLIPSOID\", \"NAVD88\" and \"NGVD29\"\r\n * we expect to support a broader set in the future including, eventually, user defined vertical CRS\r\n * which will require additional parameters to be added.\r\n * @public\r\n*/\r\nexport class VerticalCRS implements VerticalCRSProps {\r\n /** Vertical CRS Key name. The only supported values are currently \"GEOID\", \"ELLIPSOID\", \"NAVD88\" and \"NGVD29\". The default is ELLIPSOID */\r\n public readonly id: \"GEOID\" | \"ELLIPSOID\" | \"NGVD29\" | \"NAVD88\";\r\n\r\n public constructor(data?: VerticalCRSProps) {\r\n this.id = \"ELLIPSOID\";\r\n if (data)\r\n this.id = data.id;\r\n }\r\n\r\n /** Creates a Vertical CRS from JSON representation.\r\n * @public */\r\n public static fromJSON(data: VerticalCRSProps): VerticalCRS {\r\n return new VerticalCRS(data);\r\n }\r\n\r\n /** Creates a JSON from the Vertical CRS definition\r\n * @public */\r\n public toJSON(): VerticalCRSProps {\r\n return { id: this.id };\r\n }\r\n\r\n /** Compares two vertical CRS.\r\n * @public */\r\n public equals(other: VerticalCRS): boolean {\r\n return (this.id === other.id);\r\n }\r\n}\r\n\r\n/** Geographic Coordinate Reference System definition that includes both the horizontal and vertical definitions\r\n * @public\r\n */\r\nexport interface GeographicCRSProps {\r\n /** The horizontal portion of the geographic coordinate reference system. */\r\n horizontalCRS?: HorizontalCRSProps;\r\n /** The vertical portion of the geographic coordinate reference system. */\r\n verticalCRS?: VerticalCRSProps;\r\n /** The optional additional transform the geographic coordinate reference system. */\r\n additionalTransform?: AdditionalTransformProps;\r\n}\r\n\r\n/** Geographic Coordinate Reference System implementation. This is the class that indicates the definition of a Geographic\r\n * coordinate reference system comprised of two components: Horizontal and Vertical.\r\n * The vertical component (see [[VerticalCRS]]) is the simplest being formed of a simple identifier as a string.\r\n * The horizontal component contains a list of identification and documentation properties as well as\r\n * defining details possibly including the projection with method and parameters, the definition of the datum, ellipsoid, extent and so on.\r\n * The principle of describing a Geographic CRS is that the definition may be incomplete. The whole set of classes related to geographic\r\n * coordinate reference system classes ([[GeodeticEllipsoid]], [[GeodeticDatum]], [[Projection]], [[GeodeticTransform]], ...) are designed\r\n * so that they can be parsed from incomplete JSON fragments, or produce incomplete JSON fragments such as would be\r\n * generated from a request to a REST API to a server when select OData clauses are used.\r\n * Often GeographicCRS would knowingly be created incomplete but with sufficient information to perform conversion from some\r\n * reprojection engine (the present set of classes do not provide any GeographicCRS conversion).\r\n * For example the following definitions are quite sufficient to request conversion to or from by a reprojection engine:\r\n * { horizontalCRS: {id: \"LL84\"}, verticalCRS: {id:\"GEOID\"}\r\n * or\r\n * { horizontalCRS: {datumId: \"WGS84\", projection: {method: \"None\"}}, verticalCRS: \"ELLIPSOID\"}\r\n * The reprojection engine will use the engine internal dictionary to obtain the details if it can.\r\n * Some definitions will originate from other sources (a parsed WKT for example) and the reprojection engine will require\r\n * all mathematical and operational details to perform any conversion (descriptive information are ignored in the conversion process).\r\n * @note In the absence of the verticalCRS property then ELLIPSOID (Geodetic elevation) will be assumed by reprojection engines.\r\n * @note see important detailed explanation in the [[HorizontalCRS]] documentation.\r\n * @note Earth Centered, Earth Fixed coordinate system (ECEF) is a full 3D cartesian system that unambiguously\r\n * expressed coordinates relative to the Earth Center. Since there is no horizontal portion independent from\r\n * the vertical portion this system cannot be represented by a GeographicCRS and remains a separate concept.\r\n * @public\r\n*/\r\nexport class GeographicCRS implements GeographicCRSProps {\r\n /** The horizontal portion of the geographic coordinate reference system. */\r\n public readonly horizontalCRS?: HorizontalCRS;\r\n /** The vertical portion of the geographic coordinate reference system. */\r\n public readonly verticalCRS?: VerticalCRS;\r\n /** The optional additional transform the geographic coordinate reference system. */\r\n public readonly additionalTransform?: AdditionalTransform;\r\n\r\n public constructor(data?: GeographicCRSProps) {\r\n if (data) {\r\n this.horizontalCRS = data.horizontalCRS ? HorizontalCRS.fromJSON(data.horizontalCRS) : undefined;\r\n this.verticalCRS = data.verticalCRS ? VerticalCRS.fromJSON(data.verticalCRS) : undefined;\r\n this.additionalTransform = data.additionalTransform ? AdditionalTransform.fromJSON(data.additionalTransform) : undefined;\r\n }\r\n }\r\n\r\n /** Creates a Geographic CRS from JSON representation.\r\n * @public */\r\n public static fromJSON(data: GeographicCRSProps): GeographicCRS {\r\n return new GeographicCRS(data);\r\n }\r\n\r\n /** Creates a JSON from the Geographic CRS definition\r\n * @public */\r\n public toJSON(): GeographicCRSProps {\r\n const data: GeographicCRSProps = {};\r\n if (this.horizontalCRS)\r\n data.horizontalCRS = this.horizontalCRS.toJSON();\r\n\r\n if (this.verticalCRS)\r\n data.verticalCRS = this.verticalCRS.toJSON();\r\n\r\n if (this.additionalTransform)\r\n data.additionalTransform = this.additionalTransform.toJSON();\r\n\r\n return data;\r\n }\r\n\r\n /** Compares two Geographic CRS. It is a strict compare operation not an equivalence test though\r\n * number compares are applied a minuscule tolerance.\r\n * It takes into account descriptive properties not only mathematical definition properties.\r\n * @public\r\n */\r\n public equals(other: GeographicCRS): boolean {\r\n if ((this.horizontalCRS === undefined) !== (other.horizontalCRS === undefined))\r\n return false;\r\n\r\n if (this.horizontalCRS && !this.horizontalCRS.equals(other.horizontalCRS!))\r\n return false;\r\n\r\n if ((this.verticalCRS === undefined) !== (other.verticalCRS === undefined))\r\n return false;\r\n\r\n if (this.verticalCRS && !this.verticalCRS.equals(other.verticalCRS!))\r\n return false;\r\n\r\n if ((this.additionalTransform === undefined) !== (other.additionalTransform === undefined))\r\n return false;\r\n\r\n if (this.additionalTransform && !this.additionalTransform.equals(other.additionalTransform!))\r\n return false;\r\n\r\n return true;\r\n }\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 */\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 */\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 */\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 */\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 */\nexport type GridFileFormat =\n \"NONE\" |\n \"NTv1\" |\n \"NTv2\" |\n \"NADCON\" |\n \"FRENCH\" |\n \"JAPAN\" |\n \"ATS77\" |\n \"GEOCN\";\n\n/** type to indicate the grid file application direction.\n * @public\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 */\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 */\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 */\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 /** 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 /** 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.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.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.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. 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 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}\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\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 }\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 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 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 */\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 */\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 */\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 */\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 */\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\r\n/** type to indicate the grid file application direction.\r\n * @public\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 */\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 */\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 */\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 /** 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 /** 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.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.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.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. 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 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}\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\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 }\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 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 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,wDAAgD;AA4BhD;;;;;;;;;;;;GAYG;AACH,MAAa,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,MAAA,IAAI,CAAC,UAAU,mCAAI,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,wBAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EAAE,wBAAQ,CAAC,mBAAmB,CAAC;YAC3G,wBAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,wBAAQ,CAAC,mBAAmB,CAAC,CAAC;IACtG,CAAC;CACF;AAjED,8CAiEC","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 */\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,wDAAgD;AA4BhD;;;;;;;;;;;;GAYG;AACH,MAAa,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,MAAA,IAAI,CAAC,UAAU,mCAAI,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,wBAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EAAE,wBAAQ,CAAC,mBAAmB,CAAC;YAC3G,wBAAQ,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,wBAAQ,CAAC,mBAAmB,CAAC,CAAC;IACtG,CAAC;CACF;AAjED,8CAiEC","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 */\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":"LineStyle.js","sourceRoot":"","sources":["../../../src/geometry/LineStyle.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAGH,wDAA4G;AAE5G,cAAc;AACd,IAAiB,SAAS,CAoLzB;AApLD,WAAiB,SAAS;IAkCxB,2DAA2D;IAC3D,MAAa,QAAQ;QAcnB,yCAAyC;QACzC,YAAY,KAAoB;YAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YACjC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;YACzC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,wBAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YACzE,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,kCAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC3F,CAAC;QAED,0CAA0C;QACnC,KAAK;YACV,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC;QAED,qDAAqD;QAC9C,MAAM,CAAC,KAAe;YAC3B,IAAI,IAAI,KAAK,KAAK,EAAI,eAAe;gBACnC,OAAO,IAAI,CAAC;YAEd,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK;gBAC5B,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS;gBAClC,KAAK,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ;gBAChC,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU;gBACpC,KAAK,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ;gBAChC,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS;gBAClC,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU;gBACpC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW;gBACtC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW;gBACtC,KAAK,CAAC,aAAa,KAAK,IAAI,CAAC,aAAa;gBAC1C,OAAO,KAAK,CAAC;YAEf,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC;gBAC9D,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,MAAO,CAAC;gBAC1D,OAAO,KAAK,CAAC;YAEf,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC;gBAClE,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,QAAS,CAAC;gBAChE,OAAO,KAAK,CAAC;YAEf,OAAO,IAAI,CAAC;QACd,CAAC;QAEM,cAAc,CAAC,SAAoB;YACxC,IAAI,SAAS,CAAC,UAAU;gBACtB,OAAO,IAAI,CAAC;YACd,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC1D,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;gBAC3C,IAAI,UAAU;oBACZ,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;;oBAEhC,OAAO,KAAK,CAAC;aAChB;YACD,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;gBACnF,MAAM,MAAM,GAAG,IAAI,wBAAQ,EAAE,CAAC;gBAC9B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,uBAAuB,CAAC,MAAM,CAAC;oBACtD,OAAO,KAAK,CAAC;gBACf,MAAM,WAAW,GAAG,kCAAkB,CAAC,kBAAkB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;gBAC/E,IAAI,SAAS,KAAK,WAAW;oBAC3B,OAAO,KAAK,CAAC;gBACf,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;aACpC;YAED,IAAI,WAAW,CAAC;YAChB,MAAM,WAAW,GAAG,wBAAQ,CAAC,MAAM,EAAE,CAAC;YACtC,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;YACrC,WAAW,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAC;YAE9C,iFAAiF;YACjF,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG;gBACzE,WAAW,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;;gBAEpE,WAAW,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YAEtE,IAAI,GAAG,KAAK,WAAW;gBACrB,OAAO,IAAI,CAAC;YAEd,IAAI,IAAI,CAAC,KAAK;gBACZ,IAAI,CAAC,KAAK,IAAI,WAAW,CAAC;YAE5B,IAAI,IAAI,CAAC,aAAa;gBACpB,OAAO,IAAI,CAAC;YAEd,IAAI,IAAI,CAAC,UAAU;gBACjB,IAAI,CAAC,UAAU,IAAI,WAAW,CAAC;YAEjC,IAAI,IAAI,CAAC,QAAQ;gBACf,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;YAE/B,OAAO,IAAI,CAAC;QACd,CAAC;KACF;IAnHY,kBAAQ,WAmHpB,CAAA;IAED,6EAA6E;IAC7E,MAAa,IAAI;QAIf,sCAAsC;QACtC,YAAY,OAAmB,EAAE,QAAmB;YAClD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,0CAA0C;QACnC,KAAK;YACV,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QACnF,CAAC;QAEM,MAAM,CAAC,KAAW;YACvB,IAAI,IAAI,KAAK,KAAK;gBAChB,OAAO,IAAI,CAAC;YACd,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO;gBAChC,OAAO,KAAK,CAAC;YACf,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC;gBAClE,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAS,CAAC;gBACzD,OAAO,KAAK,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;KACF;IA1BY,cAAI,OA0BhB,CAAA;AACH,CAAC,EApLgB,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAoLzB","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 Symbology\n */\n\nimport { Id64String } from \"@itwin/core-bentley\";\nimport { Transform, Vector3d, XYZProps, YawPitchRollAngles, YawPitchRollProps } from \"@itwin/core-geometry\";\n\n/** @public */\nexport namespace LineStyle {\n\n /** Modify the line style appearance without changing the line style definition.\n * Applies to the style previously established by a [[GeometryAppearanceProps]] or current [[SubCategoryAppearance]].\n * Most of the modifiers affect the line style stroke pattern, with the orientation and scales being the exception.\n * @see [[GeometryStreamEntryProps]]\n */\n export interface ModifierProps {\n /** Optional scale to apply to all length values, 1.0 if undefined */\n scale?: number;\n /** Optional scale to apply to scalable dashes, 1.0 if undefined */\n dashScale?: number;\n /** Optional scale to apply to scalable gaps, 1.0 if undefined */\n gapScale?: number;\n /** Optional start width in meters to apply to dashes, no width if undefined */\n startWidth?: number;\n /** Optional end width in meters to apply to dashes, same as startWidth if undefined */\n endWidth?: number;\n /** Optional shift by distance in meters, 0.0 if undefined */\n distPhase?: number;\n /** Optional shift by fraction, 0.0 if undefined */\n fractPhase?: number;\n /** Optional flag to center stroke pattern and stretch ends, false if undefined */\n centerPhase?: boolean;\n /** Optional flag to enable or disable single segment mode */\n segmentMode?: boolean;\n /** Optional flag that denotes startWidth and endWidth represent physical widths that should not be affected by scale, false if undefined */\n physicalWidth?: boolean;\n /** Optional up vector for style (applicable to 3d only), 0.0,0.0,1.0 if undefined */\n normal?: XYZProps;\n /** Optional orientation for style (applicable to 3d only), 0.0,0.0,0.0 if undefined */\n rotation?: YawPitchRollProps;\n }\n\n /** Optional modifiers to override line style definition */\n export class Modifier implements ModifierProps {\n public scale?: number;\n public dashScale?: number;\n public gapScale?: number;\n public startWidth?: number;\n public endWidth?: number;\n public distPhase?: number;\n public fractPhase?: number;\n public centerPhase?: boolean;\n public segmentMode?: boolean;\n public physicalWidth?: boolean;\n public normal?: Vector3d;\n public rotation?: YawPitchRollAngles;\n\n /** constructor for LineStyle.Modifier */\n constructor(props: ModifierProps) {\n this.scale = props.scale;\n this.dashScale = props.dashScale;\n this.gapScale = props.gapScale;\n this.startWidth = props.startWidth;\n this.endWidth = props.endWidth;\n this.distPhase = props.distPhase;\n this.fractPhase = props.fractPhase;\n this.centerPhase = props.centerPhase;\n this.segmentMode = props.segmentMode;\n this.physicalWidth = props.physicalWidth;\n this.normal = props.normal ? Vector3d.fromJSON(props.normal) : undefined;\n this.rotation = props.rotation ? YawPitchRollAngles.fromJSON(props.rotation) : undefined;\n }\n\n /** Returns a deep copy of this object. */\n public clone() {\n return new Modifier(this);\n }\n\n /** Compare two LineStyle.Modifier for equivalence */\n public equals(other: Modifier): boolean {\n if (this === other) // same pointer\n return true;\n\n if (other.scale !== this.scale ||\n other.dashScale !== this.dashScale ||\n other.gapScale !== this.gapScale ||\n other.startWidth !== this.startWidth ||\n other.endWidth !== this.endWidth ||\n other.distPhase !== this.distPhase ||\n other.fractPhase !== this.fractPhase ||\n other.centerPhase !== this.centerPhase ||\n other.segmentMode !== this.segmentMode ||\n other.physicalWidth !== this.physicalWidth)\n return false;\n\n if ((this.normal === undefined) !== (other.normal === undefined))\n return false;\n if (this.normal && !this.normal.isAlmostEqual(other.normal!))\n return false;\n\n if ((this.rotation === undefined) !== (other.rotation === undefined))\n return false;\n if (this.rotation && !this.rotation.isAlmostEqual(other.rotation!))\n return false;\n\n return true;\n }\n\n public applyTransform(transform: Transform): boolean {\n if (transform.isIdentity)\n return true;\n if (this.normal) {\n transform.matrix.multiplyVector(this.normal, this.normal);\n const normalized = this.normal.normalize();\n if (normalized)\n this.normal.setFrom(normalized);\n else\n return false;\n }\n if (this.rotation) {\n const newTransform = this.rotation.toMatrix3d().multiplyMatrixTransform(transform);\n const scales = new Vector3d();\n if (!newTransform.matrix.normalizeColumnsInPlace(scales))\n return false;\n const newRotation = YawPitchRollAngles.createFromMatrix3d(newTransform.matrix);\n if (undefined === newRotation)\n return false;\n this.rotation.setFrom(newRotation);\n }\n\n let scaleFactor;\n const scaleVector = Vector3d.create();\n const scaleMatrix = transform.matrix;\n scaleMatrix.normalizeRowsInPlace(scaleVector);\n\n // Check for flatten transform, dividing scaleVector by 3 gives wrong scaleFactor\n if (scaleVector.x !== 0.0 && scaleVector.y !== 0.0 && scaleVector.z !== 0.0)\n scaleFactor = (scaleVector.x + scaleVector.y + scaleVector.z) / 3.0;\n else\n scaleFactor = (scaleVector.x + scaleVector.y + scaleVector.z) / 2.0;\n\n if (1.0 === scaleFactor)\n return true;\n\n if (this.scale)\n this.scale *= scaleFactor;\n\n if (this.physicalWidth)\n return true;\n\n if (this.startWidth)\n this.startWidth *= scaleFactor;\n\n if (this.endWidth)\n this.endWidth *= scaleFactor;\n\n return true;\n }\n }\n\n /** Line style id and optional modifiers to override line style definition */\n export class Info {\n public styleId: Id64String;\n public styleMod?: Modifier; // Optional modifiers to override line style definition\n\n /** Creates a LineStyle.Info object */\n constructor(styleId: Id64String, styleMod?: Modifier) {\n this.styleId = styleId;\n this.styleMod = styleMod;\n }\n\n /** Returns a deep copy of this object. */\n public clone(): Info {\n return new Info(this.styleId, this.styleMod ? this.styleMod.clone() : undefined);\n }\n\n public equals(other: Info): boolean {\n if (this === other)\n return true;\n if (this.styleId !== other.styleId)\n return false;\n if ((this.styleMod === undefined) !== (other.styleMod === undefined))\n return false;\n if (this.styleMod && !this.styleMod.equals(other.styleMod!))\n return false;\n return true;\n }\n }\n}\n"]}
1
+ {"version":3,"file":"LineStyle.js","sourceRoot":"","sources":["../../../src/geometry/LineStyle.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;AAC/F;;GAEG;;;AAGH,wDAA4G;AAE5G,cAAc;AACd,IAAiB,SAAS,CAoLzB;AApLD,WAAiB,SAAS;IAkCxB,2DAA2D;IAC3D,MAAa,QAAQ;QAcnB,yCAAyC;QACzC,YAAY,KAAoB;YAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YACjC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YACrC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;YACzC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,wBAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YACzE,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,kCAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC3F,CAAC;QAED,0CAA0C;QACnC,KAAK;YACV,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC;QAED,qDAAqD;QAC9C,MAAM,CAAC,KAAe;YAC3B,IAAI,IAAI,KAAK,KAAK,EAAI,eAAe;gBACnC,OAAO,IAAI,CAAC;YAEd,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK;gBAC5B,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS;gBAClC,KAAK,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ;gBAChC,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU;gBACpC,KAAK,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ;gBAChC,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS;gBAClC,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU;gBACpC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW;gBACtC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW;gBACtC,KAAK,CAAC,aAAa,KAAK,IAAI,CAAC,aAAa;gBAC1C,OAAO,KAAK,CAAC;YAEf,IAAI,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC;gBAC9D,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,MAAO,CAAC;gBAC1D,OAAO,KAAK,CAAC;YAEf,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC;gBAClE,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,QAAS,CAAC;gBAChE,OAAO,KAAK,CAAC;YAEf,OAAO,IAAI,CAAC;QACd,CAAC;QAEM,cAAc,CAAC,SAAoB;YACxC,IAAI,SAAS,CAAC,UAAU;gBACtB,OAAO,IAAI,CAAC;YACd,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC1D,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;gBAC3C,IAAI,UAAU;oBACZ,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;;oBAEhC,OAAO,KAAK,CAAC;aAChB;YACD,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;gBACnF,MAAM,MAAM,GAAG,IAAI,wBAAQ,EAAE,CAAC;gBAC9B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,uBAAuB,CAAC,MAAM,CAAC;oBACtD,OAAO,KAAK,CAAC;gBACf,MAAM,WAAW,GAAG,kCAAkB,CAAC,kBAAkB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;gBAC/E,IAAI,SAAS,KAAK,WAAW;oBAC3B,OAAO,KAAK,CAAC;gBACf,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;aACpC;YAED,IAAI,WAAW,CAAC;YAChB,MAAM,WAAW,GAAG,wBAAQ,CAAC,MAAM,EAAE,CAAC;YACtC,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;YACrC,WAAW,CAAC,oBAAoB,CAAC,WAAW,CAAC,CAAC;YAE9C,iFAAiF;YACjF,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG,IAAI,WAAW,CAAC,CAAC,KAAK,GAAG;gBACzE,WAAW,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;;gBAEpE,WAAW,GAAG,CAAC,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YAEtE,IAAI,GAAG,KAAK,WAAW;gBACrB,OAAO,IAAI,CAAC;YAEd,IAAI,IAAI,CAAC,KAAK;gBACZ,IAAI,CAAC,KAAK,IAAI,WAAW,CAAC;YAE5B,IAAI,IAAI,CAAC,aAAa;gBACpB,OAAO,IAAI,CAAC;YAEd,IAAI,IAAI,CAAC,UAAU;gBACjB,IAAI,CAAC,UAAU,IAAI,WAAW,CAAC;YAEjC,IAAI,IAAI,CAAC,QAAQ;gBACf,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;YAE/B,OAAO,IAAI,CAAC;QACd,CAAC;KACF;IAnHY,kBAAQ,WAmHpB,CAAA;IAED,6EAA6E;IAC7E,MAAa,IAAI;QAIf,sCAAsC;QACtC,YAAY,OAAmB,EAAE,QAAmB;YAClD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC3B,CAAC;QAED,0CAA0C;QACnC,KAAK;YACV,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QACnF,CAAC;QAEM,MAAM,CAAC,KAAW;YACvB,IAAI,IAAI,KAAK,KAAK;gBAChB,OAAO,IAAI,CAAC;YACd,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO;gBAChC,OAAO,KAAK,CAAC;YACf,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC;gBAClE,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAS,CAAC;gBACzD,OAAO,KAAK,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;KACF;IA1BY,cAAI,OA0BhB,CAAA;AACH,CAAC,EApLgB,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAoLzB","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 Symbology\r\n */\r\n\r\nimport { Id64String } from \"@itwin/core-bentley\";\r\nimport { Transform, Vector3d, XYZProps, YawPitchRollAngles, YawPitchRollProps } from \"@itwin/core-geometry\";\r\n\r\n/** @public */\r\nexport namespace LineStyle {\r\n\r\n /** Modify the line style appearance without changing the line style definition.\r\n * Applies to the style previously established by a [[GeometryAppearanceProps]] or current [[SubCategoryAppearance]].\r\n * Most of the modifiers affect the line style stroke pattern, with the orientation and scales being the exception.\r\n * @see [[GeometryStreamEntryProps]]\r\n */\r\n export interface ModifierProps {\r\n /** Optional scale to apply to all length values, 1.0 if undefined */\r\n scale?: number;\r\n /** Optional scale to apply to scalable dashes, 1.0 if undefined */\r\n dashScale?: number;\r\n /** Optional scale to apply to scalable gaps, 1.0 if undefined */\r\n gapScale?: number;\r\n /** Optional start width in meters to apply to dashes, no width if undefined */\r\n startWidth?: number;\r\n /** Optional end width in meters to apply to dashes, same as startWidth if undefined */\r\n endWidth?: number;\r\n /** Optional shift by distance in meters, 0.0 if undefined */\r\n distPhase?: number;\r\n /** Optional shift by fraction, 0.0 if undefined */\r\n fractPhase?: number;\r\n /** Optional flag to center stroke pattern and stretch ends, false if undefined */\r\n centerPhase?: boolean;\r\n /** Optional flag to enable or disable single segment mode */\r\n segmentMode?: boolean;\r\n /** Optional flag that denotes startWidth and endWidth represent physical widths that should not be affected by scale, false if undefined */\r\n physicalWidth?: boolean;\r\n /** Optional up vector for style (applicable to 3d only), 0.0,0.0,1.0 if undefined */\r\n normal?: XYZProps;\r\n /** Optional orientation for style (applicable to 3d only), 0.0,0.0,0.0 if undefined */\r\n rotation?: YawPitchRollProps;\r\n }\r\n\r\n /** Optional modifiers to override line style definition */\r\n export class Modifier implements ModifierProps {\r\n public scale?: number;\r\n public dashScale?: number;\r\n public gapScale?: number;\r\n public startWidth?: number;\r\n public endWidth?: number;\r\n public distPhase?: number;\r\n public fractPhase?: number;\r\n public centerPhase?: boolean;\r\n public segmentMode?: boolean;\r\n public physicalWidth?: boolean;\r\n public normal?: Vector3d;\r\n public rotation?: YawPitchRollAngles;\r\n\r\n /** constructor for LineStyle.Modifier */\r\n constructor(props: ModifierProps) {\r\n this.scale = props.scale;\r\n this.dashScale = props.dashScale;\r\n this.gapScale = props.gapScale;\r\n this.startWidth = props.startWidth;\r\n this.endWidth = props.endWidth;\r\n this.distPhase = props.distPhase;\r\n this.fractPhase = props.fractPhase;\r\n this.centerPhase = props.centerPhase;\r\n this.segmentMode = props.segmentMode;\r\n this.physicalWidth = props.physicalWidth;\r\n this.normal = props.normal ? Vector3d.fromJSON(props.normal) : undefined;\r\n this.rotation = props.rotation ? YawPitchRollAngles.fromJSON(props.rotation) : undefined;\r\n }\r\n\r\n /** Returns a deep copy of this object. */\r\n public clone() {\r\n return new Modifier(this);\r\n }\r\n\r\n /** Compare two LineStyle.Modifier for equivalence */\r\n public equals(other: Modifier): boolean {\r\n if (this === other) // same pointer\r\n return true;\r\n\r\n if (other.scale !== this.scale ||\r\n other.dashScale !== this.dashScale ||\r\n other.gapScale !== this.gapScale ||\r\n other.startWidth !== this.startWidth ||\r\n other.endWidth !== this.endWidth ||\r\n other.distPhase !== this.distPhase ||\r\n other.fractPhase !== this.fractPhase ||\r\n other.centerPhase !== this.centerPhase ||\r\n other.segmentMode !== this.segmentMode ||\r\n other.physicalWidth !== this.physicalWidth)\r\n return false;\r\n\r\n if ((this.normal === undefined) !== (other.normal === undefined))\r\n return false;\r\n if (this.normal && !this.normal.isAlmostEqual(other.normal!))\r\n return false;\r\n\r\n if ((this.rotation === undefined) !== (other.rotation === undefined))\r\n return false;\r\n if (this.rotation && !this.rotation.isAlmostEqual(other.rotation!))\r\n return false;\r\n\r\n return true;\r\n }\r\n\r\n public applyTransform(transform: Transform): boolean {\r\n if (transform.isIdentity)\r\n return true;\r\n if (this.normal) {\r\n transform.matrix.multiplyVector(this.normal, this.normal);\r\n const normalized = this.normal.normalize();\r\n if (normalized)\r\n this.normal.setFrom(normalized);\r\n else\r\n return false;\r\n }\r\n if (this.rotation) {\r\n const newTransform = this.rotation.toMatrix3d().multiplyMatrixTransform(transform);\r\n const scales = new Vector3d();\r\n if (!newTransform.matrix.normalizeColumnsInPlace(scales))\r\n return false;\r\n const newRotation = YawPitchRollAngles.createFromMatrix3d(newTransform.matrix);\r\n if (undefined === newRotation)\r\n return false;\r\n this.rotation.setFrom(newRotation);\r\n }\r\n\r\n let scaleFactor;\r\n const scaleVector = Vector3d.create();\r\n const scaleMatrix = transform.matrix;\r\n scaleMatrix.normalizeRowsInPlace(scaleVector);\r\n\r\n // Check for flatten transform, dividing scaleVector by 3 gives wrong scaleFactor\r\n if (scaleVector.x !== 0.0 && scaleVector.y !== 0.0 && scaleVector.z !== 0.0)\r\n scaleFactor = (scaleVector.x + scaleVector.y + scaleVector.z) / 3.0;\r\n else\r\n scaleFactor = (scaleVector.x + scaleVector.y + scaleVector.z) / 2.0;\r\n\r\n if (1.0 === scaleFactor)\r\n return true;\r\n\r\n if (this.scale)\r\n this.scale *= scaleFactor;\r\n\r\n if (this.physicalWidth)\r\n return true;\r\n\r\n if (this.startWidth)\r\n this.startWidth *= scaleFactor;\r\n\r\n if (this.endWidth)\r\n this.endWidth *= scaleFactor;\r\n\r\n return true;\r\n }\r\n }\r\n\r\n /** Line style id and optional modifiers to override line style definition */\r\n export class Info {\r\n public styleId: Id64String;\r\n public styleMod?: Modifier; // Optional modifiers to override line style definition\r\n\r\n /** Creates a LineStyle.Info object */\r\n constructor(styleId: Id64String, styleMod?: Modifier) {\r\n this.styleId = styleId;\r\n this.styleMod = styleMod;\r\n }\r\n\r\n /** Returns a deep copy of this object. */\r\n public clone(): Info {\r\n return new Info(this.styleId, this.styleMod ? this.styleMod.clone() : undefined);\r\n }\r\n\r\n public equals(other: Info): boolean {\r\n if (this === other)\r\n return true;\r\n if (this.styleId !== other.styleId)\r\n return false;\r\n if ((this.styleMod === undefined) !== (other.styleMod === undefined))\r\n return false;\r\n if (this.styleMod && !this.styleMod.equals(other.styleMod!))\r\n return false;\r\n return true;\r\n }\r\n }\r\n}\r\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Projection.js","sourceRoot":"","sources":["../../../src/geometry/Projection.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 Albers, Krovak, OSTN, Cassini, Grinten, Mollweide, Eckert, Homolosine, Carree, Winkel, Tripel, Polyconic\n\nimport { Geometry } from \"@itwin/core-geometry\";\n\n/** This enum contains the list of all projection methods that can be represented as part of the HorizontalCRS\n * class. The None method indicates there is no projection and thus the CRS is longitude/latitude based\n * with units as degrees.\n * All other projection indicated a projected CRS.\n * @public\n */\nexport type ProjectionMethod =\n \"None\" |\n \"TransverseMercator\" |\n \"SouthOrientedTransverseMercator\" |\n \"TransverseMercatorWisconsin\" |\n \"TransverseMercatorMinnesota\" |\n \"TransverseMercatorAffine\" |\n \"MercatorStandardParallel\" |\n \"Mercator\" |\n \"UniversalTransverseMercator\" |\n \"LambertConformalConicTwoParallels\" |\n \"LambertConformalConicBelgium\" |\n \"LambertConformalConicAffine\" |\n \"LambertConformalConicWisconsin\" |\n \"LambertConformalConicMinnesota\" |\n \"LambertConformalConicMichigan\" |\n \"LambertConformalConicOneParallel\" |\n \"AlbersEqualArea\" |\n \"NewZealandNationalGrid\" |\n \"ObliqueMercator1\" |\n \"ObliqueMercator2\" |\n \"TransverseMercatorOSTN97\" |\n \"TransverseMercatorOSTN02\" |\n \"TransverseMercatorOSTN15\" |\n \"Krovak\" |\n \"KrovakModified\" |\n \"ObliqueCylindricalSwiss\" |\n \"TransverseMercatorDenmarkSystem34\" |\n \"TransverseMercatorDenmarkSystem3499\" |\n \"TransverseMercatorDenmarkSystem3401\" |\n \"Cassini\" |\n \"Sinusoidal\" |\n \"VanDerGrinten\" |\n \"Bonne\" |\n \"Mollweide\" |\n \"EckertIV\" |\n \"EckertVI\" |\n \"GoodeHomolosine\" |\n \"Robinson\" |\n \"PlateCarree\" |\n \"MillerCylindrical\" |\n \"WinkelTripel\" |\n \"AzimuthalEqualArea\" |\n \"ObliqueStereographic\" |\n \"RectifiedSkewOrthomorphicCentered\" |\n \"RectifiedSkewOrthomorphicOrigin\" |\n \"ObliqueCylindricalHungary\" |\n \"Orthographic\" |\n \"AmericanPolyconic\" |\n \"LambertEquidistantAzimuthal\" |\n \"ObliqueMercatorMinnesota\";\n\n/** The equations are:\n * X1 = a1*X + a2*Y + TranslationX\n * Y1 = b1*X + b2*Y + translationY\n * An affine representing no transformation will have: a1 = 1.0, a2 = 0.0, b1 = 0.0, b2 = 1.0.\n * @public\n */\nexport interface AffineTransformProps {\n /** The X post translation */\n translationX: number;\n /** The Y post-translation */\n translationY: number;\n /** A1 value as defined in global comment. */\n a1: number;\n /** B1 value as defined in global comment. */\n b1: number;\n /** A2 value as defined in global comment. */\n a2: number;\n /** B2 value as defined in global comment. */\n b2: number;\n}\n\n/** The equations are:\n * X1 = a1*X + a2*Y + TranslationX\n * Y1 = b1*X + b2*Y + translationY\n * An affine representing no transformation will have: a1 = 1.0, a2 = 0.0, b1 = 0.0, b2 = 1.0.\n * @public\n */\nexport class AffineTransform implements AffineTransformProps {\n /** The X post translation */\n public readonly translationX!: number;\n /** The Y post-translation */\n public readonly translationY!: number;\n /** A1 value as defined in global comment. */\n public readonly a1!: number;\n /** B1 value as defined in global comment. */\n public readonly b1!: number;\n /** A2 value as defined in global comment. */\n public readonly a2!: number;\n /** B2 value as defined in global comment. */\n public readonly b2!: number;\n\n constructor(data?: AffineTransformProps) {\n if (data) {\n this.translationX = data.translationX;\n this.translationY = data.translationY;\n this.a1 = data.a1;\n this.b1 = data.b1;\n this.a2 = data.a2;\n this.b2 = data.b2;\n }\n }\n\n /** Creates an Affine Transform from JSON representation.\n * @public */\n public static fromJSON(data: AffineTransformProps): AffineTransform {\n return new AffineTransform(data);\n }\n\n /** Creates a JSON from the Affine Transform definition\n * @public */\n public toJSON(): AffineTransformProps {\n return { translationX: this.translationX, a1: this.a1, a2: this.a2, translationY: this.translationY, b1: this.b1, b2: this.b2 };\n }\n\n /** Compares two Affine Transforms. It applies a minuscule tolerance for number compares\n * @public */\n public equals(other: AffineTransform): boolean {\n return (Math.abs(this.translationX - other.translationX) < Geometry.smallMetricDistance &&\n Math.abs(this.translationY - other.translationY) < Geometry.smallMetricDistance &&\n Math.abs(this.a1 - other.a1) < Geometry.smallFraction &&\n Math.abs(this.b1 - other.b1) < Geometry.smallFraction &&\n Math.abs(this.a2 - other.a2) < Geometry.smallFraction &&\n Math.abs(this.b2 - other.b2) < Geometry.smallFraction);\n }\n}\n\n/** Type used in the definition of UTM Zoning projection. This projection only requires a zone number and\n * the hemisphere North or South.\n * @public\n */\nexport type HemisphereEnum = \"South\" | \"North\";\n\n/** The type to define the three zones of the Danish System 34 projections.\n * @public\n */\nexport type DanishSystem34Region = \"Jylland\" | \"Sjaelland\" | \"Bornholm\";\n\n/** This class encapsulates the projection of the CRS. The projection relies on a projection method\n * and a set of projection parameters specific to projection method selected.\n * @public\n */\nexport interface ProjectionProps {\n /** The projection method. */\n method: ProjectionMethod;\n /** The False Easting of the projection. */\n falseEasting?: number;\n /** The False Northing of the projection. */\n falseNorthing?: number;\n /** The Central Meridian. */\n centralMeridian?: number;\n /** The latitude of origin of the projection. */\n latitudeOfOrigin?: number;\n /** Longitude of origin of the projection. */\n longitudeOfOrigin?: number;\n /** The scale reduction factor applied at origin. The nature of the projection has a\n * inherent scale factor applied that gradually varies outward from the projection origin.\n * The scale factor at origin enables to level the inherent scale factor over an use extent.\n * For the michigan variation of the Lambert Conformal Conic projection it\n * can be used instead or in addition to Standard Parallel to define\n * a scale factor.\n */\n scaleFactor?: number;\n /** The elevation of the origin of the projection above the geoid. This value\n * allows compensation for the scale factor related to elevation above the sea level.\n */\n elevationAboveGeoid?: number;\n /** The geoid separation. It represents the elevation of the geoid above the ellipsoid at the center of the projection. */\n geoidSeparation?: number;\n /** The definition of the affine post-transformation for Transverse Mercator and Lambert Conformal Conic with post-affine projections */\n affine?: AffineTransformProps;\n /** Standard parallel for projection that only use one.\n * For cylindrical projections (mercator, transverse mercator ...) it defines the parallel at\n * which the cylinder crosses the ellipsoid resulting in a scale factor being applied.\n * For conic projections (Lambert Tangential ...) it defines\n * the standard parallel at which the cone is tangent to the ellipsoid.\n */\n standardParallel?: number;\n /** The first standard parallel at which the cone crosses the ellipsoid. */\n standardParallel1?: number;\n /** The second standard parallel at which the cone crosses the ellipsoid. */\n standardParallel2?: number;\n /** The UTM zone number. A number from 0 to 60. */\n zoneNumber?: number;\n /** The hemisphere for Universal Transverse Mercator projection. */\n hemisphere?: HemisphereEnum;\n /** Longitude of the central point. */\n centralPointLongitude?: number;\n /** Latitude of the central point. */\n centralPointLatitude?: number;\n /** Longitude of the first alignment point for some Oblique Mercator and Krovak projections. */\n point1Longitude?: number;\n /** Latitude of the first alignment point for some Oblique Mercator and Krovak projections. */\n point1Latitude?: number;\n /** Longitude of the second alignment point for some Oblique Mercator projections. */\n point2Longitude?: number;\n /** Latitude of the second alignment point for some Oblique Mercator projections. */\n point2Latitude?: number;\n /** The Danish zone for Danish projections. */\n danishSystem34Region?: DanishSystem34Region;\n /** Azimuth. */\n azimuth?: number;\n}\n\n/** This class encapsulates the projection of the CRS. The projection relies on a projection method and a set\n * of projection parameters specific to projection method selected to flatten the surface of the model of the Earth\n * defines as a geodetic ellipsoid. The flattening and the distortion angular, linear, scale from the process varies between methods.\n * Refer to appropriate external documentation for details.\n * @note Various property sets are required for specific projection methods. The current class implementation does not enforce\n * these rules yet and it is possible to define or not define any property regardless the method used.\n * @public\n */\nexport class Projection implements ProjectionProps {\n /** The projection method. */\n public readonly method!: ProjectionMethod;\n /** The False Easting of the projection. */\n public readonly falseEasting?: number;\n /** The False Northing of the projection. */\n public readonly falseNorthing?: number;\n /** The Central Meridian. */\n public readonly centralMeridian?: number;\n /** The latitude of origin of the projection. */\n public readonly latitudeOfOrigin?: number;\n /** Longitude of origin of the projection. */\n public readonly longitudeOfOrigin?: number;\n /** The scale reduction factor applied at origin. The nature of the projection has a\n * inherent scale factor applied that gradually varies outward from the projection origin.\n * The scale factor at origin enables to level the inherent scale factor over an use extent.\n * For the michigan variation of the Lambert Conformal Conic projection it\n * can be used instead or in addition to Standard Parallel to define\n * a scale factor.\n */\n public readonly scaleFactor?: number;\n /** The elevation of the origin of the projection above the geoid. This value\n * allows compensation for the scale factor related to elevation above the sea level.\n */\n public readonly elevationAboveGeoid?: number;\n /** The geoid separation. It represents the elevation of the geoid above the ellipsoid at the center of the projection. */\n public readonly geoidSeparation?: number;\n /** The definition of the affine post-transformation for Transverse Mercator and Lambert Conformal Conic with post-affine projections */\n public readonly affine?: AffineTransform;\n /** Standard parallel for projection that only use one.\n * For cylindrical projections (mercator, transverse mercator ...) it defines the parallel at\n ** which the cylinder crosses the ellipsoid resulting in a scale factor being applied.\n * For conic projections (Lambert Tangential ...) it defines\n * the standard parallel at which the cone is tangent to the ellipsoid.\n */\n public readonly standardParallel?: number;\n /** The first standard parallel at which the cone crosses the ellipsoid. */\n public readonly standardParallel1?: number;\n /** The second standard parallel at which the cone crosses the ellipsoid. */\n public readonly standardParallel2?: number;\n /** The UTM zone number. A number from 0 to 60. */\n public readonly zoneNumber?: number;\n /** The hemisphere for Universal Transverse Mercator projection. */\n public readonly hemisphere?: HemisphereEnum;\n /** Longitude of the central point. */\n public readonly centralPointLongitude?: number;\n /** Latitude of the central point. */\n public readonly centralPointLatitude?: number;\n /** Longitude of the first alignment point for some Oblique Mercator and Krovak projections. */\n public readonly point1Longitude?: number;\n /** Latitude of the first alignment point for some Oblique Mercator and Krovak projections. */\n public readonly point1Latitude?: number;\n /** Longitude of the second alignment point for some Oblique Mercator projections. */\n public readonly point2Longitude?: number;\n /** Latitude of the second alignment point for some Oblique Mercator projections. */\n public readonly point2Latitude?: number;\n /** The Danish zone for Danish projections. */\n public readonly danishSystem34Region?: DanishSystem34Region;\n /** Azimuth. */\n public readonly azimuth?: number;\n\n public constructor(_data?: ProjectionProps) {\n if (_data) {\n this.method = _data.method;\n this.falseEasting = _data.falseEasting;\n this.falseNorthing = _data.falseNorthing;\n this.centralMeridian = _data.centralMeridian;\n this.latitudeOfOrigin = _data.latitudeOfOrigin;\n this.longitudeOfOrigin = _data.longitudeOfOrigin;\n this.scaleFactor = _data.scaleFactor;\n this.elevationAboveGeoid = _data.elevationAboveGeoid;\n this.geoidSeparation = _data.geoidSeparation;\n this.affine = _data.affine ? AffineTransform.fromJSON(_data.affine) : undefined;\n this.standardParallel = _data.standardParallel;\n this.standardParallel1 = _data.standardParallel1;\n this.standardParallel2 = _data.standardParallel2;\n this.zoneNumber = _data.zoneNumber;\n this.hemisphere = _data.hemisphere;\n this.centralPointLongitude = _data.centralPointLongitude;\n this.centralPointLatitude = _data.centralPointLatitude;\n this.point1Longitude = _data.point1Longitude;\n this.point1Latitude = _data.point1Latitude;\n this.point2Longitude = _data.point2Longitude;\n this.point2Latitude = _data.point2Latitude;\n this.danishSystem34Region = _data.danishSystem34Region;\n this.azimuth = _data.azimuth;\n }\n }\n\n /** Creates a Projection from JSON representation.\n * @public */\n public static fromJSON(data: ProjectionProps): Projection {\n return new Projection(data);\n }\n\n /** Creates a JSON from the Projection definition\n * @public */\n public toJSON(): ProjectionProps {\n const data: ProjectionProps = { method: this.method };\n data.falseEasting = this.falseEasting;\n data.falseNorthing = this.falseNorthing;\n data.centralMeridian = this.centralMeridian;\n data.latitudeOfOrigin = this.latitudeOfOrigin;\n data.longitudeOfOrigin = this.longitudeOfOrigin;\n data.scaleFactor = this.scaleFactor;\n data.elevationAboveGeoid = this.elevationAboveGeoid;\n data.geoidSeparation = this.geoidSeparation;\n data.affine = this.affine ? this.affine.toJSON() : undefined;\n data.standardParallel = this.standardParallel;\n data.standardParallel1 = this.standardParallel1;\n data.standardParallel2 = this.standardParallel2;\n data.zoneNumber = this.zoneNumber;\n data.hemisphere = this.hemisphere;\n data.centralPointLongitude = this.centralPointLongitude;\n data.centralPointLatitude = this.centralPointLatitude;\n data.point1Longitude = this.point1Longitude;\n data.point1Latitude = this.point1Latitude;\n data.point2Longitude = this.point2Longitude;\n data.point2Latitude = this.point2Latitude;\n data.danishSystem34Region = this.danishSystem34Region;\n data.azimuth = this.azimuth;\n return data;\n }\n\n /** Compares two projections. It is a strict compare operation as descriptive data is compared\n * but a minuscule tolerance is applied to number compares.\n * @public */\n public equals(other: Projection): boolean {\n if (this.method !== other.method ||\n this.zoneNumber !== other.zoneNumber ||\n this.hemisphere !== other.hemisphere ||\n this.danishSystem34Region !== other.danishSystem34Region)\n return false;\n\n // Note that even though falseEasting, falseNorthing, elevationAboveGeoid and geoidSeparation are expressed\n // in the units of the projection which can be foot or US survey foot, they are still within the same order\n // of size that Geometry.smallMetricDistance can be used effectively.\n if (!Geometry.isAlmostEqualOptional(this.falseEasting, other.falseEasting, Geometry.smallMetricDistance) ||\n !Geometry.isAlmostEqualOptional(this.falseNorthing, other.falseNorthing, Geometry.smallMetricDistance) ||\n !Geometry.isAlmostEqualOptional(this.centralMeridian, other.centralMeridian, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.latitudeOfOrigin, other.latitudeOfOrigin, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.longitudeOfOrigin, other.longitudeOfOrigin, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.scaleFactor, other.scaleFactor, Geometry.smallFraction) ||\n !Geometry.isAlmostEqualOptional(this.elevationAboveGeoid, other.elevationAboveGeoid, Geometry.smallMetricDistance) ||\n !Geometry.isAlmostEqualOptional(this.geoidSeparation, other.geoidSeparation, Geometry.smallMetricDistance) ||\n !Geometry.isAlmostEqualOptional(this.standardParallel, other.standardParallel, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.standardParallel1, other.standardParallel1, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.standardParallel2, other.standardParallel2, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.centralPointLongitude, other.centralPointLongitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.centralPointLatitude, other.centralPointLatitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.point1Longitude, other.point1Longitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.point1Latitude, other.point1Latitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.point2Longitude, other.point2Longitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.point2Latitude, other.point2Latitude, Geometry.smallAngleDegrees) ||\n !Geometry.isAlmostEqualOptional(this.azimuth, other.azimuth, Geometry.smallAngleDegrees))\n return false;\n\n if (this.affine && other.affine) {\n if (!this.affine.equals(other.affine))\n return false;\n } else {\n if (this.affine || other.affine)\n return false;\n }\n return true;\n }\n}\n\n/** A 2D cartographic point in degrees\n * @public\n */\nexport interface Carto2DDegreesProps {\n /** Latitude value in degrees */\n latitude: number;\n /** Longitude value in degrees */\n longitude: number;\n}\n\n/** A 2D cartographic point in degrees\n * @public\n */\nexport class Carto2DDegrees implements Carto2DDegreesProps {\n /** Latitude value in degrees. Must be between -90 and +90 included */\n private _latitude!: number;\n /** Returns or sets the latitude in degrees. When setting the provided number must be between or equal from -90 to 90. */\n public get latitude() { return this._latitude; }\n public set latitude(newLatitude: number) {\n if ((newLatitude <= 90.0) && (newLatitude >= -90.0))\n this._latitude = newLatitude;\n }\n /** Longitude value in degrees */\n public longitude!: number;\n\n public constructor(data?: Carto2DDegreesProps) {\n this.latitude = 0.0; /* make sure latitude is init even if invalid latitude provided */\n if (data) {\n this.latitude = data.latitude;\n this.longitude = data.longitude;\n }\n }\n\n /** Creates a Carto2DDegrees object from JSON representation.\n * @public */\n public static fromJSON(data: Carto2DDegreesProps): Carto2DDegrees {\n return new Carto2DDegrees(data);\n }\n\n /** Creates a JSON from the Carto2DDegrees definition\n * @public */\n public toJSON(): Carto2DDegreesProps {\n return { latitude: this.latitude, longitude: this.longitude };\n }\n\n /** Compares two Carto2DDegrees object. It applies a minuscule tolerance to compares.\n * @public */\n public equals(other: Carto2DDegrees): boolean {\n return (Math.abs(this.latitude - other.latitude) < Geometry.smallAngleDegrees &&\n Math.abs(this.longitude - other.longitude) < Geometry.smallAngleDegrees);\n }\n}\n\n"]}
1
+ {"version":3,"file":"Projection.js","sourceRoot":"","sources":["../../../src/geometry/Projection.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 Albers, Krovak, OSTN, Cassini, Grinten, Mollweide, Eckert, Homolosine, Carree, Winkel, Tripel, Polyconic\r\n\r\nimport { Geometry } from \"@itwin/core-geometry\";\r\n\r\n/** This enum contains the list of all projection methods that can be represented as part of the HorizontalCRS\r\n * class. The None method indicates there is no projection and thus the CRS is longitude/latitude based\r\n * with units as degrees.\r\n * All other projection indicated a projected CRS.\r\n * @public\r\n */\r\nexport type ProjectionMethod =\r\n \"None\" |\r\n \"TransverseMercator\" |\r\n \"SouthOrientedTransverseMercator\" |\r\n \"TransverseMercatorWisconsin\" |\r\n \"TransverseMercatorMinnesota\" |\r\n \"TransverseMercatorAffine\" |\r\n \"MercatorStandardParallel\" |\r\n \"Mercator\" |\r\n \"UniversalTransverseMercator\" |\r\n \"LambertConformalConicTwoParallels\" |\r\n \"LambertConformalConicBelgium\" |\r\n \"LambertConformalConicAffine\" |\r\n \"LambertConformalConicWisconsin\" |\r\n \"LambertConformalConicMinnesota\" |\r\n \"LambertConformalConicMichigan\" |\r\n \"LambertConformalConicOneParallel\" |\r\n \"AlbersEqualArea\" |\r\n \"NewZealandNationalGrid\" |\r\n \"ObliqueMercator1\" |\r\n \"ObliqueMercator2\" |\r\n \"TransverseMercatorOSTN97\" |\r\n \"TransverseMercatorOSTN02\" |\r\n \"TransverseMercatorOSTN15\" |\r\n \"Krovak\" |\r\n \"KrovakModified\" |\r\n \"ObliqueCylindricalSwiss\" |\r\n \"TransverseMercatorDenmarkSystem34\" |\r\n \"TransverseMercatorDenmarkSystem3499\" |\r\n \"TransverseMercatorDenmarkSystem3401\" |\r\n \"Cassini\" |\r\n \"Sinusoidal\" |\r\n \"VanDerGrinten\" |\r\n \"Bonne\" |\r\n \"Mollweide\" |\r\n \"EckertIV\" |\r\n \"EckertVI\" |\r\n \"GoodeHomolosine\" |\r\n \"Robinson\" |\r\n \"PlateCarree\" |\r\n \"MillerCylindrical\" |\r\n \"WinkelTripel\" |\r\n \"AzimuthalEqualArea\" |\r\n \"ObliqueStereographic\" |\r\n \"RectifiedSkewOrthomorphicCentered\" |\r\n \"RectifiedSkewOrthomorphicOrigin\" |\r\n \"ObliqueCylindricalHungary\" |\r\n \"Orthographic\" |\r\n \"AmericanPolyconic\" |\r\n \"LambertEquidistantAzimuthal\" |\r\n \"ObliqueMercatorMinnesota\";\r\n\r\n/** The equations are:\r\n * X1 = a1*X + a2*Y + TranslationX\r\n * Y1 = b1*X + b2*Y + translationY\r\n * An affine representing no transformation will have: a1 = 1.0, a2 = 0.0, b1 = 0.0, b2 = 1.0.\r\n * @public\r\n */\r\nexport interface AffineTransformProps {\r\n /** The X post translation */\r\n translationX: number;\r\n /** The Y post-translation */\r\n translationY: number;\r\n /** A1 value as defined in global comment. */\r\n a1: number;\r\n /** B1 value as defined in global comment. */\r\n b1: number;\r\n /** A2 value as defined in global comment. */\r\n a2: number;\r\n /** B2 value as defined in global comment. */\r\n b2: number;\r\n}\r\n\r\n/** The equations are:\r\n * X1 = a1*X + a2*Y + TranslationX\r\n * Y1 = b1*X + b2*Y + translationY\r\n * An affine representing no transformation will have: a1 = 1.0, a2 = 0.0, b1 = 0.0, b2 = 1.0.\r\n * @public\r\n */\r\nexport class AffineTransform implements AffineTransformProps {\r\n /** The X post translation */\r\n public readonly translationX!: number;\r\n /** The Y post-translation */\r\n public readonly translationY!: number;\r\n /** A1 value as defined in global comment. */\r\n public readonly a1!: number;\r\n /** B1 value as defined in global comment. */\r\n public readonly b1!: number;\r\n /** A2 value as defined in global comment. */\r\n public readonly a2!: number;\r\n /** B2 value as defined in global comment. */\r\n public readonly b2!: number;\r\n\r\n constructor(data?: AffineTransformProps) {\r\n if (data) {\r\n this.translationX = data.translationX;\r\n this.translationY = data.translationY;\r\n this.a1 = data.a1;\r\n this.b1 = data.b1;\r\n this.a2 = data.a2;\r\n this.b2 = data.b2;\r\n }\r\n }\r\n\r\n /** Creates an Affine Transform from JSON representation.\r\n * @public */\r\n public static fromJSON(data: AffineTransformProps): AffineTransform {\r\n return new AffineTransform(data);\r\n }\r\n\r\n /** Creates a JSON from the Affine Transform definition\r\n * @public */\r\n public toJSON(): AffineTransformProps {\r\n return { translationX: this.translationX, a1: this.a1, a2: this.a2, translationY: this.translationY, b1: this.b1, b2: this.b2 };\r\n }\r\n\r\n /** Compares two Affine Transforms. It applies a minuscule tolerance for number compares\r\n * @public */\r\n public equals(other: AffineTransform): boolean {\r\n return (Math.abs(this.translationX - other.translationX) < Geometry.smallMetricDistance &&\r\n Math.abs(this.translationY - other.translationY) < Geometry.smallMetricDistance &&\r\n Math.abs(this.a1 - other.a1) < Geometry.smallFraction &&\r\n Math.abs(this.b1 - other.b1) < Geometry.smallFraction &&\r\n Math.abs(this.a2 - other.a2) < Geometry.smallFraction &&\r\n Math.abs(this.b2 - other.b2) < Geometry.smallFraction);\r\n }\r\n}\r\n\r\n/** Type used in the definition of UTM Zoning projection. This projection only requires a zone number and\r\n * the hemisphere North or South.\r\n * @public\r\n */\r\nexport type HemisphereEnum = \"South\" | \"North\";\r\n\r\n/** The type to define the three zones of the Danish System 34 projections.\r\n * @public\r\n */\r\nexport type DanishSystem34Region = \"Jylland\" | \"Sjaelland\" | \"Bornholm\";\r\n\r\n/** This class encapsulates the projection of the CRS. The projection relies on a projection method\r\n * and a set of projection parameters specific to projection method selected.\r\n * @public\r\n */\r\nexport interface ProjectionProps {\r\n /** The projection method. */\r\n method: ProjectionMethod;\r\n /** The False Easting of the projection. */\r\n falseEasting?: number;\r\n /** The False Northing of the projection. */\r\n falseNorthing?: number;\r\n /** The Central Meridian. */\r\n centralMeridian?: number;\r\n /** The latitude of origin of the projection. */\r\n latitudeOfOrigin?: number;\r\n /** Longitude of origin of the projection. */\r\n longitudeOfOrigin?: number;\r\n /** The scale reduction factor applied at origin. The nature of the projection has a\r\n * inherent scale factor applied that gradually varies outward from the projection origin.\r\n * The scale factor at origin enables to level the inherent scale factor over an use extent.\r\n * For the michigan variation of the Lambert Conformal Conic projection it\r\n * can be used instead or in addition to Standard Parallel to define\r\n * a scale factor.\r\n */\r\n scaleFactor?: number;\r\n /** The elevation of the origin of the projection above the geoid. This value\r\n * allows compensation for the scale factor related to elevation above the sea level.\r\n */\r\n elevationAboveGeoid?: number;\r\n /** The geoid separation. It represents the elevation of the geoid above the ellipsoid at the center of the projection. */\r\n geoidSeparation?: number;\r\n /** The definition of the affine post-transformation for Transverse Mercator and Lambert Conformal Conic with post-affine projections */\r\n affine?: AffineTransformProps;\r\n /** Standard parallel for projection that only use one.\r\n * For cylindrical projections (mercator, transverse mercator ...) it defines the parallel at\r\n * which the cylinder crosses the ellipsoid resulting in a scale factor being applied.\r\n * For conic projections (Lambert Tangential ...) it defines\r\n * the standard parallel at which the cone is tangent to the ellipsoid.\r\n */\r\n standardParallel?: number;\r\n /** The first standard parallel at which the cone crosses the ellipsoid. */\r\n standardParallel1?: number;\r\n /** The second standard parallel at which the cone crosses the ellipsoid. */\r\n standardParallel2?: number;\r\n /** The UTM zone number. A number from 0 to 60. */\r\n zoneNumber?: number;\r\n /** The hemisphere for Universal Transverse Mercator projection. */\r\n hemisphere?: HemisphereEnum;\r\n /** Longitude of the central point. */\r\n centralPointLongitude?: number;\r\n /** Latitude of the central point. */\r\n centralPointLatitude?: number;\r\n /** Longitude of the first alignment point for some Oblique Mercator and Krovak projections. */\r\n point1Longitude?: number;\r\n /** Latitude of the first alignment point for some Oblique Mercator and Krovak projections. */\r\n point1Latitude?: number;\r\n /** Longitude of the second alignment point for some Oblique Mercator projections. */\r\n point2Longitude?: number;\r\n /** Latitude of the second alignment point for some Oblique Mercator projections. */\r\n point2Latitude?: number;\r\n /** The Danish zone for Danish projections. */\r\n danishSystem34Region?: DanishSystem34Region;\r\n /** Azimuth. */\r\n azimuth?: number;\r\n}\r\n\r\n/** This class encapsulates the projection of the CRS. The projection relies on a projection method and a set\r\n * of projection parameters specific to projection method selected to flatten the surface of the model of the Earth\r\n * defines as a geodetic ellipsoid. The flattening and the distortion angular, linear, scale from the process varies between methods.\r\n * Refer to appropriate external documentation for details.\r\n * @note Various property sets are required for specific projection methods. The current class implementation does not enforce\r\n * these rules yet and it is possible to define or not define any property regardless the method used.\r\n * @public\r\n */\r\nexport class Projection implements ProjectionProps {\r\n /** The projection method. */\r\n public readonly method!: ProjectionMethod;\r\n /** The False Easting of the projection. */\r\n public readonly falseEasting?: number;\r\n /** The False Northing of the projection. */\r\n public readonly falseNorthing?: number;\r\n /** The Central Meridian. */\r\n public readonly centralMeridian?: number;\r\n /** The latitude of origin of the projection. */\r\n public readonly latitudeOfOrigin?: number;\r\n /** Longitude of origin of the projection. */\r\n public readonly longitudeOfOrigin?: number;\r\n /** The scale reduction factor applied at origin. The nature of the projection has a\r\n * inherent scale factor applied that gradually varies outward from the projection origin.\r\n * The scale factor at origin enables to level the inherent scale factor over an use extent.\r\n * For the michigan variation of the Lambert Conformal Conic projection it\r\n * can be used instead or in addition to Standard Parallel to define\r\n * a scale factor.\r\n */\r\n public readonly scaleFactor?: number;\r\n /** The elevation of the origin of the projection above the geoid. This value\r\n * allows compensation for the scale factor related to elevation above the sea level.\r\n */\r\n public readonly elevationAboveGeoid?: number;\r\n /** The geoid separation. It represents the elevation of the geoid above the ellipsoid at the center of the projection. */\r\n public readonly geoidSeparation?: number;\r\n /** The definition of the affine post-transformation for Transverse Mercator and Lambert Conformal Conic with post-affine projections */\r\n public readonly affine?: AffineTransform;\r\n /** Standard parallel for projection that only use one.\r\n * For cylindrical projections (mercator, transverse mercator ...) it defines the parallel at\r\n ** which the cylinder crosses the ellipsoid resulting in a scale factor being applied.\r\n * For conic projections (Lambert Tangential ...) it defines\r\n * the standard parallel at which the cone is tangent to the ellipsoid.\r\n */\r\n public readonly standardParallel?: number;\r\n /** The first standard parallel at which the cone crosses the ellipsoid. */\r\n public readonly standardParallel1?: number;\r\n /** The second standard parallel at which the cone crosses the ellipsoid. */\r\n public readonly standardParallel2?: number;\r\n /** The UTM zone number. A number from 0 to 60. */\r\n public readonly zoneNumber?: number;\r\n /** The hemisphere for Universal Transverse Mercator projection. */\r\n public readonly hemisphere?: HemisphereEnum;\r\n /** Longitude of the central point. */\r\n public readonly centralPointLongitude?: number;\r\n /** Latitude of the central point. */\r\n public readonly centralPointLatitude?: number;\r\n /** Longitude of the first alignment point for some Oblique Mercator and Krovak projections. */\r\n public readonly point1Longitude?: number;\r\n /** Latitude of the first alignment point for some Oblique Mercator and Krovak projections. */\r\n public readonly point1Latitude?: number;\r\n /** Longitude of the second alignment point for some Oblique Mercator projections. */\r\n public readonly point2Longitude?: number;\r\n /** Latitude of the second alignment point for some Oblique Mercator projections. */\r\n public readonly point2Latitude?: number;\r\n /** The Danish zone for Danish projections. */\r\n public readonly danishSystem34Region?: DanishSystem34Region;\r\n /** Azimuth. */\r\n public readonly azimuth?: number;\r\n\r\n public constructor(_data?: ProjectionProps) {\r\n if (_data) {\r\n this.method = _data.method;\r\n this.falseEasting = _data.falseEasting;\r\n this.falseNorthing = _data.falseNorthing;\r\n this.centralMeridian = _data.centralMeridian;\r\n this.latitudeOfOrigin = _data.latitudeOfOrigin;\r\n this.longitudeOfOrigin = _data.longitudeOfOrigin;\r\n this.scaleFactor = _data.scaleFactor;\r\n this.elevationAboveGeoid = _data.elevationAboveGeoid;\r\n this.geoidSeparation = _data.geoidSeparation;\r\n this.affine = _data.affine ? AffineTransform.fromJSON(_data.affine) : undefined;\r\n this.standardParallel = _data.standardParallel;\r\n this.standardParallel1 = _data.standardParallel1;\r\n this.standardParallel2 = _data.standardParallel2;\r\n this.zoneNumber = _data.zoneNumber;\r\n this.hemisphere = _data.hemisphere;\r\n this.centralPointLongitude = _data.centralPointLongitude;\r\n this.centralPointLatitude = _data.centralPointLatitude;\r\n this.point1Longitude = _data.point1Longitude;\r\n this.point1Latitude = _data.point1Latitude;\r\n this.point2Longitude = _data.point2Longitude;\r\n this.point2Latitude = _data.point2Latitude;\r\n this.danishSystem34Region = _data.danishSystem34Region;\r\n this.azimuth = _data.azimuth;\r\n }\r\n }\r\n\r\n /** Creates a Projection from JSON representation.\r\n * @public */\r\n public static fromJSON(data: ProjectionProps): Projection {\r\n return new Projection(data);\r\n }\r\n\r\n /** Creates a JSON from the Projection definition\r\n * @public */\r\n public toJSON(): ProjectionProps {\r\n const data: ProjectionProps = { method: this.method };\r\n data.falseEasting = this.falseEasting;\r\n data.falseNorthing = this.falseNorthing;\r\n data.centralMeridian = this.centralMeridian;\r\n data.latitudeOfOrigin = this.latitudeOfOrigin;\r\n data.longitudeOfOrigin = this.longitudeOfOrigin;\r\n data.scaleFactor = this.scaleFactor;\r\n data.elevationAboveGeoid = this.elevationAboveGeoid;\r\n data.geoidSeparation = this.geoidSeparation;\r\n data.affine = this.affine ? this.affine.toJSON() : undefined;\r\n data.standardParallel = this.standardParallel;\r\n data.standardParallel1 = this.standardParallel1;\r\n data.standardParallel2 = this.standardParallel2;\r\n data.zoneNumber = this.zoneNumber;\r\n data.hemisphere = this.hemisphere;\r\n data.centralPointLongitude = this.centralPointLongitude;\r\n data.centralPointLatitude = this.centralPointLatitude;\r\n data.point1Longitude = this.point1Longitude;\r\n data.point1Latitude = this.point1Latitude;\r\n data.point2Longitude = this.point2Longitude;\r\n data.point2Latitude = this.point2Latitude;\r\n data.danishSystem34Region = this.danishSystem34Region;\r\n data.azimuth = this.azimuth;\r\n return data;\r\n }\r\n\r\n /** Compares two projections. It is a strict compare operation as descriptive data is compared\r\n * but a minuscule tolerance is applied to number compares.\r\n * @public */\r\n public equals(other: Projection): boolean {\r\n if (this.method !== other.method ||\r\n this.zoneNumber !== other.zoneNumber ||\r\n this.hemisphere !== other.hemisphere ||\r\n this.danishSystem34Region !== other.danishSystem34Region)\r\n return false;\r\n\r\n // Note that even though falseEasting, falseNorthing, elevationAboveGeoid and geoidSeparation are expressed\r\n // in the units of the projection which can be foot or US survey foot, they are still within the same order\r\n // of size that Geometry.smallMetricDistance can be used effectively.\r\n if (!Geometry.isAlmostEqualOptional(this.falseEasting, other.falseEasting, Geometry.smallMetricDistance) ||\r\n !Geometry.isAlmostEqualOptional(this.falseNorthing, other.falseNorthing, Geometry.smallMetricDistance) ||\r\n !Geometry.isAlmostEqualOptional(this.centralMeridian, other.centralMeridian, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.latitudeOfOrigin, other.latitudeOfOrigin, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.longitudeOfOrigin, other.longitudeOfOrigin, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.scaleFactor, other.scaleFactor, Geometry.smallFraction) ||\r\n !Geometry.isAlmostEqualOptional(this.elevationAboveGeoid, other.elevationAboveGeoid, Geometry.smallMetricDistance) ||\r\n !Geometry.isAlmostEqualOptional(this.geoidSeparation, other.geoidSeparation, Geometry.smallMetricDistance) ||\r\n !Geometry.isAlmostEqualOptional(this.standardParallel, other.standardParallel, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.standardParallel1, other.standardParallel1, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.standardParallel2, other.standardParallel2, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.centralPointLongitude, other.centralPointLongitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.centralPointLatitude, other.centralPointLatitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.point1Longitude, other.point1Longitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.point1Latitude, other.point1Latitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.point2Longitude, other.point2Longitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.point2Latitude, other.point2Latitude, Geometry.smallAngleDegrees) ||\r\n !Geometry.isAlmostEqualOptional(this.azimuth, other.azimuth, Geometry.smallAngleDegrees))\r\n return false;\r\n\r\n if (this.affine && other.affine) {\r\n if (!this.affine.equals(other.affine))\r\n return false;\r\n } else {\r\n if (this.affine || other.affine)\r\n return false;\r\n }\r\n return true;\r\n }\r\n}\r\n\r\n/** A 2D cartographic point in degrees\r\n * @public\r\n */\r\nexport interface Carto2DDegreesProps {\r\n /** Latitude value in degrees */\r\n latitude: number;\r\n /** Longitude value in degrees */\r\n longitude: number;\r\n}\r\n\r\n/** A 2D cartographic point in degrees\r\n * @public\r\n */\r\nexport class Carto2DDegrees implements Carto2DDegreesProps {\r\n /** Latitude value in degrees. Must be between -90 and +90 included */\r\n private _latitude!: number;\r\n /** Returns or sets the latitude in degrees. When setting the provided number must be between or equal from -90 to 90. */\r\n public get latitude() { return this._latitude; }\r\n public set latitude(newLatitude: number) {\r\n if ((newLatitude <= 90.0) && (newLatitude >= -90.0))\r\n this._latitude = newLatitude;\r\n }\r\n /** Longitude value in degrees */\r\n public longitude!: number;\r\n\r\n public constructor(data?: Carto2DDegreesProps) {\r\n this.latitude = 0.0; /* make sure latitude is init even if invalid latitude provided */\r\n if (data) {\r\n this.latitude = data.latitude;\r\n this.longitude = data.longitude;\r\n }\r\n }\r\n\r\n /** Creates a Carto2DDegrees object from JSON representation.\r\n * @public */\r\n public static fromJSON(data: Carto2DDegreesProps): Carto2DDegrees {\r\n return new Carto2DDegrees(data);\r\n }\r\n\r\n /** Creates a JSON from the Carto2DDegrees definition\r\n * @public */\r\n public toJSON(): Carto2DDegreesProps {\r\n return { latitude: this.latitude, longitude: this.longitude };\r\n }\r\n\r\n /** Compares two Carto2DDegrees object. It applies a minuscule tolerance to compares.\r\n * @public */\r\n public equals(other: Carto2DDegrees): boolean {\r\n return (Math.abs(this.latitude - other.latitude) < Geometry.smallAngleDegrees &&\r\n Math.abs(this.longitude - other.longitude) < Geometry.smallAngleDegrees);\r\n }\r\n}\r\n\r\n"]}