HorizontalCRS Class
Horizontal Geographic Coordinate reference System implementation. An horizontal CRS defines the portion which is horizontal to the Earth surface (within the deformation brought by the projection process). There are two major classes of Horizontal Coordinate Reference Systems:
- The projected CRS which rely on a projection to flatten the coordinate system space into axises using linear units (meter, US Survey Feet, ...) relative to some origin.
- The non projected CRS (also named geographic CRS by EPSG nomenclature) that does not require a projection (projection method = None) and horizontal coordinates are expressed as longitude and latitude (see Cartographic) Horizontal Coordinate Systems rely on a projection to flatten the surface of an ellipsoid (see GeodeticEllipsoid) which is the mathematical model of the Earth surface. Explanations in more details of the various concepts can be obtained from other sources including the page on the subject on itwinJS.org (see https://www.itwinjs.org/learning/geolocation/?term=coordinate+system). A few details are still required to grasp the model. Geographic Coordinate Reference Systems rely on the concept of geodetic datums (see GeodeticDatum) to convert latitude/longitude from one frame of reference to another. Such geodetic datum will bind the ellipsoid and possibly define transformation steps required to convert from the currently used geodetic datum to the common datum WGS84 used for worldwide data (such as most popular imagery data sources). If there are no rules established to convert to WGS84 or if those rules are secret then the horizontal CRS can be datum-less and must make direct use of the ellipsoid to define the earth surface. For this purpose either the geodetic datum must be specified using either datumId or datum properties or both. If both these values are undefined then it is possible to define the ellipsoid using properties ellipsoidId or ellipsoid or both. These two pairs of properties are mutually exclusive with datum related properties having precedence. If a datum or datumId is set then ellipsoid properties will automatically be undefined. If datumId or datum is defined then attempts to set ellipsoidId or ellipsoid will fail silently, the values remaining undefined. The ellipsoidId will not be a repeat of the ellipsoidId property part of the geodetic datum definition.
Implements
Methods
Name | Description | |
---|---|---|
constructor(_data?: HorizontalCRSProps): HorizontalCRS | ||
equals(other: HorizontalCRS): boolean | Compares two horizontal CRS. | |
toJSON(): HorizontalCRSProps | Creates a JSON from the Horizontal CRS definition | |
fromJSON(data: HorizontalCRSProps): HorizontalCRS Static | Creates an Horizontal CRS from JSON representation. |
Properties
Name | Type | Description | |
---|---|---|---|
datum Readonly | GeodeticDatum | undefined | The complete definition of the geodetic datum referred to by datumId. | |
datumId Readonly | string | undefined | The identifier of the geodetic datum as stored in the dictionary or the service database. | |
deprecated Readonly | boolean | If true then indicates the definition is deprecated. | |
description Readonly | string | undefined | Description | |
ellipsoid Readonly | GeodeticEllipsoid | undefined | The complete definition of the geodetic ellipsoid referred to by ellipsoidId. | |
ellipsoidId Readonly | string | undefined | The identifier of the geodetic ellipsoid as stored in the dictionary or the service database. | |
epsg Readonly | number | undefined | The EPSG code of the CRS. | |
extent Readonly | HorizontalCRSExtent | undefined | Extent representing the domain of application of the CRS. | |
id Readonly | string | undefined | The identifier of the horizontal CRS as stored in the dictionary or the service database | |
name Readonly | string | undefined | Used only for user-defined definitions that will typically use a GUID as id. | |
projection Readonly | Projection | undefined | Projection including projection parameters. | |
source Readonly | string | undefined | The source of the CRS definition. | |
unit Readonly | UnitType | undefined | The text indicating the unit used. |
Defined in
Last Updated: 18 January, 2025
Found something wrong, missing, or unclear on this page?Raise an issue in our repo.