@itwin/core-common 3.2.0-dev.3 → 3.2.0-dev.34

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 (92) hide show
  1. package/CHANGELOG.md +28 -1
  2. package/lib/cjs/BackgroundMapProvider.d.ts +4 -0
  3. package/lib/cjs/BackgroundMapProvider.d.ts.map +1 -1
  4. package/lib/cjs/BackgroundMapProvider.js +9 -0
  5. package/lib/cjs/BackgroundMapProvider.js.map +1 -1
  6. package/lib/cjs/CloudStorage.d.ts.map +1 -1
  7. package/lib/cjs/CloudStorage.js +14 -20
  8. package/lib/cjs/CloudStorage.js.map +1 -1
  9. package/lib/cjs/ColorByName.d.ts +152 -152
  10. package/lib/cjs/ColorByName.d.ts.map +1 -1
  11. package/lib/cjs/ColorByName.js +152 -153
  12. package/lib/cjs/ColorByName.js.map +1 -1
  13. package/lib/cjs/ColorDef.d.ts +53 -46
  14. package/lib/cjs/ColorDef.d.ts.map +1 -1
  15. package/lib/cjs/ColorDef.js +48 -31
  16. package/lib/cjs/ColorDef.js.map +1 -1
  17. package/lib/cjs/geometry/GeodeticDatum.d.ts +69 -0
  18. package/lib/cjs/geometry/GeodeticDatum.d.ts.map +1 -1
  19. package/lib/cjs/geometry/GeodeticDatum.js +79 -1
  20. package/lib/cjs/geometry/GeodeticDatum.js.map +1 -1
  21. package/lib/cjs/geometry/GeometryStream.d.ts.map +1 -1
  22. package/lib/cjs/geometry/GeometryStream.js +10 -7
  23. package/lib/cjs/geometry/GeometryStream.js.map +1 -1
  24. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts +4 -2
  25. package/lib/cjs/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  26. package/lib/cjs/rpc/IModelTileRpcInterface.js +4 -2
  27. package/lib/cjs/rpc/IModelTileRpcInterface.js.map +1 -1
  28. package/lib/cjs/rpc/core/RpcInvocation.d.ts.map +1 -1
  29. package/lib/cjs/rpc/core/RpcInvocation.js +1 -6
  30. package/lib/cjs/rpc/core/RpcInvocation.js.map +1 -1
  31. package/lib/cjs/rpc/core/RpcMarshaling.d.ts.map +1 -1
  32. package/lib/cjs/rpc/core/RpcMarshaling.js +2 -1
  33. package/lib/cjs/rpc/core/RpcMarshaling.js.map +1 -1
  34. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.d.ts.map +1 -1
  35. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js +1 -2
  36. package/lib/cjs/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  37. package/lib/cjs/rpc/web/WebAppRpcLogging.d.ts.map +1 -1
  38. package/lib/cjs/rpc/web/WebAppRpcLogging.js +14 -10
  39. package/lib/cjs/rpc/web/WebAppRpcLogging.js.map +1 -1
  40. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts +0 -1
  41. package/lib/cjs/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  42. package/lib/cjs/rpc/web/WebAppRpcRequest.js +0 -1
  43. package/lib/cjs/rpc/web/WebAppRpcRequest.js.map +1 -1
  44. package/lib/cjs/tile/IModelTileIO.d.ts +2 -2
  45. package/lib/cjs/tile/IModelTileIO.js +2 -2
  46. package/lib/cjs/tile/IModelTileIO.js.map +1 -1
  47. package/lib/esm/BackgroundMapProvider.d.ts +4 -0
  48. package/lib/esm/BackgroundMapProvider.d.ts.map +1 -1
  49. package/lib/esm/BackgroundMapProvider.js +9 -0
  50. package/lib/esm/BackgroundMapProvider.js.map +1 -1
  51. package/lib/esm/CloudStorage.d.ts.map +1 -1
  52. package/lib/esm/CloudStorage.js +14 -20
  53. package/lib/esm/CloudStorage.js.map +1 -1
  54. package/lib/esm/ColorByName.d.ts +152 -152
  55. package/lib/esm/ColorByName.d.ts.map +1 -1
  56. package/lib/esm/ColorByName.js +152 -153
  57. package/lib/esm/ColorByName.js.map +1 -1
  58. package/lib/esm/ColorDef.d.ts +53 -46
  59. package/lib/esm/ColorDef.d.ts.map +1 -1
  60. package/lib/esm/ColorDef.js +48 -31
  61. package/lib/esm/ColorDef.js.map +1 -1
  62. package/lib/esm/geometry/GeodeticDatum.d.ts +69 -0
  63. package/lib/esm/geometry/GeodeticDatum.d.ts.map +1 -1
  64. package/lib/esm/geometry/GeodeticDatum.js +77 -0
  65. package/lib/esm/geometry/GeodeticDatum.js.map +1 -1
  66. package/lib/esm/geometry/GeometryStream.d.ts.map +1 -1
  67. package/lib/esm/geometry/GeometryStream.js +10 -7
  68. package/lib/esm/geometry/GeometryStream.js.map +1 -1
  69. package/lib/esm/rpc/IModelTileRpcInterface.d.ts +4 -2
  70. package/lib/esm/rpc/IModelTileRpcInterface.d.ts.map +1 -1
  71. package/lib/esm/rpc/IModelTileRpcInterface.js +4 -2
  72. package/lib/esm/rpc/IModelTileRpcInterface.js.map +1 -1
  73. package/lib/esm/rpc/core/RpcInvocation.d.ts.map +1 -1
  74. package/lib/esm/rpc/core/RpcInvocation.js +1 -6
  75. package/lib/esm/rpc/core/RpcInvocation.js.map +1 -1
  76. package/lib/esm/rpc/core/RpcMarshaling.d.ts.map +1 -1
  77. package/lib/esm/rpc/core/RpcMarshaling.js +1 -0
  78. package/lib/esm/rpc/core/RpcMarshaling.js.map +1 -1
  79. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.d.ts.map +1 -1
  80. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js +0 -1
  81. package/lib/esm/rpc/web/BentleyCloudRpcProtocol.js.map +1 -1
  82. package/lib/esm/rpc/web/WebAppRpcLogging.d.ts.map +1 -1
  83. package/lib/esm/rpc/web/WebAppRpcLogging.js +14 -10
  84. package/lib/esm/rpc/web/WebAppRpcLogging.js.map +1 -1
  85. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts +0 -1
  86. package/lib/esm/rpc/web/WebAppRpcRequest.d.ts.map +1 -1
  87. package/lib/esm/rpc/web/WebAppRpcRequest.js +0 -1
  88. package/lib/esm/rpc/web/WebAppRpcRequest.js.map +1 -1
  89. package/lib/esm/tile/IModelTileIO.d.ts +2 -2
  90. package/lib/esm/tile/IModelTileIO.js +2 -2
  91. package/lib/esm/tile/IModelTileIO.js.map +1 -1
  92. package/package.json +9 -9
