@pggis/pg-sdk 3.3.10 → 3.5.0

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 (163) hide show
  1. package/README.md +8 -8
  2. package/dist/index.js +1966 -4
  3. package/dist/pggis.min.css +1 -1
  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-F3YA3Y2Z.js → chunk-A56XVLQR.js} +2 -13
  19. package/dist/resources/Workers/chunk-AJYK4IVJ.js +26 -0
  20. package/dist/resources/Workers/{chunk-EHWHNOEX.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-4H7PY4U5.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-BBWDMCVU.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-WZDE3RYP.js +28 -0
  60. package/dist/resources/Workers/chunk-XRL4AVS5.js +26 -0
  61. package/dist/resources/Workers/combineGeometry.js +2 -44
  62. package/dist/resources/Workers/createBoxGeometry.js +2 -34
  63. package/dist/resources/Workers/createBoxOutlineGeometry.js +2 -211
  64. package/dist/resources/Workers/createCircleGeometry.js +2 -173
  65. package/dist/resources/Workers/createCircleOutlineGeometry.js +2 -123
  66. package/dist/resources/Workers/createCoplanarPolygonGeometry.js +2 -482
  67. package/dist/resources/Workers/createCoplanarPolygonOutlineGeometry.js +2 -201
  68. package/dist/resources/Workers/createCorridorGeometry.js +2 -1239
  69. package/dist/resources/Workers/createCorridorOutlineGeometry.js +2 -544
  70. package/dist/resources/Workers/createCylinderGeometry.js +2 -36
  71. package/dist/resources/Workers/createCylinderOutlineGeometry.js +2 -207
  72. package/dist/resources/Workers/createEllipseGeometry.js +2 -47
  73. package/dist/resources/Workers/createEllipseOutlineGeometry.js +2 -40
  74. package/dist/resources/Workers/createEllipsoidGeometry.js +2 -35
  75. package/dist/resources/Workers/createEllipsoidOutlineGeometry.js +2 -37
  76. package/dist/resources/Workers/createFrustumGeometry.js +2 -34
  77. package/dist/resources/Workers/createFrustumOutlineGeometry.js +2 -211
  78. package/dist/resources/Workers/createGeometry.js +2 -147
  79. package/dist/resources/Workers/createGroundPolylineGeometry.js +2 -1584
  80. package/dist/resources/Workers/createPlaneGeometry.js +2 -200
  81. package/dist/resources/Workers/createPlaneOutlineGeometry.js +2 -100
  82. package/dist/resources/Workers/createPolygonGeometry.js +2 -1387
  83. package/dist/resources/Workers/createPolygonOutlineGeometry.js +2 -519
  84. package/dist/resources/Workers/createPolylineGeometry.js +2 -472
  85. package/dist/resources/Workers/createPolylineVolumeGeometry.js +2 -355
  86. package/dist/resources/Workers/createPolylineVolumeOutlineGeometry.js +2 -253
  87. package/dist/resources/Workers/createRectangleGeometry.js +2 -1250
  88. package/dist/resources/Workers/createRectangleOutlineGeometry.js +2 -455
  89. package/dist/resources/Workers/createSimplePolylineGeometry.js +2 -376
  90. package/dist/resources/Workers/createSphereGeometry.js +2 -94
  91. package/dist/resources/Workers/createSphereOutlineGeometry.js +2 -94
  92. package/dist/resources/Workers/createTaskProcessorWorker.js +2 -8
  93. package/dist/resources/Workers/createVectorTileClampedPolylines.js +2 -468
  94. package/dist/resources/Workers/createVectorTileGeometries.js +2 -363
  95. package/dist/resources/Workers/createVectorTilePoints.js +2 -88
  96. package/dist/resources/Workers/createVectorTilePolygons.js +2 -361
  97. package/dist/resources/Workers/createVectorTilePolylines.js +2 -238
  98. package/dist/resources/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +2 -545
  99. package/dist/resources/Workers/createVerticesFromHeightmap.js +2 -2254
  100. package/dist/resources/Workers/createVerticesFromQuantizedTerrainMesh.js +2 -722
  101. package/dist/resources/Workers/createWallGeometry.js +2 -466
  102. package/dist/resources/Workers/createWallOutlineGeometry.js +2 -314
  103. package/dist/resources/Workers/decodeDraco.js +2 -345
  104. package/dist/resources/Workers/decodeGoogleEarthEnterprisePacket.js +2 -2626
  105. package/dist/resources/Workers/decodeI3S.js +2 -1320
  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 -3398
  109. package/dist/resources/Workers/transferTypedArrayTest.js +2 -17
  110. package/dist/resources/Workers/upsampleQuantizedTerrainMesh.js +2 -795
  111. package/package.json +9 -8
  112. package/dist/pggis.min.js +0 -14796
  113. package/dist/resources/ThirdParty/Workers/basis_transcoder.js +0 -21
  114. package/dist/resources/Workers/chunk-23UFSGND.js +0 -236
  115. package/dist/resources/Workers/chunk-2A75IWRS.js +0 -218
  116. package/dist/resources/Workers/chunk-2FRVPMCS.js +0 -1258
  117. package/dist/resources/Workers/chunk-2FWRMUTY.js +0 -138
  118. package/dist/resources/Workers/chunk-2UPKWTMJ.js +0 -117
  119. package/dist/resources/Workers/chunk-34FXV7D7.js +0 -73
  120. package/dist/resources/Workers/chunk-3VAZEH7M.js +0 -101
  121. package/dist/resources/Workers/chunk-4DO5W5XZ.js +0 -196
  122. package/dist/resources/Workers/chunk-5QULIR53.js +0 -501
  123. package/dist/resources/Workers/chunk-7TC63SJW.js +0 -302
  124. package/dist/resources/Workers/chunk-7ZFGPDJA.js +0 -122
  125. package/dist/resources/Workers/chunk-A5DWLWCY.js +0 -834
  126. package/dist/resources/Workers/chunk-BG4UCVXN.js +0 -73
  127. package/dist/resources/Workers/chunk-BIKA3NRA.js +0 -59
  128. package/dist/resources/Workers/chunk-BROJAZRZ.js +0 -390
  129. package/dist/resources/Workers/chunk-DDUQAJ4P.js +0 -476
  130. package/dist/resources/Workers/chunk-EERJKOAF.js +0 -305
  131. package/dist/resources/Workers/chunk-EG6PTBY2.js +0 -2716
  132. package/dist/resources/Workers/chunk-F4HFJMGM.js +0 -353
  133. package/dist/resources/Workers/chunk-FJKNFAKQ.js +0 -8219
  134. package/dist/resources/Workers/chunk-FNIRWHJB.js +0 -289
  135. package/dist/resources/Workers/chunk-FZRIVR7Y.js +0 -100
  136. package/dist/resources/Workers/chunk-G43QFN4Q.js +0 -157
  137. package/dist/resources/Workers/chunk-GATZHF3K.js +0 -1860
  138. package/dist/resources/Workers/chunk-GRC2ZTAF.js +0 -398
  139. package/dist/resources/Workers/chunk-HU6N6EXB.js +0 -767
  140. package/dist/resources/Workers/chunk-I46ZRR5W.js +0 -1052
  141. package/dist/resources/Workers/chunk-JURN7NPV.js +0 -1075
  142. package/dist/resources/Workers/chunk-KKCR2YOP.js +0 -421
  143. package/dist/resources/Workers/chunk-LPR3YNP2.js +0 -138
  144. package/dist/resources/Workers/chunk-M7ERACJJ.js +0 -511
  145. package/dist/resources/Workers/chunk-MDWEGWPA.js +0 -1007
  146. package/dist/resources/Workers/chunk-OGXZVPPM.js +0 -2365
  147. package/dist/resources/Workers/chunk-PGSJK77E.js +0 -634
  148. package/dist/resources/Workers/chunk-PPH7OFP3.js +0 -258
  149. package/dist/resources/Workers/chunk-SH5USDPI.js +0 -456
  150. package/dist/resources/Workers/chunk-SOWMRMWA.js +0 -629
  151. package/dist/resources/Workers/chunk-STW2DGFI.js +0 -58
  152. package/dist/resources/Workers/chunk-T3XIFPYR.js +0 -1477
  153. package/dist/resources/Workers/chunk-TTUZP4BO.js +0 -501
  154. package/dist/resources/Workers/chunk-UEXTBDBE.js +0 -693
  155. package/dist/resources/Workers/chunk-VOXYEYJT.js +0 -684
  156. package/dist/resources/Workers/chunk-X4356LRH.js +0 -368
  157. package/dist/resources/Workers/chunk-XGI5BXZY.js +0 -163
  158. package/dist/resources/Workers/chunk-Y2ME2IJV.js +0 -781
  159. package/dist/resources/Workers/chunk-Y5UQJLYE.js +0 -171
  160. package/dist/resources/Workers/chunk-YJEBABKH.js +0 -2977
  161. package/dist/resources/Workers/chunk-YWTJ2B4B.js +0 -77
  162. package/dist/resources/Workers/chunk-Z3TIFFGF.js +0 -430
  163. package/dist/resources/Workers/chunk-ZT7KWISZ.js +0 -102
@@ -1,781 +0,0 @@
1
- /**
2
- * @license
3
- * Cesium - https://github.com/CesiumGS/cesium
4
- * Version 1.115
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
- WebMercatorProjection_default
28
- } from "./chunk-2UPKWTMJ.js";
29
- import {
30
- GeometryPipeline_default
31
- } from "./chunk-EG6PTBY2.js";
32
- import {
33
- IndexDatatype_default
34
- } from "./chunk-LPR3YNP2.js";
35
- import {
36
- GeometryAttributes_default
37
- } from "./chunk-4H7PY4U5.js";
38
- import {
39
- GeometryAttribute_default,
40
- Geometry_default
41
- } from "./chunk-7TC63SJW.js";
42
- import {
43
- BoundingSphere_default,
44
- GeographicProjection_default
45
- } from "./chunk-FJKNFAKQ.js";
46
- import {
47
- Matrix4_default
48
- } from "./chunk-YJEBABKH.js";
49
- import {
50
- ComponentDatatype_default
51
- } from "./chunk-PPH7OFP3.js";
52
- import {
53
- Ellipsoid_default
54
- } from "./chunk-OGXZVPPM.js";
55
- import {
56
- defaultValue_default
57
- } from "./chunk-BBWDMCVU.js";
58
- import {
59
- Check_default,
60
- DeveloperError_default
61
- } from "./chunk-XGI5BXZY.js";
62
- import {
63
- defined_default
64
- } from "./chunk-YWTJ2B4B.js";
65
-
66
- // packages/engine/Source/Core/OffsetGeometryInstanceAttribute.js
67
- function OffsetGeometryInstanceAttribute(x, y, z) {
68
- x = defaultValue_default(x, 0);
69
- y = defaultValue_default(y, 0);
70
- z = defaultValue_default(z, 0);
71
- this.value = new Float32Array([x, y, z]);
72
- }
73
- Object.defineProperties(OffsetGeometryInstanceAttribute.prototype, {
74
- /**
75
- * The datatype of each component in the attribute, e.g., individual elements in
76
- * {@link OffsetGeometryInstanceAttribute#value}.
77
- *
78
- * @memberof OffsetGeometryInstanceAttribute.prototype
79
- *
80
- * @type {ComponentDatatype}
81
- * @readonly
82
- *
83
- * @default {@link ComponentDatatype.FLOAT}
84
- */
85
- componentDatatype: {
86
- get: function() {
87
- return ComponentDatatype_default.FLOAT;
88
- }
89
- },
90
- /**
91
- * The number of components in the attributes, i.e., {@link OffsetGeometryInstanceAttribute#value}.
92
- *
93
- * @memberof OffsetGeometryInstanceAttribute.prototype
94
- *
95
- * @type {number}
96
- * @readonly
97
- *
98
- * @default 3
99
- */
100
- componentsPerAttribute: {
101
- get: function() {
102
- return 3;
103
- }
104
- },
105
- /**
106
- * When <code>true</code> and <code>componentDatatype</code> is an integer format,
107
- * indicate that the components should be mapped to the range [0, 1] (unsigned)
108
- * or [-1, 1] (signed) when they are accessed as floating-point for rendering.
109
- *
110
- * @memberof OffsetGeometryInstanceAttribute.prototype
111
- *
112
- * @type {boolean}
113
- * @readonly
114
- *
115
- * @default false
116
- */
117
- normalize: {
118
- get: function() {
119
- return false;
120
- }
121
- }
122
- });
123
- OffsetGeometryInstanceAttribute.fromCartesian3 = function(offset) {
124
- Check_default.defined("offset", offset);
125
- return new OffsetGeometryInstanceAttribute(offset.x, offset.y, offset.z);
126
- };
127
- OffsetGeometryInstanceAttribute.toValue = function(offset, result) {
128
- Check_default.defined("offset", offset);
129
- if (!defined_default(result)) {
130
- result = new Float32Array([offset.x, offset.y, offset.z]);
131
- }
132
- result[0] = offset.x;
133
- result[1] = offset.y;
134
- result[2] = offset.z;
135
- return result;
136
- };
137
- var OffsetGeometryInstanceAttribute_default = OffsetGeometryInstanceAttribute;
138
-
139
- // packages/engine/Source/Scene/PrimitivePipeline.js
140
- function transformToWorldCoordinates(instances, primitiveModelMatrix, scene3DOnly) {
141
- let toWorld = !scene3DOnly;
142
- const length = instances.length;
143
- let i;
144
- if (!toWorld && length > 1) {
145
- const modelMatrix = instances[0].modelMatrix;
146
- for (i = 1; i < length; ++i) {
147
- if (!Matrix4_default.equals(modelMatrix, instances[i].modelMatrix)) {
148
- toWorld = true;
149
- break;
150
- }
151
- }
152
- }
153
- if (toWorld) {
154
- for (i = 0; i < length; ++i) {
155
- if (defined_default(instances[i].geometry)) {
156
- GeometryPipeline_default.transformToWorldCoordinates(instances[i]);
157
- }
158
- }
159
- } else {
160
- Matrix4_default.multiplyTransformation(
161
- primitiveModelMatrix,
162
- instances[0].modelMatrix,
163
- primitiveModelMatrix
164
- );
165
- }
166
- }
167
- function addGeometryBatchId(geometry, batchId) {
168
- const attributes = geometry.attributes;
169
- const positionAttr = attributes.position;
170
- const numberOfComponents = positionAttr.values.length / positionAttr.componentsPerAttribute;
171
- attributes.batchId = new GeometryAttribute_default({
172
- componentDatatype: ComponentDatatype_default.FLOAT,
173
- componentsPerAttribute: 1,
174
- values: new Float32Array(numberOfComponents)
175
- });
176
- const values = attributes.batchId.values;
177
- for (let j = 0; j < numberOfComponents; ++j) {
178
- values[j] = batchId;
179
- }
180
- }
181
- function addBatchIds(instances) {
182
- const length = instances.length;
183
- for (let i = 0; i < length; ++i) {
184
- const instance = instances[i];
185
- if (defined_default(instance.geometry)) {
186
- addGeometryBatchId(instance.geometry, i);
187
- } else if (defined_default(instance.westHemisphereGeometry) && defined_default(instance.eastHemisphereGeometry)) {
188
- addGeometryBatchId(instance.westHemisphereGeometry, i);
189
- addGeometryBatchId(instance.eastHemisphereGeometry, i);
190
- }
191
- }
192
- }
193
- function geometryPipeline(parameters) {
194
- const instances = parameters.instances;
195
- const projection = parameters.projection;
196
- const uintIndexSupport = parameters.elementIndexUintSupported;
197
- const scene3DOnly = parameters.scene3DOnly;
198
- const vertexCacheOptimize = parameters.vertexCacheOptimize;
199
- const compressVertices = parameters.compressVertices;
200
- const modelMatrix = parameters.modelMatrix;
201
- let i;
202
- let geometry;
203
- let primitiveType;
204
- let length = instances.length;
205
- for (i = 0; i < length; ++i) {
206
- if (defined_default(instances[i].geometry)) {
207
- primitiveType = instances[i].geometry.primitiveType;
208
- break;
209
- }
210
- }
211
- for (i = 1; i < length; ++i) {
212
- if (defined_default(instances[i].geometry) && instances[i].geometry.primitiveType !== primitiveType) {
213
- throw new DeveloperError_default(
214
- "All instance geometries must have the same primitiveType."
215
- );
216
- }
217
- }
218
- transformToWorldCoordinates(instances, modelMatrix, scene3DOnly);
219
- if (!scene3DOnly) {
220
- for (i = 0; i < length; ++i) {
221
- if (defined_default(instances[i].geometry)) {
222
- GeometryPipeline_default.splitLongitude(instances[i]);
223
- }
224
- }
225
- }
226
- addBatchIds(instances);
227
- if (vertexCacheOptimize) {
228
- for (i = 0; i < length; ++i) {
229
- const instance = instances[i];
230
- if (defined_default(instance.geometry)) {
231
- GeometryPipeline_default.reorderForPostVertexCache(instance.geometry);
232
- GeometryPipeline_default.reorderForPreVertexCache(instance.geometry);
233
- } else if (defined_default(instance.westHemisphereGeometry) && defined_default(instance.eastHemisphereGeometry)) {
234
- GeometryPipeline_default.reorderForPostVertexCache(
235
- instance.westHemisphereGeometry
236
- );
237
- GeometryPipeline_default.reorderForPreVertexCache(
238
- instance.westHemisphereGeometry
239
- );
240
- GeometryPipeline_default.reorderForPostVertexCache(
241
- instance.eastHemisphereGeometry
242
- );
243
- GeometryPipeline_default.reorderForPreVertexCache(
244
- instance.eastHemisphereGeometry
245
- );
246
- }
247
- }
248
- }
249
- let geometries = GeometryPipeline_default.combineInstances(instances);
250
- length = geometries.length;
251
- for (i = 0; i < length; ++i) {
252
- geometry = geometries[i];
253
- const attributes = geometry.attributes;
254
- if (!scene3DOnly) {
255
- for (const name in attributes) {
256
- if (attributes.hasOwnProperty(name) && attributes[name].componentDatatype === ComponentDatatype_default.DOUBLE) {
257
- const name3D = `${name}3D`;
258
- const name2D = `${name}2D`;
259
- GeometryPipeline_default.projectTo2D(
260
- geometry,
261
- name,
262
- name3D,
263
- name2D,
264
- projection
265
- );
266
- if (defined_default(geometry.boundingSphere) && name === "position") {
267
- geometry.boundingSphereCV = BoundingSphere_default.fromVertices(
268
- geometry.attributes.position2D.values
269
- );
270
- }
271
- GeometryPipeline_default.encodeAttribute(
272
- geometry,
273
- name3D,
274
- `${name3D}High`,
275
- `${name3D}Low`
276
- );
277
- GeometryPipeline_default.encodeAttribute(
278
- geometry,
279
- name2D,
280
- `${name2D}High`,
281
- `${name2D}Low`
282
- );
283
- }
284
- }
285
- } else {
286
- for (const name in attributes) {
287
- if (attributes.hasOwnProperty(name) && attributes[name].componentDatatype === ComponentDatatype_default.DOUBLE) {
288
- GeometryPipeline_default.encodeAttribute(
289
- geometry,
290
- name,
291
- `${name}3DHigh`,
292
- `${name}3DLow`
293
- );
294
- }
295
- }
296
- }
297
- if (compressVertices) {
298
- GeometryPipeline_default.compressVertices(geometry);
299
- }
300
- }
301
- if (!uintIndexSupport) {
302
- let splitGeometries = [];
303
- length = geometries.length;
304
- for (i = 0; i < length; ++i) {
305
- geometry = geometries[i];
306
- splitGeometries = splitGeometries.concat(
307
- GeometryPipeline_default.fitToUnsignedShortIndices(geometry)
308
- );
309
- }
310
- geometries = splitGeometries;
311
- }
312
- return geometries;
313
- }
314
- function createPickOffsets(instances, geometryName, geometries, pickOffsets) {
315
- let offset;
316
- let indexCount;
317
- let geometryIndex;
318
- const offsetIndex = pickOffsets.length - 1;
319
- if (offsetIndex >= 0) {
320
- const pickOffset = pickOffsets[offsetIndex];
321
- offset = pickOffset.offset + pickOffset.count;
322
- geometryIndex = pickOffset.index;
323
- indexCount = geometries[geometryIndex].indices.length;
324
- } else {
325
- offset = 0;
326
- geometryIndex = 0;
327
- indexCount = geometries[geometryIndex].indices.length;
328
- }
329
- const length = instances.length;
330
- for (let i = 0; i < length; ++i) {
331
- const instance = instances[i];
332
- const geometry = instance[geometryName];
333
- if (!defined_default(geometry)) {
334
- continue;
335
- }
336
- const count = geometry.indices.length;
337
- if (offset + count > indexCount) {
338
- offset = 0;
339
- indexCount = geometries[++geometryIndex].indices.length;
340
- }
341
- pickOffsets.push({
342
- index: geometryIndex,
343
- offset,
344
- count
345
- });
346
- offset += count;
347
- }
348
- }
349
- function createInstancePickOffsets(instances, geometries) {
350
- const pickOffsets = [];
351
- createPickOffsets(instances, "geometry", geometries, pickOffsets);
352
- createPickOffsets(
353
- instances,
354
- "westHemisphereGeometry",
355
- geometries,
356
- pickOffsets
357
- );
358
- createPickOffsets(
359
- instances,
360
- "eastHemisphereGeometry",
361
- geometries,
362
- pickOffsets
363
- );
364
- return pickOffsets;
365
- }
366
- var PrimitivePipeline = {};
367
- PrimitivePipeline.combineGeometry = function(parameters) {
368
- let geometries;
369
- let attributeLocations;
370
- const instances = parameters.instances;
371
- const length = instances.length;
372
- let pickOffsets;
373
- let offsetInstanceExtend;
374
- let hasOffset = false;
375
- if (length > 0) {
376
- geometries = geometryPipeline(parameters);
377
- if (geometries.length > 0) {
378
- attributeLocations = GeometryPipeline_default.createAttributeLocations(
379
- geometries[0]
380
- );
381
- if (parameters.createPickOffsets) {
382
- pickOffsets = createInstancePickOffsets(instances, geometries);
383
- }
384
- }
385
- if (defined_default(instances[0].attributes) && defined_default(instances[0].attributes.offset)) {
386
- offsetInstanceExtend = new Array(length);
387
- hasOffset = true;
388
- }
389
- }
390
- const boundingSpheres = new Array(length);
391
- const boundingSpheresCV = new Array(length);
392
- for (let i = 0; i < length; ++i) {
393
- const instance = instances[i];
394
- const geometry = instance.geometry;
395
- if (defined_default(geometry)) {
396
- boundingSpheres[i] = geometry.boundingSphere;
397
- boundingSpheresCV[i] = geometry.boundingSphereCV;
398
- if (hasOffset) {
399
- offsetInstanceExtend[i] = instance.geometry.offsetAttribute;
400
- }
401
- }
402
- const eastHemisphereGeometry = instance.eastHemisphereGeometry;
403
- const westHemisphereGeometry = instance.westHemisphereGeometry;
404
- if (defined_default(eastHemisphereGeometry) && defined_default(westHemisphereGeometry)) {
405
- if (defined_default(eastHemisphereGeometry.boundingSphere) && defined_default(westHemisphereGeometry.boundingSphere)) {
406
- boundingSpheres[i] = BoundingSphere_default.union(
407
- eastHemisphereGeometry.boundingSphere,
408
- westHemisphereGeometry.boundingSphere
409
- );
410
- }
411
- if (defined_default(eastHemisphereGeometry.boundingSphereCV) && defined_default(westHemisphereGeometry.boundingSphereCV)) {
412
- boundingSpheresCV[i] = BoundingSphere_default.union(
413
- eastHemisphereGeometry.boundingSphereCV,
414
- westHemisphereGeometry.boundingSphereCV
415
- );
416
- }
417
- }
418
- }
419
- return {
420
- geometries,
421
- modelMatrix: parameters.modelMatrix,
422
- attributeLocations,
423
- pickOffsets,
424
- offsetInstanceExtend,
425
- boundingSpheres,
426
- boundingSpheresCV
427
- };
428
- };
429
- function transferGeometry(geometry, transferableObjects) {
430
- const attributes = geometry.attributes;
431
- for (const name in attributes) {
432
- if (attributes.hasOwnProperty(name)) {
433
- const attribute = attributes[name];
434
- if (defined_default(attribute) && defined_default(attribute.values)) {
435
- transferableObjects.push(attribute.values.buffer);
436
- }
437
- }
438
- }
439
- if (defined_default(geometry.indices)) {
440
- transferableObjects.push(geometry.indices.buffer);
441
- }
442
- }
443
- function transferGeometries(geometries, transferableObjects) {
444
- const length = geometries.length;
445
- for (let i = 0; i < length; ++i) {
446
- transferGeometry(geometries[i], transferableObjects);
447
- }
448
- }
449
- function countCreateGeometryResults(items) {
450
- let count = 1;
451
- const length = items.length;
452
- for (let i = 0; i < length; i++) {
453
- const geometry = items[i];
454
- ++count;
455
- if (!defined_default(geometry)) {
456
- continue;
457
- }
458
- const attributes = geometry.attributes;
459
- count += 7 + 2 * BoundingSphere_default.packedLength + (defined_default(geometry.indices) ? geometry.indices.length : 0);
460
- for (const property in attributes) {
461
- if (attributes.hasOwnProperty(property) && defined_default(attributes[property])) {
462
- const attribute = attributes[property];
463
- count += 5 + attribute.values.length;
464
- }
465
- }
466
- }
467
- return count;
468
- }
469
- PrimitivePipeline.packCreateGeometryResults = function(items, transferableObjects) {
470
- const packedData = new Float64Array(countCreateGeometryResults(items));
471
- const stringTable = [];
472
- const stringHash = {};
473
- const length = items.length;
474
- let count = 0;
475
- packedData[count++] = length;
476
- for (let i = 0; i < length; i++) {
477
- const geometry = items[i];
478
- const validGeometry = defined_default(geometry);
479
- packedData[count++] = validGeometry ? 1 : 0;
480
- if (!validGeometry) {
481
- continue;
482
- }
483
- packedData[count++] = geometry.primitiveType;
484
- packedData[count++] = geometry.geometryType;
485
- packedData[count++] = defaultValue_default(geometry.offsetAttribute, -1);
486
- const validBoundingSphere = defined_default(geometry.boundingSphere) ? 1 : 0;
487
- packedData[count++] = validBoundingSphere;
488
- if (validBoundingSphere) {
489
- BoundingSphere_default.pack(geometry.boundingSphere, packedData, count);
490
- }
491
- count += BoundingSphere_default.packedLength;
492
- const validBoundingSphereCV = defined_default(geometry.boundingSphereCV) ? 1 : 0;
493
- packedData[count++] = validBoundingSphereCV;
494
- if (validBoundingSphereCV) {
495
- BoundingSphere_default.pack(geometry.boundingSphereCV, packedData, count);
496
- }
497
- count += BoundingSphere_default.packedLength;
498
- const attributes = geometry.attributes;
499
- const attributesToWrite = [];
500
- for (const property in attributes) {
501
- if (attributes.hasOwnProperty(property) && defined_default(attributes[property])) {
502
- attributesToWrite.push(property);
503
- if (!defined_default(stringHash[property])) {
504
- stringHash[property] = stringTable.length;
505
- stringTable.push(property);
506
- }
507
- }
508
- }
509
- packedData[count++] = attributesToWrite.length;
510
- for (let q = 0; q < attributesToWrite.length; q++) {
511
- const name = attributesToWrite[q];
512
- const attribute = attributes[name];
513
- packedData[count++] = stringHash[name];
514
- packedData[count++] = attribute.componentDatatype;
515
- packedData[count++] = attribute.componentsPerAttribute;
516
- packedData[count++] = attribute.normalize ? 1 : 0;
517
- packedData[count++] = attribute.values.length;
518
- packedData.set(attribute.values, count);
519
- count += attribute.values.length;
520
- }
521
- const indicesLength = defined_default(geometry.indices) ? geometry.indices.length : 0;
522
- packedData[count++] = indicesLength;
523
- if (indicesLength > 0) {
524
- packedData.set(geometry.indices, count);
525
- count += indicesLength;
526
- }
527
- }
528
- transferableObjects.push(packedData.buffer);
529
- return {
530
- stringTable,
531
- packedData
532
- };
533
- };
534
- PrimitivePipeline.unpackCreateGeometryResults = function(createGeometryResult) {
535
- const stringTable = createGeometryResult.stringTable;
536
- const packedGeometry = createGeometryResult.packedData;
537
- let i;
538
- const result = new Array(packedGeometry[0]);
539
- let resultIndex = 0;
540
- let packedGeometryIndex = 1;
541
- while (packedGeometryIndex < packedGeometry.length) {
542
- const valid = packedGeometry[packedGeometryIndex++] === 1;
543
- if (!valid) {
544
- result[resultIndex++] = void 0;
545
- continue;
546
- }
547
- const primitiveType = packedGeometry[packedGeometryIndex++];
548
- const geometryType = packedGeometry[packedGeometryIndex++];
549
- let offsetAttribute = packedGeometry[packedGeometryIndex++];
550
- if (offsetAttribute === -1) {
551
- offsetAttribute = void 0;
552
- }
553
- let boundingSphere;
554
- let boundingSphereCV;
555
- const validBoundingSphere = packedGeometry[packedGeometryIndex++] === 1;
556
- if (validBoundingSphere) {
557
- boundingSphere = BoundingSphere_default.unpack(
558
- packedGeometry,
559
- packedGeometryIndex
560
- );
561
- }
562
- packedGeometryIndex += BoundingSphere_default.packedLength;
563
- const validBoundingSphereCV = packedGeometry[packedGeometryIndex++] === 1;
564
- if (validBoundingSphereCV) {
565
- boundingSphereCV = BoundingSphere_default.unpack(
566
- packedGeometry,
567
- packedGeometryIndex
568
- );
569
- }
570
- packedGeometryIndex += BoundingSphere_default.packedLength;
571
- let length;
572
- let values;
573
- let componentsPerAttribute;
574
- const attributes = new GeometryAttributes_default();
575
- const numAttributes = packedGeometry[packedGeometryIndex++];
576
- for (i = 0; i < numAttributes; i++) {
577
- const name = stringTable[packedGeometry[packedGeometryIndex++]];
578
- const componentDatatype = packedGeometry[packedGeometryIndex++];
579
- componentsPerAttribute = packedGeometry[packedGeometryIndex++];
580
- const normalize = packedGeometry[packedGeometryIndex++] !== 0;
581
- length = packedGeometry[packedGeometryIndex++];
582
- values = ComponentDatatype_default.createTypedArray(componentDatatype, length);
583
- for (let valuesIndex = 0; valuesIndex < length; valuesIndex++) {
584
- values[valuesIndex] = packedGeometry[packedGeometryIndex++];
585
- }
586
- attributes[name] = new GeometryAttribute_default({
587
- componentDatatype,
588
- componentsPerAttribute,
589
- normalize,
590
- values
591
- });
592
- }
593
- let indices;
594
- length = packedGeometry[packedGeometryIndex++];
595
- if (length > 0) {
596
- const numberOfVertices = values.length / componentsPerAttribute;
597
- indices = IndexDatatype_default.createTypedArray(numberOfVertices, length);
598
- for (i = 0; i < length; i++) {
599
- indices[i] = packedGeometry[packedGeometryIndex++];
600
- }
601
- }
602
- result[resultIndex++] = new Geometry_default({
603
- primitiveType,
604
- geometryType,
605
- boundingSphere,
606
- boundingSphereCV,
607
- indices,
608
- attributes,
609
- offsetAttribute
610
- });
611
- }
612
- return result;
613
- };
614
- function packInstancesForCombine(instances, transferableObjects) {
615
- const length = instances.length;
616
- const packedData = new Float64Array(1 + length * 19);
617
- let count = 0;
618
- packedData[count++] = length;
619
- for (let i = 0; i < length; i++) {
620
- const instance = instances[i];
621
- Matrix4_default.pack(instance.modelMatrix, packedData, count);
622
- count += Matrix4_default.packedLength;
623
- if (defined_default(instance.attributes) && defined_default(instance.attributes.offset)) {
624
- const values = instance.attributes.offset.value;
625
- packedData[count] = values[0];
626
- packedData[count + 1] = values[1];
627
- packedData[count + 2] = values[2];
628
- }
629
- count += 3;
630
- }
631
- transferableObjects.push(packedData.buffer);
632
- return packedData;
633
- }
634
- function unpackInstancesForCombine(data) {
635
- const packedInstances = data;
636
- const result = new Array(packedInstances[0]);
637
- let count = 0;
638
- let i = 1;
639
- while (i < packedInstances.length) {
640
- const modelMatrix = Matrix4_default.unpack(packedInstances, i);
641
- let attributes;
642
- i += Matrix4_default.packedLength;
643
- if (defined_default(packedInstances[i])) {
644
- attributes = {
645
- offset: new OffsetGeometryInstanceAttribute_default(
646
- packedInstances[i],
647
- packedInstances[i + 1],
648
- packedInstances[i + 2]
649
- )
650
- };
651
- }
652
- i += 3;
653
- result[count++] = {
654
- modelMatrix,
655
- attributes
656
- };
657
- }
658
- return result;
659
- }
660
- PrimitivePipeline.packCombineGeometryParameters = function(parameters, transferableObjects) {
661
- const createGeometryResults = parameters.createGeometryResults;
662
- const length = createGeometryResults.length;
663
- for (let i = 0; i < length; i++) {
664
- transferableObjects.push(createGeometryResults[i].packedData.buffer);
665
- }
666
- return {
667
- createGeometryResults: parameters.createGeometryResults,
668
- packedInstances: packInstancesForCombine(
669
- parameters.instances,
670
- transferableObjects
671
- ),
672
- ellipsoid: parameters.ellipsoid,
673
- isGeographic: parameters.projection instanceof GeographicProjection_default,
674
- elementIndexUintSupported: parameters.elementIndexUintSupported,
675
- scene3DOnly: parameters.scene3DOnly,
676
- vertexCacheOptimize: parameters.vertexCacheOptimize,
677
- compressVertices: parameters.compressVertices,
678
- modelMatrix: parameters.modelMatrix,
679
- createPickOffsets: parameters.createPickOffsets
680
- };
681
- };
682
- PrimitivePipeline.unpackCombineGeometryParameters = function(packedParameters) {
683
- const instances = unpackInstancesForCombine(packedParameters.packedInstances);
684
- const createGeometryResults = packedParameters.createGeometryResults;
685
- const length = createGeometryResults.length;
686
- let instanceIndex = 0;
687
- for (let resultIndex = 0; resultIndex < length; resultIndex++) {
688
- const geometries = PrimitivePipeline.unpackCreateGeometryResults(
689
- createGeometryResults[resultIndex]
690
- );
691
- const geometriesLength = geometries.length;
692
- for (let geometryIndex = 0; geometryIndex < geometriesLength; geometryIndex++) {
693
- const geometry = geometries[geometryIndex];
694
- const instance = instances[instanceIndex];
695
- instance.geometry = geometry;
696
- ++instanceIndex;
697
- }
698
- }
699
- const ellipsoid = Ellipsoid_default.clone(packedParameters.ellipsoid);
700
- const projection = packedParameters.isGeographic ? new GeographicProjection_default(ellipsoid) : new WebMercatorProjection_default(ellipsoid);
701
- return {
702
- instances,
703
- ellipsoid,
704
- projection,
705
- elementIndexUintSupported: packedParameters.elementIndexUintSupported,
706
- scene3DOnly: packedParameters.scene3DOnly,
707
- vertexCacheOptimize: packedParameters.vertexCacheOptimize,
708
- compressVertices: packedParameters.compressVertices,
709
- modelMatrix: Matrix4_default.clone(packedParameters.modelMatrix),
710
- createPickOffsets: packedParameters.createPickOffsets
711
- };
712
- };
713
- function packBoundingSpheres(boundingSpheres) {
714
- const length = boundingSpheres.length;
715
- const bufferLength = 1 + (BoundingSphere_default.packedLength + 1) * length;
716
- const buffer = new Float32Array(bufferLength);
717
- let bufferIndex = 0;
718
- buffer[bufferIndex++] = length;
719
- for (let i = 0; i < length; ++i) {
720
- const bs = boundingSpheres[i];
721
- if (!defined_default(bs)) {
722
- buffer[bufferIndex++] = 0;
723
- } else {
724
- buffer[bufferIndex++] = 1;
725
- BoundingSphere_default.pack(boundingSpheres[i], buffer, bufferIndex);
726
- }
727
- bufferIndex += BoundingSphere_default.packedLength;
728
- }
729
- return buffer;
730
- }
731
- function unpackBoundingSpheres(buffer) {
732
- const result = new Array(buffer[0]);
733
- let count = 0;
734
- let i = 1;
735
- while (i < buffer.length) {
736
- if (buffer[i++] === 1) {
737
- result[count] = BoundingSphere_default.unpack(buffer, i);
738
- }
739
- ++count;
740
- i += BoundingSphere_default.packedLength;
741
- }
742
- return result;
743
- }
744
- PrimitivePipeline.packCombineGeometryResults = function(results, transferableObjects) {
745
- if (defined_default(results.geometries)) {
746
- transferGeometries(results.geometries, transferableObjects);
747
- }
748
- const packedBoundingSpheres = packBoundingSpheres(results.boundingSpheres);
749
- const packedBoundingSpheresCV = packBoundingSpheres(
750
- results.boundingSpheresCV
751
- );
752
- transferableObjects.push(
753
- packedBoundingSpheres.buffer,
754
- packedBoundingSpheresCV.buffer
755
- );
756
- return {
757
- geometries: results.geometries,
758
- attributeLocations: results.attributeLocations,
759
- modelMatrix: results.modelMatrix,
760
- pickOffsets: results.pickOffsets,
761
- offsetInstanceExtend: results.offsetInstanceExtend,
762
- boundingSpheres: packedBoundingSpheres,
763
- boundingSpheresCV: packedBoundingSpheresCV
764
- };
765
- };
766
- PrimitivePipeline.unpackCombineGeometryResults = function(packedResult) {
767
- return {
768
- geometries: packedResult.geometries,
769
- attributeLocations: packedResult.attributeLocations,
770
- modelMatrix: packedResult.modelMatrix,
771
- pickOffsets: packedResult.pickOffsets,
772
- offsetInstanceExtend: packedResult.offsetInstanceExtend,
773
- boundingSpheres: unpackBoundingSpheres(packedResult.boundingSpheres),
774
- boundingSpheresCV: unpackBoundingSpheres(packedResult.boundingSpheresCV)
775
- };
776
- };
777
- var PrimitivePipeline_default = PrimitivePipeline;
778
-
779
- export {
780
- PrimitivePipeline_default
781
- };