@gmgis/gm-sdk 1.12.5 → 2.0.2

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 (159) hide show
  1. package/dist/dist/index.js +1848 -0
  2. package/dist/gm.min.js +16983 -16483
  3. package/dist/index.js +1436 -1434
  4. package/dist/resources/ThirdParty/Workers/pako_deflate.min.js +1 -2
  5. package/dist/resources/ThirdParty/Workers/pako_inflate.min.js +1 -2
  6. package/dist/resources/ThirdParty/Workers/z-worker-pako.js +1 -1
  7. package/dist/resources/ThirdParty/google-earth-dbroot-parser.js +1 -8337
  8. package/dist/resources/ThirdParty/wasm_splats_bg.wasm +0 -0
  9. package/dist/resources/Workers/chunk-35SHYARM.js +26 -0
  10. package/dist/resources/Workers/chunk-37F5JSTI.js +26 -0
  11. package/dist/resources/Workers/chunk-3SSKC3VN.js +26 -0
  12. package/dist/resources/Workers/chunk-3W4GT7KQ.js +26 -0
  13. package/dist/resources/Workers/chunk-4IW2T6GF.js +26 -0
  14. package/dist/resources/Workers/chunk-5YEWO3HT.js +26 -0
  15. package/dist/resources/Workers/chunk-64RSHJUE.js +28 -0
  16. package/dist/resources/Workers/chunk-77IHZJJ3.js +26 -0
  17. package/dist/resources/Workers/chunk-7HTKERZY.js +26 -0
  18. package/dist/resources/Workers/{chunk-I2ITFFPX.js → chunk-A56XVLQR.js} +2 -13
  19. package/dist/resources/Workers/chunk-AJYK4IVJ.js +26 -0
  20. package/dist/resources/Workers/{chunk-PRGYLLJT.js → chunk-ARG42DC4.js} +2 -31
  21. package/dist/resources/Workers/chunk-AU7IKHOH.js +26 -0
  22. package/dist/resources/Workers/chunk-B4AA3ARO.js +26 -0
  23. package/dist/resources/Workers/chunk-CNCV5UL7.js +26 -0
  24. package/dist/resources/Workers/chunk-CYCB63OH.js +26 -0
  25. package/dist/resources/Workers/{chunk-DI5NGJUP.js → chunk-D6AA5QVT.js} +2 -20
  26. package/dist/resources/Workers/chunk-D6C66QON.js +26 -0
  27. package/dist/resources/Workers/chunk-DEPHB2WM.js +26 -0
  28. package/dist/resources/Workers/chunk-DMEY62ID.js +26 -0
  29. package/dist/resources/Workers/chunk-DQQ63PYM.js +26 -0
  30. package/dist/resources/Workers/chunk-ED5JPB3S.js +27 -0
  31. package/dist/resources/Workers/chunk-EZUYS2JF.js +26 -0
  32. package/dist/resources/Workers/chunk-FEVXJ54I.js +26 -0
  33. package/dist/resources/Workers/chunk-G5AGHVVC.js +26 -0
  34. package/dist/resources/Workers/{chunk-7JO7GPJN.js → chunk-GBYLG25F.js} +2 -15
  35. package/dist/resources/Workers/chunk-GILIDQNQ.js +26 -0
  36. package/dist/resources/Workers/chunk-HMIYSTF6.js +26 -0
  37. package/dist/resources/Workers/chunk-HTFSEEMT.js +26 -0
  38. package/dist/resources/Workers/chunk-HWXX4CWK.js +26 -0
  39. package/dist/resources/Workers/chunk-IYTZ52EY.js +26 -0
  40. package/dist/resources/Workers/chunk-J6UP6FLE.js +26 -0
  41. package/dist/resources/Workers/chunk-LEYMRMBK.js +27 -0
  42. package/dist/resources/Workers/chunk-M3MGYQSL.js +26 -0
  43. package/dist/resources/Workers/chunk-N4VJKXZS.js +26 -0
  44. package/dist/resources/Workers/chunk-NB3ML6JO.js +26 -0
  45. package/dist/resources/Workers/chunk-OFUUQVMR.js +26 -0
  46. package/dist/resources/Workers/chunk-OSW76XDF.js +26 -0
  47. package/dist/resources/Workers/chunk-PSPPBZWI.js +66 -0
  48. package/dist/resources/Workers/chunk-QN3VOORQ.js +26 -0
  49. package/dist/resources/Workers/chunk-QOUAJ6TL.js +26 -0
  50. package/dist/resources/Workers/chunk-RCV6KWXS.js +26 -0
  51. package/dist/resources/Workers/chunk-TCGIRNHN.js +26 -0
  52. package/dist/resources/Workers/chunk-U4IEOH5K.js +26 -0
  53. package/dist/resources/Workers/chunk-UP6I5URU.js +26 -0
  54. package/dist/resources/Workers/chunk-VTAIKJXX.js +26 -0
  55. package/dist/resources/Workers/chunk-VTBDSFTG.js +26 -0
  56. package/dist/resources/Workers/chunk-VW6VD53G.js +26 -0
  57. package/dist/resources/Workers/chunk-WGGIH7QW.js +26 -0
  58. package/dist/resources/Workers/chunk-WWA5PL4H.js +26 -0
  59. package/dist/resources/Workers/{chunk-6CHGCNMW.js → chunk-WZDE3RYP.js} +4 -34
  60. package/dist/resources/Workers/chunk-XRL4AVS5.js +26 -0
  61. package/dist/resources/Workers/combineGeometry.js +2 -40
  62. package/dist/resources/Workers/createBoxGeometry.js +2 -32
  63. package/dist/resources/Workers/createBoxOutlineGeometry.js +2 -209
  64. package/dist/resources/Workers/createCircleGeometry.js +2 -175
  65. package/dist/resources/Workers/createCircleOutlineGeometry.js +2 -121
  66. package/dist/resources/Workers/createCoplanarPolygonGeometry.js +2 -481
  67. package/dist/resources/Workers/createCoplanarPolygonOutlineGeometry.js +2 -199
  68. package/dist/resources/Workers/createCorridorGeometry.js +2 -1237
  69. package/dist/resources/Workers/createCorridorOutlineGeometry.js +2 -542
  70. package/dist/resources/Workers/createCylinderGeometry.js +2 -34
  71. package/dist/resources/Workers/createCylinderOutlineGeometry.js +2 -205
  72. package/dist/resources/Workers/createEllipseGeometry.js +2 -45
  73. package/dist/resources/Workers/createEllipseOutlineGeometry.js +2 -38
  74. package/dist/resources/Workers/createEllipsoidGeometry.js +2 -33
  75. package/dist/resources/Workers/createEllipsoidOutlineGeometry.js +2 -35
  76. package/dist/resources/Workers/createFrustumGeometry.js +2 -32
  77. package/dist/resources/Workers/createFrustumOutlineGeometry.js +2 -210
  78. package/dist/resources/Workers/createGeometry.js +2 -144
  79. package/dist/resources/Workers/createGroundPolylineGeometry.js +2 -1582
  80. package/dist/resources/Workers/createPlaneGeometry.js +2 -198
  81. package/dist/resources/Workers/createPlaneOutlineGeometry.js +2 -98
  82. package/dist/resources/Workers/createPolygonGeometry.js +2 -1381
  83. package/dist/resources/Workers/createPolygonOutlineGeometry.js +2 -509
  84. package/dist/resources/Workers/createPolylineGeometry.js +2 -470
  85. package/dist/resources/Workers/createPolylineVolumeGeometry.js +2 -354
  86. package/dist/resources/Workers/createPolylineVolumeOutlineGeometry.js +2 -251
  87. package/dist/resources/Workers/createRectangleGeometry.js +2 -1246
  88. package/dist/resources/Workers/createRectangleOutlineGeometry.js +2 -453
  89. package/dist/resources/Workers/createSimplePolylineGeometry.js +2 -374
  90. package/dist/resources/Workers/createSphereGeometry.js +2 -92
  91. package/dist/resources/Workers/createSphereOutlineGeometry.js +2 -92
  92. package/dist/resources/Workers/createTaskProcessorWorker.js +2 -8
  93. package/dist/resources/Workers/createVectorTileClampedPolylines.js +2 -466
  94. package/dist/resources/Workers/createVectorTileGeometries.js +2 -361
  95. package/dist/resources/Workers/createVectorTilePoints.js +2 -88
  96. package/dist/resources/Workers/createVectorTilePolygons.js +2 -359
  97. package/dist/resources/Workers/createVectorTilePolylines.js +2 -236
  98. package/dist/resources/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +2 -539
  99. package/dist/resources/Workers/createVerticesFromHeightmap.js +2 -2252
  100. package/dist/resources/Workers/createVerticesFromQuantizedTerrainMesh.js +2 -729
  101. package/dist/resources/Workers/createWallGeometry.js +2 -464
  102. package/dist/resources/Workers/createWallOutlineGeometry.js +2 -312
  103. package/dist/resources/Workers/decodeDraco.js +2 -345
  104. package/dist/resources/Workers/decodeGoogleEarthEnterprisePacket.js +2 -2642
  105. package/dist/resources/Workers/decodeI3S.js +2 -1319
  106. package/dist/resources/Workers/gaussianSplatSorter.js +26 -0
  107. package/dist/resources/Workers/gaussianSplatTextureGenerator.js +26 -0
  108. package/dist/resources/Workers/transcodeKTX2.js +29 -3360
  109. package/dist/resources/Workers/transferTypedArrayTest.js +2 -17
  110. package/dist/resources/Workers/upsampleQuantizedTerrainMesh.js +2 -793
  111. package/package.json +74 -74
  112. package/dist/resources/ThirdParty/Workers/basis_transcoder.js +0 -21
  113. package/dist/resources/Workers/chunk-26GA3JAM.js +0 -139
  114. package/dist/resources/Workers/chunk-27HUZ7SA.js +0 -305
  115. package/dist/resources/Workers/chunk-2ZGOQXYU.js +0 -171
  116. package/dist/resources/Workers/chunk-3Q2L65QU.js +0 -1258
  117. package/dist/resources/Workers/chunk-472HQ3EH.js +0 -100
  118. package/dist/resources/Workers/chunk-5ODQSF26.js +0 -101
  119. package/dist/resources/Workers/chunk-5OOFQLKF.js +0 -634
  120. package/dist/resources/Workers/chunk-5PTXS2GO.js +0 -10390
  121. package/dist/resources/Workers/chunk-76BYBWHP.js +0 -122
  122. package/dist/resources/Workers/chunk-7BMOHCPM.js +0 -390
  123. package/dist/resources/Workers/chunk-7KTQP4VB.js +0 -59
  124. package/dist/resources/Workers/chunk-7O373FFS.js +0 -665
  125. package/dist/resources/Workers/chunk-AD63PIY6.js +0 -163
  126. package/dist/resources/Workers/chunk-BHQJ2NT7.js +0 -353
  127. package/dist/resources/Workers/chunk-C6YYBQXW.js +0 -102
  128. package/dist/resources/Workers/chunk-CKY7HOHV.js +0 -287
  129. package/dist/resources/Workers/chunk-DHYHSFFJ.js +0 -73
  130. package/dist/resources/Workers/chunk-E27BLMDD.js +0 -115
  131. package/dist/resources/Workers/chunk-E63IIM5T.js +0 -75
  132. package/dist/resources/Workers/chunk-E6V6SQZW.js +0 -456
  133. package/dist/resources/Workers/chunk-EJZTDTUH.js +0 -138
  134. package/dist/resources/Workers/chunk-FDOV2LBJ.js +0 -220
  135. package/dist/resources/Workers/chunk-FIGIZHAQ.js +0 -684
  136. package/dist/resources/Workers/chunk-GESF4OXQ.js +0 -1800
  137. package/dist/resources/Workers/chunk-GGZJN2TI.js +0 -2717
  138. package/dist/resources/Workers/chunk-GNBFYG7F.js +0 -1481
  139. package/dist/resources/Workers/chunk-GWCFU2SA.js +0 -300
  140. package/dist/resources/Workers/chunk-IBLIYJZR.js +0 -196
  141. package/dist/resources/Workers/chunk-JW4FOI6M.js +0 -476
  142. package/dist/resources/Workers/chunk-K4GQUNB5.js +0 -262
  143. package/dist/resources/Workers/chunk-M3GMB5OP.js +0 -834
  144. package/dist/resources/Workers/chunk-MXIZJAPH.js +0 -629
  145. package/dist/resources/Workers/chunk-N5KJGGCM.js +0 -1073
  146. package/dist/resources/Workers/chunk-NGPPMXRM.js +0 -435
  147. package/dist/resources/Workers/chunk-O3E4OAOE.js +0 -511
  148. package/dist/resources/Workers/chunk-PGRPDNHG.js +0 -1048
  149. package/dist/resources/Workers/chunk-S6MRMMQU.js +0 -157
  150. package/dist/resources/Workers/chunk-SMDOP47J.js +0 -945
  151. package/dist/resources/Workers/chunk-TGONEMZO.js +0 -421
  152. package/dist/resources/Workers/chunk-TKVT5GQM.js +0 -781
  153. package/dist/resources/Workers/chunk-U72QNFOJ.js +0 -758
  154. package/dist/resources/Workers/chunk-VJZB3WAV.js +0 -963
  155. package/dist/resources/Workers/chunk-VU2MNO7L.js +0 -239
  156. package/dist/resources/Workers/chunk-XY4BATBS.js +0 -500
  157. package/dist/resources/Workers/chunk-YFXQECWV.js +0 -2857
  158. package/dist/resources/Workers/chunk-YSGTGQQO.js +0 -398
  159. package/dist/resources/Workers/chunk-YZ733KKS.js +0 -368
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * @license
3
3
  * Cesium - https://github.com/CesiumGS/cesium
