@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,398 +0,0 @@
1
- /**
2
- * @license
3
- * Cesium - https://github.com/CesiumGS/cesium
4
- * Version 1.122
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
- CylinderGeometryLibrary_default
28
- } from "./chunk-DHYHSFFJ.js";
29
- import {
30
- GeometryOffsetAttribute_default
31
- } from "./chunk-I2ITFFPX.js";
32
- import {
33
- VertexFormat_default
34
- } from "./chunk-EJZTDTUH.js";
35
- import {
36
- IndexDatatype_default
37
- } from "./chunk-26GA3JAM.js";
38
- import {
39
- GeometryAttributes_default
40
- } from "./chunk-DI5NGJUP.js";
41
- import {
42
- GeometryAttribute_default,
43
- Geometry_default,
44
- PrimitiveType_default
45
- } from "./chunk-GWCFU2SA.js";
46
- import {
47
- BoundingSphere_default
48
- } from "./chunk-VJZB3WAV.js";
49
- import {
50
- ComponentDatatype_default
51
- } from "./chunk-K4GQUNB5.js";
52
- import {
53
- Cartesian2_default,
54
- Cartesian3_default
55
- } from "./chunk-YFXQECWV.js";
56
- import {
57
- Math_default
58
- } from "./chunk-XY4BATBS.js";
59
- import {
60
- defaultValue_default
61
- } from "./chunk-7JO7GPJN.js";
62
- import {
63
- DeveloperError_default
64
- } from "./chunk-AD63PIY6.js";
65
- import {
66
- defined_default
67
- } from "./chunk-E63IIM5T.js";
68
-
69
- // packages/engine/Source/Core/CylinderGeometry.js
70
- var radiusScratch = new Cartesian2_default();
71
- var normalScratch = new Cartesian3_default();
72
- var bitangentScratch = new Cartesian3_default();
73
- var tangentScratch = new Cartesian3_default();
74
- var positionScratch = new Cartesian3_default();
75
- function CylinderGeometry(options) {
76
- options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT);
77
- const length = options.length;
78
- const topRadius = options.topRadius;
79
- const bottomRadius = options.bottomRadius;
80
- const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT);
81
- const slices = defaultValue_default(options.slices, 128);
82
- if (!defined_default(length)) {
83
- throw new DeveloperError_default("options.length must be defined.");
84
- }
85
- if (!defined_default(topRadius)) {
86
- throw new DeveloperError_default("options.topRadius must be defined.");
87
- }
88
- if (!defined_default(bottomRadius)) {
89
- throw new DeveloperError_default("options.bottomRadius must be defined.");
90
- }
91
- if (slices < 3) {
92
- throw new DeveloperError_default(
93
- "options.slices must be greater than or equal to 3."
94
- );
95
- }
96
- if (defined_default(options.offsetAttribute) && options.offsetAttribute === GeometryOffsetAttribute_default.TOP) {
97
- throw new DeveloperError_default(
98
- "GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry."
99
- );
100
- }
101
- this._length = length;
102
- this._topRadius = topRadius;
103
- this._bottomRadius = bottomRadius;
104
- this._vertexFormat = VertexFormat_default.clone(vertexFormat);
105
- this._slices = slices;
106
- this._offsetAttribute = options.offsetAttribute;
107
- this._workerName = "createCylinderGeometry";
108
- }
109
- CylinderGeometry.packedLength = VertexFormat_default.packedLength + 5;
110
- CylinderGeometry.pack = function(value, array, startingIndex) {
111
- if (!defined_default(value)) {
112
- throw new DeveloperError_default("value is required");
113
- }
114
- if (!defined_default(array)) {
115
- throw new DeveloperError_default("array is required");
116
- }
117
- startingIndex = defaultValue_default(startingIndex, 0);
118
- VertexFormat_default.pack(value._vertexFormat, array, startingIndex);
119
- startingIndex += VertexFormat_default.packedLength;
120
- array[startingIndex++] = value._length;
121
- array[startingIndex++] = value._topRadius;
122
- array[startingIndex++] = value._bottomRadius;
123
- array[startingIndex++] = value._slices;
124
- array[startingIndex] = defaultValue_default(value._offsetAttribute, -1);
125
- return array;
126
- };
127
- var scratchVertexFormat = new VertexFormat_default();
128
- var scratchOptions = {
129
- vertexFormat: scratchVertexFormat,
130
- length: void 0,
131
- topRadius: void 0,
132
- bottomRadius: void 0,
133
- slices: void 0,
134
- offsetAttribute: void 0
135
- };
136
- CylinderGeometry.unpack = function(array, startingIndex, result) {
137
- if (!defined_default(array)) {
138
- throw new DeveloperError_default("array is required");
139
- }
140
- startingIndex = defaultValue_default(startingIndex, 0);
141
- const vertexFormat = VertexFormat_default.unpack(
142
- array,
143
- startingIndex,
144
- scratchVertexFormat
145
- );
146
- startingIndex += VertexFormat_default.packedLength;
147
- const length = array[startingIndex++];
148
- const topRadius = array[startingIndex++];
149
- const bottomRadius = array[startingIndex++];
150
- const slices = array[startingIndex++];
151
- const offsetAttribute = array[startingIndex];
152
- if (!defined_default(result)) {
153
- scratchOptions.length = length;
154
- scratchOptions.topRadius = topRadius;
155
- scratchOptions.bottomRadius = bottomRadius;
156
- scratchOptions.slices = slices;
157
- scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute;
158
- return new CylinderGeometry(scratchOptions);
159
- }
160
- result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat);
161
- result._length = length;
162
- result._topRadius = topRadius;
163
- result._bottomRadius = bottomRadius;
164
- result._slices = slices;
165
- result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute;
166
- return result;
167
- };
168
- CylinderGeometry.createGeometry = function(cylinderGeometry) {
169
- let length = cylinderGeometry._length;
170
- const topRadius = cylinderGeometry._topRadius;
171
- const bottomRadius = cylinderGeometry._bottomRadius;
172
- const vertexFormat = cylinderGeometry._vertexFormat;
173
- const slices = cylinderGeometry._slices;
174
- if (length <= 0 || topRadius < 0 || bottomRadius < 0 || topRadius === 0 && bottomRadius === 0) {
175
- return;
176
- }
177
- const twoSlices = slices + slices;
178
- const threeSlices = slices + twoSlices;
179
- const numVertices = twoSlices + twoSlices;
180
- const positions = CylinderGeometryLibrary_default.computePositions(
181
- length,
182
- topRadius,
183
- bottomRadius,
184
- slices,
185
- true
186
- );
187
- const st = vertexFormat.st ? new Float32Array(numVertices * 2) : void 0;
188
- const normals = vertexFormat.normal ? new Float32Array(numVertices * 3) : void 0;
189
- const tangents = vertexFormat.tangent ? new Float32Array(numVertices * 3) : void 0;
190
- const bitangents = vertexFormat.bitangent ? new Float32Array(numVertices * 3) : void 0;
191
- let i;
192
- const computeNormal = vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent;
193
- if (computeNormal) {
194
- const computeTangent = vertexFormat.tangent || vertexFormat.bitangent;
195
- let normalIndex = 0;
196
- let tangentIndex = 0;
197
- let bitangentIndex = 0;
198
- const theta = Math.atan2(bottomRadius - topRadius, length);
199
- const normal = normalScratch;
200
- normal.z = Math.sin(theta);
201
- const normalScale = Math.cos(theta);
202
- let tangent = tangentScratch;
203
- let bitangent = bitangentScratch;
204
- for (i = 0; i < slices; i++) {
205
- const angle = i / slices * Math_default.TWO_PI;
206
- const x = normalScale * Math.cos(angle);
207
- const y = normalScale * Math.sin(angle);
208
- if (computeNormal) {
209
- normal.x = x;
210
- normal.y = y;
211
- if (computeTangent) {
212
- tangent = Cartesian3_default.normalize(
213
- Cartesian3_default.cross(Cartesian3_default.UNIT_Z, normal, tangent),
214
- tangent
215
- );
216
- }
217
- if (vertexFormat.normal) {
218
- normals[normalIndex++] = normal.x;
219
- normals[normalIndex++] = normal.y;
220
- normals[normalIndex++] = normal.z;
221
- normals[normalIndex++] = normal.x;
222
- normals[normalIndex++] = normal.y;
223
- normals[normalIndex++] = normal.z;
224
- }
225
- if (vertexFormat.tangent) {
226
- tangents[tangentIndex++] = tangent.x;
227
- tangents[tangentIndex++] = tangent.y;
228
- tangents[tangentIndex++] = tangent.z;
229
- tangents[tangentIndex++] = tangent.x;
230
- tangents[tangentIndex++] = tangent.y;
231
- tangents[tangentIndex++] = tangent.z;
232
- }
233
- if (vertexFormat.bitangent) {
234
- bitangent = Cartesian3_default.normalize(
235
- Cartesian3_default.cross(normal, tangent, bitangent),
236
- bitangent
237
- );
238
- bitangents[bitangentIndex++] = bitangent.x;
239
- bitangents[bitangentIndex++] = bitangent.y;
240
- bitangents[bitangentIndex++] = bitangent.z;
241
- bitangents[bitangentIndex++] = bitangent.x;
242
- bitangents[bitangentIndex++] = bitangent.y;
243
- bitangents[bitangentIndex++] = bitangent.z;
244
- }
245
- }
246
- }
247
- for (i = 0; i < slices; i++) {
248
- if (vertexFormat.normal) {
249
- normals[normalIndex++] = 0;
250
- normals[normalIndex++] = 0;
251
- normals[normalIndex++] = -1;
252
- }
253
- if (vertexFormat.tangent) {
254
- tangents[tangentIndex++] = 1;
255
- tangents[tangentIndex++] = 0;
256
- tangents[tangentIndex++] = 0;
257
- }
258
- if (vertexFormat.bitangent) {
259
- bitangents[bitangentIndex++] = 0;
260
- bitangents[bitangentIndex++] = -1;
261
- bitangents[bitangentIndex++] = 0;
262
- }
263
- }
264
- for (i = 0; i < slices; i++) {
265
- if (vertexFormat.normal) {
266
- normals[normalIndex++] = 0;
267
- normals[normalIndex++] = 0;
268
- normals[normalIndex++] = 1;
269
- }
270
- if (vertexFormat.tangent) {
271
- tangents[tangentIndex++] = 1;
272
- tangents[tangentIndex++] = 0;
273
- tangents[tangentIndex++] = 0;
274
- }
275
- if (vertexFormat.bitangent) {
276
- bitangents[bitangentIndex++] = 0;
277
- bitangents[bitangentIndex++] = 1;
278
- bitangents[bitangentIndex++] = 0;
279
- }
280
- }
281
- }
282
- const numIndices = 12 * slices - 12;
283
- const indices = IndexDatatype_default.createTypedArray(numVertices, numIndices);
284
- let index = 0;
285
- let j = 0;
286
- for (i = 0; i < slices - 1; i++) {
287
- indices[index++] = j;
288
- indices[index++] = j + 2;
289
- indices[index++] = j + 3;
290
- indices[index++] = j;
291
- indices[index++] = j + 3;
292
- indices[index++] = j + 1;
293
- j += 2;
294
- }
295
- indices[index++] = twoSlices - 2;
296
- indices[index++] = 0;
297
- indices[index++] = 1;
298
- indices[index++] = twoSlices - 2;
299
- indices[index++] = 1;
300
- indices[index++] = twoSlices - 1;
301
- for (i = 1; i < slices - 1; i++) {
302
- indices[index++] = twoSlices + i + 1;
303
- indices[index++] = twoSlices + i;
304
- indices[index++] = twoSlices;
305
- }
306
- for (i = 1; i < slices - 1; i++) {
307
- indices[index++] = threeSlices;
308
- indices[index++] = threeSlices + i;
309
- indices[index++] = threeSlices + i + 1;
310
- }
311
- let textureCoordIndex = 0;
312
- if (vertexFormat.st) {
313
- const rad = Math.max(topRadius, bottomRadius);
314
- for (i = 0; i < numVertices; i++) {
315
- const position = Cartesian3_default.fromArray(positions, i * 3, positionScratch);
316
- st[textureCoordIndex++] = (position.x + rad) / (2 * rad);
317
- st[textureCoordIndex++] = (position.y + rad) / (2 * rad);
318
- }
319
- }
320
- const attributes = new GeometryAttributes_default();
321
- if (vertexFormat.position) {
322
- attributes.position = new GeometryAttribute_default({
323
- componentDatatype: ComponentDatatype_default.DOUBLE,
324
- componentsPerAttribute: 3,
325
- values: positions
326
- });
327
- }
328
- if (vertexFormat.normal) {
329
- attributes.normal = new GeometryAttribute_default({
330
- componentDatatype: ComponentDatatype_default.FLOAT,
331
- componentsPerAttribute: 3,
332
- values: normals
333
- });
334
- }
335
- if (vertexFormat.tangent) {
336
- attributes.tangent = new GeometryAttribute_default({
337
- componentDatatype: ComponentDatatype_default.FLOAT,
338
- componentsPerAttribute: 3,
339
- values: tangents
340
- });
341
- }
342
- if (vertexFormat.bitangent) {
343
- attributes.bitangent = new GeometryAttribute_default({
344
- componentDatatype: ComponentDatatype_default.FLOAT,
345
- componentsPerAttribute: 3,
346
- values: bitangents
347
- });
348
- }
349
- if (vertexFormat.st) {
350
- attributes.st = new GeometryAttribute_default({
351
- componentDatatype: ComponentDatatype_default.FLOAT,
352
- componentsPerAttribute: 2,
353
- values: st
354
- });
355
- }
356
- radiusScratch.x = length * 0.5;
357
- radiusScratch.y = Math.max(bottomRadius, topRadius);
358
- const boundingSphere = new BoundingSphere_default(
359
- Cartesian3_default.ZERO,
360
- Cartesian2_default.magnitude(radiusScratch)
361
- );
362
- if (defined_default(cylinderGeometry._offsetAttribute)) {
363
- length = positions.length;
364
- const offsetValue = cylinderGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1;
365
- const applyOffset = new Uint8Array(length / 3).fill(offsetValue);
366
- attributes.applyOffset = new GeometryAttribute_default({
367
- componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE,
368
- componentsPerAttribute: 1,
369
- values: applyOffset
370
- });
371
- }
372
- return new Geometry_default({
373
- attributes,
374
- indices,
375
- primitiveType: PrimitiveType_default.TRIANGLES,
376
- boundingSphere,
377
- offsetAttribute: cylinderGeometry._offsetAttribute
378
- });
379
- };
380
- var unitCylinderGeometry;
381
- CylinderGeometry.getUnitCylinder = function() {
382
- if (!defined_default(unitCylinderGeometry)) {
383
- unitCylinderGeometry = CylinderGeometry.createGeometry(
384
- new CylinderGeometry({
385
- topRadius: 1,
386
- bottomRadius: 1,
387
- length: 1,
388
- vertexFormat: VertexFormat_default.POSITION_ONLY
389
- })
390
- );
391
- }
392
- return unitCylinderGeometry;
393
- };
394
- var CylinderGeometry_default = CylinderGeometry;
395
-
396
- export {
397
- CylinderGeometry_default
398
- };