deeptwins-cesium-engine 0.1.2 → 0.1.4

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 (219) hide show
  1. package/Build/Workers/chunk-2HWLF3FT.js +837 -0
  2. package/Build/Workers/chunk-2KXMJ5XS.js +3792 -0
  3. package/Build/Workers/chunk-2NPCLB3H.js +56 -0
  4. package/Build/Workers/chunk-2ZHQTIBH.js +1483 -0
  5. package/Build/Workers/chunk-3GLYOW63.js +352 -0
  6. package/Build/Workers/chunk-3L22KMPU.js +219 -0
  7. package/Build/Workers/chunk-3Q6V2B2I.js +73 -0
  8. package/Build/Workers/chunk-3QOKKRIG.js +387 -0
  9. package/Build/Workers/chunk-44YZFGRH.js +1800 -0
  10. package/Build/Workers/chunk-45VV4SBO.js +2342 -0
  11. package/Build/Workers/chunk-4EJ4AA2S.js +368 -0
  12. package/Build/Workers/chunk-4IJFHUL6.js +414 -0
  13. package/Build/Workers/chunk-4K3V5CGW.js +454 -0
  14. package/Build/Workers/chunk-4M4QL6KJ.js +305 -0
  15. package/Build/Workers/chunk-4YNRIEQ6.js +288 -0
  16. package/Build/Workers/chunk-56CVDPH5.js +352 -0
  17. package/Build/Workers/chunk-5CTAAPXH.js +1483 -0
  18. package/Build/Workers/chunk-5ISZ6NJD.js +102 -0
  19. package/Build/Workers/chunk-5SDHYIOS.js +56 -0
  20. package/Build/Workers/chunk-66TGUMCU.js +2719 -0
  21. package/Build/Workers/chunk-6EJMTDQJ.js +163 -0
  22. package/Build/Workers/chunk-6VWXYSMH.js +959 -0
  23. package/Build/Workers/chunk-6VZ7VB2Q.js +241 -0
  24. package/Build/Workers/chunk-7AMRE57Q.js +301 -0
  25. package/Build/Workers/chunk-7DH6C33H.js +398 -0
  26. package/Build/Workers/chunk-7VUS3FVE.js +38 -0
  27. package/Build/Workers/chunk-7Y3ZA6H3.js +198 -0
  28. package/Build/Workers/chunk-A6BMHZNA.js +38 -0
  29. package/Build/Workers/chunk-A7XY2MN7.js +171 -0
  30. package/Build/Workers/chunk-AC7ND63S.js +57 -0
  31. package/Build/Workers/chunk-AHCZ757M.js +9230 -0
  32. package/Build/Workers/chunk-ANOA7E7F.js +56 -0
  33. package/Build/Workers/chunk-AYO5HHV6.js +789 -0
  34. package/Build/Workers/chunk-BE2N56VZ.js +1344 -0
  35. package/Build/Workers/chunk-BR3BPM64.js +9230 -0
  36. package/Build/Workers/chunk-BVMRWGOK.js +455 -0
  37. package/Build/Workers/chunk-BXEL2NX7.js +455 -0
  38. package/Build/Workers/chunk-C5BO2JCG.js +278 -0
  39. package/Build/Workers/chunk-CIRQNZVR.js +301 -0
  40. package/Build/Workers/chunk-CM67CQME.js +305 -0
  41. package/Build/Workers/chunk-D3QIW4DH.js +630 -0
  42. package/Build/Workers/chunk-E5W7QIGZ.js +511 -0
  43. package/Build/Workers/chunk-E6CYGUJI.js +1054 -0
  44. package/Build/Workers/chunk-EIZ23IOX.js +414 -0
  45. package/Build/Workers/chunk-EIZJUMQY.js +101 -0
  46. package/Build/Workers/chunk-EXTMZJXB.js +82 -0
  47. package/Build/Workers/chunk-EYOOSIBW.js +682 -0
  48. package/Build/Workers/chunk-F37WADVC.js +1054 -0
  49. package/Build/Workers/chunk-FIWPJFHX.js +101 -0
  50. package/Build/Workers/chunk-FM32TNGT.js +198 -0
  51. package/Build/Workers/chunk-FOMYIEIB.js +476 -0
  52. package/Build/Workers/chunk-FWYDLSVQ.js +97 -0
  53. package/Build/Workers/chunk-HGZR6CZF.js +1067 -0
  54. package/Build/Workers/chunk-HIXHDABG.js +288 -0
  55. package/Build/Workers/chunk-HMCCZZWE.js +97 -0
  56. package/Build/Workers/chunk-HW54WHGM.js +2719 -0
  57. package/Build/Workers/chunk-IHYAI7GF.js +973 -0
  58. package/Build/Workers/chunk-INLQ7LVK.js +837 -0
  59. package/Build/Workers/chunk-IQMESTCB.js +124 -0
  60. package/Build/Workers/chunk-J4PISUNT.js +2342 -0
  61. package/Build/Workers/chunk-JSWU557I.js +693 -0
  62. package/Build/Workers/chunk-KHONDSQ7.js +693 -0
  63. package/Build/Workers/chunk-KLUL2SOE.js +352 -0
  64. package/Build/Workers/chunk-KMBLKQCC.js +1992 -0
  65. package/Build/Workers/chunk-KOTWWQN7.js +171 -0
  66. package/Build/Workers/chunk-KWV6ZTF4.js +163 -0
  67. package/Build/Workers/chunk-LSEFPQHG.js +476 -0
  68. package/Build/Workers/chunk-M66X4O24.js +44 -0
  69. package/Build/Workers/chunk-M6IXKBC7.js +1992 -0
  70. package/Build/Workers/chunk-MFUC3D5C.js +162 -0
  71. package/Build/Workers/chunk-MRMNELAH.js +82 -0
  72. package/Build/Workers/chunk-N3NUA5H2.js +3792 -0
  73. package/Build/Workers/chunk-NFB2NXJN.js +138 -0
  74. package/Build/Workers/chunk-NQAXBK4K.js +789 -0
  75. package/Build/Workers/chunk-NUGQWV6S.js +352 -0
  76. package/Build/Workers/chunk-O7S7WL7K.js +278 -0
  77. package/Build/Workers/chunk-ODZYB26X.js +1287 -0
  78. package/Build/Workers/chunk-OEHJY463.js +3201 -0
  79. package/Build/Workers/chunk-OMMRNMXF.js +44 -0
  80. package/Build/Workers/chunk-OZ3CQDO3.js +138 -0
  81. package/Build/Workers/chunk-PNXBG64I.js +219 -0
  82. package/Build/Workers/chunk-PYR35GK4.js +973 -0
  83. package/Build/Workers/chunk-Q4CXGW74.js +57 -0
  84. package/Build/Workers/chunk-QGISLKCW.js +147 -0
  85. package/Build/Workers/chunk-QQHVOJW6.js +497 -0
  86. package/Build/Workers/chunk-QWCMMRJW.js +58 -0
  87. package/Build/Workers/chunk-RDEZCHF4.js +398 -0
  88. package/Build/Workers/chunk-SJTE7FVN.js +778 -0
  89. package/Build/Workers/chunk-SM5T67LR.js +162 -0
  90. package/Build/Workers/chunk-T27NNXEU.js +58 -0
  91. package/Build/Workers/chunk-T4J5BWUO.js +511 -0
  92. package/Build/Workers/chunk-T6JS4BRN.js +140 -0
  93. package/Build/Workers/chunk-UH6DUQBW.js +140 -0
  94. package/Build/Workers/chunk-UJAH6XKF.js +73 -0
  95. package/Build/Workers/chunk-UKSTJ2PH.js +454 -0
  96. package/Build/Workers/chunk-UQCDCCZ7.js +368 -0
  97. package/Build/Workers/chunk-UXIFNEA3.js +1287 -0
  98. package/Build/Workers/chunk-UXJ6J5L7.js +56 -0
  99. package/Build/Workers/chunk-V4VUAZXI.js +1800 -0
  100. package/Build/Workers/chunk-VQH2YXO2.js +497 -0
  101. package/Build/Workers/chunk-VXKCLSE4.js +241 -0
  102. package/Build/Workers/chunk-W3U6YBEI.js +280 -0
  103. package/Build/Workers/chunk-W75ZVFKP.js +778 -0
  104. package/Build/Workers/chunk-WCDFJYFB.js +1344 -0
  105. package/Build/Workers/chunk-WME5M6W3.js +630 -0
  106. package/Build/Workers/chunk-XDQBQB64.js +1067 -0
  107. package/Build/Workers/chunk-Y6HOIWE5.js +959 -0
  108. package/Build/Workers/chunk-YEMC2ZOR.js +147 -0
  109. package/Build/Workers/chunk-YWNF3TPE.js +682 -0
  110. package/Build/Workers/chunk-Z55VGWJP.js +280 -0
  111. package/Build/Workers/chunk-Z5YWP24C.js +124 -0
  112. package/Build/Workers/chunk-ZHXCWUJB.js +387 -0
  113. package/Build/Workers/chunk-ZIMPUF2I.js +102 -0
  114. package/Build/Workers/chunk-ZKDWYQKC.js +3201 -0
  115. package/Build/Workers/combineGeometry.js +24 -22
  116. package/Build/Workers/createBoxGeometry.js +18 -16
  117. package/Build/Workers/createBoxOutlineGeometry.js +23 -25
  118. package/Build/Workers/createCircleGeometry.js +29 -27
  119. package/Build/Workers/createCircleOutlineGeometry.js +22 -20
  120. package/Build/Workers/createCoplanarPolygonGeometry.js +43 -43
  121. package/Build/Workers/createCoplanarPolygonOutlineGeometry.js +37 -35
  122. package/Build/Workers/createCorridorGeometry.js +46 -49
  123. package/Build/Workers/createCorridorOutlineGeometry.js +40 -43
  124. package/Build/Workers/createCylinderGeometry.js +20 -18
  125. package/Build/Workers/createCylinderOutlineGeometry.js +27 -25
  126. package/Build/Workers/createEllipseGeometry.js +28 -25
  127. package/Build/Workers/createEllipseOutlineGeometry.js +21 -18
  128. package/Build/Workers/createEllipsoidGeometry.js +19 -17
  129. package/Build/Workers/createEllipsoidOutlineGeometry.js +18 -16
  130. package/Build/Workers/createFrustumGeometry.js +18 -16
  131. package/Build/Workers/createFrustumOutlineGeometry.js +21 -21
  132. package/Build/Workers/createGeometry.js +31 -26
  133. package/Build/Workers/createGroundPolylineGeometry.js +188 -135
  134. package/Build/Workers/createPlaneGeometry.js +22 -21
  135. package/Build/Workers/createPlaneOutlineGeometry.js +15 -13
  136. package/Build/Workers/createPolygonGeometry.js +51 -52
  137. package/Build/Workers/createPolygonOutlineGeometry.js +43 -44
  138. package/Build/Workers/createPolylineGeometry.js +37 -40
  139. package/Build/Workers/createPolylineVolumeGeometry.js +41 -44
  140. package/Build/Workers/createPolylineVolumeOutlineGeometry.js +36 -39
  141. package/Build/Workers/createRectangleGeometry.js +47 -53
  142. package/Build/Workers/createRectangleOutlineGeometry.js +32 -33
  143. package/Build/Workers/createSimplePolylineGeometry.js +33 -34
  144. package/Build/Workers/createSphereGeometry.js +20 -20
  145. package/Build/Workers/createSphereOutlineGeometry.js +19 -19
  146. package/Build/Workers/createTaskProcessorWorker.js +3 -3
  147. package/Build/Workers/createVectorTileClampedPolylines.js +16 -14
  148. package/Build/Workers/createVectorTileGeometries.js +24 -22
  149. package/Build/Workers/createVectorTilePoints.js +15 -13
  150. package/Build/Workers/createVectorTilePolygons.js +24 -21
  151. package/Build/Workers/createVectorTilePolylines.js +16 -14
  152. package/Build/Workers/createVerticesFromCesium3DTilesTerrain.js +25 -25
  153. package/Build/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +29 -27
  154. package/Build/Workers/createVerticesFromHeightmap.js +42 -63
  155. package/Build/Workers/createVerticesFromQuantizedTerrainMesh.js +26 -280
  156. package/Build/Workers/createWallGeometry.js +35 -36
  157. package/Build/Workers/createWallOutlineGeometry.js +33 -34
  158. package/Build/Workers/decodeDraco.js +10 -11
  159. package/Build/Workers/decodeGoogleEarthEnterprisePacket.js +5 -5
  160. package/Build/Workers/decodeI3S.js +16 -20
  161. package/Build/Workers/gaussianSplatSorter.js +4 -4
  162. package/Build/Workers/gaussianSplatTextureGenerator.js +4 -4
  163. package/Build/Workers/incrementallyBuildTerrainPicker.js +20 -12
  164. package/Build/Workers/transcodeKTX2.js +42 -14
  165. package/Build/Workers/transferTypedArrayTest.js +1 -1
  166. package/Build/Workers/upsampleQuantizedTerrainMesh.js +24 -21
  167. package/Build/Workers/upsampleVerticesFromCesium3DTilesTerrain.js +25 -25
  168. package/Source/Shaders/BillboardCollectionFS.js +85 -81
  169. package/Source/Shaders/BillboardCollectionVS.js +60 -118
  170. package/Source/Shaders/Builtin/Constants/passCesium3DTile.js +1 -1
  171. package/Source/Shaders/Builtin/Constants/passCesium3DTileClassification.js +1 -1
  172. package/Source/Shaders/Builtin/Constants/passCesium3DTileClassificationIgnoreShow.js +1 -1
  173. package/Source/Shaders/Builtin/Constants/passCesium3DTileEdges.js +12 -0
  174. package/Source/Shaders/Builtin/Constants/passCesium3DTileEdgesDirect.js +11 -0
  175. package/Source/Shaders/Builtin/Constants/passGaussianSplats.js +11 -0
  176. package/Source/Shaders/Builtin/Constants/passOpaque.js +1 -1
  177. package/Source/Shaders/Builtin/Constants/passOverlay.js +1 -1
  178. package/Source/Shaders/Builtin/Constants/passTranslucent.js +1 -1
  179. package/Source/Shaders/Builtin/Constants/passVoxels.js +1 -1
  180. package/Source/Shaders/Builtin/CzmBuiltins.js +12 -0
  181. package/Source/Shaders/Builtin/Functions/columbusViewMorph.js +8 -1
  182. package/Source/Shaders/Builtin/Functions/computeTextureTransform.js +25 -0
  183. package/Source/Shaders/Builtin/Functions/decodeRGB8.js +24 -0
  184. package/Source/Shaders/Builtin/Functions/modelToWindowCoordinates.js +2 -1
  185. package/Source/Shaders/Builtin/Functions/unpackTexture.js +37 -0
  186. package/Source/Shaders/Builtin/Functions/windowToEyeCoordinates.js +0 -1
  187. package/Source/Shaders/EllipsoidVS.js +4 -4
  188. package/Source/Shaders/FXAA3_11.js +2 -0
  189. package/Source/Shaders/GlobeFS.js +22 -0
  190. package/Source/Shaders/GlobeVS.js +3 -2
  191. package/Source/Shaders/Model/MaterialStageFS.js +50 -20
  192. package/Source/Shaders/Model/MetadataStageFS.js +2 -1
  193. package/Source/Shaders/Model/MetadataStageVS.js +2 -1
  194. package/Source/Shaders/Model/ModelFS.js +32 -2
  195. package/Source/Shaders/Model/ModelVS.js +15 -1
  196. package/Source/Shaders/Model/PointCloudStylingStageVS.js +2 -1
  197. package/Source/Shaders/Model/PrimitiveOutlineStageFS.js +0 -1
  198. package/Source/Shaders/PointPrimitiveCollectionVS.js +8 -39
  199. package/Source/Shaders/PolygonSignedDistanceFS.js +64 -33
  200. package/Source/Shaders/PolylineCommon.js +1 -1
  201. package/Source/Shaders/ShadowVolumeAppearanceFS.js +7 -15
  202. package/Source/Shaders/SkyAtmosphereVS.js +2 -1
  203. package/Source/Shaders/Voxels/IntersectBox.js +20 -33
  204. package/Source/Shaders/Voxels/IntersectCylinder.js +28 -32
  205. package/Source/Shaders/Voxels/IntersectDepth.js +10 -6
  206. package/Source/Shaders/Voxels/IntersectEllipsoid.js +12 -20
  207. package/Source/Shaders/Voxels/IntersectLongitude.js +21 -9
  208. package/Source/Shaders/Voxels/Intersection.js +3 -5
  209. package/Source/Shaders/Voxels/IntersectionUtils.js +2 -1
  210. package/Source/Shaders/Voxels/Megatexture.js +15 -83
  211. package/Source/Shaders/Voxels/Octree.js +53 -61
  212. package/Source/Shaders/Voxels/VoxelFS.js +67 -52
  213. package/Source/Shaders/Voxels/VoxelUtils.js +0 -19
  214. package/index.js +346 -261
  215. package/package.json +1 -1
  216. package/Source/Shaders/Voxels/IntersectClippingPlanes.js +0 -80
  217. package/Source/Shaders/Voxels/convertUvToBox.js +0 -46
  218. package/Source/Shaders/Voxels/convertUvToCylinder.js +0 -101
  219. package/Source/Shaders/Voxels/convertUvToEllipsoid.js +0 -141