4
- * Version 1.122
4
+ * Version 1.132
5
5
  *
6
6
  * Copyright 2011-2022 Cesium Contributors
7
7
  *
@@ -23,541 +23,4 @@
23
23
  * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details.
24
24
  */
25
25
 
26
- import {
27
- EllipsoidalOccluder_default,
28
- TerrainEncoding_default
29
- } from "./chunk-U72QNFOJ.js";
30
- import {
31
- createTaskProcessorWorker_default
32
- } from "./chunk-5ODQSF26.js";
33
- import {
34
- WebMercatorProjection_default
35
- } from "./chunk-E27BLMDD.js";
36
- import {
37
- OrientedBoundingBox_default
38
- } from "./chunk-M3GMB5OP.js";
39
- import "./chunk-NGPPMXRM.js";
40
- import "./chunk-CKY7HOHV.js";
41
- import {
42
- AxisAlignedBoundingBox_default
43
- } from "./chunk-S6MRMMQU.js";
44
- import "./chunk-3Q2L65QU.js";
45
- import "./chunk-2ZGOQXYU.js";
46
- import {
47
- BoundingSphere_default
48
- } from "./chunk-VJZB3WAV.js";
49
- import {
50
- Matrix4_default,
51
- Rectangle_default,
52
- Transforms_default
53
- } from "./chunk-5PTXS2GO.js";
54
- import "./chunk-K4GQUNB5.js";
55
- import {
56
- Cartesian2_default,
57
- Cartesian3_default,
58
- Cartographic_default,
59
- Ellipsoid_default
60
- } from "./chunk-YFXQECWV.js";
61
- import {
62
- Math_default
63
- } from "./chunk-XY4BATBS.js";
64
- import "./chunk-MXIZJAPH.js";
65
- import {
66
- RuntimeError_default
67
- } from "./chunk-6CHGCNMW.js";
68
- import {
69
- defaultValue_default
70
- } from "./chunk-7JO7GPJN.js";
71
- import "./chunk-AD63PIY6.js";
72
- import {
73
- defined_default
74
- } from "./chunk-E63IIM5T.js";
75
-
76
- // packages/engine/Source/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js
77
- var sizeOfUint16 = Uint16Array.BYTES_PER_ELEMENT;
78
- var sizeOfInt32 = Int32Array.BYTES_PER_ELEMENT;
79
- var sizeOfUint32 = Uint32Array.BYTES_PER_ELEMENT;
80
- var sizeOfFloat = Float32Array.BYTES_PER_ELEMENT;
81
- var sizeOfDouble = Float64Array.BYTES_PER_ELEMENT;
82
- function indexOfEpsilon(arr, elem, elemType) {
83
- elemType = defaultValue_default(elemType, Math_default);
84
- const count = arr.length;
85
- for (let i = 0; i < count; ++i) {
86
- if (elemType.equalsEpsilon(arr[i], elem, Math_default.EPSILON12)) {
87
- return i;
88
- }
89
- }
90
- return -1;
91
- }
92
- function createVerticesFromGoogleEarthEnterpriseBuffer(parameters, transferableObjects) {
93
- parameters.ellipsoid = Ellipsoid_default.clone(parameters.ellipsoid);
94
- parameters.rectangle = Rectangle_default.clone(parameters.rectangle);
95
- const statistics = processBuffer(
96
- parameters.buffer,
97
- parameters.relativeToCenter,
98
- parameters.ellipsoid,
99
- parameters.rectangle,
100
- parameters.nativeRectangle,
101
- parameters.exaggeration,
102
- parameters.exaggerationRelativeHeight,
103
- parameters.skirtHeight,
104
- parameters.includeWebMercatorT,
105
- parameters.negativeAltitudeExponentBias,
106
- parameters.negativeElevationThreshold
107
- );
108
- const vertices = statistics.vertices;
109
- transferableObjects.push(vertices.buffer);
110
- const indices = statistics.indices;
111
- transferableObjects.push(indices.buffer);
112
- return {
113
- vertices: vertices.buffer,
114
- indices: indices.buffer,
115
- numberOfAttributes: statistics.encoding.stride,
116
- minimumHeight: statistics.minimumHeight,
117
- maximumHeight: statistics.maximumHeight,
118
- boundingSphere3D: statistics.boundingSphere3D,
119
- orientedBoundingBox: statistics.orientedBoundingBox,
120
- occludeePointInScaledSpace: statistics.occludeePointInScaledSpace,
121
- encoding: statistics.encoding,
122
- vertexCountWithoutSkirts: statistics.vertexCountWithoutSkirts,
123
- indexCountWithoutSkirts: statistics.indexCountWithoutSkirts,
124
- westIndicesSouthToNorth: statistics.westIndicesSouthToNorth,
125
- southIndicesEastToWest: statistics.southIndicesEastToWest,
126
- eastIndicesNorthToSouth: statistics.eastIndicesNorthToSouth,
127
- northIndicesWestToEast: statistics.northIndicesWestToEast
128
- };
129
- }
130
- var scratchCartographic = new Cartographic_default();
131
- var scratchCartesian = new Cartesian3_default();
132
- var minimumScratch = new Cartesian3_default();
133
- var maximumScratch = new Cartesian3_default();
134
- var matrix4Scratch = new Matrix4_default();
135
- function processBuffer(buffer, relativeToCenter, ellipsoid, rectangle, nativeRectangle, exaggeration, exaggerationRelativeHeight, skirtHeight, includeWebMercatorT, negativeAltitudeExponentBias, negativeElevationThreshold) {
136
- let geographicWest;
137
- let geographicSouth;
138
- let geographicEast;
139
- let geographicNorth;
140
- let rectangleWidth, rectangleHeight;
141
- if (!defined_default(rectangle)) {
142
- geographicWest = Math_default.toRadians(nativeRectangle.west);
143
- geographicSouth = Math_default.toRadians(nativeRectangle.south);
144
- geographicEast = Math_default.toRadians(nativeRectangle.east);
145
- geographicNorth = Math_default.toRadians(nativeRectangle.north);
146
- rectangleWidth = Math_default.toRadians(rectangle.width);
147
- rectangleHeight = Math_default.toRadians(rectangle.height);
148
- } else {
149
- geographicWest = rectangle.west;
150
- geographicSouth = rectangle.south;
151
- geographicEast = rectangle.east;
152
- geographicNorth = rectangle.north;
153
- rectangleWidth = rectangle.width;
154
- rectangleHeight = rectangle.height;
155
- }
156
- const quadBorderLatitudes = [geographicSouth, geographicNorth];
157
- const quadBorderLongitudes = [geographicWest, geographicEast];
158
- const fromENU = Transforms_default.eastNorthUpToFixedFrame(
159
- relativeToCenter,
160
- ellipsoid
161
- );
162
- const toENU = Matrix4_default.inverseTransformation(fromENU, matrix4Scratch);
163
- let southMercatorY;
164
- let oneOverMercatorHeight;
165
- if (includeWebMercatorT) {
166
- southMercatorY = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(geographicSouth);
167
- oneOverMercatorHeight = 1 / (WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(geographicNorth) - southMercatorY);
168
- }
169
- const hasExaggeration = exaggeration !== 1;
170
- const includeGeodeticSurfaceNormals = hasExaggeration;
171
- const dv = new DataView(buffer);
172
- let minHeight = Number.POSITIVE_INFINITY;
173
- let maxHeight = Number.NEGATIVE_INFINITY;
174
- const minimum = minimumScratch;
175
- minimum.x = Number.POSITIVE_INFINITY;
176
- minimum.y = Number.POSITIVE_INFINITY;
177
- minimum.z = Number.POSITIVE_INFINITY;
178
- const maximum = maximumScratch;
179
- maximum.x = Number.NEGATIVE_INFINITY;
180
- maximum.y = Number.NEGATIVE_INFINITY;
181
- maximum.z = Number.NEGATIVE_INFINITY;
182
- let offset = 0;
183
- let size = 0;
184
- let indicesSize = 0;
185
- let quadSize;
186
- let quad;
187
- for (quad = 0; quad < 4; ++quad) {
188
- let o = offset;
189
- quadSize = dv.getUint32(o, true);
190
- o += sizeOfUint32;
191
- const x = Math_default.toRadians(dv.getFloat64(o, true) * 180);
192
- o += sizeOfDouble;
193
- if (indexOfEpsilon(quadBorderLongitudes, x) === -1) {
194
- quadBorderLongitudes.push(x);
195
- }
196
- const y = Math_default.toRadians(dv.getFloat64(o, true) * 180);
197
- o += sizeOfDouble;
198
- if (indexOfEpsilon(quadBorderLatitudes, y) === -1) {
199
- quadBorderLatitudes.push(y);
200
- }
201
- o += 2 * sizeOfDouble;
202
- let c = dv.getInt32(o, true);
203
- o += sizeOfInt32;
204
- size += c;
205
- c = dv.getInt32(o, true);
206
- indicesSize += c * 3;
207
- offset += quadSize + sizeOfUint32;
208
- }
209
- const quadBorderPoints = [];
210
- const quadBorderIndices = [];
211
- const positions = new Array(size);
212
- const uvs = new Array(size);
213
- const heights = new Array(size);
214
- const webMercatorTs = includeWebMercatorT ? new Array(size) : [];
215
- const geodeticSurfaceNormals = includeGeodeticSurfaceNormals ? new Array(size) : [];
216
- const indices = new Array(indicesSize);
217
- const westBorder = [];
218
- const southBorder = [];
219
- const eastBorder = [];
220
- const northBorder = [];
221
- let pointOffset = 0;
222
- let indicesOffset = 0;
223
- offset = 0;
224
- for (quad = 0; quad < 4; ++quad) {
225
- quadSize = dv.getUint32(offset, true);
226
- offset += sizeOfUint32;
227
- const startQuad = offset;
228
- const originX = Math_default.toRadians(dv.getFloat64(offset, true) * 180);
229
- offset += sizeOfDouble;
230
- const originY = Math_default.toRadians(dv.getFloat64(offset, true) * 180);
231
- offset += sizeOfDouble;
232
- const stepX = Math_default.toRadians(dv.getFloat64(offset, true) * 180);
233
- const halfStepX = stepX * 0.5;
234
- offset += sizeOfDouble;
235
- const stepY = Math_default.toRadians(dv.getFloat64(offset, true) * 180);
236
- const halfStepY = stepY * 0.5;
237
- offset += sizeOfDouble;
238
- const numPoints = dv.getInt32(offset, true);
239
- offset += sizeOfInt32;
240
- const numFaces = dv.getInt32(offset, true);
241
- offset += sizeOfInt32;
242
- offset += sizeOfInt32;
243
- const indicesMapping = new Array(numPoints);
244
- for (let i = 0; i < numPoints; ++i) {
245
- const longitude = originX + dv.getUint8(offset++) * stepX;
246
- scratchCartographic.longitude = longitude;
247
- const latitude = originY + dv.getUint8(offset++) * stepY;
248
- scratchCartographic.latitude = latitude;
249
- let height = dv.getFloat32(offset, true);
250
- offset += sizeOfFloat;
251
- if (height !== 0 && height < negativeElevationThreshold) {
252
- height *= -Math.pow(2, negativeAltitudeExponentBias);
253
- }
254
- height *= 6371010;
255
- scratchCartographic.height = height;
256
- if (indexOfEpsilon(quadBorderLongitudes, longitude) !== -1 || indexOfEpsilon(quadBorderLatitudes, latitude) !== -1) {
257
- const index = indexOfEpsilon(
258
- quadBorderPoints,
259
- scratchCartographic,
260
- Cartographic_default
261
- );
262
- if (index === -1) {
263
- quadBorderPoints.push(Cartographic_default.clone(scratchCartographic));
264
- quadBorderIndices.push(pointOffset);
265
- } else {
266
- indicesMapping[i] = quadBorderIndices[index];
267
- continue;
268
- }
269
- }
270
- indicesMapping[i] = pointOffset;
271
- if (Math.abs(longitude - geographicWest) < halfStepX) {
272
- westBorder.push({
273
- index: pointOffset,
274
- cartographic: Cartographic_default.clone(scratchCartographic)
275
- });
276
- } else if (Math.abs(longitude - geographicEast) < halfStepX) {
277
- eastBorder.push({
278
- index: pointOffset,
279
- cartographic: Cartographic_default.clone(scratchCartographic)
280
- });
281
- } else if (Math.abs(latitude - geographicSouth) < halfStepY) {
282
- southBorder.push({
283
- index: pointOffset,
284
- cartographic: Cartographic_default.clone(scratchCartographic)
285
- });
286
- } else if (Math.abs(latitude - geographicNorth) < halfStepY) {
287
- northBorder.push({
288
- index: pointOffset,
289
- cartographic: Cartographic_default.clone(scratchCartographic)
290
- });
291
- }
292
- minHeight = Math.min(height, minHeight);
293
- maxHeight = Math.max(height, maxHeight);
294
- heights[pointOffset] = height;
295
- const pos = ellipsoid.cartographicToCartesian(scratchCartographic);
296
- positions[pointOffset] = pos;
297
- if (includeWebMercatorT) {
298
- webMercatorTs[pointOffset] = (WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(latitude) - southMercatorY) * oneOverMercatorHeight;
299
- }
300
- if (includeGeodeticSurfaceNormals) {
301
- const normal = ellipsoid.geodeticSurfaceNormal(pos);
302
- geodeticSurfaceNormals[pointOffset] = normal;
303
- }
304
- Matrix4_default.multiplyByPoint(toENU, pos, scratchCartesian);
305
- Cartesian3_default.minimumByComponent(scratchCartesian, minimum, minimum);
306
- Cartesian3_default.maximumByComponent(scratchCartesian, maximum, maximum);
307
- let u = (longitude - geographicWest) / (geographicEast - geographicWest);
308
- u = Math_default.clamp(u, 0, 1);
309
- let v = (latitude - geographicSouth) / (geographicNorth - geographicSouth);
310
- v = Math_default.clamp(v, 0, 1);
311
- uvs[pointOffset] = new Cartesian2_default(u, v);
312
- ++pointOffset;
313
- }
314
- const facesElementCount = numFaces * 3;
315
- for (let j = 0; j < facesElementCount; ++j, ++indicesOffset) {
316
- indices[indicesOffset] = indicesMapping[dv.getUint16(offset, true)];
317
- offset += sizeOfUint16;
318
- }
319
- if (quadSize !== offset - startQuad) {
320
- throw new RuntimeError_default("Invalid terrain tile.");
321
- }
322
- }
323
- positions.length = pointOffset;
324
- uvs.length = pointOffset;
325
- heights.length = pointOffset;
326
- if (includeWebMercatorT) {
327
- webMercatorTs.length = pointOffset;
328
- }
329
- if (includeGeodeticSurfaceNormals) {
330
- geodeticSurfaceNormals.length = pointOffset;
331
- }
332
- const vertexCountWithoutSkirts = pointOffset;
333
- const indexCountWithoutSkirts = indicesOffset;
334
- const skirtOptions = {
335
- hMin: minHeight,
336
- lastBorderPoint: void 0,
337
- skirtHeight,
338
- toENU,
339
- ellipsoid,
340
- minimum,
341
- maximum
342
- };
343
- westBorder.sort(function(a, b) {
344
- return b.cartographic.latitude - a.cartographic.latitude;
345
- });
346
- southBorder.sort(function(a, b) {
347
- return a.cartographic.longitude - b.cartographic.longitude;
348
- });
349
- eastBorder.sort(function(a, b) {
350
- return a.cartographic.latitude - b.cartographic.latitude;
351
- });
352
- northBorder.sort(function(a, b) {
353
- return b.cartographic.longitude - a.cartographic.longitude;
354
- });
355
- const percentage = 1e-5;
356
- addSkirt(
357
- positions,
358
- heights,
359
- uvs,
360
- webMercatorTs,
361
- geodeticSurfaceNormals,
362
- indices,
363
- skirtOptions,
364
- westBorder,
365
- -percentage * rectangleWidth,
366
- true,
367
- -percentage * rectangleHeight
368
- );
369
- addSkirt(
370
- positions,
371
- heights,
372
- uvs,
373
- webMercatorTs,
374
- geodeticSurfaceNormals,
375
- indices,
376
- skirtOptions,
377
- southBorder,
378
- -percentage * rectangleHeight,
379
- false
380
- );
381
- addSkirt(
382
- positions,
383
- heights,
384
- uvs,
385
- webMercatorTs,
386
- geodeticSurfaceNormals,
387
- indices,
388
- skirtOptions,
389
- eastBorder,
390
- percentage * rectangleWidth,
391
- true,
392
- percentage * rectangleHeight
393
- );
394
- addSkirt(
395
- positions,
396
- heights,
397
- uvs,
398
- webMercatorTs,
399
- geodeticSurfaceNormals,
400
- indices,
401
- skirtOptions,
402
- northBorder,
403
- percentage * rectangleHeight,
404
- false
405
- );
406
- if (westBorder.length > 0 && northBorder.length > 0) {
407
- const firstBorderIndex = westBorder[0].index;
408
- const firstSkirtIndex = vertexCountWithoutSkirts;
409
- const lastBorderIndex = northBorder[northBorder.length - 1].index;
410
- const lastSkirtIndex = positions.length - 1;
411
- indices.push(
412
- lastBorderIndex,
413
- lastSkirtIndex,
414
- firstSkirtIndex,
415
- firstSkirtIndex,
416
- firstBorderIndex,
417
- lastBorderIndex
418
- );
419
- }
420
- size = positions.length;
421
- const boundingSphere3D = BoundingSphere_default.fromPoints(positions);
422
- let orientedBoundingBox;
423
- if (defined_default(rectangle)) {
424
- orientedBoundingBox = OrientedBoundingBox_default.fromRectangle(
425
- rectangle,
426
- minHeight,
427
- maxHeight,
428
- ellipsoid
429
- );
430
- }
431
- const occluder = new EllipsoidalOccluder_default(ellipsoid);
432
- const occludeePointInScaledSpace = occluder.computeHorizonCullingPointPossiblyUnderEllipsoid(
433
- relativeToCenter,
434
- positions,
435
- minHeight
436
- );
437
- const aaBox = new AxisAlignedBoundingBox_default(minimum, maximum, relativeToCenter);
438
- const encoding = new TerrainEncoding_default(
439
- relativeToCenter,
440
- aaBox,
441
- skirtOptions.hMin,
442
- maxHeight,
443
- fromENU,
444
- false,
445
- includeWebMercatorT,
446
- includeGeodeticSurfaceNormals,
447
- exaggeration,
448
- exaggerationRelativeHeight
449
- );
450
- const vertices = new Float32Array(size * encoding.stride);
451
- let bufferIndex = 0;
452
- for (let k = 0; k < size; ++k) {
453
- bufferIndex = encoding.encode(
454
- vertices,
455
- bufferIndex,
456
- positions[k],
457
- uvs[k],
458
- heights[k],
459
- void 0,
460
- webMercatorTs[k],
461
- geodeticSurfaceNormals[k]
462
- );
463
- }
464
- const westIndicesSouthToNorth = westBorder.map(function(vertex) {
465
- return vertex.index;
466
- }).reverse();
467
- const southIndicesEastToWest = southBorder.map(function(vertex) {
468
- return vertex.index;
469
- }).reverse();
470
- const eastIndicesNorthToSouth = eastBorder.map(function(vertex) {
471
- return vertex.index;
472
- }).reverse();
473
- const northIndicesWestToEast = northBorder.map(function(vertex) {
474
- return vertex.index;
475
- }).reverse();
476
- southIndicesEastToWest.unshift(
477
- eastIndicesNorthToSouth[eastIndicesNorthToSouth.length - 1]
478
- );
479
- southIndicesEastToWest.push(westIndicesSouthToNorth[0]);
480
- northIndicesWestToEast.unshift(
481
- westIndicesSouthToNorth[westIndicesSouthToNorth.length - 1]
482
- );
483
- northIndicesWestToEast.push(eastIndicesNorthToSouth[0]);
484
- return {
485
- vertices,
486
- indices: new Uint16Array(indices),
487
- maximumHeight: maxHeight,
488
- minimumHeight: minHeight,
489
- encoding,
490
- boundingSphere3D,
491
- orientedBoundingBox,
492
- occludeePointInScaledSpace,
493
- vertexCountWithoutSkirts,
494
- indexCountWithoutSkirts,
495
- westIndicesSouthToNorth,
496
- southIndicesEastToWest,
497
- eastIndicesNorthToSouth,
498
- northIndicesWestToEast
499
- };
500
- }
501
- function addSkirt(positions, heights, uvs, webMercatorTs, geodeticSurfaceNormals, indices, skirtOptions, borderPoints, fudgeFactor, eastOrWest, cornerFudge) {
502
- const count = borderPoints.length;
503
- for (let j = 0; j < count; ++j) {
504
- const borderPoint = borderPoints[j];
505
- const borderCartographic = borderPoint.cartographic;
506
- const borderIndex = borderPoint.index;
507
- const currentIndex = positions.length;
508
- const longitude = borderCartographic.longitude;
509
- let latitude = borderCartographic.latitude;
510
- latitude = Math_default.clamp(
511
- latitude,
512
- -Math_default.PI_OVER_TWO,
513
- Math_default.PI_OVER_TWO
514
- );
515
- const height = borderCartographic.height - skirtOptions.skirtHeight;
516
- skirtOptions.hMin = Math.min(skirtOptions.hMin, height);
517
- Cartographic_default.fromRadians(longitude, latitude, height, scratchCartographic);
518
- if (eastOrWest) {
519
- scratchCartographic.longitude += fudgeFactor;
520
- }
521
- if (!eastOrWest) {
522
- scratchCartographic.latitude += fudgeFactor;
523
- } else if (j === count - 1) {
524
- scratchCartographic.latitude += cornerFudge;
525
- } else if (j === 0) {
526
- scratchCartographic.latitude -= cornerFudge;
527
- }
528
- const pos = skirtOptions.ellipsoid.cartographicToCartesian(scratchCartographic);
529
- positions.push(pos);
530
- heights.push(height);
531
- uvs.push(Cartesian2_default.clone(uvs[borderIndex]));
532
- if (webMercatorTs.length > 0) {
533
- webMercatorTs.push(webMercatorTs[borderIndex]);
534
- }
535
- if (geodeticSurfaceNormals.length > 0) {
536
- geodeticSurfaceNormals.push(geodeticSurfaceNormals[borderIndex]);
537
- }
538
- Matrix4_default.multiplyByPoint(skirtOptions.toENU, pos, scratchCartesian);
539
- const minimum = skirtOptions.minimum;
540
- const maximum = skirtOptions.maximum;
541
- Cartesian3_default.minimumByComponent(scratchCartesian, minimum, minimum);
542
- Cartesian3_default.maximumByComponent(scratchCartesian, maximum, maximum);
543
- const lastBorderPoint = skirtOptions.lastBorderPoint;
544
- if (defined_default(lastBorderPoint)) {
545
- const lastBorderIndex = lastBorderPoint.index;
546
- indices.push(
547
- lastBorderIndex,
548
- currentIndex - 1,
549
- currentIndex,
550
- currentIndex,
551
- borderIndex,
552
- lastBorderIndex
553
- );
554
- }
555
- skirtOptions.lastBorderPoint = borderPoint;
556
- }
557
- }
558
- var createVerticesFromGoogleEarthEnterpriseBuffer_default = createTaskProcessorWorker_default(
559
- createVerticesFromGoogleEarthEnterpriseBuffer
560
- );
561
- export {
562
- createVerticesFromGoogleEarthEnterpriseBuffer_default as default
563
- };
26
+ import{a as Dt,b as Gt}from"./chunk-7HTKERZY.js";import{a as Lt}from"./chunk-WZDE3RYP.js";import{a as lt}from"./chunk-DQQ63PYM.js";import{a as qt}from"./chunk-CNCV5UL7.js";import"./chunk-DEPHB2WM.js";import"./chunk-TCGIRNHN.js";import{a as kt}from"./chunk-N4VJKXZS.js";import"./chunk-DMEY62ID.js";import"./chunk-HTFSEEMT.js";import{d as zt}from"./chunk-4IW2T6GF.js";import{b as $,g as Ot,h as Vt}from"./chunk-PSPPBZWI.js";import"./chunk-AU7IKHOH.js";import{a as P,b as N,c as wt,d as Ut}from"./chunk-64RSHJUE.js";import{a as r}from"./chunk-3SSKC3VN.js";import"./chunk-OSW76XDF.js";import{a as Ht}from"./chunk-ED5JPB3S.js";import"./chunk-LEYMRMBK.js";import{e as ht}from"./chunk-VTAIKJXX.js";var $t=Uint16Array.BYTES_PER_ELEMENT,mt=Int32Array.BYTES_PER_ELEMENT,Pt=Uint32Array.BYTES_PER_ELEMENT,te=Float32Array.BYTES_PER_ELEMENT,H=Float64Array.BYTES_PER_ELEMENT;function tt(n,l,e){e=e??r;let i=n.length;for(let c=0;c<i;++c)if(e.equalsEpsilon(n[c],l,r.EPSILON12))return c;return-1}function ee(n,l){n.ellipsoid=Ut.clone(n.ellipsoid),n.rectangle=Vt.clone(n.rectangle);let e=re(n.buffer,n.relativeToCenter,n.ellipsoid,n.rectangle,n.nativeRectangle,n.exaggeration,n.exaggerationRelativeHeight,n.skirtHeight,n.includeWebMercatorT,n.negativeAltitudeExponentBias,n.negativeElevationThreshold),i=e.vertices;l.push(i.buffer);let c=e.indices;return l.push(c.buffer),{vertices:i.buffer,indices:c.buffer,numberOfAttributes:e.encoding.stride,minimumHeight:e.minimumHeight,maximumHeight:e.maximumHeight,boundingSphere3D:e.boundingSphere3D,orientedBoundingBox:e.orientedBoundingBox,occludeePointInScaledSpace:e.occludeePointInScaledSpace,encoding:e.encoding,vertexCountWithoutSkirts:e.vertexCountWithoutSkirts,indexCountWithoutSkirts:e.indexCountWithoutSkirts,westIndicesSouthToNorth:e.westIndicesSouthToNorth,southIndicesEastToWest:e.southIndicesEastToWest,eastIndicesNorthToSouth:e.eastIndicesNorthToSouth,northIndicesWestToEast:e.northIndicesWestToEast}}var u=new N,G=new P,oe=new P,ne=new P,ie=new $;function re(n,l,e,i,c,et,m,ot,T,nt,it){let I,h,E,f,x,p;ht(i)?(I=i.west,h=i.south,E=i.east,f=i.north,x=i.width,p=i.height):(I=r.toRadians(c.west),h=r.toRadians(c.south),E=r.toRadians(c.east),f=r.toRadians(c.north),x=r.toRadians(i.width),p=r.toRadians(i.height));let X=[h,f],A=[I,E],O=Ot.eastNorthUpToFixedFrame(l,e),j=$.inverseTransformation(O,ie),V,Q;T&&(V=lt.geodeticLatitudeToMercatorAngle(h),Q=1/(lt.geodeticLatitudeToMercatorAngle(f)-V));let y=et!==1,a=new DataView(n),z=Number.POSITIVE_INFINITY,J=Number.NEGATIVE_INFINITY,b=oe;b.x=Number.POSITIVE_INFINITY,b.y=Number.POSITIVE_INFINITY,b.z=Number.POSITIVE_INFINITY;let M=ne;M.x=Number.NEGATIVE_INFINITY,M.y=Number.NEGATIVE_INFINITY,M.z=Number.NEGATIVE_INFINITY;let o=0,S=0,At=0,rt,L;for(L=0;L<4;++L){let t=o;rt=a.getUint32(t,!0),t+=Pt;let d=r.toRadians(a.getFloat64(t,!0)*180);t+=H,tt(A,d)===-1&&A.push(d);let Y=r.toRadians(a.getFloat64(t,!0)*180);t+=H,tt(X,Y)===-1&&X.push(Y),t+=2*H;let B=a.getInt32(t,!0);t+=mt,S+=B,B=a.getInt32(t,!0),At+=B*3,o+=rt+Pt}let yt=[],bt=[],g=new Array(S),R=new Array(S),_=new Array(S),C=T?new Array(S):[],F=y?new Array(S):[],v=new Array(At),k=[],st=[],ct=[],W=[],s=0,pt=0;for(o=0,L=0;L<4;++L){rt=a.getUint32(o,!0),o+=Pt;let t=o,d=r.toRadians(a.getFloat64(o,!0)*180);o+=H;let Y=r.toRadians(a.getFloat64(o,!0)*180);o+=H;let B=r.toRadians(a.getFloat64(o,!0)*180),Ft=B*.5;o+=H;let vt=r.toRadians(a.getFloat64(o,!0)*180),Wt=vt*.5;o+=H;let Yt=a.getInt32(o,!0);o+=mt;let Kt=a.getInt32(o,!0);o+=mt,o+=mt;let St=new Array(Yt);for(let U=0;U<Yt;++U){let Z=d+a.getUint8(o++)*B;u.longitude=Z;let D=Y+a.getUint8(o++)*vt;u.latitude=D;let w=a.getFloat32(o,!0);if(o+=te,w!==0&&w<it&&(w*=-Math.pow(2,nt)),w*=6371010,u.height=w,tt(A,Z)!==-1||tt(X,D)!==-1){let dt=tt(yt,u,N);if(dt===-1)yt.push(N.clone(u)),bt.push(s);else{St[U]=bt[dt];continue}}St[U]=s,Math.abs(Z-I)<Ft?k.push({index:s,cartographic:N.clone(u)}):Math.abs(Z-E)<Ft?ct.push({index:s,cartographic:N.clone(u)}):Math.abs(D-h)<Wt?st.push({index:s,cartographic:N.clone(u)}):Math.abs(D-f)<Wt&&W.push({index:s,cartographic:N.clone(u)}),z=Math.min(w,z),J=Math.max(w,J),_[s]=w;let Nt=e.cartographicToCartesian(u);if(g[s]=Nt,T&&(C[s]=(lt.geodeticLatitudeToMercatorAngle(D)-V)*Q),y){let dt=e.geodeticSurfaceNormal(Nt);F[s]=dt}$.multiplyByPoint(j,Nt,G),P.minimumByComponent(G,b,b),P.maximumByComponent(G,M,M);let Tt=(Z-I)/(E-I);Tt=r.clamp(Tt,0,1);let Bt=(D-h)/(f-h);Bt=r.clamp(Bt,0,1),R[s]=new wt(Tt,Bt),++s}let Zt=Kt*3;for(let U=0;U<Zt;++U,++pt)v[pt]=St[a.getUint16(o,!0)],o+=$t;if(rt!==o-t)throw new Ht("Invalid terrain tile.")}g.length=s,R.length=s,_.length=s,T&&(C.length=s),y&&(F.length=s);let Mt=s,Xt=pt,K={hMin:z,lastBorderPoint:void 0,skirtHeight:ot,toENU:j,ellipsoid:e,minimum:b,maximum:M};k.sort(function(t,d){return d.cartographic.latitude-t.cartographic.latitude}),st.sort(function(t,d){return t.cartographic.longitude-d.cartographic.longitude}),ct.sort(function(t,d){return t.cartographic.latitude-d.cartographic.latitude}),W.sort(function(t,d){return d.cartographic.longitude-t.cartographic.longitude});let q=1e-5;if(gt(g,_,R,C,F,v,K,k,-q*x,!0,-q*p),gt(g,_,R,C,F,v,K,st,-q*p,!1),gt(g,_,R,C,F,v,K,ct,q*x,!0,q*p),gt(g,_,R,C,F,v,K,W,q*p,!1),k.length>0&&W.length>0){let t=k[0].index,d=Mt,Y=W[W.length-1].index,B=g.length-1;v.push(Y,B,d,d,t,Y)}S=g.length;let jt=zt.fromPoints(g),Rt;ht(i)&&(Rt=qt.fromRectangle(i,z,J,e));let Qt=new Dt(e).computeHorizonCullingPointPossiblyUnderEllipsoid(l,g,z),Jt=new kt(b,M,l),It=new Gt(l,Jt,K.hMin,J,O,!1,T,y,et,m),_t=new Float32Array(S*It.stride),Ct=0;for(let t=0;t<S;++t)Ct=It.encode(_t,Ct,g[t],R[t],_[t],void 0,C[t],F[t]);let at=k.map(function(t){return t.index}).reverse(),Et=st.map(function(t){return t.index}).reverse(),ut=ct.map(function(t){return t.index}).reverse(),xt=W.map(function(t){return t.index}).reverse();return Et.unshift(ut[ut.length-1]),Et.push(at[0]),xt.unshift(at[at.length-1]),xt.push(ut[0]),{vertices:_t,indices:new Uint16Array(v),maximumHeight:J,minimumHeight:z,encoding:It,boundingSphere3D:jt,orientedBoundingBox:Rt,occludeePointInScaledSpace:Qt,vertexCountWithoutSkirts:Mt,indexCountWithoutSkirts:Xt,westIndicesSouthToNorth:at,southIndicesEastToWest:Et,eastIndicesNorthToSouth:ut,northIndicesWestToEast:xt}}function gt(n,l,e,i,c,et,m,ot,T,nt,it){let I=ot.length;for(let h=0;h<I;++h){let E=ot[h],f=E.cartographic,x=E.index,p=n.length,X=f.longitude,A=f.latitude;A=r.clamp(A,-r.PI_OVER_TWO,r.PI_OVER_TWO);let O=f.height-m.skirtHeight;m.hMin=Math.min(m.hMin,O),N.fromRadians(X,A,O,u),nt&&(u.longitude+=T),nt?h===I-1?u.latitude+=it:h===0&&(u.latitude-=it):u.latitude+=T;let j=m.ellipsoid.cartographicToCartesian(u);n.push(j),l.push(O),e.push(wt.clone(e[x])),i.length>0&&i.push(i[x]),c.length>0&&c.push(c[x]),$.multiplyByPoint(m.toENU,j,G);let V=m.minimum,Q=m.maximum;P.minimumByComponent(G,V,V),P.maximumByComponent(G,Q,Q);let ft=m.lastBorderPoint;if(ht(ft)){let y=ft.index;et.push(y,p-1,p,p,x,y)}m.lastBorderPoint=E}}var we=Lt(ee);export{we as default};