@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,476 +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
- CornerType_default,
28
- PolylineVolumeGeometryLibrary_default
29
- } from "./chunk-7O373FFS.js";
30
- import {
31
- PolylinePipeline_default
32
- } from "./chunk-TGONEMZO.js";
33
- import {
34
- Quaternion_default
35
- } from "./chunk-5PTXS2GO.js";
36
- import {
37
- Cartesian3_default,
38
- Matrix3_default
39
- } from "./chunk-YFXQECWV.js";
40
- import {
41
- Math_default
42
- } from "./chunk-XY4BATBS.js";
43
- import {
44
- defined_default
45
- } from "./chunk-E63IIM5T.js";
46
-
47
- // packages/engine/Source/Core/CorridorGeometryLibrary.js
48
- var CorridorGeometryLibrary = {};
49
- var scratch1 = new Cartesian3_default();
50
- var scratch2 = new Cartesian3_default();
51
- var scratch3 = new Cartesian3_default();
52
- var scratch4 = new Cartesian3_default();
53
- var scaleArray2 = [new Cartesian3_default(), new Cartesian3_default()];
54
- var cartesian1 = new Cartesian3_default();
55
- var cartesian2 = new Cartesian3_default();
56
- var cartesian3 = new Cartesian3_default();
57
- var cartesian4 = new Cartesian3_default();
58
- var cartesian5 = new Cartesian3_default();
59
- var cartesian6 = new Cartesian3_default();
60
- var cartesian7 = new Cartesian3_default();
61
- var cartesian8 = new Cartesian3_default();
62
- var cartesian9 = new Cartesian3_default();
63
- var cartesian10 = new Cartesian3_default();
64
- var quaterion = new Quaternion_default();
65
- var rotMatrix = new Matrix3_default();
66
- function computeRoundCorner(cornerPoint, startPoint, endPoint, cornerType, leftIsOutside) {
67
- const angle = Cartesian3_default.angleBetween(
68
- Cartesian3_default.subtract(startPoint, cornerPoint, scratch1),
69
- Cartesian3_default.subtract(endPoint, cornerPoint, scratch2)
70
- );
71
- const granularity = cornerType === CornerType_default.BEVELED ? 1 : Math.ceil(angle / Math_default.toRadians(5)) + 1;
72
- const size = granularity * 3;
73
- const array = new Array(size);
74
- array[size - 3] = endPoint.x;
75
- array[size - 2] = endPoint.y;
76
- array[size - 1] = endPoint.z;
77
- let m;
78
- if (leftIsOutside) {
79
- m = Matrix3_default.fromQuaternion(
80
- Quaternion_default.fromAxisAngle(
81
- Cartesian3_default.negate(cornerPoint, scratch1),
82
- angle / granularity,
83
- quaterion
84
- ),
85
- rotMatrix
86
- );
87
- } else {
88
- m = Matrix3_default.fromQuaternion(
89
- Quaternion_default.fromAxisAngle(cornerPoint, angle / granularity, quaterion),
90
- rotMatrix
91
- );
92
- }
93
- let index = 0;
94
- startPoint = Cartesian3_default.clone(startPoint, scratch1);
95
- for (let i = 0; i < granularity; i++) {
96
- startPoint = Matrix3_default.multiplyByVector(m, startPoint, startPoint);
97
- array[index++] = startPoint.x;
98
- array[index++] = startPoint.y;
99
- array[index++] = startPoint.z;
100
- }
101
- return array;
102
- }
103
- function addEndCaps(calculatedPositions) {
104
- let cornerPoint = cartesian1;
105
- let startPoint = cartesian2;
106
- let endPoint = cartesian3;
107
- let leftEdge = calculatedPositions[1];
108
- startPoint = Cartesian3_default.fromArray(
109
- calculatedPositions[1],
110
- leftEdge.length - 3,
111
- startPoint
112
- );
113
- endPoint = Cartesian3_default.fromArray(calculatedPositions[0], 0, endPoint);
114
- cornerPoint = Cartesian3_default.midpoint(startPoint, endPoint, cornerPoint);
115
- const firstEndCap = computeRoundCorner(
116
- cornerPoint,
117
- startPoint,
118
- endPoint,
119
- CornerType_default.ROUNDED,
120
- false
121
- );
122
- const length = calculatedPositions.length - 1;
123
- const rightEdge = calculatedPositions[length - 1];
124
- leftEdge = calculatedPositions[length];
125
- startPoint = Cartesian3_default.fromArray(
126
- rightEdge,
127
- rightEdge.length - 3,
128
- startPoint
129
- );
130
- endPoint = Cartesian3_default.fromArray(leftEdge, 0, endPoint);
131
- cornerPoint = Cartesian3_default.midpoint(startPoint, endPoint, cornerPoint);
132
- const lastEndCap = computeRoundCorner(
133
- cornerPoint,
134
- startPoint,
135
- endPoint,
136
- CornerType_default.ROUNDED,
137
- false
138
- );
139
- return [firstEndCap, lastEndCap];
140
- }
141
- function computeMiteredCorner(position, leftCornerDirection, lastPoint, leftIsOutside) {
142
- let cornerPoint = scratch1;
143
- if (leftIsOutside) {
144
- cornerPoint = Cartesian3_default.add(position, leftCornerDirection, cornerPoint);
145
- } else {
146
- leftCornerDirection = Cartesian3_default.negate(
147
- leftCornerDirection,
148
- leftCornerDirection
149
- );
150
- cornerPoint = Cartesian3_default.add(position, leftCornerDirection, cornerPoint);
151
- }
152
- return [
153
- cornerPoint.x,
154
- cornerPoint.y,
155
- cornerPoint.z,
156
- lastPoint.x,
157
- lastPoint.y,
158
- lastPoint.z
159
- ];
160
- }
161
- function addShiftedPositions(positions, left, scalar, calculatedPositions) {
162
- const rightPositions = new Array(positions.length);
163
- const leftPositions = new Array(positions.length);
164
- const scaledLeft = Cartesian3_default.multiplyByScalar(left, scalar, scratch1);
165
- const scaledRight = Cartesian3_default.negate(scaledLeft, scratch2);
166
- let rightIndex = 0;
167
- let leftIndex = positions.length - 1;
168
- for (let i = 0; i < positions.length; i += 3) {
169
- const pos = Cartesian3_default.fromArray(positions, i, scratch3);
170
- const rightPos = Cartesian3_default.add(pos, scaledRight, scratch4);
171
- rightPositions[rightIndex++] = rightPos.x;
172
- rightPositions[rightIndex++] = rightPos.y;
173
- rightPositions[rightIndex++] = rightPos.z;
174
- const leftPos = Cartesian3_default.add(pos, scaledLeft, scratch4);
175
- leftPositions[leftIndex--] = leftPos.z;
176
- leftPositions[leftIndex--] = leftPos.y;
177
- leftPositions[leftIndex--] = leftPos.x;
178
- }
179
- calculatedPositions.push(rightPositions, leftPositions);
180
- return calculatedPositions;
181
- }
182
- CorridorGeometryLibrary.addAttribute = function(attribute, value, front, back) {
183
- const x = value.x;
184
- const y = value.y;
185
- const z = value.z;
186
- if (defined_default(front)) {
187
- attribute[front] = x;
188
- attribute[front + 1] = y;
189
- attribute[front + 2] = z;
190
- }
191
- if (defined_default(back)) {
192
- attribute[back] = z;
193
- attribute[back - 1] = y;
194
- attribute[back - 2] = x;
195
- }
196
- };
197
- var scratchForwardProjection = new Cartesian3_default();
198
- var scratchBackwardProjection = new Cartesian3_default();
199
- CorridorGeometryLibrary.computePositions = function(params) {
200
- const granularity = params.granularity;
201
- const positions = params.positions;
202
- const ellipsoid = params.ellipsoid;
203
- const width = params.width / 2;
204
- const cornerType = params.cornerType;
205
- const saveAttributes = params.saveAttributes;
206
- let normal = cartesian1;
207
- let forward = cartesian2;
208
- let backward = cartesian3;
209
- let left = cartesian4;
210
- let cornerDirection = cartesian5;
211
- let startPoint = cartesian6;
212
- let previousPos = cartesian7;
213
- let rightPos = cartesian8;
214
- let leftPos = cartesian9;
215
- let center = cartesian10;
216
- let calculatedPositions = [];
217
- const calculatedLefts = saveAttributes ? [] : void 0;
218
- const calculatedNormals = saveAttributes ? [] : void 0;
219
- let position = positions[0];
220
- let nextPosition = positions[1];
221
- forward = Cartesian3_default.normalize(
222
- Cartesian3_default.subtract(nextPosition, position, forward),
223
- forward
224
- );
225
- normal = ellipsoid.geodeticSurfaceNormal(position, normal);
226
- left = Cartesian3_default.normalize(Cartesian3_default.cross(normal, forward, left), left);
227
- if (saveAttributes) {
228
- calculatedLefts.push(left.x, left.y, left.z);
229
- calculatedNormals.push(normal.x, normal.y, normal.z);
230
- }
231
- previousPos = Cartesian3_default.clone(position, previousPos);
232
- position = nextPosition;
233
- backward = Cartesian3_default.negate(forward, backward);
234
- let subdividedPositions;
235
- const corners = [];
236
- let i;
237
- const length = positions.length;
238
- for (i = 1; i < length - 1; i++) {
239
- normal = ellipsoid.geodeticSurfaceNormal(position, normal);
240
- nextPosition = positions[i + 1];
241
- forward = Cartesian3_default.normalize(
242
- Cartesian3_default.subtract(nextPosition, position, forward),
243
- forward
244
- );
245
- cornerDirection = Cartesian3_default.normalize(
246
- Cartesian3_default.add(forward, backward, cornerDirection),
247
- cornerDirection
248
- );
249
- const forwardProjection = Cartesian3_default.multiplyByScalar(
250
- normal,
251
- Cartesian3_default.dot(forward, normal),
252
- scratchForwardProjection
253
- );
254
- Cartesian3_default.subtract(forward, forwardProjection, forwardProjection);
255
- Cartesian3_default.normalize(forwardProjection, forwardProjection);
256
- const backwardProjection = Cartesian3_default.multiplyByScalar(
257
- normal,
258
- Cartesian3_default.dot(backward, normal),
259
- scratchBackwardProjection
260
- );
261
- Cartesian3_default.subtract(backward, backwardProjection, backwardProjection);
262
- Cartesian3_default.normalize(backwardProjection, backwardProjection);
263
- const doCorner = !Math_default.equalsEpsilon(
264
- Math.abs(Cartesian3_default.dot(forwardProjection, backwardProjection)),
265
- 1,
266
- Math_default.EPSILON7
267
- );
268
- if (doCorner) {
269
- cornerDirection = Cartesian3_default.cross(
270
- cornerDirection,
271
- normal,
272
- cornerDirection
273
- );
274
- cornerDirection = Cartesian3_default.cross(
275
- normal,
276
- cornerDirection,
277
- cornerDirection
278
- );
279
- cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection);
280
- const scalar = width / Math.max(
281
- 0.25,
282
- Cartesian3_default.magnitude(
283
- Cartesian3_default.cross(cornerDirection, backward, scratch1)
284
- )
285
- );
286
- const leftIsOutside = PolylineVolumeGeometryLibrary_default.angleIsGreaterThanPi(
287
- forward,
288
- backward,
289
- position,
290
- ellipsoid
291
- );
292
- cornerDirection = Cartesian3_default.multiplyByScalar(
293
- cornerDirection,
294
- scalar,
295
- cornerDirection
296
- );
297
- if (leftIsOutside) {
298
- rightPos = Cartesian3_default.add(position, cornerDirection, rightPos);
299
- center = Cartesian3_default.add(
300
- rightPos,
301
- Cartesian3_default.multiplyByScalar(left, width, center),
302
- center
303
- );
304
- leftPos = Cartesian3_default.add(
305
- rightPos,
306
- Cartesian3_default.multiplyByScalar(left, width * 2, leftPos),
307
- leftPos
308
- );
309
- scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]);
310
- scaleArray2[1] = Cartesian3_default.clone(center, scaleArray2[1]);
311
- subdividedPositions = PolylinePipeline_default.generateArc({
312
- positions: scaleArray2,
313
- granularity,
314
- ellipsoid
315
- });
316
- calculatedPositions = addShiftedPositions(
317
- subdividedPositions,
318
- left,
319
- width,
320
- calculatedPositions
321
- );
322
- if (saveAttributes) {
323
- calculatedLefts.push(left.x, left.y, left.z);
324
- calculatedNormals.push(normal.x, normal.y, normal.z);
325
- }
326
- startPoint = Cartesian3_default.clone(leftPos, startPoint);
327
- left = Cartesian3_default.normalize(
328
- Cartesian3_default.cross(normal, forward, left),
329
- left
330
- );
331
- leftPos = Cartesian3_default.add(
332
- rightPos,
333
- Cartesian3_default.multiplyByScalar(left, width * 2, leftPos),
334
- leftPos
335
- );
336
- previousPos = Cartesian3_default.add(
337
- rightPos,
338
- Cartesian3_default.multiplyByScalar(left, width, previousPos),
339
- previousPos
340
- );
341
- if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) {
342
- corners.push({
343
- leftPositions: computeRoundCorner(
344
- rightPos,
345
- startPoint,
346
- leftPos,
347
- cornerType,
348
- leftIsOutside
349
- )
350
- });
351
- } else {
352
- corners.push({
353
- leftPositions: computeMiteredCorner(
354
- position,
355
- Cartesian3_default.negate(cornerDirection, cornerDirection),
356
- leftPos,
357
- leftIsOutside
358
- )
359
- });
360
- }
361
- } else {
362
- leftPos = Cartesian3_default.add(position, cornerDirection, leftPos);
363
- center = Cartesian3_default.add(
364
- leftPos,
365
- Cartesian3_default.negate(
366
- Cartesian3_default.multiplyByScalar(left, width, center),
367
- center
368
- ),
369
- center
370
- );
371
- rightPos = Cartesian3_default.add(
372
- leftPos,
373
- Cartesian3_default.negate(
374
- Cartesian3_default.multiplyByScalar(left, width * 2, rightPos),
375
- rightPos
376
- ),
377
- rightPos
378
- );
379
- scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]);
380
- scaleArray2[1] = Cartesian3_default.clone(center, scaleArray2[1]);
381
- subdividedPositions = PolylinePipeline_default.generateArc({
382
- positions: scaleArray2,
383
- granularity,
384
- ellipsoid
385
- });
386
- calculatedPositions = addShiftedPositions(
387
- subdividedPositions,
388
- left,
389
- width,
390
- calculatedPositions
391
- );
392
- if (saveAttributes) {
393
- calculatedLefts.push(left.x, left.y, left.z);
394
- calculatedNormals.push(normal.x, normal.y, normal.z);
395
- }
396
- startPoint = Cartesian3_default.clone(rightPos, startPoint);
397
- left = Cartesian3_default.normalize(
398
- Cartesian3_default.cross(normal, forward, left),
399
- left
400
- );
401
- rightPos = Cartesian3_default.add(
402
- leftPos,
403
- Cartesian3_default.negate(
404
- Cartesian3_default.multiplyByScalar(left, width * 2, rightPos),
405
- rightPos
406
- ),
407
- rightPos
408
- );
409
- previousPos = Cartesian3_default.add(
410
- leftPos,
411
- Cartesian3_default.negate(
412
- Cartesian3_default.multiplyByScalar(left, width, previousPos),
413
- previousPos
414
- ),
415
- previousPos
416
- );
417
- if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) {
418
- corners.push({
419
- rightPositions: computeRoundCorner(
420
- leftPos,
421
- startPoint,
422
- rightPos,
423
- cornerType,
424
- leftIsOutside
425
- )
426
- });
427
- } else {
428
- corners.push({
429
- rightPositions: computeMiteredCorner(
430
- position,
431
- cornerDirection,
432
- rightPos,
433
- leftIsOutside
434
- )
435
- });
436
- }
437
- }
438
- backward = Cartesian3_default.negate(forward, backward);
439
- }
440
- position = nextPosition;
441
- }
442
- normal = ellipsoid.geodeticSurfaceNormal(position, normal);
443
- scaleArray2[0] = Cartesian3_default.clone(previousPos, scaleArray2[0]);
444
- scaleArray2[1] = Cartesian3_default.clone(position, scaleArray2[1]);
445
- subdividedPositions = PolylinePipeline_default.generateArc({
446
- positions: scaleArray2,
447
- granularity,
448
- ellipsoid
449
- });
450
- calculatedPositions = addShiftedPositions(
451
- subdividedPositions,
452
- left,
453
- width,
454
- calculatedPositions
455
- );
456
- if (saveAttributes) {
457
- calculatedLefts.push(left.x, left.y, left.z);
458
- calculatedNormals.push(normal.x, normal.y, normal.z);
459
- }
460
- let endPositions;
461
- if (cornerType === CornerType_default.ROUNDED) {
462
- endPositions = addEndCaps(calculatedPositions);
463
- }
464
- return {
465
- positions: calculatedPositions,
466
- corners,
467
- lefts: calculatedLefts,
468
- normals: calculatedNormals,
469
- endPositions
470
- };
471
- };
472
- var CorridorGeometryLibrary_default = CorridorGeometryLibrary;
473
-
474
- export {
475
- CorridorGeometryLibrary_default
476
- };