deeptwins-cesium-engine 0.0.39 → 0.0.41

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 (157) hide show
  1. package/Build/Workers/chunk-22YARAUJ.js +629 -0
  2. package/Build/Workers/chunk-27NCQCM4.js +163 -0
  3. package/Build/Workers/chunk-2HVM4MOI.js +220 -0
  4. package/Build/Workers/chunk-2PWEYBYR.js +75 -0
  5. package/Build/Workers/chunk-2UUDETVF.js +101 -0
  6. package/Build/Workers/chunk-2ZI2BRKI.js +37 -0
  7. package/Build/Workers/chunk-32DGBF6Y.js +959 -0
  8. package/Build/Workers/chunk-3CTY2CGO.js +220 -0
  9. package/Build/Workers/chunk-3Q6HPHTH.js +684 -0
  10. package/Build/Workers/chunk-4LE3SGQH.js +634 -0
  11. package/Build/Workers/chunk-4UQOXHJT.js +421 -0
  12. package/Build/Workers/chunk-5IBSBFAA.js +287 -0
  13. package/Build/Workers/chunk-5ZELPLWF.js +58 -0
  14. package/Build/Workers/chunk-666ITZYK.js +1073 -0
  15. package/Build/Workers/chunk-6IFCG35V.js +390 -0
  16. package/Build/Workers/chunk-6LFOGNRP.js +1800 -0
  17. package/Build/Workers/chunk-6QHSHP53.js +1258 -0
  18. package/Build/Workers/chunk-6XIAYRGW.js +1055 -0
  19. package/Build/Workers/chunk-73EDFMPB.js +1073 -0
  20. package/Build/Workers/chunk-76TOSCCT.js +629 -0
  21. package/Build/Workers/chunk-7ODSCNSY.js +2857 -0
  22. package/Build/Workers/chunk-ALIDMMNJ.js +10357 -0
  23. package/Build/Workers/chunk-AXTXYHVG.js +59 -0
  24. package/Build/Workers/chunk-B3DSUDQQ.js +101 -0
  25. package/Build/Workers/chunk-B7R4KLQV.js +959 -0
  26. package/Build/Workers/chunk-BR5MKJPV.js +963 -0
  27. package/Build/Workers/chunk-BSQAU7IM.js +138 -0
  28. package/Build/Workers/chunk-C2ACDJD5.js +58 -0
  29. package/Build/Workers/chunk-CET7MMFD.js +1055 -0
  30. package/Build/Workers/chunk-CZUIRW4F.js +44 -0
  31. package/Build/Workers/chunk-D6ESIYSS.js +75 -0
  32. package/Build/Workers/chunk-DGWWFN6L.js +102 -0
  33. package/Build/Workers/chunk-DPZEBUVY.js +122 -0
  34. package/Build/Workers/chunk-EKUYACAZ.js +163 -0
  35. package/Build/Workers/chunk-EOQHBUGL.js +239 -0
  36. package/Build/Workers/chunk-ETQJFLBY.js +435 -0
  37. package/Build/Workers/chunk-EZKONOBC.js +300 -0
  38. package/Build/Workers/chunk-GXRKKREQ.js +2717 -0
  39. package/Build/Workers/chunk-HDJDQBU6.js +758 -0
  40. package/Build/Workers/chunk-HOO3H5M5.js +171 -0
  41. package/Build/Workers/chunk-IOE6TIOI.js +39 -0
  42. package/Build/Workers/chunk-JRFRSSGD.js +1800 -0
  43. package/Build/Workers/chunk-JUI6MY3E.js +435 -0
  44. package/Build/Workers/chunk-JV7ZLA3D.js +398 -0
  45. package/Build/Workers/chunk-KM5VHFRK.js +100 -0
  46. package/Build/Workers/chunk-KMDXAR34.js +1481 -0
  47. package/Build/Workers/chunk-KZDZFG2L.js +157 -0
  48. package/Build/Workers/chunk-L5A2N2AG.js +262 -0
  49. package/Build/Workers/chunk-LDXSEGOX.js +2857 -0
  50. package/Build/Workers/chunk-LSUSXL5L.js +353 -0
  51. package/Build/Workers/chunk-LYJFG66W.js +196 -0
  52. package/Build/Workers/chunk-ME5FR5CS.js +511 -0
  53. package/Build/Workers/chunk-MNCDXIX2.js +691 -0
  54. package/Build/Workers/chunk-N2UJHZ4W.js +368 -0
  55. package/Build/Workers/chunk-NZU4VBYI.js +834 -0
  56. package/Build/Workers/chunk-O2ZGG4HX.js +59 -0
  57. package/Build/Workers/chunk-O7JXDDHF.js +758 -0
  58. package/Build/Workers/chunk-OHM3HXGW.js +781 -0
  59. package/Build/Workers/chunk-OUFXKPAP.js +115 -0
  60. package/Build/Workers/chunk-OY2Z6SFD.js +100 -0
  61. package/Build/Workers/chunk-P3YNN4UB.js +10357 -0
  62. package/Build/Workers/chunk-PA4JZFFM.js +353 -0
  63. package/Build/Workers/chunk-PBS2UPII.js +122 -0
  64. package/Build/Workers/chunk-QFSPETA6.js +834 -0
  65. package/Build/Workers/chunk-QSO4DE6J.js +171 -0
  66. package/Build/Workers/chunk-QSTX55K5.js +37 -0
  67. package/Build/Workers/chunk-QUJ6BNQF.js +39 -0
  68. package/Build/Workers/chunk-QXWEMH73.js +102 -0
  69. package/Build/Workers/chunk-ROPEB47Y.js +300 -0
  70. package/Build/Workers/chunk-S3RIIJID.js +781 -0
  71. package/Build/Workers/chunk-SPS2I45W.js +73 -0
  72. package/Build/Workers/chunk-SUSQ3MVC.js +684 -0
  73. package/Build/Workers/chunk-TA7O77R5.js +368 -0
  74. package/Build/Workers/chunk-TBJBVKDE.js +262 -0
  75. package/Build/Workers/chunk-TJAONFQM.js +44 -0
  76. package/Build/Workers/chunk-TJNJ6CLS.js +239 -0
  77. package/Build/Workers/chunk-TMW7OQZD.js +476 -0
  78. package/Build/Workers/chunk-U4SUBL6L.js +390 -0
  79. package/Build/Workers/chunk-U6RITS73.js +456 -0
  80. package/Build/Workers/chunk-UHPBZJQF.js +2717 -0
  81. package/Build/Workers/chunk-UHS2YM44.js +115 -0
  82. package/Build/Workers/chunk-UHYBTCZW.js +305 -0
  83. package/Build/Workers/chunk-UN3RMNI2.js +500 -0
  84. package/Build/Workers/chunk-UYS2HZVM.js +421 -0
  85. package/Build/Workers/chunk-VGP546UW.js +1481 -0
  86. package/Build/Workers/chunk-VQY5ILOS.js +500 -0
  87. package/Build/Workers/chunk-VSEDVQN7.js +305 -0
  88. package/Build/Workers/chunk-VVDHEEL6.js +55 -0
  89. package/Build/Workers/chunk-VZSNLUE3.js +287 -0
  90. package/Build/Workers/chunk-W4BJBHPZ.js +456 -0
  91. package/Build/Workers/chunk-W7KOAHR2.js +691 -0
  92. package/Build/Workers/chunk-WCYXXO6P.js +139 -0
  93. package/Build/Workers/chunk-WGHS4HMU.js +55 -0
  94. package/Build/Workers/chunk-XV4SYFDP.js +138 -0
  95. package/Build/Workers/chunk-XX7RETEX.js +1258 -0
  96. package/Build/Workers/chunk-XYFT3BAX.js +196 -0
  97. package/Build/Workers/chunk-XYMJZUFF.js +476 -0
  98. package/Build/Workers/chunk-YCU6WHSN.js +963 -0
  99. package/Build/Workers/chunk-YTCJWLQC.js +73 -0
  100. package/Build/Workers/chunk-YWEX5QFW.js +398 -0
  101. package/Build/Workers/chunk-Z2WOKKJM.js +511 -0
  102. package/Build/Workers/chunk-ZEFV3C42.js +634 -0
  103. package/Build/Workers/chunk-ZYUOPFWQ.js +139 -0
  104. package/Build/Workers/chunk-ZYYPIDBI.js +157 -0
  105. package/Build/Workers/combineGeometry.js +22 -22
  106. package/Build/Workers/createBoxGeometry.js +16 -16
  107. package/Build/Workers/createBoxOutlineGeometry.js +14 -14
  108. package/Build/Workers/createCircleGeometry.js +24 -24
  109. package/Build/Workers/createCircleOutlineGeometry.js +17 -17
  110. package/Build/Workers/createCoplanarPolygonGeometry.js +31 -31
  111. package/Build/Workers/createCoplanarPolygonOutlineGeometry.js +29 -29
  112. package/Build/Workers/createCorridorGeometry.js +27 -27
  113. package/Build/Workers/createCorridorOutlineGeometry.js +26 -26
  114. package/Build/Workers/createCylinderGeometry.js +18 -18
  115. package/Build/Workers/createCylinderOutlineGeometry.js +16 -16
  116. package/Build/Workers/createEllipseGeometry.js +24 -24
  117. package/Build/Workers/createEllipseOutlineGeometry.js +17 -17
  118. package/Build/Workers/createEllipsoidGeometry.js +17 -17
  119. package/Build/Workers/createEllipsoidOutlineGeometry.js +16 -16
  120. package/Build/Workers/createFrustumGeometry.js +16 -16
  121. package/Build/Workers/createFrustumOutlineGeometry.js +16 -16
  122. package/Build/Workers/createGeometry.js +22 -22
  123. package/Build/Workers/createGroundPolylineGeometry.js +20 -20
  124. package/Build/Workers/createPlaneGeometry.js +14 -14
  125. package/Build/Workers/createPlaneOutlineGeometry.js +13 -13
  126. package/Build/Workers/createPolygonGeometry.js +30 -30
  127. package/Build/Workers/createPolygonOutlineGeometry.js +28 -28
  128. package/Build/Workers/createPolylineGeometry.js +23 -23
  129. package/Build/Workers/createPolylineVolumeGeometry.js +29 -29
  130. package/Build/Workers/createPolylineVolumeOutlineGeometry.js +25 -25
  131. package/Build/Workers/createRectangleGeometry.js +25 -25
  132. package/Build/Workers/createRectangleOutlineGeometry.js +18 -18
  133. package/Build/Workers/createSimplePolylineGeometry.js +21 -21
  134. package/Build/Workers/createSphereGeometry.js +17 -17
  135. package/Build/Workers/createSphereOutlineGeometry.js +16 -16
  136. package/Build/Workers/createTaskProcessorWorker.js +3 -3
  137. package/Build/Workers/createVectorTileClampedPolylines.js +13 -13
  138. package/Build/Workers/createVectorTileGeometries.js +22 -22
  139. package/Build/Workers/createVectorTilePoints.js +12 -12
  140. package/Build/Workers/createVectorTilePolygons.js +20 -20
  141. package/Build/Workers/createVectorTilePolylines.js +13 -13
  142. package/Build/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +20 -20
  143. package/Build/Workers/createVerticesFromHeightmap.js +20 -20
  144. package/Build/Workers/createVerticesFromQuantizedTerrainMesh.js +17 -17
  145. package/Build/Workers/createWallGeometry.js +22 -22
  146. package/Build/Workers/createWallOutlineGeometry.js +21 -21
  147. package/Build/Workers/decodeDraco.js +11 -11
  148. package/Build/Workers/decodeGoogleEarthEnterprisePacket.js +5 -5
  149. package/Build/Workers/decodeI3S.js +10 -10
  150. package/Build/Workers/transcodeKTX2.js +7 -7
  151. package/Build/Workers/transferTypedArrayTest.js +1 -1
  152. package/Build/Workers/upsampleQuantizedTerrainMesh.js +20 -20
  153. package/Source/Renderer/TextureAtlas.js +28 -1
  154. package/Source/Scene/Billboard.js +22 -0
  155. package/Source/Scene/BillboardTexture.js +95 -3
  156. package/index.js +53 -53
  157. package/package.json +1 -1
