@pggis/pg-sdk 3.3.10 → 4.3.3

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/pggis.min.js +10980 -7539
  5. package/dist/resources/ThirdParty/Workers/pako_deflate.min.js +1 -2
  6. package/dist/resources/ThirdParty/Workers/pako_inflate.min.js +1 -2
  7. package/dist/resources/ThirdParty/Workers/z-worker-pako.js +1 -1
  8. package/dist/resources/ThirdParty/google-earth-dbroot-parser.js +1 -8337
  9. package/dist/resources/ThirdParty/wasm_splats_bg.wasm +0 -0
  10. package/dist/resources/Workers/chunk-35SHYARM.js +26 -0
  11. package/dist/resources/Workers/chunk-37F5JSTI.js +26 -0
  12. package/dist/resources/Workers/chunk-3SSKC3VN.js +26 -0
  13. package/dist/resources/Workers/chunk-3W4GT7KQ.js +26 -0
  14. package/dist/resources/Workers/chunk-4IW2T6GF.js +26 -0
  15. package/dist/resources/Workers/chunk-5YEWO3HT.js +26 -0
  16. package/dist/resources/Workers/chunk-64RSHJUE.js +28 -0
  17. package/dist/resources/Workers/chunk-77IHZJJ3.js +26 -0
  18. package/dist/resources/Workers/chunk-7HTKERZY.js +26 -0
  19. package/dist/resources/Workers/{chunk-F3YA3Y2Z.js → chunk-A56XVLQR.js} +2 -13
  20. package/dist/resources/Workers/chunk-AJYK4IVJ.js +26 -0
  21. package/dist/resources/Workers/{chunk-EHWHNOEX.js → chunk-ARG42DC4.js} +2 -31
  22. package/dist/resources/Workers/chunk-AU7IKHOH.js +26 -0
  23. package/dist/resources/Workers/chunk-B4AA3ARO.js +26 -0
  24. package/dist/resources/Workers/chunk-CNCV5UL7.js +26 -0
  25. package/dist/resources/Workers/chunk-CYCB63OH.js +26 -0
  26. package/dist/resources/Workers/{chunk-4H7PY4U5.js → chunk-D6AA5QVT.js} +2 -20
  27. package/dist/resources/Workers/chunk-D6C66QON.js +26 -0
  28. package/dist/resources/Workers/chunk-DEPHB2WM.js +26 -0
  29. package/dist/resources/Workers/chunk-DMEY62ID.js +26 -0
  30. package/dist/resources/Workers/chunk-DQQ63PYM.js +26 -0
  31. package/dist/resources/Workers/chunk-ED5JPB3S.js +27 -0
  32. package/dist/resources/Workers/chunk-EZUYS2JF.js +26 -0
  33. package/dist/resources/Workers/chunk-FEVXJ54I.js +26 -0
  34. package/dist/resources/Workers/chunk-G5AGHVVC.js +26 -0
  35. package/dist/resources/Workers/{chunk-BBWDMCVU.js → chunk-GBYLG25F.js} +2 -15
  36. package/dist/resources/Workers/chunk-GILIDQNQ.js +26 -0
  37. package/dist/resources/Workers/chunk-HMIYSTF6.js +26 -0
  38. package/dist/resources/Workers/chunk-HTFSEEMT.js +26 -0
  39. package/dist/resources/Workers/chunk-HWXX4CWK.js +26 -0
  40. package/dist/resources/Workers/chunk-IYTZ52EY.js +26 -0
  41. package/dist/resources/Workers/chunk-J6UP6FLE.js +26 -0
  42. package/dist/resources/Workers/chunk-LEYMRMBK.js +27 -0
  43. package/dist/resources/Workers/chunk-M3MGYQSL.js +26 -0
  44. package/dist/resources/Workers/chunk-N4VJKXZS.js +26 -0
  45. package/dist/resources/Workers/chunk-NB3ML6JO.js +26 -0
  46. package/dist/resources/Workers/chunk-OFUUQVMR.js +26 -0
  47. package/dist/resources/Workers/chunk-OSW76XDF.js +26 -0
  48. package/dist/resources/Workers/chunk-PSPPBZWI.js +66 -0
  49. package/dist/resources/Workers/chunk-QN3VOORQ.js +26 -0
  50. package/dist/resources/Workers/chunk-QOUAJ6TL.js +26 -0
  51. package/dist/resources/Workers/chunk-RCV6KWXS.js +26 -0
  52. package/dist/resources/Workers/chunk-TCGIRNHN.js +26 -0
  53. package/dist/resources/Workers/chunk-U4IEOH5K.js +26 -0
  54. package/dist/resources/Workers/chunk-UP6I5URU.js +26 -0
  55. package/dist/resources/Workers/chunk-VTAIKJXX.js +26 -0
  56. package/dist/resources/Workers/chunk-VTBDSFTG.js +26 -0
  57. package/dist/resources/Workers/chunk-VW6VD53G.js +26 -0
  58. package/dist/resources/Workers/chunk-WGGIH7QW.js +26 -0
  59. package/dist/resources/Workers/chunk-WWA5PL4H.js +26 -0
  60. package/dist/resources/Workers/chunk-WZDE3RYP.js +28 -0
  61. package/dist/resources/Workers/chunk-XRL4AVS5.js +26 -0
  62. package/dist/resources/Workers/combineGeometry.js +2 -44
  63. package/dist/resources/Workers/createBoxGeometry.js +2 -34
  64. package/dist/resources/Workers/createBoxOutlineGeometry.js +2 -211
  65. package/dist/resources/Workers/createCircleGeometry.js +2 -173
  66. package/dist/resources/Workers/createCircleOutlineGeometry.js +2 -123
  67. package/dist/resources/Workers/createCoplanarPolygonGeometry.js +2 -482
  68. package/dist/resources/Workers/createCoplanarPolygonOutlineGeometry.js +2 -201
  69. package/dist/resources/Workers/createCorridorGeometry.js +2 -1239
  70. package/dist/resources/Workers/createCorridorOutlineGeometry.js +2 -544
  71. package/dist/resources/Workers/createCylinderGeometry.js +2 -36
  72. package/dist/resources/Workers/createCylinderOutlineGeometry.js +2 -207
  73. package/dist/resources/Workers/createEllipseGeometry.js +2 -47
  74. package/dist/resources/Workers/createEllipseOutlineGeometry.js +2 -40
  75. package/dist/resources/Workers/createEllipsoidGeometry.js +2 -35
  76. package/dist/resources/Workers/createEllipsoidOutlineGeometry.js +2 -37
  77. package/dist/resources/Workers/createFrustumGeometry.js +2 -34
  78. package/dist/resources/Workers/createFrustumOutlineGeometry.js +2 -211
  79. package/dist/resources/Workers/createGeometry.js +2 -147
  80. package/dist/resources/Workers/createGroundPolylineGeometry.js +2 -1584
  81. package/dist/resources/Workers/createPlaneGeometry.js +2 -200
  82. package/dist/resources/Workers/createPlaneOutlineGeometry.js +2 -100
  83. package/dist/resources/Workers/createPolygonGeometry.js +2 -1387
  84. package/dist/resources/Workers/createPolygonOutlineGeometry.js +2 -519
  85. package/dist/resources/Workers/createPolylineGeometry.js +2 -472
  86. package/dist/resources/Workers/createPolylineVolumeGeometry.js +2 -355
  87. package/dist/resources/Workers/createPolylineVolumeOutlineGeometry.js +2 -253
  88. package/dist/resources/Workers/createRectangleGeometry.js +2 -1250
  89. package/dist/resources/Workers/createRectangleOutlineGeometry.js +2 -455
  90. package/dist/resources/Workers/createSimplePolylineGeometry.js +2 -376
  91. package/dist/resources/Workers/createSphereGeometry.js +2 -94
  92. package/dist/resources/Workers/createSphereOutlineGeometry.js +2 -94
  93. package/dist/resources/Workers/createTaskProcessorWorker.js +2 -8
  94. package/dist/resources/Workers/createVectorTileClampedPolylines.js +2 -468
  95. package/dist/resources/Workers/createVectorTileGeometries.js +2 -363
  96. package/dist/resources/Workers/createVectorTilePoints.js +2 -88
  97. package/dist/resources/Workers/createVectorTilePolygons.js +2 -361
  98. package/dist/resources/Workers/createVectorTilePolylines.js +2 -238
  99. package/dist/resources/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +2 -545
  100. package/dist/resources/Workers/createVerticesFromHeightmap.js +2 -2254
  101. package/dist/resources/Workers/createVerticesFromQuantizedTerrainMesh.js +2 -722
  102. package/dist/resources/Workers/createWallGeometry.js +2 -466
  103. package/dist/resources/Workers/createWallOutlineGeometry.js +2 -314
  104. package/dist/resources/Workers/decodeDraco.js +2 -345
  105. package/dist/resources/Workers/decodeGoogleEarthEnterprisePacket.js +2 -2626
  106. package/dist/resources/Workers/decodeI3S.js +2 -1320
  107. package/dist/resources/Workers/gaussianSplatSorter.js +26 -0
  108. package/dist/resources/Workers/gaussianSplatTextureGenerator.js +26 -0
  109. package/dist/resources/Workers/transcodeKTX2.js +29 -3398
  110. package/dist/resources/Workers/transferTypedArrayTest.js +2 -17
  111. package/dist/resources/Workers/upsampleQuantizedTerrainMesh.js +2 -795
  112. package/package.json +9 -8
  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,476 +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
- CornerType_default,
28
- PolylineVolumeGeometryLibrary_default
29
- } from "./chunk-UEXTBDBE.js";
30
- import {
31
- PolylinePipeline_default
32
- } from "./chunk-KKCR2YOP.js";
33
- import {
34
- Quaternion_default
35
- } from "./chunk-FJKNFAKQ.js";
36
- import {
37
- Cartesian3_default,
38
- Matrix3_default
39
- } from "./chunk-OGXZVPPM.js";
40
- import {
41
- Math_default
42
- } from "./chunk-5QULIR53.js";
43
- import {
44
- defined_default
45
- } from "./chunk-YWTJ2B4B.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
- };