@@ -0,0 +1,455 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.1.3
5
+ *
6
+ * Copyright 2011-2022 Cesium Contributors
7
+ *
8
+ * Licensed under the Apache License, Version 2.0 (the "License");
9
+ * you may not use this file except in compliance with the License.
10
+ * You may obtain a copy of the License at
11
+ *
12
+ * http://www.apache.org/licenses/LICENSE-2.0
13
+ *
14
+ * Unless required by applicable law or agreed to in writing, software
15
+ * distributed under the License is distributed on an "AS IS" BASIS,
16
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ * See the License for the specific language governing permissions and
18
+ * limitations under the License.
19
+ *
20
+ * Columbus View (Pat. Pend.)
21
+ *
22
+ * Portions licensed separately.
23
+ * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details.
24
+ */
25
+
26
+ import {
27
+ Cartographic_default,
28
+ Ellipsoid_default
29
+ } from "./chunk-KMBLKQCC.js";
30
+ import {
31
+ Cartesian3_default
32
+ } from "./chunk-45VV4SBO.js";
33
+ import {
34
+ Math_default
35
+ } from "./chunk-QQHVOJW6.js";
36
+ import {
37
+ Check_default,
38
+ DeveloperError_default
39
+ } from "./chunk-6EJMTDQJ.js";
40
+ import {
41
+ defined_default
42
+ } from "./chunk-EXTMZJXB.js";
43
+
44
+ // packages/engine/Source/Core/EllipsoidRhumbLine.js
45
+ function calculateM(ellipticity, major, latitude) {
46
+ if (ellipticity === 0) {
47
+ return major * latitude;
48
+ }
49
+ const e2 = ellipticity * ellipticity;
50
+ const e4 = e2 * e2;
51
+ const e6 = e4 * e2;
52
+ const e8 = e6 * e2;
53
+ const e10 = e8 * e2;
54
+ const e12 = e10 * e2;
55
+ const phi = latitude;
56
+ const sin2Phi = Math.sin(2 * phi);
57
+ const sin4Phi = Math.sin(4 * phi);
58
+ const sin6Phi = Math.sin(6 * phi);
59
+ const sin8Phi = Math.sin(8 * phi);
60
+ const sin10Phi = Math.sin(10 * phi);
61
+ const sin12Phi = Math.sin(12 * phi);
62
+ return major * ((1 - e2 / 4 - 3 * e4 / 64 - 5 * e6 / 256 - 175 * e8 / 16384 - 441 * e10 / 65536 - 4851 * e12 / 1048576) * phi - (3 * e2 / 8 + 3 * e4 / 32 + 45 * e6 / 1024 + 105 * e8 / 4096 + 2205 * e10 / 131072 + 6237 * e12 / 524288) * sin2Phi + (15 * e4 / 256 + 45 * e6 / 1024 + 525 * e8 / 16384 + 1575 * e10 / 65536 + 155925 * e12 / 8388608) * sin4Phi - (35 * e6 / 3072 + 175 * e8 / 12288 + 3675 * e10 / 262144 + 13475 * e12 / 1048576) * sin6Phi + (315 * e8 / 131072 + 2205 * e10 / 524288 + 43659 * e12 / 8388608) * sin8Phi - (693 * e10 / 1310720 + 6237 * e12 / 5242880) * sin10Phi + 1001 * e12 / 8388608 * sin12Phi);
63
+ }
64
+ function calculateInverseM(M, ellipticity, major) {
65
+ const d = M / major;
66
+ if (ellipticity === 0) {
67
+ return d;
68
+ }
69
+ const d2 = d * d;
70
+ const d3 = d2 * d;
71
+ const d4 = d3 * d;
72
+ const e = ellipticity;
73
+ const e2 = e * e;
74
+ const e4 = e2 * e2;
75
+ const e6 = e4 * e2;
76
+ const e8 = e6 * e2;
77
+ const e10 = e8 * e2;
78
+ const e12 = e10 * e2;
79
+ const sin2D = Math.sin(2 * d);
80
+ const cos2D = Math.cos(2 * d);
81
+ const sin4D = Math.sin(4 * d);
82
+ const cos4D = Math.cos(4 * d);
83
+ const sin6D = Math.sin(6 * d);
84
+ const cos6D = Math.cos(6 * d);
85
+ const sin8D = Math.sin(8 * d);
86
+ const cos8D = Math.cos(8 * d);
87
+ const sin10D = Math.sin(10 * d);
88
+ const cos10D = Math.cos(10 * d);
89
+ const sin12D = Math.sin(12 * d);
90
+ return d + d * e2 / 4 + 7 * d * e4 / 64 + 15 * d * e6 / 256 + 579 * d * e8 / 16384 + 1515 * d * e10 / 65536 + 16837 * d * e12 / 1048576 + (3 * d * e4 / 16 + 45 * d * e6 / 256 - d * (32 * d2 - 561) * e8 / 4096 - d * (232 * d2 - 1677) * e10 / 16384 + d * (399985 - 90560 * d2 + 512 * d4) * e12 / 5242880) * cos2D + (21 * d * e6 / 256 + 483 * d * e8 / 4096 - d * (224 * d2 - 1969) * e10 / 16384 - d * (33152 * d2 - 112599) * e12 / 1048576) * cos4D + (151 * d * e8 / 4096 + 4681 * d * e10 / 65536 + 1479 * d * e12 / 16384 - 453 * d3 * e12 / 32768) * cos6D + (1097 * d * e10 / 65536 + 42783 * d * e12 / 1048576) * cos8D + 8011 * d * e12 / 1048576 * cos10D + (3 * e2 / 8 + 3 * e4 / 16 + 213 * e6 / 2048 - 3 * d2 * e6 / 64 + 255 * e8 / 4096 - 33 * d2 * e8 / 512 + 20861 * e10 / 524288 - 33 * d2 * e10 / 512 + d4 * e10 / 1024 + 28273 * e12 / 1048576 - 471 * d2 * e12 / 8192 + 9 * d4 * e12 / 4096) * sin2D + (21 * e4 / 256 + 21 * e6 / 256 + 533 * e8 / 8192 - 21 * d2 * e8 / 512 + 197 * e10 / 4096 - 315 * d2 * e10 / 4096 + 584039 * e12 / 16777216 - 12517 * d2 * e12 / 131072 + 7 * d4 * e12 / 2048) * sin4D + (151 * e6 / 6144 + 151 * e8 / 4096 + 5019 * e10 / 131072 - 453 * d2 * e10 / 16384 + 26965 * e12 / 786432 - 8607 * d2 * e12 / 131072) * sin6D + (1097 * e8 / 131072 + 1097 * e10 / 65536 + 225797 * e12 / 10485760 - 1097 * d2 * e12 / 65536) * sin8D + (8011 * e10 / 2621440 + 8011 * e12 / 1048576) * sin10D + 293393 * e12 / 251658240 * sin12D;
91
+ }
92
+ function calculateSigma(ellipticity, latitude) {
93
+ if (ellipticity === 0) {
94
+ return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude)));
95
+ }
96
+ const eSinL = ellipticity * Math.sin(latitude);
97
+ return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude))) - ellipticity / 2 * Math.log((1 + eSinL) / (1 - eSinL));
98
+ }
99
+ function calculateHeading(ellipsoidRhumbLine, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
100
+ const sigma1 = calculateSigma(ellipsoidRhumbLine._ellipticity, firstLatitude);
101
+ const sigma2 = calculateSigma(
102
+ ellipsoidRhumbLine._ellipticity,
103
+ secondLatitude
104
+ );
105
+ return Math.atan2(
106
+ Math_default.negativePiToPi(secondLongitude - firstLongitude),
107
+ sigma2 - sigma1
108
+ );
109
+ }
110
+ function calculateArcLength(ellipsoidRhumbLine, major, minor, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
111
+ const heading = ellipsoidRhumbLine._heading;
112
+ const deltaLongitude = secondLongitude - firstLongitude;
113
+ let distance = 0;
114
+ if (Math_default.equalsEpsilon(
115
+ Math.abs(heading),
116
+ Math_default.PI_OVER_TWO,
117
+ Math_default.EPSILON8
118
+ )) {
119
+ if (major === minor) {
120
+ distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude);
121
+ } else {
122
+ const sinPhi = Math.sin(firstLatitude);
123
+ distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude) / Math.sqrt(1 - ellipsoidRhumbLine._ellipticitySquared * sinPhi * sinPhi);
124
+ }
125
+ } else {
126
+ const M1 = calculateM(
127
+ ellipsoidRhumbLine._ellipticity,
128
+ major,
129
+ firstLatitude
130
+ );
131
+ const M2 = calculateM(
132
+ ellipsoidRhumbLine._ellipticity,
133
+ major,
134
+ secondLatitude
135
+ );
136
+ distance = (M2 - M1) / Math.cos(heading);
137
+ }
138
+ return Math.abs(distance);
139
+ }
140
+ var scratchCart1 = new Cartesian3_default();
141
+ var scratchCart2 = new Cartesian3_default();
142
+ function computeProperties(ellipsoidRhumbLine, start, end, ellipsoid) {
143
+ const firstCartesian = Cartesian3_default.normalize(
144
+ ellipsoid.cartographicToCartesian(start, scratchCart2),
145
+ scratchCart1
146
+ );
147
+ const lastCartesian = Cartesian3_default.normalize(
148
+ ellipsoid.cartographicToCartesian(end, scratchCart2),
149
+ scratchCart2
150
+ );
151
+ Check_default.typeOf.number.greaterThanOrEquals(
152
+ "value",
153
+ Math.abs(
154
+ Math.abs(Cartesian3_default.angleBetween(firstCartesian, lastCartesian)) - Math.PI
155
+ ),
156
+ 0.0125
157
+ );
158
+ const major = ellipsoid.maximumRadius;
159
+ const minor = ellipsoid.minimumRadius;
160
+ const majorSquared = major * major;
161
+ const minorSquared = minor * minor;
162
+ ellipsoidRhumbLine._ellipticitySquared = (majorSquared - minorSquared) / majorSquared;
163
+ ellipsoidRhumbLine._ellipticity = Math.sqrt(
164
+ ellipsoidRhumbLine._ellipticitySquared
165
+ );
166
+ ellipsoidRhumbLine._start = Cartographic_default.clone(
167
+ start,
168
+ ellipsoidRhumbLine._start
169
+ );
170
+ ellipsoidRhumbLine._start.height = 0;
171
+ ellipsoidRhumbLine._end = Cartographic_default.clone(end, ellipsoidRhumbLine._end);
172
+ ellipsoidRhumbLine._end.height = 0;
173
+ ellipsoidRhumbLine._heading = calculateHeading(
174
+ ellipsoidRhumbLine,
175
+ start.longitude,
176
+ start.latitude,
177
+ end.longitude,
178
+ end.latitude
179
+ );
180
+ ellipsoidRhumbLine._distance = calculateArcLength(
181
+ ellipsoidRhumbLine,
182
+ ellipsoid.maximumRadius,
183
+ ellipsoid.minimumRadius,
184
+ start.longitude,
185
+ start.latitude,
186
+ end.longitude,
187
+ end.latitude
188
+ );
189
+ }
190
+ function interpolateUsingSurfaceDistance(start, heading, distance, major, ellipticity, result) {
191
+ if (distance === 0) {
192
+ return Cartographic_default.clone(start, result);
193
+ }
194
+ const ellipticitySquared = ellipticity * ellipticity;
195
+ let longitude;
196
+ let latitude;
197
+ let deltaLongitude;
198
+ if (Math.abs(Math_default.PI_OVER_TWO - Math.abs(heading)) > Math_default.EPSILON8) {
199
+ const M1 = calculateM(ellipticity, major, start.latitude);
200
+ const deltaM = distance * Math.cos(heading);
201
+ const M2 = M1 + deltaM;
202
+ latitude = calculateInverseM(M2, ellipticity, major);
203
+ if (Math.abs(heading) < Math_default.EPSILON10) {
204
+ longitude = Math_default.negativePiToPi(start.longitude);
205
+ } else {
206
+ const sigma1 = calculateSigma(ellipticity, start.latitude);
207
+ const sigma2 = calculateSigma(ellipticity, latitude);
208
+ deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
209
+ longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
210
+ }
211
+ } else {
212
+ latitude = start.latitude;
213
+ let localRad;
214
+ if (ellipticity === 0) {
215
+ localRad = major * Math.cos(start.latitude);
216
+ } else {
217
+ const sinPhi = Math.sin(start.latitude);
218
+ localRad = major * Math.cos(start.latitude) / Math.sqrt(1 - ellipticitySquared * sinPhi * sinPhi);
219
+ }
220
+ deltaLongitude = distance / localRad;
221
+ if (heading > 0) {
222
+ longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
223
+ } else {
224
+ longitude = Math_default.negativePiToPi(start.longitude - deltaLongitude);
225
+ }
226
+ }
227
+ if (defined_default(result)) {
228
+ result.longitude = longitude;
229
+ result.latitude = latitude;
230
+ result.height = 0;
231
+ return result;
232
+ }
233
+ return new Cartographic_default(longitude, latitude, 0);
234
+ }
235
+ function EllipsoidRhumbLine(start, end, ellipsoid) {
236
+ const e = ellipsoid ?? Ellipsoid_default.default;
237
+ this._ellipsoid = e;
238
+ this._start = new Cartographic_default();
239
+ this._end = new Cartographic_default();
240
+ this._heading = void 0;
241
+ this._distance = void 0;
242
+ this._ellipticity = void 0;
243
+ this._ellipticitySquared = void 0;
244
+ if (defined_default(start) && defined_default(end)) {
245
+ computeProperties(this, start, end, e);
246
+ }
247
+ }
248
+ Object.defineProperties(EllipsoidRhumbLine.prototype, {
249
+ /**
250
+ * Gets the ellipsoid.
251
+ * @memberof EllipsoidRhumbLine.prototype
252
+ * @type {Ellipsoid}
253
+ * @readonly
254
+ */
255
+ ellipsoid: {
256
+ get: function() {
257
+ return this._ellipsoid;
258
+ }
259
+ },
260
+ /**
261
+ * Gets the surface distance between the start and end point
262
+ * @memberof EllipsoidRhumbLine.prototype
263
+ * @type {number}
264
+ * @readonly
265
+ */
266
+ surfaceDistance: {
267
+ get: function() {
268
+ Check_default.defined("distance", this._distance);
269
+ return this._distance;
270
+ }
271
+ },
272
+ /**
273
+ * Gets the initial planetodetic point on the path.
274
+ * @memberof EllipsoidRhumbLine.prototype
275
+ * @type {Cartographic}
276
+ * @readonly
277
+ */
278
+ start: {
279
+ get: function() {
280
+ return this._start;
281
+ }
282
+ },
283
+ /**
284
+ * Gets the final planetodetic point on the path.
285
+ * @memberof EllipsoidRhumbLine.prototype
286
+ * @type {Cartographic}
287
+ * @readonly
288
+ */
289
+ end: {
290
+ get: function() {
291
+ return this._end;
292
+ }
293
+ },
294
+ /**
295
+ * Gets the heading from the start point to the end point.
296
+ * @memberof EllipsoidRhumbLine.prototype
297
+ * @type {number}
298
+ * @readonly
299
+ */
300
+ heading: {
301
+ get: function() {
302
+ Check_default.defined("distance", this._distance);
303
+ return this._heading;
304
+ }
305
+ }
306
+ });
307
+ EllipsoidRhumbLine.fromStartHeadingDistance = function(start, heading, distance, ellipsoid, result) {
308
+ Check_default.defined("start", start);
309
+ Check_default.defined("heading", heading);
310
+ Check_default.defined("distance", distance);
311
+ Check_default.typeOf.number.greaterThan("distance", distance, 0);
312
+ const e = ellipsoid ?? Ellipsoid_default.default;
313
+ const major = e.maximumRadius;
314
+ const minor = e.minimumRadius;
315
+ const majorSquared = major * major;
316
+ const minorSquared = minor * minor;
317
+ const ellipticity = Math.sqrt((majorSquared - minorSquared) / majorSquared);
318
+ heading = Math_default.negativePiToPi(heading);
319
+ const end = interpolateUsingSurfaceDistance(
320
+ start,
321
+ heading,
322
+ distance,
323
+ e.maximumRadius,
324
+ ellipticity
325
+ );
326
+ if (!defined_default(result) || defined_default(ellipsoid) && !ellipsoid.equals(result.ellipsoid)) {
327
+ return new EllipsoidRhumbLine(start, end, e);
328
+ }
329
+ result.setEndPoints(start, end);
330
+ return result;
331
+ };
332
+ EllipsoidRhumbLine.prototype.setEndPoints = function(start, end) {
333
+ Check_default.defined("start", start);
334
+ Check_default.defined("end", end);
335
+ computeProperties(this, start, end, this._ellipsoid);
336
+ };
337
+ EllipsoidRhumbLine.prototype.interpolateUsingFraction = function(fraction, result) {
338
+ return this.interpolateUsingSurfaceDistance(
339
+ fraction * this._distance,
340
+ result
341
+ );
342
+ };
343
+ EllipsoidRhumbLine.prototype.interpolateUsingSurfaceDistance = function(distance, result) {
344
+ Check_default.typeOf.number("distance", distance);
345
+ if (!defined_default(this._distance) || this._distance === 0) {
346
+ throw new DeveloperError_default(
347
+ "EllipsoidRhumbLine must have distinct start and end set."
348
+ );
349
+ }
350
+ return interpolateUsingSurfaceDistance(
351
+ this._start,
352
+ this._heading,
353
+ distance,
354
+ this._ellipsoid.maximumRadius,
355
+ this._ellipticity,
356
+ result
357
+ );
358
+ };
359
+ EllipsoidRhumbLine.prototype.findIntersectionWithLongitude = function(intersectionLongitude, result) {
360
+ Check_default.typeOf.number("intersectionLongitude", intersectionLongitude);
361
+ if (!defined_default(this._distance) || this._distance === 0) {
362
+ throw new DeveloperError_default(
363
+ "EllipsoidRhumbLine must have distinct start and end set."
364
+ );
365
+ }
366
+ const ellipticity = this._ellipticity;
367
+ const heading = this._heading;
368
+ const absHeading = Math.abs(heading);
369
+ const start = this._start;
370
+ intersectionLongitude = Math_default.negativePiToPi(intersectionLongitude);
371
+ if (Math_default.equalsEpsilon(
372
+ Math.abs(intersectionLongitude),
373
+ Math.PI,
374
+ Math_default.EPSILON14
375
+ )) {
376
+ intersectionLongitude = Math_default.sign(start.longitude) * Math.PI;
377
+ }
378
+ if (!defined_default(result)) {
379
+ result = new Cartographic_default();
380
+ }
381
+ if (Math.abs(Math_default.PI_OVER_TWO - absHeading) <= Math_default.EPSILON8) {
382
+ result.longitude = intersectionLongitude;
383
+ result.latitude = start.latitude;
384
+ result.height = 0;
385
+ return result;
386
+ } else if (Math_default.equalsEpsilon(
387
+ Math.abs(Math_default.PI_OVER_TWO - absHeading),
388
+ Math_default.PI_OVER_TWO,
389
+ Math_default.EPSILON8
390
+ )) {
391
+ if (Math_default.equalsEpsilon(
392
+ intersectionLongitude,
393
+ start.longitude,
394
+ Math_default.EPSILON12
395
+ )) {
396
+ return void 0;
397
+ }
398
+ result.longitude = intersectionLongitude;
399
+ result.latitude = Math_default.PI_OVER_TWO * Math_default.sign(Math_default.PI_OVER_TWO - heading);
400
+ result.height = 0;
401
+ return result;
402
+ }
403
+ const phi1 = start.latitude;
404
+ const eSinPhi1 = ellipticity * Math.sin(phi1);
405
+ const leftComponent = Math.tan(0.5 * (Math_default.PI_OVER_TWO + phi1)) * Math.exp((intersectionLongitude - start.longitude) / Math.tan(heading));
406
+ const denominator = (1 + eSinPhi1) / (1 - eSinPhi1);
407
+ let newPhi = start.latitude;
408
+ let phi;
409
+ do {
410
+ phi = newPhi;
411
+ const eSinPhi = ellipticity * Math.sin(phi);
412
+ const numerator = (1 + eSinPhi) / (1 - eSinPhi);
413
+ newPhi = 2 * Math.atan(
414
+ leftComponent * Math.pow(numerator / denominator, ellipticity / 2)
415
+ ) - Math_default.PI_OVER_TWO;
416
+ } while (!Math_default.equalsEpsilon(newPhi, phi, Math_default.EPSILON12));
417
+ result.longitude = intersectionLongitude;
418
+ result.latitude = newPhi;
419
+ result.height = 0;
420
+ return result;
421
+ };
422
+ EllipsoidRhumbLine.prototype.findIntersectionWithLatitude = function(intersectionLatitude, result) {
423
+ Check_default.typeOf.number("intersectionLatitude", intersectionLatitude);
424
+ if (!defined_default(this._distance) || this._distance === 0) {
425
+ throw new DeveloperError_default(
426
+ "EllipsoidRhumbLine must have distinct start and end set."
427
+ );
428
+ }
429
+ const ellipticity = this._ellipticity;
430
+ const heading = this._heading;
431
+ const start = this._start;
432
+ if (Math_default.equalsEpsilon(
433
+ Math.abs(heading),
434
+ Math_default.PI_OVER_TWO,
435
+ Math_default.EPSILON8
436
+ )) {
437
+ return;
438
+ }
439
+ const sigma1 = calculateSigma(ellipticity, start.latitude);
440
+ const sigma2 = calculateSigma(ellipticity, intersectionLatitude);
441
+ const deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
442
+ const longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
443
+ if (defined_default(result)) {
444
+ result.longitude = longitude;
445
+ result.latitude = intersectionLatitude;
446
+ result.height = 0;
447
+ return result;
448
+ }
449
+ return new Cartographic_default(longitude, intersectionLatitude, 0);
450
+ };
451
+ var EllipsoidRhumbLine_default = EllipsoidRhumbLine;
452
+
453
+ export {
454
+ EllipsoidRhumbLine_default
455
+ };