@@ -0,0 +1,305 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.0.39
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
+ Quaternion_default
28
+ } from "./chunk-ALIDMMNJ.js";
29
+ import {
30
+ Cartesian3_default,
31
+ Matrix3_default
32
+ } from "./chunk-LDXSEGOX.js";
33
+ import {
34
+ Math_default
35
+ } from "./chunk-UN3RMNI2.js";
36
+
37
+ // packages/engine/Source/Core/EllipseGeometryLibrary.js
38
+ var EllipseGeometryLibrary = {};
39
+ var rotAxis = new Cartesian3_default();
40
+ var tempVec = new Cartesian3_default();
41
+ var unitQuat = new Quaternion_default();
42
+ var rotMtx = new Matrix3_default();
43
+ function pointOnEllipsoid(theta, rotation, northVec, eastVec, aSqr, ab, bSqr, mag, unitPos, result) {
44
+ const azimuth = theta + rotation;
45
+ Cartesian3_default.multiplyByScalar(eastVec, Math.cos(azimuth), rotAxis);
46
+ Cartesian3_default.multiplyByScalar(northVec, Math.sin(azimuth), tempVec);
47
+ Cartesian3_default.add(rotAxis, tempVec, rotAxis);
48
+ let cosThetaSquared = Math.cos(theta);
49
+ cosThetaSquared = cosThetaSquared * cosThetaSquared;
50
+ let sinThetaSquared = Math.sin(theta);
51
+ sinThetaSquared = sinThetaSquared * sinThetaSquared;
52
+ const radius = ab / Math.sqrt(bSqr * cosThetaSquared + aSqr * sinThetaSquared);
53
+ const angle = radius / mag;
54
+ Quaternion_default.fromAxisAngle(rotAxis, angle, unitQuat);
55
+ Matrix3_default.fromQuaternion(unitQuat, rotMtx);
56
+ Matrix3_default.multiplyByVector(rotMtx, unitPos, result);
57
+ Cartesian3_default.normalize(result, result);
58
+ Cartesian3_default.multiplyByScalar(result, mag, result);
59
+ return result;
60
+ }
61
+ var scratchCartesian1 = new Cartesian3_default();
62
+ var scratchCartesian2 = new Cartesian3_default();
63
+ var scratchCartesian3 = new Cartesian3_default();
64
+ var scratchNormal = new Cartesian3_default();
65
+ EllipseGeometryLibrary.raisePositionsToHeight = function(positions, options, extrude) {
66
+ const ellipsoid = options.ellipsoid;
67
+ const height = options.height;
68
+ const extrudedHeight = options.extrudedHeight;
69
+ const size = extrude ? positions.length / 3 * 2 : positions.length / 3;
70
+ const finalPositions = new Float64Array(size * 3);
71
+ const length = positions.length;
72
+ const bottomOffset = extrude ? length : 0;
73
+ for (let i = 0; i < length; i += 3) {
74
+ const i1 = i + 1;
75
+ const i2 = i + 2;
76
+ const position = Cartesian3_default.fromArray(positions, i, scratchCartesian1);
77
+ ellipsoid.scaleToGeodeticSurface(position, position);
78
+ const extrudedPosition = Cartesian3_default.clone(position, scratchCartesian2);
79
+ const normal = ellipsoid.geodeticSurfaceNormal(position, scratchNormal);
80
+ const scaledNormal = Cartesian3_default.multiplyByScalar(
81
+ normal,
82
+ height,
83
+ scratchCartesian3
84
+ );
85
+ Cartesian3_default.add(position, scaledNormal, position);
86
+ if (extrude) {
87
+ Cartesian3_default.multiplyByScalar(normal, extrudedHeight, scaledNormal);
88
+ Cartesian3_default.add(extrudedPosition, scaledNormal, extrudedPosition);
89
+ finalPositions[i + bottomOffset] = extrudedPosition.x;
90
+ finalPositions[i1 + bottomOffset] = extrudedPosition.y;
91
+ finalPositions[i2 + bottomOffset] = extrudedPosition.z;
92
+ }
93
+ finalPositions[i] = position.x;
94
+ finalPositions[i1] = position.y;
95
+ finalPositions[i2] = position.z;
96
+ }
97
+ return finalPositions;
98
+ };
99
+ var unitPosScratch = new Cartesian3_default();
100
+ var eastVecScratch = new Cartesian3_default();
101
+ var northVecScratch = new Cartesian3_default();
102
+ EllipseGeometryLibrary.computeEllipsePositions = function(options, addFillPositions, addEdgePositions) {
103
+ const semiMinorAxis = options.semiMinorAxis;
104
+ const semiMajorAxis = options.semiMajorAxis;
105
+ const rotation = options.rotation;
106
+ const center = options.center;
107
+ const granularity = options.granularity * 8;
108
+ const aSqr = semiMinorAxis * semiMinorAxis;
109
+ const bSqr = semiMajorAxis * semiMajorAxis;
110
+ const ab = semiMajorAxis * semiMinorAxis;
111
+ const mag = Cartesian3_default.magnitude(center);
112
+ const unitPos = Cartesian3_default.normalize(center, unitPosScratch);
113
+ let eastVec = Cartesian3_default.cross(Cartesian3_default.UNIT_Z, center, eastVecScratch);
114
+ eastVec = Cartesian3_default.normalize(eastVec, eastVec);
115
+ const northVec = Cartesian3_default.cross(unitPos, eastVec, northVecScratch);
116
+ let numPts = 1 + Math.ceil(Math_default.PI_OVER_TWO / granularity);
117
+ const deltaTheta = Math_default.PI_OVER_TWO / (numPts - 1);
118
+ let theta = Math_default.PI_OVER_TWO - numPts * deltaTheta;
119
+ if (theta < 0) {
120
+ numPts -= Math.ceil(Math.abs(theta) / deltaTheta);
121
+ }
122
+ const size = 2 * (numPts * (numPts + 2));
123
+ const positions = addFillPositions ? new Array(size * 3) : void 0;
124
+ let positionIndex = 0;
125
+ let position = scratchCartesian1;
126
+ let reflectedPosition = scratchCartesian2;
127
+ const outerPositionsLength = numPts * 4 * 3;
128
+ let outerRightIndex = outerPositionsLength - 1;
129
+ let outerLeftIndex = 0;
130
+ const outerPositions = addEdgePositions ? new Array(outerPositionsLength) : void 0;
131
+ let i;
132
+ let j;
133
+ let numInterior;
134
+ let t;
135
+ let interiorPosition;
136
+ theta = Math_default.PI_OVER_TWO;
137
+ position = pointOnEllipsoid(
138
+ theta,
139
+ rotation,
140
+ northVec,
141
+ eastVec,
142
+ aSqr,
143
+ ab,
144
+ bSqr,
145
+ mag,
146
+ unitPos,
147
+ position
148
+ );
149
+ if (addFillPositions) {
150
+ positions[positionIndex++] = position.x;
151
+ positions[positionIndex++] = position.y;
152
+ positions[positionIndex++] = position.z;
153
+ }
154
+ if (addEdgePositions) {
155
+ outerPositions[outerRightIndex--] = position.z;
156
+ outerPositions[outerRightIndex--] = position.y;
157
+ outerPositions[outerRightIndex--] = position.x;
158
+ }
159
+ theta = Math_default.PI_OVER_TWO - deltaTheta;
160
+ for (i = 1; i < numPts + 1; ++i) {
161
+ position = pointOnEllipsoid(
162
+ theta,
163
+ rotation,
164
+ northVec,
165
+ eastVec,
166
+ aSqr,
167
+ ab,
168
+ bSqr,
169
+ mag,
170
+ unitPos,
171
+ position
172
+ );
173
+ reflectedPosition = pointOnEllipsoid(
174
+ Math.PI - theta,
175
+ rotation,
176
+ northVec,
177
+ eastVec,
178
+ aSqr,
179
+ ab,
180
+ bSqr,
181
+ mag,
182
+ unitPos,
183
+ reflectedPosition
184
+ );
185
+ if (addFillPositions) {
186
+ positions[positionIndex++] = position.x;
187
+ positions[positionIndex++] = position.y;
188
+ positions[positionIndex++] = position.z;
189
+ numInterior = 2 * i + 2;
190
+ for (j = 1; j < numInterior - 1; ++j) {
191
+ t = j / (numInterior - 1);
192
+ interiorPosition = Cartesian3_default.lerp(
193
+ position,
194
+ reflectedPosition,
195
+ t,
196
+ scratchCartesian3
197
+ );
198
+ positions[positionIndex++] = interiorPosition.x;
199
+ positions[positionIndex++] = interiorPosition.y;
200
+ positions[positionIndex++] = interiorPosition.z;
201
+ }
202
+ positions[positionIndex++] = reflectedPosition.x;
203
+ positions[positionIndex++] = reflectedPosition.y;
204
+ positions[positionIndex++] = reflectedPosition.z;
205
+ }
206
+ if (addEdgePositions) {
207
+ outerPositions[outerRightIndex--] = position.z;
208
+ outerPositions[outerRightIndex--] = position.y;
209
+ outerPositions[outerRightIndex--] = position.x;
210
+ outerPositions[outerLeftIndex++] = reflectedPosition.x;
211
+ outerPositions[outerLeftIndex++] = reflectedPosition.y;
212
+ outerPositions[outerLeftIndex++] = reflectedPosition.z;
213
+ }
214
+ theta = Math_default.PI_OVER_TWO - (i + 1) * deltaTheta;
215
+ }
216
+ for (i = numPts; i > 1; --i) {
217
+ theta = Math_default.PI_OVER_TWO - (i - 1) * deltaTheta;
218
+ position = pointOnEllipsoid(
219
+ -theta,
220
+ rotation,
221
+ northVec,
222
+ eastVec,
223
+ aSqr,
224
+ ab,
225
+ bSqr,
226
+ mag,
227
+ unitPos,
228
+ position
229
+ );
230
+ reflectedPosition = pointOnEllipsoid(
231
+ theta + Math.PI,
232
+ rotation,
233
+ northVec,
234
+ eastVec,
235
+ aSqr,
236
+ ab,
237
+ bSqr,
238
+ mag,
239
+ unitPos,
240
+ reflectedPosition
241
+ );
242
+ if (addFillPositions) {
243
+ positions[positionIndex++] = position.x;
244
+ positions[positionIndex++] = position.y;
245
+ positions[positionIndex++] = position.z;
246
+ numInterior = 2 * (i - 1) + 2;
247
+ for (j = 1; j < numInterior - 1; ++j) {
248
+ t = j / (numInterior - 1);
249
+ interiorPosition = Cartesian3_default.lerp(
250
+ position,
251
+ reflectedPosition,
252
+ t,
253
+ scratchCartesian3
254
+ );
255
+ positions[positionIndex++] = interiorPosition.x;
256
+ positions[positionIndex++] = interiorPosition.y;
257
+ positions[positionIndex++] = interiorPosition.z;
258
+ }
259
+ positions[positionIndex++] = reflectedPosition.x;
260
+ positions[positionIndex++] = reflectedPosition.y;
261
+ positions[positionIndex++] = reflectedPosition.z;
262
+ }
263
+ if (addEdgePositions) {
264
+ outerPositions[outerRightIndex--] = position.z;
265
+ outerPositions[outerRightIndex--] = position.y;
266
+ outerPositions[outerRightIndex--] = position.x;
267
+ outerPositions[outerLeftIndex++] = reflectedPosition.x;
268
+ outerPositions[outerLeftIndex++] = reflectedPosition.y;
269
+ outerPositions[outerLeftIndex++] = reflectedPosition.z;
270
+ }
271
+ }
272
+ theta = Math_default.PI_OVER_TWO;
273
+ position = pointOnEllipsoid(
274
+ -theta,
275
+ rotation,
276
+ northVec,
277
+ eastVec,
278
+ aSqr,
279
+ ab,
280
+ bSqr,
281
+ mag,
282
+ unitPos,
283
+ position
284
+ );
285
+ const r = {};
286
+ if (addFillPositions) {
287
+ positions[positionIndex++] = position.x;
288
+ positions[positionIndex++] = position.y;
289
+ positions[positionIndex++] = position.z;
290
+ r.positions = positions;
291
+ r.numPts = numPts;
292
+ }
293
+ if (addEdgePositions) {
294
+ outerPositions[outerRightIndex--] = position.z;
295
+ outerPositions[outerRightIndex--] = position.y;
296
+ outerPositions[outerRightIndex--] = position.x;
297
+ r.outerPositions = outerPositions;
298
+ }
299
+ return r;
300
+ };
301
+ var EllipseGeometryLibrary_default = EllipseGeometryLibrary;
302
+
303
+ export {
304
+ EllipseGeometryLibrary_default
305
+ };
@@ -0,0 +1,55 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.0.40
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
+
27
+ // packages/engine/Source/Core/ArcType.js
28
+ var ArcType = {
29
+ /**
30
+ * Straight line that does not conform to the surface of the ellipsoid.
31
+ *
32
+ * @type {number}
33
+ * @constant
34
+ */
35
+ NONE: 0,
36
+ /**
37
+ * Follow geodesic path.
38
+ *
39
+ * @type {number}
40
+ * @constant
41
+ */
42
+ GEODESIC: 1,
43
+ /**
44
+ * Follow rhumb or loxodrome path.
45
+ *
46
+ * @type {number}
47
+ * @constant
48
+ */
49
+ RHUMB: 2
50
+ };
51
+ var ArcType_default = Object.freeze(ArcType);
52
+
53
+ export {
54
+ ArcType_default
55
+ };
@@ -0,0 +1,287 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.0.40
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
+ AxisAlignedBoundingBox_default
28
+ } from "./chunk-ZYYPIDBI.js";
29
+ import {
30
+ IntersectionTests_default,
31
+ Ray_default
32
+ } from "./chunk-6QHSHP53.js";
33
+ import {
34
+ Plane_default
35
+ } from "./chunk-QSO4DE6J.js";
36
+ import {
37
+ Cartesian4_default,
38
+ Matrix4_default,
39
+ Transforms_default
40
+ } from "./chunk-P3YNN4UB.js";
41
+ import {
42
+ Cartesian2_default,
43
+ Cartesian3_default,
44
+ Ellipsoid_default
45
+ } from "./chunk-7ODSCNSY.js";
46
+ import {
47
+ defaultValue_default
48
+ } from "./chunk-IOE6TIOI.js";
49
+ import {
50
+ Check_default,
51
+ DeveloperError_default
52
+ } from "./chunk-27NCQCM4.js";
53
+ import {
54
+ defined_default
55
+ } from "./chunk-D6ESIYSS.js";
56
+
57
+ // packages/engine/Source/Core/EllipsoidTangentPlane.js
58
+ var scratchCart4 = new Cartesian4_default();
59
+ function EllipsoidTangentPlane(origin, ellipsoid) {
60
+ Check_default.defined("origin", origin);
61
+ ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.default);
62
+ origin = ellipsoid.scaleToGeodeticSurface(origin);
63
+ if (!defined_default(origin)) {
64
+ throw new DeveloperError_default(
65
+ "origin must not be at the center of the ellipsoid."
66
+ );
67
+ }
68
+ const eastNorthUp = Transforms_default.eastNorthUpToFixedFrame(origin, ellipsoid);
69
+ this._ellipsoid = ellipsoid;
70
+ this._origin = origin;
71
+ this._xAxis = Cartesian3_default.fromCartesian4(
72
+ Matrix4_default.getColumn(eastNorthUp, 0, scratchCart4)
73
+ );
74
+ this._yAxis = Cartesian3_default.fromCartesian4(
75
+ Matrix4_default.getColumn(eastNorthUp, 1, scratchCart4)
76
+ );
77
+ const normal = Cartesian3_default.fromCartesian4(
78
+ Matrix4_default.getColumn(eastNorthUp, 2, scratchCart4)
79
+ );
80
+ this._plane = Plane_default.fromPointNormal(origin, normal);
81
+ }
82
+ Object.defineProperties(EllipsoidTangentPlane.prototype, {
83
+ /**
84
+ * Gets the ellipsoid.
85
+ * @memberof EllipsoidTangentPlane.prototype
86
+ * @type {Ellipsoid}
87
+ */
88
+ ellipsoid: {
89
+ get: function() {
90
+ return this._ellipsoid;
91
+ }
92
+ },
93
+ /**
94
+ * Gets the origin.
95
+ * @memberof EllipsoidTangentPlane.prototype
96
+ * @type {Cartesian3}
97
+ */
98
+ origin: {
99
+ get: function() {
100
+ return this._origin;
101
+ }
102
+ },
103
+ /**
104
+ * Gets the plane which is tangent to the ellipsoid.
105
+ * @memberof EllipsoidTangentPlane.prototype
106
+ * @readonly
107
+ * @type {Plane}
108
+ */
109
+ plane: {
110
+ get: function() {
111
+ return this._plane;
112
+ }
113
+ },
114
+ /**
115
+ * Gets the local X-axis (east) of the tangent plane.
116
+ * @memberof EllipsoidTangentPlane.prototype
117
+ * @readonly
118
+ * @type {Cartesian3}
119
+ */
120
+ xAxis: {
121
+ get: function() {
122
+ return this._xAxis;
123
+ }
124
+ },
125
+ /**
126
+ * Gets the local Y-axis (north) of the tangent plane.
127
+ * @memberof EllipsoidTangentPlane.prototype
128
+ * @readonly
129
+ * @type {Cartesian3}
130
+ */
131
+ yAxis: {
132
+ get: function() {
133
+ return this._yAxis;
134
+ }
135
+ },
136
+ /**
137
+ * Gets the local Z-axis (up) of the tangent plane.
138
+ * @memberof EllipsoidTangentPlane.prototype
139
+ * @readonly
140
+ * @type {Cartesian3}
141
+ */
142
+ zAxis: {
143
+ get: function() {
144
+ return this._plane.normal;
145
+ }
146
+ }
147
+ });
148
+ var tmp = new AxisAlignedBoundingBox_default();
149
+ EllipsoidTangentPlane.fromPoints = function(cartesians, ellipsoid) {
150
+ Check_default.defined("cartesians", cartesians);
151
+ const box = AxisAlignedBoundingBox_default.fromPoints(cartesians, tmp);
152
+ return new EllipsoidTangentPlane(box.center, ellipsoid);
153
+ };
154
+ var scratchProjectPointOntoPlaneRay = new Ray_default();
155
+ var scratchProjectPointOntoPlaneCartesian3 = new Cartesian3_default();
156
+ EllipsoidTangentPlane.prototype.projectPointOntoPlane = function(cartesian, result) {
157
+ Check_default.defined("cartesian", cartesian);
158
+ const ray = scratchProjectPointOntoPlaneRay;
159
+ ray.origin = cartesian;
160
+ Cartesian3_default.normalize(cartesian, ray.direction);
161
+ let intersectionPoint = IntersectionTests_default.rayPlane(
162
+ ray,
163
+ this._plane,
164
+ scratchProjectPointOntoPlaneCartesian3
165
+ );
166
+ if (!defined_default(intersectionPoint)) {
167
+ Cartesian3_default.negate(ray.direction, ray.direction);
168
+ intersectionPoint = IntersectionTests_default.rayPlane(
169
+ ray,
170
+ this._plane,
171
+ scratchProjectPointOntoPlaneCartesian3
172
+ );
173
+ }
174
+ if (defined_default(intersectionPoint)) {
175
+ const v = Cartesian3_default.subtract(
176
+ intersectionPoint,
177
+ this._origin,
178
+ intersectionPoint
179
+ );
180
+ const x = Cartesian3_default.dot(this._xAxis, v);
181
+ const y = Cartesian3_default.dot(this._yAxis, v);
182
+ if (!defined_default(result)) {
183
+ return new Cartesian2_default(x, y);
184
+ }
185
+ result.x = x;
186
+ result.y = y;
187
+ return result;
188
+ }
189
+ return void 0;
190
+ };
191
+ EllipsoidTangentPlane.prototype.projectPointsOntoPlane = function(cartesians, result) {
192
+ Check_default.defined("cartesians", cartesians);
193
+ if (!defined_default(result)) {
194
+ result = [];
195
+ }
196
+ let count = 0;
197
+ const length = cartesians.length;
198
+ for (let i = 0; i < length; i++) {
199
+ const p = this.projectPointOntoPlane(cartesians[i], result[count]);
200
+ if (defined_default(p)) {
201
+ result[count] = p;
202
+ count++;
203
+ }
204
+ }
205
+ result.length = count;
206
+ return result;
207
+ };
208
+ EllipsoidTangentPlane.prototype.projectPointToNearestOnPlane = function(cartesian, result) {
209
+ Check_default.defined("cartesian", cartesian);
210
+ if (!defined_default(result)) {
211
+ result = new Cartesian2_default();
212
+ }
213
+ const ray = scratchProjectPointOntoPlaneRay;
214
+ ray.origin = cartesian;
215
+ Cartesian3_default.clone(this._plane.normal, ray.direction);
216
+ let intersectionPoint = IntersectionTests_default.rayPlane(
217
+ ray,
218
+ this._plane,
219
+ scratchProjectPointOntoPlaneCartesian3
220
+ );
221
+ if (!defined_default(intersectionPoint)) {
222
+ Cartesian3_default.negate(ray.direction, ray.direction);
223
+ intersectionPoint = IntersectionTests_default.rayPlane(
224
+ ray,
225
+ this._plane,
226
+ scratchProjectPointOntoPlaneCartesian3
227
+ );
228
+ }
229
+ const v = Cartesian3_default.subtract(
230
+ intersectionPoint,
231
+ this._origin,
232
+ intersectionPoint
233
+ );
234
+ const x = Cartesian3_default.dot(this._xAxis, v);
235
+ const y = Cartesian3_default.dot(this._yAxis, v);
236
+ result.x = x;
237
+ result.y = y;
238
+ return result;
239
+ };
240
+ EllipsoidTangentPlane.prototype.projectPointsToNearestOnPlane = function(cartesians, result) {
241
+ Check_default.defined("cartesians", cartesians);
242
+ if (!defined_default(result)) {
243
+ result = [];
244
+ }
245
+ const length = cartesians.length;
246
+ result.length = length;
247
+ for (let i = 0; i < length; i++) {
248
+ result[i] = this.projectPointToNearestOnPlane(cartesians[i], result[i]);
249
+ }
250
+ return result;
251
+ };
252
+ var projectPointsOntoEllipsoidScratch = new Cartesian3_default();
253
+ EllipsoidTangentPlane.prototype.projectPointOntoEllipsoid = function(cartesian, result) {
254
+ Check_default.defined("cartesian", cartesian);
255
+ if (!defined_default(result)) {
256
+ result = new Cartesian3_default();
257
+ }
258
+ const ellipsoid = this._ellipsoid;
259
+ const origin = this._origin;
260
+ const xAxis = this._xAxis;
261
+ const yAxis = this._yAxis;
262
+ const tmp2 = projectPointsOntoEllipsoidScratch;
263
+ Cartesian3_default.multiplyByScalar(xAxis, cartesian.x, tmp2);
264
+ result = Cartesian3_default.add(origin, tmp2, result);
265
+ Cartesian3_default.multiplyByScalar(yAxis, cartesian.y, tmp2);
266
+ Cartesian3_default.add(result, tmp2, result);
267
+ ellipsoid.scaleToGeocentricSurface(result, result);
268
+ return result;
269
+ };
270
+ EllipsoidTangentPlane.prototype.projectPointsOntoEllipsoid = function(cartesians, result) {
271
+ Check_default.defined("cartesians", cartesians);
272
+ const length = cartesians.length;
273
+ if (!defined_default(result)) {
274
+ result = new Array(length);
275
+ } else {
276
+ result.length = length;
277
+ }
278
+ for (let i = 0; i < length; ++i) {
279
+ result[i] = this.projectPointOntoEllipsoid(cartesians[i], result[i]);
280
+ }
281
+ return result;
282
+ };
283
+ var EllipsoidTangentPlane_default = EllipsoidTangentPlane;
284
+
285
+ export {
286
+ EllipsoidTangentPlane_default
287
+ };