@@ -1 +1 @@
1
- {"version":3,"file":"ColorDef.js","sourceRoot":"","sources":["../../src/ColorDef.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 Symbology\r\n */\r\n\r\nimport { Geometry } from \"@itwin/core-geometry\";\r\nimport { ColorByName } from \"./ColorByName\";\r\nimport { HSLColor } from \"./HSLColor\";\r\nimport { HSVColor, HSVConstants } from \"./HSVColor\";\r\n\r\n// cspell: ignore ttbbggrr bbggrr rrggbb aabbggrr abgr rrggbb hsla lerp torgb dhue dsaturation dvalue intpart fractpart cyanish\r\n\r\n// portions adapted from Three.js Copyright © 2010-2017 three.js authors\r\n\r\nconst scratchBytes = new Uint8Array(4);\r\nconst scratchUInt32 = new Uint32Array(scratchBytes.buffer);\r\n\r\n/** An unsigned 32-bit integer in 0xTTBBGGRR format\r\n * @public\r\n */\r\nexport type ColorDefProps = number;\r\n\r\n/** An immutable integer representation of a color.\r\n *\r\n * Colors are stored as 4 components: Red, Blue, Green, and Transparency (0=fully opaque). Each is an 8-bit integer between 0-255.\r\n *\r\n * Much confusion results from attempting to interpret those 4 one-byte values as a 4 byte integer. There are generally two sources\r\n * of confusion:\r\n * 1. The ordering of the Red, Green, Blue bytes; and\r\n * 2. Whether to specify transparency or opacity (sometimes referred to as \"alpha\").\r\n *\r\n * ColorDef uses `0xTTBBGGRR` (red in the low byte. 0==fully opaque in high byte) internally, but it also provides methods\r\n * to convert to `0xRRGGBB` (see [[getRgb]]) and `0xAABBGGRR` (red in the low byte, 0==fully transparent in high byte. see [[getAbgr]]).\r\n *\r\n * The [[create]] method also accepts strings in the common HTML formats.\r\n *\r\n * ColorDef is immutable. To obtain a modified copy of a ColorDef, use methods like [[adjustedForContrast]], [[inverse]], or [[withTransparency]]. For example:\r\n * ```ts\r\n * const semiTransparentBlue = ColorDef.blue.withTransparency(100);\r\n * ```\r\n * @public\r\n */\r\nexport class ColorDef {\r\n private readonly _tbgr: number;\r\n\r\n private constructor(tbgr: number) {\r\n scratchUInt32[0] = tbgr; // Force to be a 32-bit unsigned integer\r\n this._tbgr = scratchUInt32[0];\r\n }\r\n\r\n /**\r\n * Create a new ColorDef.\r\n * @param val value to use.\r\n * If a number, it is interpreted as a 0xTTBBGGRR (Red in the low byte, high byte is transparency 0==fully opaque) value.\r\n *\r\n * If a string, must be in one of the following forms:\r\n * *\"rgb(255,0,0)\"*\r\n * *\"rgba(255,0,0,.2)\"*\r\n * *\"rgb(100%,0%,0%)\"*\r\n * *\"hsl(120,50%,50%)\"*\r\n * *\"#rrggbb\"*\r\n * *\"blanchedAlmond\"* (see possible values from [[ColorByName]]). Case insensitive.\r\n */\r\n public static create(val?: string | ColorDefProps) {\r\n return this.fromTbgr(this.computeTbgr(val));\r\n }\r\n\r\n /** @internal */\r\n public static computeTbgr(val?: string | ColorDefProps): number {\r\n switch (typeof val) {\r\n case \"number\":\r\n return val;\r\n case \"string\":\r\n return this.computeTbgrFromString(val);\r\n default:\r\n return 0;\r\n }\r\n }\r\n\r\n /** Convert this ColorDef to a 32 bit number representing the 0xTTBBGGRR value */\r\n public toJSON(): ColorDefProps { return this._tbgr; }\r\n\r\n /** Create a new ColorDef from a json object. If the json object is a number, it is assumed to be a 0xTTBBGGRR value. */\r\n public static fromJSON(json?: ColorDefProps): ColorDef {\r\n return this.create(json);\r\n }\r\n\r\n /** Create a ColorDef from Red, Green, Blue, Transparency values. All inputs should be integers between 0-255. */\r\n public static from(red: number, green: number, blue: number, transparency?: number): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromComponents(red, green, blue, transparency));\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value corresponding to the specified Red, Green, Blue, Transparency components. All inputs should be integers between 0-255. */\r\n public static computeTbgrFromComponents(red: number, green: number, blue: number, transparency?: number): number {\r\n scratchBytes[0] = red;\r\n scratchBytes[1] = green;\r\n scratchBytes[2] = blue;\r\n scratchBytes[3] = transparency || 0;\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Create a ColorDef from its 0xTTBBGGRR representation. */\r\n public static fromTbgr(tbgr: number): ColorDef {\r\n switch (tbgr) {\r\n case ColorByName.black:\r\n return this.black;\r\n case ColorByName.white:\r\n return this.white;\r\n case ColorByName.red:\r\n return this.red;\r\n case ColorByName.green:\r\n return this.green;\r\n case ColorByName.blue:\r\n return this.blue;\r\n default:\r\n return new ColorDef(tbgr);\r\n }\r\n }\r\n\r\n /** Create a ColorDef from a string representation. The following representations are supported:\r\n * *\"rgb(255,0,0)\"*\r\n * *\"rgba(255,0,0,.2)\"*\r\n * *\"rgb(100%,0%,0%)\"*\r\n * *\"hsl(120,50%,50%)\"*\r\n * *\"#rrbbgg\"*\r\n * *\"blanchedAlmond\"* (see possible values from [[ColorByName]]). Case-insensitive.\r\n */\r\n public static fromString(val: string): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromString(val));\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value corresponding to a string representation of a color. The following representations are supported:\r\n * *\"rgb(255,0,0)\"*\r\n * *\"rgba(255,0,0,.2)\"*\r\n * *\"rgb(100%,0%,0%)\"*\r\n * *\"hsl(120,50%,50%)\"*\r\n * *\"#rrbbgg\"*\r\n * *\"blanchedAlmond\"* (see possible values from [[ColorByName]]). Case-insensitive.\r\n */\r\n public static computeTbgrFromString(val: string): number {\r\n if (typeof val !== \"string\")\r\n return 0;\r\n\r\n val = val.toLowerCase();\r\n let m = /^((?:rgb|hsl)a?)\\(\\s*([^\\)]*)\\)/.exec(val);\r\n if (m) { // rgb / hsl\r\n let color;\r\n const name = m[1];\r\n const components = m[2];\r\n\r\n const hasPercent = (str: string) => str[str.length - 1] === \"%\";\r\n const floatOrPercent = (str: string) => {\r\n const v = parseFloat(str);\r\n return 255 * Geometry.clamp(hasPercent(str) ? v / 100. : v, 0, 1);\r\n };\r\n const intOrPercent = (str: string) => {\r\n const v = hasPercent(str) ? (parseFloat(str) / 100.) * 255 : parseInt(str, 10);\r\n return Geometry.clamp(v, 0, 255);\r\n };\r\n\r\n switch (name) {\r\n case \"rgb\":\r\n case \"rgba\":\r\n color = /^(\\d+%*)\\s*[, ]\\s*(\\d+%*)\\s*[, ]\\s*(\\d+%*)\\s*([,\\/]\\s*([0-9]*\\.?[0-9]+%*)\\s*)?$/.exec(components);\r\n if (color) { // rgb(255,0,0) rgba(255,0,0,0.5)\r\n return this.computeTbgrFromComponents(\r\n intOrPercent(color[1]),\r\n intOrPercent(color[2]),\r\n intOrPercent(color[3]),\r\n typeof color[5] === \"string\" ? 255 - floatOrPercent(color[5]) : 0);\r\n }\r\n\r\n break;\r\n case \"hsl\":\r\n case \"hsla\":\r\n color = /^([0-9]*\\.?[0-9]+)\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(,\\s*([0-9]*\\.?[0-9]+)\\s*)?$/.exec(components);\r\n if (color) { // hsl(120,50%,50%) hsla(120,50%,50%,0.5)\r\n const h = parseFloat(color[1]) / 360;\r\n const s = parseInt(color[2], 10) / 100;\r\n const l = parseInt(color[3], 10) / 100;\r\n const t = typeof color[5] === \"string\" ? 255 - floatOrPercent(color[5]) : 0;\r\n return this.computeTbgrFromHSL(h, s, l, t);\r\n }\r\n\r\n break;\r\n }\r\n // eslint-disable-next-line no-cond-assign\r\n } else if (m = /^\\#([a-f0-9]+)$/.exec(val)) { // hex color\r\n const hex = m[1];\r\n const size = hex.length;\r\n\r\n if (size === 3) { // #ff0\r\n return this.computeTbgrFromComponents(\r\n parseInt(hex.charAt(0) + hex.charAt(0), 16),\r\n parseInt(hex.charAt(1) + hex.charAt(1), 16),\r\n parseInt(hex.charAt(2) + hex.charAt(2), 16), 0);\r\n }\r\n if (size === 6) { // #ff0000\r\n return this.computeTbgrFromComponents(\r\n parseInt(hex.charAt(0) + hex.charAt(1), 16),\r\n parseInt(hex.charAt(2) + hex.charAt(3), 16),\r\n parseInt(hex.charAt(4) + hex.charAt(5), 16), 0);\r\n }\r\n }\r\n\r\n if (val && val.length > 0) { // ColorRgb value\r\n const colorByName = Object.entries(ColorByName).find((entry) => typeof entry[1] === \"string\" && entry[1].toLowerCase() === val);\r\n if (colorByName)\r\n return Number(colorByName[0]);\r\n }\r\n\r\n return 0;\r\n }\r\n\r\n /** Get the r,g,b,t values from this ColorDef. Values will be integers between 0-255. */\r\n public get colors(): { r: number, g: number, b: number, t: number } {\r\n return ColorDef.getColors(this._tbgr);\r\n }\r\n\r\n /** Get the r,g,b,t values encoded in an 0xTTBBGGRR value. Values will be integers between 0-255. */\r\n public static getColors(tbgr: number) {\r\n scratchUInt32[0] = tbgr;\r\n return {\r\n b: scratchBytes[2],\r\n g: scratchBytes[1],\r\n r: scratchBytes[0],\r\n t: scratchBytes[3],\r\n };\r\n }\r\n\r\n /** The color value of this ColorDef as an integer in the form 0xTTBBGGRR (red in the low byte) */\r\n public get tbgr(): number { return this._tbgr; }\r\n\r\n /** Get the value of the color as a number in 0xAABBGGRR format (i.e. red is in low byte). Transparency (0==fully opaque) converted to alpha (0==fully transparent). */\r\n public getAbgr(): number {\r\n return ColorDef.getAbgr(this._tbgr);\r\n }\r\n\r\n /** Get the value of a 0xTTBBGGRR color as a number in 0xAABBGGRR format (i.e. red is in low byte). Transparency (0==fully opaque) converted to alpha (0==fully transparent). */\r\n public static getAbgr(tbgr: number): number {\r\n scratchUInt32[0] = tbgr;\r\n scratchBytes[3] = 255 - scratchBytes[3];\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Get the RGB value of the color as a number in 0xRRGGBB format (i.e blue is in the low byte). Transparency is ignored. Value will be from 0 to 2^24 */\r\n public getRgb(): number {\r\n return ColorDef.getRgb(this._tbgr);\r\n }\r\n\r\n /** Get the RGB value of the 0xTTBBGGRR color as a number in 0xRRGGBB format (i.e blue is in the low byte). Transparency is ignored. Value will be from 0 to 2^24 */\r\n public static getRgb(tbgr: number): number {\r\n scratchUInt32[0] = tbgr;\r\n return (scratchBytes[0] << 16) + (scratchBytes[1] << 8) + scratchBytes[2];\r\n }\r\n\r\n /** Return a copy of this ColorDef with the specified alpha component.\r\n * @param alpha the new alpha value as an integer between 0-255.\r\n * @returns A ColorDef with equivalent red, green, and blue components to this one but with the specified alpha.\r\n */\r\n public withAlpha(alpha: number): ColorDef {\r\n const tbgr = ColorDef.withAlpha(this._tbgr, alpha);\r\n return tbgr === this._tbgr ? this : ColorDef.fromTbgr(tbgr);\r\n }\r\n\r\n /** Return a color equivalent to the specified 0xTTBBGGRR but with modified alpha component.\r\n * @param alpha the new alpha value as an integer between 0-255.\r\n * @returns The 0xTTBBGGRR value equivalent to `tbgr` but with the specified alpha.\r\n */\r\n public static withAlpha(tbgr: number, alpha: number): number {\r\n scratchUInt32[0] = tbgr;\r\n scratchBytes[3] = 255 - (alpha | 0);\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Get the alpha value for this ColorDef. Will be between 0-255 */\r\n public getAlpha(): number {\r\n return ColorDef.getAlpha(this._tbgr);\r\n }\r\n\r\n /** Extract the alpha value from a 0xTTBBGGRR color. */\r\n public static getAlpha(tbgr: number): number {\r\n scratchUInt32[0] = tbgr;\r\n return 255 - scratchBytes[3];\r\n }\r\n\r\n /** True if this ColorDef is fully opaque. */\r\n public get isOpaque(): boolean {\r\n return ColorDef.isOpaque(this._tbgr);\r\n }\r\n\r\n /** True if the specified 0xTTBBGGRR color is fully opaque. */\r\n public static isOpaque(tbgr: number): boolean {\r\n return 255 === this.getAlpha(tbgr);\r\n }\r\n\r\n /** Get the transparency value for this ColorDef (inverse of alpha). Will be between 0-255. */\r\n public getTransparency(): number {\r\n return ColorDef.getTransparency(this._tbgr);\r\n }\r\n\r\n /** Extract the transparency component from a 0xTTBBGGRR color as an integer between 0-255.. */\r\n public static getTransparency(tbgr: number): number {\r\n scratchUInt32[0] = tbgr;\r\n return scratchBytes[3];\r\n }\r\n\r\n /** Create a copy of this ColorDef with the specified transparency.\r\n * @param transparency the new transparency value. Must be between 0-255, where 0 means 'fully opaque' and 255 means 'fully transparent'.\r\n * @returns a new ColorDef with the same color as this one and the specified transparency.\r\n */\r\n public withTransparency(transparency: number): ColorDef {\r\n const tbgr = ColorDef.withTransparency(this._tbgr, transparency);\r\n return tbgr === this._tbgr ? this : ColorDef.fromTbgr(tbgr);\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value of the specified color and transparency.\r\n * @param transparency the new transparency as an integer between 0-255.\r\n * @returns The 0xTTBBGGRR value equivalent to `tbgr` but with the specified transparency.\r\n */\r\n public static withTransparency(tbgr: number, transparency: number): number {\r\n return this.withAlpha(tbgr, 255 - transparency);\r\n }\r\n\r\n /** The \"known name\" for this ColorDef. Will be undefined if color value is not in [[ColorByName]] list */\r\n public get name(): string | undefined {\r\n return ColorDef.getName(this.tbgr);\r\n }\r\n\r\n /** Obtain the name of the color in the [[ColorByName]] list associated with the specified 0xTTBBGGRR value, or undefined if no such named color exists. */\r\n public static getName(tbgr: number): string | undefined {\r\n return ColorByName[tbgr];\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"#rrggbb\" where values are hex digits of the respective colors */\r\n public toHexString(): string {\r\n return ColorDef.toHexString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR value to a string in the form \"#rrggbb\". */\r\n public static toHexString(tbgr: number): string {\r\n return `#${(`000000${this.getRgb(tbgr).toString(16)}`).slice(-6)}`;\r\n }\r\n\r\n private static getColorsString(tbgr: number) {\r\n const c = this.getColors(tbgr);\r\n return `${c.r},${c.g},${c.b}`;\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"rgb(r,g,b)\" where values are decimal digits of the respective colors. */\r\n public toRgbString(): string {\r\n return ColorDef.toRgbString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR color to a string in the form \"rgb(r,g,b)\" where each component is specified in decimal. */\r\n public static toRgbString(tbgr: number): string {\r\n return `rgb(${this.getColorsString(tbgr)})`;\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"rgba(r,g,b,a)\" where color values are decimal digits and a is a fraction */\r\n public toRgbaString(): string {\r\n return ColorDef.toRgbaString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR color to a string of the form \"rgba(r,g,b,a)\" where the color components are specified in decimal and the alpha component is a fraction. */\r\n public static toRgbaString(tbgr: number): string {\r\n return `rgba(${this.getColorsString(tbgr)},${this.getAlpha(tbgr) / 255.})`;\r\n }\r\n\r\n /** Create a ColorDef that is the linear interpolation of this ColorDef and another ColorDef, using a weighting factor.\r\n * @param color2 The other color\r\n * @param weight The weighting factor for color2. 0.0 = this color, 1.0 = color2.\r\n * @param result Optional ColorDef to hold result. If undefined, a new ColorDef is created.\r\n */\r\n public lerp(color2: ColorDef, weight: number): ColorDef {\r\n return ColorDef.fromTbgr(ColorDef.lerp(this.tbgr, color2.tbgr, weight));\r\n }\r\n\r\n /** Interpolate between two 0xTTBBGGRR colors using a weighting factor.\r\n * @param tbgr1 The first color\r\n * @param tbgr2 The other color\r\n * @param weight The weighting factor in [0..1]. A value of 0.0 selects `tbgr1`; 1.0 selects `tbgr2`; 0.5 mixes them evenly; etc.\r\n * @returns The linear interpolation between `tbgr1` and `tbgr2` using the specified weight.\r\n */\r\n public static lerp(tbgr1: number, tbgr2: number, weight: number): number {\r\n const c = this.getColors(tbgr1);\r\n const color = this.getColors(tbgr2);\r\n c.r += (color.r - c.r) * weight;\r\n c.g += (color.g - c.g) * weight;\r\n c.b += (color.b - c.b) * weight;\r\n return this.computeTbgrFromComponents(c.r, c.g, c.b, c.t);\r\n }\r\n\r\n /** Create a new ColorDef that is the inverse (all colors set to 255 - this) of this color. Ignores transparency - result has 0 transparency. */\r\n public inverse(): ColorDef {\r\n return ColorDef.fromTbgr(ColorDef.inverse(this.tbgr));\r\n }\r\n\r\n /** Return a 0xTTBBGGRR color whose color components are the inverse of the input color. The result has 0 transparency. */\r\n public static inverse(tbgr: number): number {\r\n const colors = this.getColors(tbgr);\r\n return this.computeTbgrFromComponents(255 - colors.r, 255 - colors.g, 255 - colors.b);\r\n }\r\n\r\n /** Create a ColorDef from hue, saturation, lightness values */\r\n public static fromHSL(h: number, s: number, l: number, transparency = 0): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromHSL(h, s, l, transparency));\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR color corresponding to the specified hue, saturation, lightness values. */\r\n public static computeTbgrFromHSL(h: number, s: number, l: number, transparency = 0): number {\r\n const torgb = (p1: number, q1: number, t: number) => {\r\n if (t < 0) t += 1;\r\n if (t > 1) t -= 1;\r\n if (t < 1 / 6) return p1 + (q1 - p1) * 6 * t;\r\n if (t < 1 / 2) return q1;\r\n if (t < 2 / 3) return p1 + (q1 - p1) * 6 * (2 / 3 - t);\r\n return p1;\r\n };\r\n\r\n const hue2rgb = (p1: number, q1: number, t: number) => Math.round(torgb(p1, q1, t) * 255);\r\n const modulo = (n: number, m: number) => ((n % m) + m) % m;\r\n\r\n // h,s,l ranges are in 0.0 - 1.0\r\n h = modulo(h, 1);\r\n s = Geometry.clamp(s, 0, 1);\r\n l = Geometry.clamp(l, 0, 1);\r\n\r\n if (s === 0) {\r\n l *= 255;\r\n return this.computeTbgrFromComponents(l, l, l, transparency);\r\n }\r\n\r\n const p = l <= 0.5 ? l * (1 + s) : l + s - (l * s);\r\n const q = (2 * l) - p;\r\n return this.computeTbgrFromComponents(\r\n hue2rgb(q, p, h + 1 / 3),\r\n hue2rgb(q, p, h),\r\n hue2rgb(q, p, h - 1 / 3),\r\n transparency);\r\n }\r\n\r\n /** Create an [[HSLColor]] from this ColorDef */\r\n public toHSL(): HSLColor {\r\n // h,s,l ranges are in 0.0 - 1.0\r\n const col = this.colors;\r\n col.r /= 255;\r\n col.g /= 255;\r\n col.b /= 255;\r\n const max = Math.max(col.r, col.g, col.b);\r\n const min = Math.min(col.r, col.g, col.b);\r\n\r\n let hue = 0;\r\n let saturation;\r\n const lightness = (min + max) / 2.0;\r\n\r\n if (min === max) {\r\n saturation = 0;\r\n } else {\r\n const delta = max - min;\r\n saturation = lightness <= 0.5 ? delta / (max + min) : delta / (2 - max - min);\r\n switch (max) {\r\n case col.r: hue = (col.g - col.b) / delta + (col.g < col.b ? 6 : 0); break;\r\n case col.g: hue = (col.b - col.r) / delta + 2; break;\r\n case col.b: hue = (col.r - col.g) / delta + 4; break;\r\n }\r\n hue /= 6;\r\n }\r\n\r\n return new HSLColor(hue, saturation, lightness);\r\n }\r\n\r\n /** Create an [[HSVColor]] from this ColorDef */\r\n public toHSV(): HSVColor {\r\n const { r, g, b } = this.colors;\r\n let min = (r < g) ? r : g;\r\n if (b < min)\r\n min = b;\r\n\r\n let max = (r > g) ? r : g;\r\n if (b > max)\r\n max = b;\r\n\r\n /* amount of \"blackness\" present */\r\n const v = Math.floor((max / 255.0 * 100) + 0.5);\r\n const deltaRgb = max - min;\r\n const s = (max !== 0.0) ? Math.floor((deltaRgb / max * 100) + 0.5) : 0;\r\n let h = 0;\r\n\r\n if (s) {\r\n const redDistance = (max - r) / deltaRgb;\r\n const greenDistance = (max - g) / deltaRgb;\r\n const blueDistance = (max - b) / deltaRgb;\r\n\r\n let intermediateHue: number;\r\n if (r === max) /* color between yellow & magenta */\r\n intermediateHue = blueDistance - greenDistance;\r\n else if (g === max) /* color between cyan & yellow */\r\n intermediateHue = 2.0 + redDistance - blueDistance;\r\n else /* color between magenta & cyan */\r\n intermediateHue = 4.0 + greenDistance - redDistance;\r\n\r\n /* intermediate hue is [0..6] */\r\n intermediateHue *= 60;\r\n\r\n if (intermediateHue < 0.0)\r\n intermediateHue += 360;\r\n\r\n h = Math.floor(intermediateHue + 0.5);\r\n\r\n if (h >= 360)\r\n h = 0;\r\n } else {\r\n h = 0;\r\n }\r\n\r\n return new HSVColor(h, s, v);\r\n }\r\n\r\n /** Create a ColorDef from an HSVColor */\r\n public static fromHSV(hsv: HSVColor, transparency = 0): ColorDef {\r\n // Check for simple case first.\r\n if ((!hsv.s) || (hsv.h === -1)) {\r\n // hue must be undefined, have no color only white\r\n const white = 0xff & Math.floor(((255.0 * hsv.v) / 100.0) + 0.5 + 3.0e-14);\r\n return ColorDef.from(white, white, white, 0);\r\n }\r\n\r\n let dhue = hsv.h, dsaturation = hsv.s, dvalue = hsv.v;\r\n if (dhue === 360)\r\n dhue = 0.0;\r\n\r\n dhue /= 60; // hue is now [0..6]\r\n const hueIntpart = Math.floor(dhue); // convert double -> int\r\n const hueFractpart = dhue - hueIntpart;\r\n dvalue /= 100;\r\n dsaturation /= 100;\r\n\r\n const p = 0xff & Math.floor((dvalue * (1.0 - dsaturation) * 255.0) + 0.5);\r\n const q = 0xff & Math.floor((dvalue * (1.0 - (dsaturation * hueFractpart)) * 255.0) + 0.5);\r\n const t = 0xff & Math.floor((dvalue * (1.0 - (dsaturation * (1.0 - hueFractpart))) * 255.0) + 0.5);\r\n const v = 0xff & Math.floor(dvalue * 255 + 0.5);\r\n\r\n let r = 0, b = 0, g = 0;\r\n switch (hueIntpart) {\r\n case 0: r = v; g = t; b = p; break; // reddish\r\n case 1: r = q, g = v; b = p; break; // yellowish\r\n case 2: r = p, g = v; b = t; break; // greenish\r\n case 3: r = p, g = q; b = v; break; // cyanish\r\n case 4: r = t, g = p; b = v; break; // bluish\r\n case 5: r = v, g = p; b = q; break; // magenta-ish\r\n }\r\n\r\n return ColorDef.from(r, g, b, transparency);\r\n }\r\n\r\n private visibilityCheck(other: ColorDef): number {\r\n const fg = this.colors;\r\n const bg = other.colors;\r\n // Compute luminosity\r\n const red = Math.abs(fg.r - bg.r);\r\n const green = Math.abs(fg.g - bg.g);\r\n const blue = Math.abs(fg.b - bg.b);\r\n return (0.30 * red) + (0.59 * green) + (0.11 * blue);\r\n }\r\n\r\n /**\r\n * Create a new ColorDef that is adjusted from this ColorDef for maximum contrast against another color. The color will either be lighter\r\n * or darker, depending on which has more visibility against the other color.\r\n * @param other the color to contrast with\r\n * @param alpha optional alpha value for the adjusted color. If not supplied alpha from this color is used.\r\n */\r\n public adjustedForContrast(other: ColorDef, alpha?: number): ColorDef {\r\n const visibility = this.visibilityCheck(other);\r\n if (HSVConstants.VISIBILITY_GOAL <= visibility) {\r\n return undefined !== alpha ? this.withAlpha(alpha) : this;\r\n }\r\n\r\n const adjPercent = Math.floor(((HSVConstants.VISIBILITY_GOAL - visibility) / 255.0) * 100.0);\r\n let darkerHSV = this.toHSV();\r\n let brightHSV = darkerHSV.clone();\r\n\r\n darkerHSV = darkerHSV.adjusted(true, adjPercent);\r\n brightHSV = brightHSV.adjusted(false, adjPercent);\r\n\r\n if (undefined === alpha)\r\n alpha = this.getAlpha();\r\n\r\n const darker = ColorDef.fromHSV(darkerHSV).withAlpha(alpha);\r\n const bright = ColorDef.fromHSV(brightHSV).withAlpha(alpha);\r\n\r\n if (bright.getRgb() === other.getRgb()) // Couldn't adjust brighter...\r\n return darker;\r\n\r\n if (darker.getRgb() === other.getRgb()) // Couldn't adjust darker...\r\n return bright;\r\n\r\n // NOTE: Best choice is the one most visible against the other color...\r\n return (bright.visibilityCheck(other) >= darker.visibilityCheck(other)) ? bright : darker;\r\n }\r\n\r\n /** True if the value of this ColorDef is the same as another ColorDef. */\r\n public equals(other: ColorDef): boolean {\r\n return this._tbgr === other._tbgr;\r\n }\r\n\r\n /** pure black */\r\n public static readonly black = new ColorDef(ColorByName.black);\r\n /** pure white */\r\n public static readonly white = new ColorDef(ColorByName.white);\r\n /** pure red */\r\n public static readonly red = new ColorDef(ColorByName.red);\r\n /** pure green */\r\n public static readonly green = new ColorDef(ColorByName.green);\r\n /** pure blue */\r\n public static readonly blue = new ColorDef(ColorByName.blue);\r\n}\r\n"]}
1
+ {"version":3,"file":"ColorDef.js","sourceRoot":"","sources":["../../src/ColorDef.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 Symbology\r\n */\r\n\r\nimport { Geometry } from \"@itwin/core-geometry\";\r\nimport { ColorByName } from \"./ColorByName\";\r\nimport { HSLColor } from \"./HSLColor\";\r\nimport { HSVColor, HSVConstants } from \"./HSVColor\";\r\n\r\n// cspell: ignore ttbbggrr bbggrr rrggbb aabbggrr abgr rrggbb hsla lerp torgb dhue dsaturation dvalue intpart fractpart cyanish\r\n\r\n// portions adapted from Three.js Copyright © 2010-2017 three.js authors\r\n\r\nconst scratchBytes = new Uint8Array(4);\r\nconst scratchUInt32 = new Uint32Array(scratchBytes.buffer);\r\n\r\n/** The JSON representation of a [[ColorDef]] - an unsigned 32-bit integer in 0xTTBBGGRR format.\r\n * @public\r\n */\r\nexport type ColorDefProps = number;\r\n\r\n/** An immutable integer representation of a color.\r\n *\r\n * A color consists of 4 components: Red, Blue, Green, and Transparency. Each component is an 8-bit unsigned integer in the range [0..255]. A value of zero means that component contributes nothing\r\n * to the color: e.g., a color with Red=0 contains no shade of red, and a color with Transparency=0 is fully opaque. A value of 255 means that component contributes its maximum\r\n * value to the color: e.g., a color with Red=255 is as red as it is possible to be, and a color with Transparency=255 is fully transparent.\r\n *\r\n * Internally, these 4 components are combined into a single 32-bit unsigned integer as represented by [[ColorDefProps]]. This representation can result in some confusion regarding:\r\n * 1. The ordering of the individual components; and\r\n * 2. Whether to specify transparency or opacity (sometimes referred to as \"alpha\").\r\n *\r\n * ColorDef uses `0xTTBBGGRR` internally, which uses Transparency and puts Red in the low byte and Transparency in the high byte. It can be converted to `0xRRGGBB` format (blue in the low byte)\r\n * using [[getRgb]] and `0xAABBGGRRx format (red in the low byte, using opacity instead of transparency) using [[getAbgr]].\r\n *\r\n * A ColorDef can be created from a numeric [[ColorDefProps]], from a string in one of the common HTML formats (e.g., [[fromString]]), or by specifying values for the individual components\r\n * (e.g., [[from]]).\r\n *\r\n * ColorDef is **immutable**. To obtain a modified copy of a ColorDef, use methods like [[adjustedForContrast]], [[inverse]], or [[withTransparency]]. For example:\r\n * ```ts\r\n * const semiTransparentBlue = ColorDef.blue.withTransparency(100);\r\n * ```\r\n * @public\r\n */\r\nexport class ColorDef {\r\n private readonly _tbgr: number;\r\n\r\n private constructor(tbgr: number) {\r\n scratchUInt32[0] = tbgr; // Force to be a 32-bit unsigned integer\r\n this._tbgr = scratchUInt32[0];\r\n }\r\n\r\n /**\r\n * Create a new ColorDef.\r\n * @param val value to use.\r\n * If a number, it is interpreted as a 0xTTBBGGRR (Red in the low byte, high byte is transparency 0==fully opaque) value.\r\n * If a string, it must be in one of the forms supported by [[fromString]] - any unrecognized string will produce [[black]].\r\n */\r\n public static create(val?: string | ColorDefProps) {\r\n return this.fromTbgr(this.computeTbgr(val));\r\n }\r\n\r\n /** @internal */\r\n public static computeTbgr(val?: string | ColorDefProps): ColorDefProps {\r\n switch (typeof val) {\r\n case \"number\":\r\n return val;\r\n case \"string\":\r\n return this.computeTbgrFromString(val);\r\n default:\r\n return 0;\r\n }\r\n }\r\n\r\n /** Convert this ColorDef to a 32 bit number representing the 0xTTBBGGRR value */\r\n public toJSON(): ColorDefProps { return this._tbgr; }\r\n\r\n /** Create a new ColorDef from a json object. If the json object is a number, it is assumed to be a 0xTTBBGGRR value. */\r\n public static fromJSON(json?: ColorDefProps): ColorDef {\r\n return this.create(json);\r\n }\r\n\r\n /** Create a ColorDef from Red, Green, Blue, Transparency values. All inputs should be integers between 0-255. */\r\n public static from(red: number, green: number, blue: number, transparency?: number): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromComponents(red, green, blue, transparency));\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value corresponding to the specified Red, Green, Blue, Transparency components. All inputs should be integers between 0-255. */\r\n public static computeTbgrFromComponents(red: number, green: number, blue: number, transparency?: number): ColorDefProps {\r\n scratchBytes[0] = red;\r\n scratchBytes[1] = green;\r\n scratchBytes[2] = blue;\r\n scratchBytes[3] = transparency || 0;\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Create a ColorDef from its 0xTTBBGGRR representation. */\r\n public static fromTbgr(tbgr: ColorDefProps): ColorDef {\r\n switch (tbgr) {\r\n case ColorByName.black:\r\n return this.black;\r\n case ColorByName.white:\r\n return this.white;\r\n case ColorByName.red:\r\n return this.red;\r\n case ColorByName.green:\r\n return this.green;\r\n case ColorByName.blue:\r\n return this.blue;\r\n default:\r\n return new ColorDef(tbgr);\r\n }\r\n }\r\n\r\n /** Create a ColorDef from a string representation. The following representations are supported:\r\n * *\"rgb(255,0,0)\"*\r\n * *\"rgba(255,0,0,.2)\"*\r\n * *\"rgb(100%,0%,0%)\"*\r\n * *\"hsl(120,50%,50%)\"*\r\n * *\"#rrbbgg\"*\r\n * *\"blanchedAlmond\"* (see possible values from [[ColorByName]]). Case-insensitive.\r\n *\r\n * If `val` is not a valid color string, this function returns [[black]].\r\n * @see [[isValidColor]] to determine if `val` is a valid color string.\r\n */\r\n public static fromString(val: string): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromString(val));\r\n }\r\n\r\n /** Determine whether the input is a valid representation of a ColorDef.\r\n * @see [[fromString]] for the definition of a valid string representation.\r\n * @see [[ColorDefProps]] for the definition of a valid numeric representation.\r\n */\r\n public static isValidColor(val: string | number): boolean {\r\n if (typeof val === \"number\")\r\n return val >= 0 && val <= 0xffffffff && Math.floor(val) === val;\r\n\r\n return undefined !== this.tryComputeTbgrFromString(val);\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value corresponding to a string representation of a color.\r\n * If `val` is not a valid color string, this function returns 0 (black).\r\n * @see [[fromString]] for the definition of a valid color string.\r\n * @see [[tryComputeTbgrFromString]] to determine if `val` is a valid color string.\r\n */\r\n public static computeTbgrFromString(val: string): ColorDefProps {\r\n return this.tryComputeTbgrFromString(val) ?? 0;\r\n }\r\n\r\n /** Try to compute the 0xTTBBGGRR value corresponding to a string representation of a ColorDef.\r\n * @returns the corresponding numeric representation, or `undefined` if the input does not represent a color.\r\n * @see [[fromString]] for the definition of a valid color string.\r\n */\r\n public static tryComputeTbgrFromString(val: string): ColorDefProps | undefined {\r\n if (typeof val !== \"string\")\r\n return undefined;\r\n\r\n val = val.toLowerCase();\r\n let m = /^((?:rgb|hsl)a?)\\(\\s*([^\\)]*)\\)/.exec(val);\r\n if (m) { // rgb / hsl\r\n let color;\r\n const name = m[1];\r\n const components = m[2];\r\n\r\n const hasPercent = (str: string) => str[str.length - 1] === \"%\";\r\n const floatOrPercent = (str: string) => {\r\n const v = parseFloat(str);\r\n return 255 * Geometry.clamp(hasPercent(str) ? v / 100. : v, 0, 1);\r\n };\r\n const intOrPercent = (str: string) => {\r\n const v = hasPercent(str) ? (parseFloat(str) / 100.) * 255 : parseInt(str, 10);\r\n return Geometry.clamp(v, 0, 255);\r\n };\r\n\r\n switch (name) {\r\n case \"rgb\":\r\n case \"rgba\":\r\n color = /^(\\d+%*)\\s*[, ]\\s*(\\d+%*)\\s*[, ]\\s*(\\d+%*)\\s*([,\\/]\\s*([0-9]*\\.?[0-9]+%*)\\s*)?$/.exec(components);\r\n if (color) { // rgb(255,0,0) rgba(255,0,0,0.5)\r\n return this.computeTbgrFromComponents(\r\n intOrPercent(color[1]),\r\n intOrPercent(color[2]),\r\n intOrPercent(color[3]),\r\n typeof color[5] === \"string\" ? 255 - floatOrPercent(color[5]) : 0);\r\n }\r\n\r\n break;\r\n case \"hsl\":\r\n case \"hsla\":\r\n color = /^([0-9]*\\.?[0-9]+)\\s*,\\s*(\\d+)\\%\\s*,\\s*(\\d+)\\%\\s*(,\\s*([0-9]*\\.?[0-9]+)\\s*)?$/.exec(components);\r\n if (color) { // hsl(120,50%,50%) hsla(120,50%,50%,0.5)\r\n const h = parseFloat(color[1]) / 360;\r\n const s = parseInt(color[2], 10) / 100;\r\n const l = parseInt(color[3], 10) / 100;\r\n const t = typeof color[5] === \"string\" ? 255 - floatOrPercent(color[5]) : 0;\r\n return this.computeTbgrFromHSL(h, s, l, t);\r\n }\r\n\r\n break;\r\n }\r\n // eslint-disable-next-line no-cond-assign\r\n } else if (m = /^\\#([a-f0-9]+)$/.exec(val)) { // hex color\r\n const hex = m[1];\r\n const size = hex.length;\r\n\r\n if (size === 3) { // #ff0\r\n return this.computeTbgrFromComponents(\r\n parseInt(hex.charAt(0) + hex.charAt(0), 16),\r\n parseInt(hex.charAt(1) + hex.charAt(1), 16),\r\n parseInt(hex.charAt(2) + hex.charAt(2), 16), 0);\r\n }\r\n if (size === 6) { // #ff0000\r\n return this.computeTbgrFromComponents(\r\n parseInt(hex.charAt(0) + hex.charAt(1), 16),\r\n parseInt(hex.charAt(2) + hex.charAt(3), 16),\r\n parseInt(hex.charAt(4) + hex.charAt(5), 16), 0);\r\n }\r\n }\r\n\r\n if (val && val.length > 0) { // ColorRgb value\r\n for (const [key, value] of Object.entries(ColorByName))\r\n if (key.toLowerCase() === val)\r\n return value;\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n /** Get the red, green, blue, and transparency values from this ColorDef. Values will be integers between 0-255. */\r\n public get colors(): { r: number, g: number, b: number, t: number } {\r\n return ColorDef.getColors(this._tbgr);\r\n }\r\n\r\n /** Get the r,g,b,t values encoded in an 0xTTBBGGRR value. Values will be integers between 0-255. */\r\n public static getColors(tbgr: ColorDefProps) {\r\n scratchUInt32[0] = tbgr;\r\n return {\r\n b: scratchBytes[2],\r\n g: scratchBytes[1],\r\n r: scratchBytes[0],\r\n t: scratchBytes[3],\r\n };\r\n }\r\n\r\n /** The color value of this ColorDef as an integer in the form 0xTTBBGGRR (red in the low byte) */\r\n public get tbgr(): ColorDefProps { return this._tbgr; }\r\n\r\n /** Get the value of the color as a number in 0xAABBGGRR format (i.e. red is in low byte). Transparency (0==fully opaque) converted to alpha (0==fully transparent). */\r\n public getAbgr(): number {\r\n return ColorDef.getAbgr(this._tbgr);\r\n }\r\n\r\n /** Get the value of a 0xTTBBGGRR color as a number in 0xAABBGGRR format (i.e. red is in low byte). Transparency (0==fully opaque) converted to alpha (0==fully transparent). */\r\n public static getAbgr(tbgr: ColorDefProps): number {\r\n scratchUInt32[0] = tbgr;\r\n scratchBytes[3] = 255 - scratchBytes[3];\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Get the RGB value of the color as a number in 0xRRGGBB format (i.e blue is in the low byte). Transparency is ignored. Value will be from 0 to 2^24 */\r\n public getRgb(): number {\r\n return ColorDef.getRgb(this._tbgr);\r\n }\r\n\r\n /** Get the RGB value of the 0xTTBBGGRR color as a number in 0xRRGGBB format (i.e blue is in the low byte). Transparency is ignored. Value will be from 0 to 2^24 */\r\n public static getRgb(tbgr: ColorDefProps): number {\r\n scratchUInt32[0] = tbgr;\r\n return (scratchBytes[0] << 16) + (scratchBytes[1] << 8) + scratchBytes[2];\r\n }\r\n\r\n /** Return a copy of this ColorDef with the specified alpha component.\r\n * @param alpha the new alpha value as an integer between 0-255.\r\n * @returns A ColorDef with equivalent red, green, and blue components to this one but with the specified alpha.\r\n */\r\n public withAlpha(alpha: number): ColorDef {\r\n const tbgr = ColorDef.withAlpha(this._tbgr, alpha);\r\n return tbgr === this._tbgr ? this : ColorDef.fromTbgr(tbgr);\r\n }\r\n\r\n /** Return a color equivalent to the specified 0xTTBBGGRR but with modified alpha component.\r\n * @param alpha the new alpha value as an integer between 0-255.\r\n * @returns The 0xTTBBGGRR value equivalent to `tbgr` but with the specified alpha.\r\n */\r\n public static withAlpha(tbgr: ColorDefProps, alpha: number): number {\r\n scratchUInt32[0] = tbgr;\r\n scratchBytes[3] = 255 - (alpha | 0);\r\n return scratchUInt32[0];\r\n }\r\n\r\n /** Get the alpha value for this ColorDef. Will be between 0-255 */\r\n public getAlpha(): number {\r\n return ColorDef.getAlpha(this._tbgr);\r\n }\r\n\r\n /** Extract the alpha value from a 0xTTBBGGRR color. */\r\n public static getAlpha(tbgr: ColorDefProps): number {\r\n scratchUInt32[0] = tbgr;\r\n return 255 - scratchBytes[3];\r\n }\r\n\r\n /** True if this ColorDef is fully opaque. */\r\n public get isOpaque(): boolean {\r\n return ColorDef.isOpaque(this._tbgr);\r\n }\r\n\r\n /** True if the specified 0xTTBBGGRR color is fully opaque. */\r\n public static isOpaque(tbgr: ColorDefProps): boolean {\r\n return 255 === this.getAlpha(tbgr);\r\n }\r\n\r\n /** Get the transparency value for this ColorDef (inverse of alpha). Will be between 0-255. */\r\n public getTransparency(): number {\r\n return ColorDef.getTransparency(this._tbgr);\r\n }\r\n\r\n /** Extract the transparency component from a 0xTTBBGGRR color as an integer between 0-255.. */\r\n public static getTransparency(tbgr: ColorDefProps): number {\r\n scratchUInt32[0] = tbgr;\r\n return scratchBytes[3];\r\n }\r\n\r\n /** Create a copy of this ColorDef with the specified transparency.\r\n * @param transparency the new transparency value. Must be between 0-255, where 0 means 'fully opaque' and 255 means 'fully transparent'.\r\n * @returns a new ColorDef with the same color as this one and the specified transparency.\r\n */\r\n public withTransparency(transparency: number): ColorDef {\r\n const tbgr = ColorDef.withTransparency(this._tbgr, transparency);\r\n return tbgr === this._tbgr ? this : ColorDef.fromTbgr(tbgr);\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR value of the specified color and transparency.\r\n * @param transparency the new transparency as an integer between 0-255.\r\n * @returns The 0xTTBBGGRR value equivalent to `tbgr` but with the specified transparency.\r\n */\r\n public static withTransparency(tbgr: ColorDefProps, transparency: number): ColorDefProps {\r\n return this.withAlpha(tbgr, 255 - transparency);\r\n }\r\n\r\n /** The \"known name\" for this ColorDef. Will be undefined if color value is not in [[ColorByName]] list */\r\n public get name(): string | undefined {\r\n return ColorDef.getName(this.tbgr);\r\n }\r\n\r\n /** Obtain the name of the color in the [[ColorByName]] list associated with the specified 0xTTBBGGRR value, or undefined if no such named color exists.\r\n * @note A handful of colors (like \"aqua\" and \"cyan\") have identical tbgr values; in such cases the first match will be returned.\r\n */\r\n public static getName(tbgr: ColorDefProps): string | undefined {\r\n for (const [key, value] of Object.entries(ColorByName))\r\n if (value === tbgr)\r\n return key;\r\n\r\n return undefined;\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"#rrggbb\" where values are hex digits of the respective colors */\r\n public toHexString(): string {\r\n return ColorDef.toHexString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR value to a string in the form \"#rrggbb\". */\r\n public static toHexString(tbgr: ColorDefProps): string {\r\n return `#${(`000000${this.getRgb(tbgr).toString(16)}`).slice(-6)}`;\r\n }\r\n\r\n private static getColorsString(tbgr: ColorDefProps) {\r\n const c = this.getColors(tbgr);\r\n return `${c.r},${c.g},${c.b}`;\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"rgb(r,g,b)\" where values are decimal digits of the respective colors. */\r\n public toRgbString(): string {\r\n return ColorDef.toRgbString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR color to a string in the form \"rgb(r,g,b)\" where each component is specified in decimal. */\r\n public static toRgbString(tbgr: ColorDefProps): string {\r\n return `rgb(${this.getColorsString(tbgr)})`;\r\n }\r\n\r\n /** Convert this ColorDef to a string in the form \"rgba(r,g,b,a)\" where color values are decimal digits and a is a fraction */\r\n public toRgbaString(): string {\r\n return ColorDef.toRgbaString(this.tbgr);\r\n }\r\n\r\n /** Convert the 0xTTBBGGRR color to a string of the form \"rgba(r,g,b,a)\" where the color components are specified in decimal and the alpha component is a fraction. */\r\n public static toRgbaString(tbgr: ColorDefProps): string {\r\n return `rgba(${this.getColorsString(tbgr)},${this.getAlpha(tbgr) / 255.})`;\r\n }\r\n\r\n /** Create a ColorDef that is the linear interpolation of this ColorDef and another ColorDef, using a weighting factor.\r\n * @param color2 The other color\r\n * @param weight The weighting factor for color2. 0.0 = this color, 1.0 = color2.\r\n * @param result Optional ColorDef to hold result. If undefined, a new ColorDef is created.\r\n */\r\n public lerp(color2: ColorDef, weight: number): ColorDef {\r\n return ColorDef.fromTbgr(ColorDef.lerp(this.tbgr, color2.tbgr, weight));\r\n }\r\n\r\n /** Interpolate between two 0xTTBBGGRR colors using a weighting factor.\r\n * @param tbgr1 The first color\r\n * @param tbgr2 The other color\r\n * @param weight The weighting factor in [0..1]. A value of 0.0 selects `tbgr1`; 1.0 selects `tbgr2`; 0.5 mixes them evenly; etc.\r\n * @returns The linear interpolation between `tbgr1` and `tbgr2` using the specified weight.\r\n */\r\n public static lerp(tbgr1: ColorDefProps, tbgr2: ColorDefProps, weight: number): ColorDefProps {\r\n const c = this.getColors(tbgr1);\r\n const color = this.getColors(tbgr2);\r\n c.r += (color.r - c.r) * weight;\r\n c.g += (color.g - c.g) * weight;\r\n c.b += (color.b - c.b) * weight;\r\n return this.computeTbgrFromComponents(c.r, c.g, c.b, c.t);\r\n }\r\n\r\n /** Create a new ColorDef that is the inverse (all colors set to 255 - this) of this color. Ignores transparency - result has 0 transparency. */\r\n public inverse(): ColorDef {\r\n return ColorDef.fromTbgr(ColorDef.inverse(this.tbgr));\r\n }\r\n\r\n /** Return a 0xTTBBGGRR color whose color components are the inverse of the input color. The result has 0 transparency. */\r\n public static inverse(tbgr: ColorDefProps): ColorDefProps {\r\n const colors = this.getColors(tbgr);\r\n return this.computeTbgrFromComponents(255 - colors.r, 255 - colors.g, 255 - colors.b);\r\n }\r\n\r\n /** Create a ColorDef from hue, saturation, lightness values */\r\n public static fromHSL(h: number, s: number, l: number, transparency = 0): ColorDef {\r\n return this.fromTbgr(this.computeTbgrFromHSL(h, s, l, transparency));\r\n }\r\n\r\n /** Compute the 0xTTBBGGRR color corresponding to the specified hue, saturation, lightness values. */\r\n public static computeTbgrFromHSL(h: number, s: number, l: number, transparency = 0): ColorDefProps {\r\n const torgb = (p1: number, q1: number, t: number) => {\r\n if (t < 0) t += 1;\r\n if (t > 1) t -= 1;\r\n if (t < 1 / 6) return p1 + (q1 - p1) * 6 * t;\r\n if (t < 1 / 2) return q1;\r\n if (t < 2 / 3) return p1 + (q1 - p1) * 6 * (2 / 3 - t);\r\n return p1;\r\n };\r\n\r\n const hue2rgb = (p1: number, q1: number, t: number) => Math.round(torgb(p1, q1, t) * 255);\r\n const modulo = (n: number, m: number) => ((n % m) + m) % m;\r\n\r\n // h,s,l ranges are in 0.0 - 1.0\r\n h = modulo(h, 1);\r\n s = Geometry.clamp(s, 0, 1);\r\n l = Geometry.clamp(l, 0, 1);\r\n\r\n if (s === 0) {\r\n l *= 255;\r\n return this.computeTbgrFromComponents(l, l, l, transparency);\r\n }\r\n\r\n const p = l <= 0.5 ? l * (1 + s) : l + s - (l * s);\r\n const q = (2 * l) - p;\r\n return this.computeTbgrFromComponents(\r\n hue2rgb(q, p, h + 1 / 3),\r\n hue2rgb(q, p, h),\r\n hue2rgb(q, p, h - 1 / 3),\r\n transparency);\r\n }\r\n\r\n /** Create an [[HSLColor]] from this ColorDef */\r\n public toHSL(): HSLColor {\r\n // h,s,l ranges are in 0.0 - 1.0\r\n const col = this.colors;\r\n col.r /= 255;\r\n col.g /= 255;\r\n col.b /= 255;\r\n const max = Math.max(col.r, col.g, col.b);\r\n const min = Math.min(col.r, col.g, col.b);\r\n\r\n let hue = 0;\r\n let saturation;\r\n const lightness = (min + max) / 2.0;\r\n\r\n if (min === max) {\r\n saturation = 0;\r\n } else {\r\n const delta = max - min;\r\n saturation = lightness <= 0.5 ? delta / (max + min) : delta / (2 - max - min);\r\n switch (max) {\r\n case col.r: hue = (col.g - col.b) / delta + (col.g < col.b ? 6 : 0); break;\r\n case col.g: hue = (col.b - col.r) / delta + 2; break;\r\n case col.b: hue = (col.r - col.g) / delta + 4; break;\r\n }\r\n hue /= 6;\r\n }\r\n\r\n return new HSLColor(hue, saturation, lightness);\r\n }\r\n\r\n /** Create an [[HSVColor]] from this ColorDef */\r\n public toHSV(): HSVColor {\r\n const { r, g, b } = this.colors;\r\n let min = (r < g) ? r : g;\r\n if (b < min)\r\n min = b;\r\n\r\n let max = (r > g) ? r : g;\r\n if (b > max)\r\n max = b;\r\n\r\n /* amount of \"blackness\" present */\r\n const v = Math.floor((max / 255.0 * 100) + 0.5);\r\n const deltaRgb = max - min;\r\n const s = (max !== 0.0) ? Math.floor((deltaRgb / max * 100) + 0.5) : 0;\r\n let h = 0;\r\n\r\n if (s) {\r\n const redDistance = (max - r) / deltaRgb;\r\n const greenDistance = (max - g) / deltaRgb;\r\n const blueDistance = (max - b) / deltaRgb;\r\n\r\n let intermediateHue: number;\r\n if (r === max) /* color between yellow & magenta */\r\n intermediateHue = blueDistance - greenDistance;\r\n else if (g === max) /* color between cyan & yellow */\r\n intermediateHue = 2.0 + redDistance - blueDistance;\r\n else /* color between magenta & cyan */\r\n intermediateHue = 4.0 + greenDistance - redDistance;\r\n\r\n /* intermediate hue is [0..6] */\r\n intermediateHue *= 60;\r\n\r\n if (intermediateHue < 0.0)\r\n intermediateHue += 360;\r\n\r\n h = Math.floor(intermediateHue + 0.5);\r\n\r\n if (h >= 360)\r\n h = 0;\r\n } else {\r\n h = 0;\r\n }\r\n\r\n return new HSVColor(h, s, v);\r\n }\r\n\r\n /** Create a ColorDef from an HSVColor */\r\n public static fromHSV(hsv: HSVColor, transparency = 0): ColorDef {\r\n // Check for simple case first.\r\n if ((!hsv.s) || (hsv.h === -1)) {\r\n // hue must be undefined, have no color only white\r\n const white = 0xff & Math.floor(((255.0 * hsv.v) / 100.0) + 0.5 + 3.0e-14);\r\n return ColorDef.from(white, white, white, 0);\r\n }\r\n\r\n let dhue = hsv.h, dsaturation = hsv.s, dvalue = hsv.v;\r\n if (dhue === 360)\r\n dhue = 0.0;\r\n\r\n dhue /= 60; // hue is now [0..6]\r\n const hueIntpart = Math.floor(dhue); // convert double -> int\r\n const hueFractpart = dhue - hueIntpart;\r\n dvalue /= 100;\r\n dsaturation /= 100;\r\n\r\n const p = 0xff & Math.floor((dvalue * (1.0 - dsaturation) * 255.0) + 0.5);\r\n const q = 0xff & Math.floor((dvalue * (1.0 - (dsaturation * hueFractpart)) * 255.0) + 0.5);\r\n const t = 0xff & Math.floor((dvalue * (1.0 - (dsaturation * (1.0 - hueFractpart))) * 255.0) + 0.5);\r\n const v = 0xff & Math.floor(dvalue * 255 + 0.5);\r\n\r\n let r = 0, b = 0, g = 0;\r\n switch (hueIntpart) {\r\n case 0: r = v; g = t; b = p; break; // reddish\r\n case 1: r = q, g = v; b = p; break; // yellowish\r\n case 2: r = p, g = v; b = t; break; // greenish\r\n case 3: r = p, g = q; b = v; break; // cyanish\r\n case 4: r = t, g = p; b = v; break; // bluish\r\n case 5: r = v, g = p; b = q; break; // magenta-ish\r\n }\r\n\r\n return ColorDef.from(r, g, b, transparency);\r\n }\r\n\r\n private visibilityCheck(other: ColorDef): number {\r\n const fg = this.colors;\r\n const bg = other.colors;\r\n // Compute luminosity\r\n const red = Math.abs(fg.r - bg.r);\r\n const green = Math.abs(fg.g - bg.g);\r\n const blue = Math.abs(fg.b - bg.b);\r\n return (0.30 * red) + (0.59 * green) + (0.11 * blue);\r\n }\r\n\r\n /**\r\n * Create a new ColorDef that is adjusted from this ColorDef for maximum contrast against another color. The color will either be lighter\r\n * or darker, depending on which has more visibility against the other color.\r\n * @param other the color to contrast with\r\n * @param alpha optional alpha value for the adjusted color. If not supplied alpha from this color is used.\r\n */\r\n public adjustedForContrast(other: ColorDef, alpha?: number): ColorDef {\r\n const visibility = this.visibilityCheck(other);\r\n if (HSVConstants.VISIBILITY_GOAL <= visibility) {\r\n return undefined !== alpha ? this.withAlpha(alpha) : this;\r\n }\r\n\r\n const adjPercent = Math.floor(((HSVConstants.VISIBILITY_GOAL - visibility) / 255.0) * 100.0);\r\n let darkerHSV = this.toHSV();\r\n let brightHSV = darkerHSV.clone();\r\n\r\n darkerHSV = darkerHSV.adjusted(true, adjPercent);\r\n brightHSV = brightHSV.adjusted(false, adjPercent);\r\n\r\n if (undefined === alpha)\r\n alpha = this.getAlpha();\r\n\r\n const darker = ColorDef.fromHSV(darkerHSV).withAlpha(alpha);\r\n const bright = ColorDef.fromHSV(brightHSV).withAlpha(alpha);\r\n\r\n if (bright.getRgb() === other.getRgb()) // Couldn't adjust brighter...\r\n return darker;\r\n\r\n if (darker.getRgb() === other.getRgb()) // Couldn't adjust darker...\r\n return bright;\r\n\r\n // NOTE: Best choice is the one most visible against the other color...\r\n return (bright.visibilityCheck(other) >= darker.visibilityCheck(other)) ? bright : darker;\r\n }\r\n\r\n /** True if the value of this ColorDef is the same as another ColorDef. */\r\n public equals(other: ColorDef): boolean {\r\n return this._tbgr === other._tbgr;\r\n }\r\n\r\n /** pure black */\r\n public static readonly black = new ColorDef(ColorByName.black);\r\n /** pure white */\r\n public static readonly white = new ColorDef(ColorByName.white);\r\n /** pure red */\r\n public static readonly red = new ColorDef(ColorByName.red);\r\n /** pure green */\r\n public static readonly green = new ColorDef(ColorByName.green);\r\n /** pure blue */\r\n public static readonly blue = new ColorDef(ColorByName.blue);\r\n}\r\n"]}
@@ -203,6 +203,12 @@ export interface GeodeticTransformProps {
203
203
  * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model
204
204
  * for the purpose of performing the transformation.*/
205
205
  targetEllipsoid?: GeodeticEllipsoidProps;
206
+ /** The id of the source datum. */
207
+ sourceDatumId?: string;
208
+ /** The id of the target datum. This id is useful to seach within a geodetic transform path for
209
+ * a shortcut to another included datum.
210
+ */
211
+ targetDatumId?: string;
206
212
  /** When method is Geocentric this property contains the geocentric parameters */
207
213
  geocentric?: GeocentricTransformProps;
208
214
  /** When method is PositionalVector this property contains the positional vector parameters */
@@ -225,6 +231,12 @@ export declare class GeodeticTransform implements GeodeticTransformProps {
225
231
  * The target ellipsoid identifier enables obtaining the shape of the Earth mathematical model
226
232
  * for the purpose of performing the transformation.*/
227
233
  readonly targetEllipsoid?: GeodeticEllipsoid;
234
+ /** The id of the source datum. */
235
+ readonly sourceDatumId?: string;
236
+ /** The id of the target datum. This id is useful to seach within a geodetic transform path for
237
+ * a shortcut to another included datum.
238
+ */
239
+ readonly targetDatumId?: string;
228
240
  /** When method is Geocentric this property contains the geocentric parameters */
229
241
  readonly geocentric?: GeocentricTransform;
230
242
  /** When method is PositionalVector this property contains the positional vector parameters */
@@ -243,6 +255,43 @@ export declare class GeodeticTransform implements GeodeticTransformProps {
243
255
  * @public */
244
256
  equals(other: GeodeticTransform): boolean;
245
257
  }
258
+ /** This interface represents a geodetic datum transform path. It contains a list of transforms linking
259
+ * a source to a target geodetic datum.
260
+ * @public
261
+ */
262
+ export interface GeodeticTransformPathProps {
263
+ /** Source geodetic datum key name */
264
+ sourceDatumId?: string;
265
+ /** Target geodetic datum key name */
266
+ targetDatumId?: string;
267
+ /** The transformation path from source datum to target datum.
268
+ */
269
+ transforms?: GeodeticTransformProps[];
270
+ }
271
+ /** This class represents a geodetic datum transform path. It contains a list of transforms linking
272
+ * a source to a target geodetic datum.
273
+ * @public
274
+ */
275
+ export declare class GeodeticTransformPath implements GeodeticTransformPathProps {
276
+ /** Source geodetic datum key name */
277
+ readonly sourceDatumId?: string;
278
+ /** Target geodetic datum key name */
279
+ readonly targetDatumId?: string;
280
+ /** The transformation path from source datum to target datum.
281
+ */
282
+ readonly transforms?: GeodeticTransform[];
283
+ constructor(_data?: GeodeticTransformPathProps);
284
+ /** Creates a Geodetic transform path from JSON representation.
285
+ * @public */
286
+ static fromJSON(data: GeodeticTransformPathProps): GeodeticTransformPath;
287
+ /** Creates a JSON from the Geodetic transform path definition
288
+ * @public */
289
+ toJSON(): GeodeticTransformPathProps;
290
+ /** Compares two Geodetic Transform Paths. It is a strict compare operation not an equivalence test.
291
+ * It takes into account descriptive properties not only mathematical definition properties.
292
+ * @public */
293
+ equals(other: GeodeticTransformPath): boolean;
294
+ }
246
295
  /** This interface represents a geodetic datum. Geodetic datums are based on an ellipsoid.
247
296
  * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.
248
297
  * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying
@@ -278,6 +327,16 @@ export interface GeodeticDatumProps {
278
327
  * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.
279
328
  */
280
329
  transforms?: GeodeticTransformProps[];
330
+ /** The optional list of transformation paths to other datum. These should only be used if the path to
331
+ * these datum is not included in the transforms property definition of the transformation to WGS84.
332
+ * It should not be used either if the transformation to the datum can be infered from the concatenation
333
+ * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is
334
+ * inherent to the nature of the datum. As an example it is required to represent the transformation
335
+ * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path
336
+ * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related
337
+ * to the available paths to WGS84.
338
+ */
339
+ additionalTransformPaths?: GeodeticTransformPathProps[];
281
340
  }
282
341
  /** This class represents a geodetic datum. Geodetic datums are based on an ellipsoid.
283
342
  * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.
@@ -316,6 +375,16 @@ export declare class GeodeticDatum implements GeodeticDatumProps {
316
375
  * required to transform to WGS84, such as the newer datum definitions for Slovakia or Switzerland.
317
376
  */
318
377
  readonly transforms?: GeodeticTransform[];
378
+ /** The optional list of transformation paths to other datum. These should only be used if the path to
379
+ * these datum is not included in the transforms property definition of the transformation to WGS84.
380
+ * It should not be used either if the transformation to the datum can be infered from the concatenation
381
+ * of their individual paths to WGS84. These should be used to express an alternate shortcut path that is
382
+ * inherent to the nature of the datum. As an example it is required to represent the transformation
383
+ * from NAD27 to NAD83/2011 since NAD83/2011 is coincident to WGS84 yet the NAD27 datum to WGS84 path
384
+ * only includes transformation to NAD83, making the path of transforms to NAD83/2011 not related
385
+ * to the available paths to WGS84.
386
+ */
387
+ readonly additionalTransformPaths?: GeodeticTransformPath[];
319
388
  constructor(_data?: GeodeticDatumProps);
320
389
  /** Creates a Geodetic Datum from JSON representation.
321
390
  * @public */
@@ -1 +1 @@
1
- {"version":3,"file":"GeodeticDatum.d.ts","sourceRoot":"","sources":["../../../src/geometry/GeodeticDatum.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"GeodeticDatum.d.ts","sourceRoot":"","sources":["../../../src/geometry/GeodeticDatum.ts"],"names":[],"mappings":"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"}
@@ -182,6 +182,8 @@ export class GeodeticTransform {
182
182
  this.method = data.method;
183
183
  this.sourceEllipsoid = data.sourceEllipsoid ? GeodeticEllipsoid.fromJSON(data.sourceEllipsoid) : undefined;
184
184
  this.targetEllipsoid = data.targetEllipsoid ? GeodeticEllipsoid.fromJSON(data.targetEllipsoid) : undefined;
185
+ this.sourceDatumId = data.sourceDatumId;
186
+ this.targetDatumId = data.targetDatumId;
185
187
  this.geocentric = data.geocentric ? GeocentricTransform.fromJSON(data.geocentric) : undefined;
186
188
  this.positionalVector = data.positionalVector ? PositionalVectorTransform.fromJSON(data.positionalVector) : undefined;
187
189
  this.gridFile = data.gridFile ? GridFileTransform.fromJSON(data.gridFile) : undefined;
@@ -198,6 +200,8 @@ export class GeodeticTransform {
198
200
  const data = { method: this.method };
199
201
  data.sourceEllipsoid = this.sourceEllipsoid ? this.sourceEllipsoid.toJSON() : undefined;
200
202
  data.targetEllipsoid = this.targetEllipsoid ? this.targetEllipsoid.toJSON() : undefined;
203
+ data.sourceDatumId = this.sourceDatumId;
204
+ data.targetDatumId = this.targetDatumId;
201
205
  data.geocentric = this.geocentric ? this.geocentric.toJSON() : undefined;
202
206
  data.positionalVector = this.positionalVector ? this.positionalVector.toJSON() : undefined;
203
207
  data.gridFile = this.gridFile ? this.gridFile.toJSON() : undefined;
@@ -209,6 +213,8 @@ export class GeodeticTransform {
209
213
  equals(other) {
210
214
  if (this.method !== other.method)
211
215
  return false;
216
+ if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)
217
+ return false;
212
218
  if ((this.sourceEllipsoid === undefined) !== (other.sourceEllipsoid === undefined))
213
219
  return false;
214
220
  if (this.sourceEllipsoid && !this.sourceEllipsoid.equals(other.sourceEllipsoid))
@@ -232,6 +238,58 @@ export class GeodeticTransform {
232
238
  return true;
233
239
  }
234
240
  }
241
+ /** This class represents a geodetic datum transform path. It contains a list of transforms linking
242
+ * a source to a target geodetic datum.
243
+ * @public
244
+ */
245
+ export class GeodeticTransformPath {
246
+ constructor(_data) {
247
+ if (_data) {
248
+ this.sourceDatumId = _data.sourceDatumId;
249
+ this.targetDatumId = _data.targetDatumId;
250
+ if (Array.isArray(_data.transforms)) {
251
+ this.transforms = [];
252
+ for (const item of _data.transforms)
253
+ this.transforms.push(GeodeticTransform.fromJSON(item));
254
+ }
255
+ }
256
+ }
257
+ /** Creates a Geodetic transform path from JSON representation.
258
+ * @public */
259
+ static fromJSON(data) {
260
+ return new GeodeticTransformPath(data);
261
+ }
262
+ /** Creates a JSON from the Geodetic transform path definition
263
+ * @public */
264
+ toJSON() {
265
+ const data = {};
266
+ data.sourceDatumId = this.sourceDatumId;
267
+ data.targetDatumId = this.targetDatumId;
268
+ if (Array.isArray(this.transforms)) {
269
+ data.transforms = [];
270
+ for (const item of this.transforms)
271
+ data.transforms.push(item.toJSON());
272
+ }
273
+ return data;
274
+ }
275
+ /** Compares two Geodetic Transform Paths. It is a strict compare operation not an equivalence test.
276
+ * It takes into account descriptive properties not only mathematical definition properties.
277
+ * @public */
278
+ equals(other) {
279
+ if (this.sourceDatumId !== other.sourceDatumId || this.targetDatumId !== other.targetDatumId)
280
+ return false;
281
+ if ((this.transforms === undefined) !== (other.transforms === undefined))
282
+ return false;
283
+ if (this.transforms && other.transforms) {
284
+ if (this.transforms.length !== other.transforms.length)
285
+ return false;
286
+ for (let idx = 0; idx < this.transforms.length; ++idx)
287
+ if (!this.transforms[idx].equals(other.transforms[idx]))
288
+ return false;
289
+ }
290
+ return true;
291
+ }
292
+ }
235
293
  /** This class represents a geodetic datum. Geodetic datums are based on an ellipsoid.
236
294
  * In addition to the ellipsoid definition they are the base for longitude/latitude coordinates.
237
295
  * Geodetic datums are the basis for geodetic transformations. Most geodetic datums are defined by specifying
@@ -258,6 +316,11 @@ export class GeodeticDatum {
258
316
  for (const item of _data.transforms)
259
317
  this.transforms.push(GeodeticTransform.fromJSON(item));
260
318
  }
319
+ if (Array.isArray(_data.additionalTransformPaths)) {
320
+ this.additionalTransformPaths = [];
321
+ for (const item of _data.additionalTransformPaths)
322
+ this.additionalTransformPaths.push(GeodeticTransformPath.fromJSON(item));
323
+ }
261
324
  }
262
325
  }
263
326
  /** Creates a Geodetic Datum from JSON representation.
@@ -282,6 +345,11 @@ export class GeodeticDatum {
282
345
  for (const item of this.transforms)
283
346
  data.transforms.push(item.toJSON());
284
347
  }
348
+ if (Array.isArray(this.additionalTransformPaths)) {
349
+ data.additionalTransformPaths = [];
350
+ for (const item of this.additionalTransformPaths)
351
+ data.additionalTransformPaths.push(item.toJSON());
352
+ }
285
353
  return data;
286
354
  }
287
355
  /** Compares two Geodetic Datums. It is a strict compare operation not an equivalence test.
@@ -308,6 +376,15 @@ export class GeodeticDatum {
308
376
  if (!this.transforms[idx].equals(other.transforms[idx]))
309
377
  return false;
310
378
  }
379
+ if ((this.additionalTransformPaths === undefined) !== (other.additionalTransformPaths === undefined))
380
+ return false;
381
+ if (this.additionalTransformPaths && other.additionalTransformPaths) {
382
+ if (this.additionalTransformPaths.length !== other.additionalTransformPaths.length)
383
+ return false;
384
+ for (let idx = 0; idx < this.additionalTransformPaths.length; ++idx)
385
+ if (!this.additionalTransformPaths[idx].equals(other.additionalTransformPaths[idx]))
386
+ return false;
387
+ }
311
388
  return true;
312
389
  }
313
390
  }