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,101 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.1.4
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
+ defined_default
28
+ } from "./chunk-MRMNELAH.js";
29
+
30
+ // packages/engine/Source/Core/formatError.js
31
+ function formatError(object) {
32
+ let result;
33
+ const name = object.name;
34
+ const message = object.message;
35
+ if (defined_default(name) && defined_default(message)) {
36
+ result = `${name}: ${message}`;
37
+ } else {
38
+ result = object.toString();
39
+ }
40
+ const stack = object.stack;
41
+ if (defined_default(stack)) {
42
+ result += `
43
+ ${stack}`;
44
+ }
45
+ return result;
46
+ }
47
+ var formatError_default = formatError;
48
+
49
+ // packages/engine/Source/Workers/createTaskProcessorWorker.js
50
+ function createTaskProcessorWorker(workerFunction) {
51
+ async function onMessageHandler({ data }) {
52
+ const transferableObjects = [];
53
+ const responseMessage = {
54
+ id: data.id,
55
+ result: void 0,
56
+ error: void 0
57
+ };
58
+ self.CESIUM_BASE_URL = data.baseUrl;
59
+ try {
60
+ const result = await workerFunction(data.parameters, transferableObjects);
61
+ responseMessage.result = result;
62
+ } catch (error) {
63
+ if (error instanceof Error) {
64
+ responseMessage.error = {
65
+ name: error.name,
66
+ message: error.message,
67
+ stack: error.stack
68
+ };
69
+ } else {
70
+ responseMessage.error = error;
71
+ }
72
+ }
73
+ if (!data.canTransferArrayBuffer) {
74
+ transferableObjects.length = 0;
75
+ }
76
+ try {
77
+ postMessage(responseMessage, transferableObjects);
78
+ } catch (error) {
79
+ responseMessage.result = void 0;
80
+ responseMessage.error = `postMessage failed with error: ${formatError_default(
81
+ error
82
+ )}
83
+ with responseMessage: ${JSON.stringify(responseMessage)}`;
84
+ postMessage(responseMessage);
85
+ }
86
+ }
87
+ function onMessageErrorHandler(event) {
88
+ postMessage({
89
+ id: event.data?.id,
90
+ error: `postMessage failed with error: ${JSON.stringify(event)}`
91
+ });
92
+ }
93
+ self.onmessage = onMessageHandler;
94
+ self.onmessageerror = onMessageErrorHandler;
95
+ return self;
96
+ }
97
+ var createTaskProcessorWorker_default = createTaskProcessorWorker;
98
+
99
+ export {
100
+ createTaskProcessorWorker_default
101
+ };
@@ -0,0 +1,198 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.1.4
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
+ PolylinePipeline_default
28
+ } from "./chunk-EIZ23IOX.js";
29
+ import {
30
+ arrayRemoveDuplicates_default
31
+ } from "./chunk-FWYDLSVQ.js";
32
+ import {
33
+ Cartographic_default
34
+ } from "./chunk-M6IXKBC7.js";
35
+ import {
36
+ Cartesian3_default
37
+ } from "./chunk-J4PISUNT.js";
38
+ import {
39
+ Math_default
40
+ } from "./chunk-VQH2YXO2.js";
41
+ import {
42
+ defined_default
43
+ } from "./chunk-MRMNELAH.js";
44
+
45
+ // packages/engine/Source/Core/WallGeometryLibrary.js
46
+ var WallGeometryLibrary = {};
47
+ function latLonEquals(c0, c1) {
48
+ return Math_default.equalsEpsilon(c0.latitude, c1.latitude, Math_default.EPSILON10) && Math_default.equalsEpsilon(c0.longitude, c1.longitude, Math_default.EPSILON10);
49
+ }
50
+ var scratchCartographic1 = new Cartographic_default();
51
+ var scratchCartographic2 = new Cartographic_default();
52
+ function removeDuplicates(ellipsoid, positions, topHeights, bottomHeights) {
53
+ positions = arrayRemoveDuplicates_default(positions, Cartesian3_default.equalsEpsilon);
54
+ const length = positions.length;
55
+ if (length < 2) {
56
+ return;
57
+ }
58
+ const hasBottomHeights = defined_default(bottomHeights);
59
+ const hasTopHeights = defined_default(topHeights);
60
+ const cleanedPositions = new Array(length);
61
+ const cleanedTopHeights = new Array(length);
62
+ const cleanedBottomHeights = new Array(length);
63
+ const v0 = positions[0];
64
+ cleanedPositions[0] = v0;
65
+ const c0 = ellipsoid.cartesianToCartographic(v0, scratchCartographic1);
66
+ if (hasTopHeights) {
67
+ c0.height = topHeights[0];
68
+ }
69
+ cleanedTopHeights[0] = c0.height;
70
+ if (hasBottomHeights) {
71
+ cleanedBottomHeights[0] = bottomHeights[0];
72
+ } else {
73
+ cleanedBottomHeights[0] = 0;
74
+ }
75
+ const startTopHeight = cleanedTopHeights[0];
76
+ const startBottomHeight = cleanedBottomHeights[0];
77
+ let hasAllSameHeights = startTopHeight === startBottomHeight;
78
+ let index = 1;
79
+ for (let i = 1; i < length; ++i) {
80
+ const v1 = positions[i];
81
+ const c1 = ellipsoid.cartesianToCartographic(v1, scratchCartographic2);
82
+ if (hasTopHeights) {
83
+ c1.height = topHeights[i];
84
+ }
85
+ hasAllSameHeights = hasAllSameHeights && c1.height === 0;
86
+ if (!latLonEquals(c0, c1)) {
87
+ cleanedPositions[index] = v1;
88
+ cleanedTopHeights[index] = c1.height;
89
+ if (hasBottomHeights) {
90
+ cleanedBottomHeights[index] = bottomHeights[i];
91
+ } else {
92
+ cleanedBottomHeights[index] = 0;
93
+ }
94
+ hasAllSameHeights = hasAllSameHeights && cleanedTopHeights[index] === cleanedBottomHeights[index];
95
+ Cartographic_default.clone(c1, c0);
96
+ ++index;
97
+ } else if (c0.height < c1.height) {
98
+ cleanedTopHeights[index - 1] = c1.height;
99
+ }
100
+ }
101
+ if (hasAllSameHeights || index < 2) {
102
+ return;
103
+ }
104
+ cleanedPositions.length = index;
105
+ cleanedTopHeights.length = index;
106
+ cleanedBottomHeights.length = index;
107
+ return {
108
+ positions: cleanedPositions,
109
+ topHeights: cleanedTopHeights,
110
+ bottomHeights: cleanedBottomHeights
111
+ };
112
+ }
113
+ var positionsArrayScratch = new Array(2);
114
+ var heightsArrayScratch = new Array(2);
115
+ var generateArcOptionsScratch = {
116
+ positions: void 0,
117
+ height: void 0,
118
+ granularity: void 0,
119
+ ellipsoid: void 0
120
+ };
121
+ WallGeometryLibrary.computePositions = function(ellipsoid, wallPositions, maximumHeights, minimumHeights, granularity, duplicateCorners) {
122
+ const o = removeDuplicates(
123
+ ellipsoid,
124
+ wallPositions,
125
+ maximumHeights,
126
+ minimumHeights
127
+ );
128
+ if (!defined_default(o)) {
129
+ return;
130
+ }
131
+ wallPositions = o.positions;
132
+ maximumHeights = o.topHeights;
133
+ minimumHeights = o.bottomHeights;
134
+ const length = wallPositions.length;
135
+ const numCorners = length - 2;
136
+ let topPositions;
137
+ let bottomPositions;
138
+ const minDistance = Math_default.chordLength(
139
+ granularity,
140
+ ellipsoid.maximumRadius
141
+ );
142
+ const generateArcOptions = generateArcOptionsScratch;
143
+ generateArcOptions.minDistance = minDistance;
144
+ generateArcOptions.ellipsoid = ellipsoid;
145
+ if (duplicateCorners) {
146
+ let count = 0;
147
+ let i;
148
+ for (i = 0; i < length - 1; i++) {
149
+ count += PolylinePipeline_default.numberOfPoints(
150
+ wallPositions[i],
151
+ wallPositions[i + 1],
152
+ minDistance
153
+ ) + 1;
154
+ }
155
+ topPositions = new Float64Array(count * 3);
156
+ bottomPositions = new Float64Array(count * 3);
157
+ const generateArcPositions = positionsArrayScratch;
158
+ const generateArcHeights = heightsArrayScratch;
159
+ generateArcOptions.positions = generateArcPositions;
160
+ generateArcOptions.height = generateArcHeights;
161
+ let offset = 0;
162
+ for (i = 0; i < length - 1; i++) {
163
+ generateArcPositions[0] = wallPositions[i];
164
+ generateArcPositions[1] = wallPositions[i + 1];
165
+ generateArcHeights[0] = maximumHeights[i];
166
+ generateArcHeights[1] = maximumHeights[i + 1];
167
+ const pos = PolylinePipeline_default.generateArc(generateArcOptions);
168
+ topPositions.set(pos, offset);
169
+ generateArcHeights[0] = minimumHeights[i];
170
+ generateArcHeights[1] = minimumHeights[i + 1];
171
+ bottomPositions.set(
172
+ PolylinePipeline_default.generateArc(generateArcOptions),
173
+ offset
174
+ );
175
+ offset += pos.length;
176
+ }
177
+ } else {
178
+ generateArcOptions.positions = wallPositions;
179
+ generateArcOptions.height = maximumHeights;
180
+ topPositions = new Float64Array(
181
+ PolylinePipeline_default.generateArc(generateArcOptions)
182
+ );
183
+ generateArcOptions.height = minimumHeights;
184
+ bottomPositions = new Float64Array(
185
+ PolylinePipeline_default.generateArc(generateArcOptions)
186
+ );
187
+ }
188
+ return {
189
+ bottomPositions,
190
+ topPositions,
191
+ numCorners
192
+ };
193
+ };
194
+ var WallGeometryLibrary_default = WallGeometryLibrary;
195
+
196
+ export {
197
+ WallGeometryLibrary_default
198
+ };