@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,834 +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
- EllipsoidTangentPlane_default
28
- } from "./chunk-CKY7HOHV.js";
29
- import {
30
- Plane_default
31
- } from "./chunk-2ZGOQXYU.js";
32
- import {
33
- BoundingSphere_default,
34
- Intersect_default,
35
- Interval_default
36
- } from "./chunk-VJZB3WAV.js";
37
- import {
38
- Matrix4_default,
39
- Rectangle_default
40
- } from "./chunk-5PTXS2GO.js";
41
- import {
42
- Cartesian2_default,
43
- Cartesian3_default,
44
- Cartographic_default,
45
- Ellipsoid_default,
46
- Matrix3_default
47
- } from "./chunk-YFXQECWV.js";
48
- import {
49
- Math_default
50
- } from "./chunk-XY4BATBS.js";
51
- import {
52
- defaultValue_default
53
- } from "./chunk-7JO7GPJN.js";
54
- import {
55
- Check_default,
56
- DeveloperError_default
57
- } from "./chunk-AD63PIY6.js";
58
- import {
59
- defined_default
60
- } from "./chunk-E63IIM5T.js";
61
-
62
- // packages/engine/Source/Core/OrientedBoundingBox.js
63
- function OrientedBoundingBox(center, halfAxes) {
64
- this.center = Cartesian3_default.clone(defaultValue_default(center, Cartesian3_default.ZERO));
65
- this.halfAxes = Matrix3_default.clone(defaultValue_default(halfAxes, Matrix3_default.ZERO));
66
- }
67
- OrientedBoundingBox.packedLength = Cartesian3_default.packedLength + Matrix3_default.packedLength;
68
- OrientedBoundingBox.pack = function(value, array, startingIndex) {
69
- Check_default.typeOf.object("value", value);
70
- Check_default.defined("array", array);
71
- startingIndex = defaultValue_default(startingIndex, 0);
72
- Cartesian3_default.pack(value.center, array, startingIndex);
73
- Matrix3_default.pack(value.halfAxes, array, startingIndex + Cartesian3_default.packedLength);
74
- return array;
75
- };
76
- OrientedBoundingBox.unpack = function(array, startingIndex, result) {
77
- Check_default.defined("array", array);
78
- startingIndex = defaultValue_default(startingIndex, 0);
79
- if (!defined_default(result)) {
80
- result = new OrientedBoundingBox();
81
- }
82
- Cartesian3_default.unpack(array, startingIndex, result.center);
83
- Matrix3_default.unpack(
84
- array,
85
- startingIndex + Cartesian3_default.packedLength,
86
- result.halfAxes
87
- );
88
- return result;
89
- };
90
- var scratchCartesian1 = new Cartesian3_default();
91
- var scratchCartesian2 = new Cartesian3_default();
92
- var scratchCartesian3 = new Cartesian3_default();
93
- var scratchCartesian4 = new Cartesian3_default();
94
- var scratchCartesian5 = new Cartesian3_default();
95
- var scratchCartesian6 = new Cartesian3_default();
96
- var scratchCovarianceResult = new Matrix3_default();
97
- var scratchEigenResult = {
98
- unitary: new Matrix3_default(),
99
- diagonal: new Matrix3_default()
100
- };
101
- OrientedBoundingBox.fromPoints = function(positions, result) {
102
- if (!defined_default(result)) {
103
- result = new OrientedBoundingBox();
104
- }
105
- if (!defined_default(positions) || positions.length === 0) {
106
- result.halfAxes = Matrix3_default.ZERO;
107
- result.center = Cartesian3_default.ZERO;
108
- return result;
109
- }
110
- let i;
111
- const length = positions.length;
112
- const meanPoint = Cartesian3_default.clone(positions[0], scratchCartesian1);
113
- for (i = 1; i < length; i++) {
114
- Cartesian3_default.add(meanPoint, positions[i], meanPoint);
115
- }
116
- const invLength = 1 / length;
117
- Cartesian3_default.multiplyByScalar(meanPoint, invLength, meanPoint);
118
- let exx = 0;
119
- let exy = 0;
120
- let exz = 0;
121
- let eyy = 0;
122
- let eyz = 0;
123
- let ezz = 0;
124
- let p;
125
- for (i = 0; i < length; i++) {
126
- p = Cartesian3_default.subtract(positions[i], meanPoint, scratchCartesian2);
127
- exx += p.x * p.x;
128
- exy += p.x * p.y;
129
- exz += p.x * p.z;
130
- eyy += p.y * p.y;
131
- eyz += p.y * p.z;
132
- ezz += p.z * p.z;
133
- }
134
- exx *= invLength;
135
- exy *= invLength;
136
- exz *= invLength;
137
- eyy *= invLength;
138
- eyz *= invLength;
139
- ezz *= invLength;
140
- const covarianceMatrix = scratchCovarianceResult;
141
- covarianceMatrix[0] = exx;
142
- covarianceMatrix[1] = exy;
143
- covarianceMatrix[2] = exz;
144
- covarianceMatrix[3] = exy;
145
- covarianceMatrix[4] = eyy;
146
- covarianceMatrix[5] = eyz;
147
- covarianceMatrix[6] = exz;
148
- covarianceMatrix[7] = eyz;
149
- covarianceMatrix[8] = ezz;
150
- const eigenDecomposition = Matrix3_default.computeEigenDecomposition(
151
- covarianceMatrix,
152
- scratchEigenResult
153
- );
154
- const rotation = Matrix3_default.clone(eigenDecomposition.unitary, result.halfAxes);
155
- let v1 = Matrix3_default.getColumn(rotation, 0, scratchCartesian4);
156
- let v2 = Matrix3_default.getColumn(rotation, 1, scratchCartesian5);
157
- let v3 = Matrix3_default.getColumn(rotation, 2, scratchCartesian6);
158
- let u1 = -Number.MAX_VALUE;
159
- let u2 = -Number.MAX_VALUE;
160
- let u3 = -Number.MAX_VALUE;
161
- let l1 = Number.MAX_VALUE;
162
- let l2 = Number.MAX_VALUE;
163
- let l3 = Number.MAX_VALUE;
164
- for (i = 0; i < length; i++) {
165
- p = positions[i];
166
- u1 = Math.max(Cartesian3_default.dot(v1, p), u1);
167
- u2 = Math.max(Cartesian3_default.dot(v2, p), u2);
168
- u3 = Math.max(Cartesian3_default.dot(v3, p), u3);
169
- l1 = Math.min(Cartesian3_default.dot(v1, p), l1);
170
- l2 = Math.min(Cartesian3_default.dot(v2, p), l2);
171
- l3 = Math.min(Cartesian3_default.dot(v3, p), l3);
172
- }
173
- v1 = Cartesian3_default.multiplyByScalar(v1, 0.5 * (l1 + u1), v1);
174
- v2 = Cartesian3_default.multiplyByScalar(v2, 0.5 * (l2 + u2), v2);
175
- v3 = Cartesian3_default.multiplyByScalar(v3, 0.5 * (l3 + u3), v3);
176
- const center = Cartesian3_default.add(v1, v2, result.center);
177
- Cartesian3_default.add(center, v3, center);
178
- const scale = scratchCartesian3;
179
- scale.x = u1 - l1;
180
- scale.y = u2 - l2;
181
- scale.z = u3 - l3;
182
- Cartesian3_default.multiplyByScalar(scale, 0.5, scale);
183
- Matrix3_default.multiplyByScale(result.halfAxes, scale, result.halfAxes);
184
- return result;
185
- };
186
- var scratchOffset = new Cartesian3_default();
187
- var scratchScale = new Cartesian3_default();
188
- function fromPlaneExtents(planeOrigin, planeXAxis, planeYAxis, planeZAxis, minimumX, maximumX, minimumY, maximumY, minimumZ, maximumZ, result) {
189
- if (!defined_default(minimumX) || !defined_default(maximumX) || !defined_default(minimumY) || !defined_default(maximumY) || !defined_default(minimumZ) || !defined_default(maximumZ)) {
190
- throw new DeveloperError_default(
191
- "all extents (minimum/maximum X/Y/Z) are required."
192
- );
193
- }
194
- if (!defined_default(result)) {
195
- result = new OrientedBoundingBox();
196
- }
197
- const halfAxes = result.halfAxes;
198
- Matrix3_default.setColumn(halfAxes, 0, planeXAxis, halfAxes);
199
- Matrix3_default.setColumn(halfAxes, 1, planeYAxis, halfAxes);
200
- Matrix3_default.setColumn(halfAxes, 2, planeZAxis, halfAxes);
201
- let centerOffset = scratchOffset;
202
- centerOffset.x = (minimumX + maximumX) / 2;
203
- centerOffset.y = (minimumY + maximumY) / 2;
204
- centerOffset.z = (minimumZ + maximumZ) / 2;
205
- const scale = scratchScale;
206
- scale.x = (maximumX - minimumX) / 2;
207
- scale.y = (maximumY - minimumY) / 2;
208
- scale.z = (maximumZ - minimumZ) / 2;
209
- const center = result.center;
210
- centerOffset = Matrix3_default.multiplyByVector(halfAxes, centerOffset, centerOffset);
211
- Cartesian3_default.add(planeOrigin, centerOffset, center);
212
- Matrix3_default.multiplyByScale(halfAxes, scale, halfAxes);
213
- return result;
214
- }
215
- var scratchRectangleCenterCartographic = new Cartographic_default();
216
- var scratchRectangleCenter = new Cartesian3_default();
217
- var scratchPerimeterCartographicNC = new Cartographic_default();
218
- var scratchPerimeterCartographicNW = new Cartographic_default();
219
- var scratchPerimeterCartographicCW = new Cartographic_default();
220
- var scratchPerimeterCartographicSW = new Cartographic_default();
221
- var scratchPerimeterCartographicSC = new Cartographic_default();
222
- var scratchPerimeterCartesianNC = new Cartesian3_default();
223
- var scratchPerimeterCartesianNW = new Cartesian3_default();
224
- var scratchPerimeterCartesianCW = new Cartesian3_default();
225
- var scratchPerimeterCartesianSW = new Cartesian3_default();
226
- var scratchPerimeterCartesianSC = new Cartesian3_default();
227
- var scratchPerimeterProjectedNC = new Cartesian2_default();
228
- var scratchPerimeterProjectedNW = new Cartesian2_default();
229
- var scratchPerimeterProjectedCW = new Cartesian2_default();
230
- var scratchPerimeterProjectedSW = new Cartesian2_default();
231
- var scratchPerimeterProjectedSC = new Cartesian2_default();
232
- var scratchPlaneOrigin = new Cartesian3_default();
233
- var scratchPlaneNormal = new Cartesian3_default();
234
- var scratchPlaneXAxis = new Cartesian3_default();
235
- var scratchHorizonCartesian = new Cartesian3_default();
236
- var scratchHorizonProjected = new Cartesian2_default();
237
- var scratchMaxY = new Cartesian3_default();
238
- var scratchMinY = new Cartesian3_default();
239
- var scratchZ = new Cartesian3_default();
240
- var scratchPlane = new Plane_default(Cartesian3_default.UNIT_X, 0);
241
- OrientedBoundingBox.fromRectangle = function(rectangle, minimumHeight, maximumHeight, ellipsoid, result) {
242
- if (!defined_default(rectangle)) {
243
- throw new DeveloperError_default("rectangle is required");
244
- }
245
- if (rectangle.width < 0 || rectangle.width > Math_default.TWO_PI) {
246
- throw new DeveloperError_default("Rectangle width must be between 0 and 2 * pi");
247
- }
248
- if (rectangle.height < 0 || rectangle.height > Math_default.PI) {
249
- throw new DeveloperError_default("Rectangle height must be between 0 and pi");
250
- }
251
- if (defined_default(ellipsoid) && !Math_default.equalsEpsilon(
252
- ellipsoid.radii.x,
253
- ellipsoid.radii.y,
254
- Math_default.EPSILON15
255
- )) {
256
- throw new DeveloperError_default(
257
- "Ellipsoid must be an ellipsoid of revolution (radii.x == radii.y)"
258
- );
259
- }
260
- minimumHeight = defaultValue_default(minimumHeight, 0);
261
- maximumHeight = defaultValue_default(maximumHeight, 0);
262
- ellipsoid = defaultValue_default(ellipsoid, Ellipsoid_default.default);
263
- let minX, maxX, minY, maxY, minZ, maxZ, plane;
264
- if (rectangle.width <= Math_default.PI) {
265
- const tangentPointCartographic = Rectangle_default.center(
266
- rectangle,
267
- scratchRectangleCenterCartographic
268
- );
269
- const tangentPoint = ellipsoid.cartographicToCartesian(
270
- tangentPointCartographic,
271
- scratchRectangleCenter
272
- );
273
- const tangentPlane = new EllipsoidTangentPlane_default(tangentPoint, ellipsoid);
274
- plane = tangentPlane.plane;
275
- const lonCenter = tangentPointCartographic.longitude;
276
- const latCenter = rectangle.south < 0 && rectangle.north > 0 ? 0 : tangentPointCartographic.latitude;
277
- const perimeterCartographicNC = Cartographic_default.fromRadians(
278
- lonCenter,
279
- rectangle.north,
280
- maximumHeight,
281
- scratchPerimeterCartographicNC
282
- );
283
- const perimeterCartographicNW = Cartographic_default.fromRadians(
284
- rectangle.west,
285
- rectangle.north,
286
- maximumHeight,
287
- scratchPerimeterCartographicNW
288
- );
289
- const perimeterCartographicCW = Cartographic_default.fromRadians(
290
- rectangle.west,
291
- latCenter,
292
- maximumHeight,
293
- scratchPerimeterCartographicCW
294
- );
295
- const perimeterCartographicSW = Cartographic_default.fromRadians(
296
- rectangle.west,
297
- rectangle.south,
298
- maximumHeight,
299
- scratchPerimeterCartographicSW
300
- );
301
- const perimeterCartographicSC = Cartographic_default.fromRadians(
302
- lonCenter,
303
- rectangle.south,
304
- maximumHeight,
305
- scratchPerimeterCartographicSC
306
- );
307
- const perimeterCartesianNC = ellipsoid.cartographicToCartesian(
308
- perimeterCartographicNC,
309
- scratchPerimeterCartesianNC
310
- );
311
- let perimeterCartesianNW = ellipsoid.cartographicToCartesian(
312
- perimeterCartographicNW,
313
- scratchPerimeterCartesianNW
314
- );
315
- const perimeterCartesianCW = ellipsoid.cartographicToCartesian(
316
- perimeterCartographicCW,
317
- scratchPerimeterCartesianCW
318
- );
319
- let perimeterCartesianSW = ellipsoid.cartographicToCartesian(
320
- perimeterCartographicSW,
321
- scratchPerimeterCartesianSW
322
- );
323
- const perimeterCartesianSC = ellipsoid.cartographicToCartesian(
324
- perimeterCartographicSC,
325
- scratchPerimeterCartesianSC
326
- );
327
- const perimeterProjectedNC = tangentPlane.projectPointToNearestOnPlane(
328
- perimeterCartesianNC,
329
- scratchPerimeterProjectedNC
330
- );
331
- const perimeterProjectedNW = tangentPlane.projectPointToNearestOnPlane(
332
- perimeterCartesianNW,
333
- scratchPerimeterProjectedNW
334
- );
335
- const perimeterProjectedCW = tangentPlane.projectPointToNearestOnPlane(
336
- perimeterCartesianCW,
337
- scratchPerimeterProjectedCW
338
- );
339
- const perimeterProjectedSW = tangentPlane.projectPointToNearestOnPlane(
340
- perimeterCartesianSW,
341
- scratchPerimeterProjectedSW
342
- );
343
- const perimeterProjectedSC = tangentPlane.projectPointToNearestOnPlane(
344
- perimeterCartesianSC,
345
- scratchPerimeterProjectedSC
346
- );
347
- minX = Math.min(
348
- perimeterProjectedNW.x,
349
- perimeterProjectedCW.x,
350
- perimeterProjectedSW.x
351
- );
352
- maxX = -minX;
353
- maxY = Math.max(perimeterProjectedNW.y, perimeterProjectedNC.y);
354
- minY = Math.min(perimeterProjectedSW.y, perimeterProjectedSC.y);
355
- perimeterCartographicNW.height = perimeterCartographicSW.height = minimumHeight;
356
- perimeterCartesianNW = ellipsoid.cartographicToCartesian(
357
- perimeterCartographicNW,
358
- scratchPerimeterCartesianNW
359
- );
360
- perimeterCartesianSW = ellipsoid.cartographicToCartesian(
361
- perimeterCartographicSW,
362
- scratchPerimeterCartesianSW
363
- );
364
- minZ = Math.min(
365
- Plane_default.getPointDistance(plane, perimeterCartesianNW),
366
- Plane_default.getPointDistance(plane, perimeterCartesianSW)
367
- );
368
- maxZ = maximumHeight;
369
- return fromPlaneExtents(
370
- tangentPlane.origin,
371
- tangentPlane.xAxis,
372
- tangentPlane.yAxis,
373
- tangentPlane.zAxis,
374
- minX,
375
- maxX,
376
- minY,
377
- maxY,
378
- minZ,
379
- maxZ,
380
- result
381
- );
382
- }
383
- const fullyAboveEquator = rectangle.south > 0;
384
- const fullyBelowEquator = rectangle.north < 0;
385
- const latitudeNearestToEquator = fullyAboveEquator ? rectangle.south : fullyBelowEquator ? rectangle.north : 0;
386
- const centerLongitude = Rectangle_default.center(
387
- rectangle,
388
- scratchRectangleCenterCartographic
389
- ).longitude;
390
- const planeOrigin = Cartesian3_default.fromRadians(
391
- centerLongitude,
392
- latitudeNearestToEquator,
393
- maximumHeight,
394
- ellipsoid,
395
- scratchPlaneOrigin
396
- );
397
- planeOrigin.z = 0;
398
- const isPole = Math.abs(planeOrigin.x) < Math_default.EPSILON10 && Math.abs(planeOrigin.y) < Math_default.EPSILON10;
399
- const planeNormal = !isPole ? Cartesian3_default.normalize(planeOrigin, scratchPlaneNormal) : Cartesian3_default.UNIT_X;
400
- const planeYAxis = Cartesian3_default.UNIT_Z;
401
- const planeXAxis = Cartesian3_default.cross(
402
- planeNormal,
403
- planeYAxis,
404
- scratchPlaneXAxis
405
- );
406
- plane = Plane_default.fromPointNormal(planeOrigin, planeNormal, scratchPlane);
407
- const horizonCartesian = Cartesian3_default.fromRadians(
408
- centerLongitude + Math_default.PI_OVER_TWO,
409
- latitudeNearestToEquator,
410
- maximumHeight,
411
- ellipsoid,
412
- scratchHorizonCartesian
413
- );
414
- maxX = Cartesian3_default.dot(
415
- Plane_default.projectPointOntoPlane(
416
- plane,
417
- horizonCartesian,
418
- scratchHorizonProjected
419
- ),
420
- planeXAxis
421
- );
422
- minX = -maxX;
423
- maxY = Cartesian3_default.fromRadians(
424
- 0,
425
- rectangle.north,
426
- fullyBelowEquator ? minimumHeight : maximumHeight,
427
- ellipsoid,
428
- scratchMaxY
429
- ).z;
430
- minY = Cartesian3_default.fromRadians(
431
- 0,
432
- rectangle.south,
433
- fullyAboveEquator ? minimumHeight : maximumHeight,
434
- ellipsoid,
435
- scratchMinY
436
- ).z;
437
- const farZ = Cartesian3_default.fromRadians(
438
- rectangle.east,
439
- latitudeNearestToEquator,
440
- maximumHeight,
441
- ellipsoid,
442
- scratchZ
443
- );
444
- minZ = Plane_default.getPointDistance(plane, farZ);
445
- maxZ = 0;
446
- return fromPlaneExtents(
447
- planeOrigin,
448
- planeXAxis,
449
- planeYAxis,
450
- planeNormal,
451
- minX,
452
- maxX,
453
- minY,
454
- maxY,
455
- minZ,
456
- maxZ,
457
- result
458
- );
459
- };
460
- OrientedBoundingBox.fromTransformation = function(transformation, result) {
461
- Check_default.typeOf.object("transformation", transformation);
462
- if (!defined_default(result)) {
463
- result = new OrientedBoundingBox();
464
- }
465
- result.center = Matrix4_default.getTranslation(transformation, result.center);
466
- result.halfAxes = Matrix4_default.getMatrix3(transformation, result.halfAxes);
467
- result.halfAxes = Matrix3_default.multiplyByScalar(
468
- result.halfAxes,
469
- 0.5,
470
- result.halfAxes
471
- );
472
- return result;
473
- };
474
- OrientedBoundingBox.clone = function(box, result) {
475
- if (!defined_default(box)) {
476
- return void 0;
477
- }
478
- if (!defined_default(result)) {
479
- return new OrientedBoundingBox(box.center, box.halfAxes);
480
- }
481
- Cartesian3_default.clone(box.center, result.center);
482
- Matrix3_default.clone(box.halfAxes, result.halfAxes);
483
- return result;
484
- };
485
- OrientedBoundingBox.intersectPlane = function(box, plane) {
486
- if (!defined_default(box)) {
487
- throw new DeveloperError_default("box is required.");
488
- }
489
- if (!defined_default(plane)) {
490
- throw new DeveloperError_default("plane is required.");
491
- }
492
- const center = box.center;
493
- const normal = plane.normal;
494
- const halfAxes = box.halfAxes;
495
- const normalX = normal.x, normalY = normal.y, normalZ = normal.z;
496
- const radEffective = Math.abs(
497
- normalX * halfAxes[Matrix3_default.COLUMN0ROW0] + normalY * halfAxes[Matrix3_default.COLUMN0ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN0ROW2]
498
- ) + Math.abs(
499
- normalX * halfAxes[Matrix3_default.COLUMN1ROW0] + normalY * halfAxes[Matrix3_default.COLUMN1ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN1ROW2]
500
- ) + Math.abs(
501
- normalX * halfAxes[Matrix3_default.COLUMN2ROW0] + normalY * halfAxes[Matrix3_default.COLUMN2ROW1] + normalZ * halfAxes[Matrix3_default.COLUMN2ROW2]
502
- );
503
- const distanceToPlane = Cartesian3_default.dot(normal, center) + plane.distance;
504
- if (distanceToPlane <= -radEffective) {
505
- return Intersect_default.OUTSIDE;
506
- } else if (distanceToPlane >= radEffective) {
507
- return Intersect_default.INSIDE;
508
- }
509
- return Intersect_default.INTERSECTING;
510
- };
511
- var scratchCartesianU = new Cartesian3_default();
512
- var scratchCartesianV = new Cartesian3_default();
513
- var scratchCartesianW = new Cartesian3_default();
514
- var scratchValidAxis2 = new Cartesian3_default();
515
- var scratchValidAxis3 = new Cartesian3_default();
516
- var scratchPPrime = new Cartesian3_default();
517
- OrientedBoundingBox.distanceSquaredTo = function(box, cartesian) {
518
- if (!defined_default(box)) {
519
- throw new DeveloperError_default("box is required.");
520
- }
521
- if (!defined_default(cartesian)) {
522
- throw new DeveloperError_default("cartesian is required.");
523
- }
524
- const offset = Cartesian3_default.subtract(cartesian, box.center, scratchOffset);
525
- const halfAxes = box.halfAxes;
526
- let u = Matrix3_default.getColumn(halfAxes, 0, scratchCartesianU);
527
- let v = Matrix3_default.getColumn(halfAxes, 1, scratchCartesianV);
528
- let w = Matrix3_default.getColumn(halfAxes, 2, scratchCartesianW);
529
- const uHalf = Cartesian3_default.magnitude(u);
530
- const vHalf = Cartesian3_default.magnitude(v);
531
- const wHalf = Cartesian3_default.magnitude(w);
532
- let uValid = true;
533
- let vValid = true;
534
- let wValid = true;
535
- if (uHalf > 0) {
536
- Cartesian3_default.divideByScalar(u, uHalf, u);
537
- } else {
538
- uValid = false;
539
- }
540
- if (vHalf > 0) {
541
- Cartesian3_default.divideByScalar(v, vHalf, v);
542
- } else {
543
- vValid = false;
544
- }
545
- if (wHalf > 0) {
546
- Cartesian3_default.divideByScalar(w, wHalf, w);
547
- } else {
548
- wValid = false;
549
- }
550
- const numberOfDegenerateAxes = !uValid + !vValid + !wValid;
551
- let validAxis1;
552
- let validAxis2;
553
- let validAxis3;
554
- if (numberOfDegenerateAxes === 1) {
555
- let degenerateAxis = u;
556
- validAxis1 = v;
557
- validAxis2 = w;
558
- if (!vValid) {
559
- degenerateAxis = v;
560
- validAxis1 = u;
561
- } else if (!wValid) {
562
- degenerateAxis = w;
563
- validAxis2 = u;
564
- }
565
- validAxis3 = Cartesian3_default.cross(validAxis1, validAxis2, scratchValidAxis3);
566
- if (degenerateAxis === u) {
567
- u = validAxis3;
568
- } else if (degenerateAxis === v) {
569
- v = validAxis3;
570
- } else if (degenerateAxis === w) {
571
- w = validAxis3;
572
- }
573
- } else if (numberOfDegenerateAxes === 2) {
574
- validAxis1 = u;
575
- if (vValid) {
576
- validAxis1 = v;
577
- } else if (wValid) {
578
- validAxis1 = w;
579
- }
580
- let crossVector = Cartesian3_default.UNIT_Y;
581
- if (crossVector.equalsEpsilon(validAxis1, Math_default.EPSILON3)) {
582
- crossVector = Cartesian3_default.UNIT_X;
583
- }
584
- validAxis2 = Cartesian3_default.cross(validAxis1, crossVector, scratchValidAxis2);
585
- Cartesian3_default.normalize(validAxis2, validAxis2);
586
- validAxis3 = Cartesian3_default.cross(validAxis1, validAxis2, scratchValidAxis3);
587
- Cartesian3_default.normalize(validAxis3, validAxis3);
588
- if (validAxis1 === u) {
589
- v = validAxis2;
590
- w = validAxis3;
591
- } else if (validAxis1 === v) {
592
- w = validAxis2;
593
- u = validAxis3;
594
- } else if (validAxis1 === w) {
595
- u = validAxis2;
596
- v = validAxis3;
597
- }
598
- } else if (numberOfDegenerateAxes === 3) {
599
- u = Cartesian3_default.UNIT_X;
600
- v = Cartesian3_default.UNIT_Y;
601
- w = Cartesian3_default.UNIT_Z;
602
- }
603
- const pPrime = scratchPPrime;
604
- pPrime.x = Cartesian3_default.dot(offset, u);
605
- pPrime.y = Cartesian3_default.dot(offset, v);
606
- pPrime.z = Cartesian3_default.dot(offset, w);
607
- let distanceSquared = 0;
608
- let d;
609
- if (pPrime.x < -uHalf) {
610
- d = pPrime.x + uHalf;
611
- distanceSquared += d * d;
612
- } else if (pPrime.x > uHalf) {
613
- d = pPrime.x - uHalf;
614
- distanceSquared += d * d;
615
- }
616
- if (pPrime.y < -vHalf) {
617
- d = pPrime.y + vHalf;
618
- distanceSquared += d * d;
619
- } else if (pPrime.y > vHalf) {
620
- d = pPrime.y - vHalf;
621
- distanceSquared += d * d;
622
- }
623
- if (pPrime.z < -wHalf) {
624
- d = pPrime.z + wHalf;
625
- distanceSquared += d * d;
626
- } else if (pPrime.z > wHalf) {
627
- d = pPrime.z - wHalf;
628
- distanceSquared += d * d;
629
- }
630
- return distanceSquared;
631
- };
632
- var scratchCorner = new Cartesian3_default();
633
- var scratchToCenter = new Cartesian3_default();
634
- OrientedBoundingBox.computePlaneDistances = function(box, position, direction, result) {
635
- if (!defined_default(box)) {
636
- throw new DeveloperError_default("box is required.");
637
- }
638
- if (!defined_default(position)) {
639
- throw new DeveloperError_default("position is required.");
640
- }
641
- if (!defined_default(direction)) {
642
- throw new DeveloperError_default("direction is required.");
643
- }
644
- if (!defined_default(result)) {
645
- result = new Interval_default();
646
- }
647
- let minDist = Number.POSITIVE_INFINITY;
648
- let maxDist = Number.NEGATIVE_INFINITY;
649
- const center = box.center;
650
- const halfAxes = box.halfAxes;
651
- const u = Matrix3_default.getColumn(halfAxes, 0, scratchCartesianU);
652
- const v = Matrix3_default.getColumn(halfAxes, 1, scratchCartesianV);
653
- const w = Matrix3_default.getColumn(halfAxes, 2, scratchCartesianW);
654
- const corner = Cartesian3_default.add(u, v, scratchCorner);
655
- Cartesian3_default.add(corner, w, corner);
656
- Cartesian3_default.add(corner, center, corner);
657
- const toCenter = Cartesian3_default.subtract(corner, position, scratchToCenter);
658
- let mag = Cartesian3_default.dot(direction, toCenter);
659
- minDist = Math.min(mag, minDist);
660
- maxDist = Math.max(mag, maxDist);
661
- Cartesian3_default.add(center, u, corner);
662
- Cartesian3_default.add(corner, v, corner);
663
- Cartesian3_default.subtract(corner, w, corner);
664
- Cartesian3_default.subtract(corner, position, toCenter);
665
- mag = Cartesian3_default.dot(direction, toCenter);
666
- minDist = Math.min(mag, minDist);
667
- maxDist = Math.max(mag, maxDist);
668
- Cartesian3_default.add(center, u, corner);
669
- Cartesian3_default.subtract(corner, v, corner);
670
- Cartesian3_default.add(corner, w, corner);
671
- Cartesian3_default.subtract(corner, position, toCenter);
672
- mag = Cartesian3_default.dot(direction, toCenter);
673
- minDist = Math.min(mag, minDist);
674
- maxDist = Math.max(mag, maxDist);
675
- Cartesian3_default.add(center, u, corner);
676
- Cartesian3_default.subtract(corner, v, corner);
677
- Cartesian3_default.subtract(corner, w, corner);
678
- Cartesian3_default.subtract(corner, position, toCenter);
679
- mag = Cartesian3_default.dot(direction, toCenter);
680
- minDist = Math.min(mag, minDist);
681
- maxDist = Math.max(mag, maxDist);
682
- Cartesian3_default.subtract(center, u, corner);
683
- Cartesian3_default.add(corner, v, corner);
684
- Cartesian3_default.add(corner, w, corner);
685
- Cartesian3_default.subtract(corner, position, toCenter);
686
- mag = Cartesian3_default.dot(direction, toCenter);
687
- minDist = Math.min(mag, minDist);
688
- maxDist = Math.max(mag, maxDist);
689
- Cartesian3_default.subtract(center, u, corner);
690
- Cartesian3_default.add(corner, v, corner);
691
- Cartesian3_default.subtract(corner, w, corner);
692
- Cartesian3_default.subtract(corner, position, toCenter);
693
- mag = Cartesian3_default.dot(direction, toCenter);
694
- minDist = Math.min(mag, minDist);
695
- maxDist = Math.max(mag, maxDist);
696
- Cartesian3_default.subtract(center, u, corner);
697
- Cartesian3_default.subtract(corner, v, corner);
698
- Cartesian3_default.add(corner, w, corner);
699
- Cartesian3_default.subtract(corner, position, toCenter);
700
- mag = Cartesian3_default.dot(direction, toCenter);
701
- minDist = Math.min(mag, minDist);
702
- maxDist = Math.max(mag, maxDist);
703
- Cartesian3_default.subtract(center, u, corner);
704
- Cartesian3_default.subtract(corner, v, corner);
705
- Cartesian3_default.subtract(corner, w, corner);
706
- Cartesian3_default.subtract(corner, position, toCenter);
707
- mag = Cartesian3_default.dot(direction, toCenter);
708
- minDist = Math.min(mag, minDist);
709
- maxDist = Math.max(mag, maxDist);
710
- result.start = minDist;
711
- result.stop = maxDist;
712
- return result;
713
- };
714
- var scratchXAxis = new Cartesian3_default();
715
- var scratchYAxis = new Cartesian3_default();
716
- var scratchZAxis = new Cartesian3_default();
717
- OrientedBoundingBox.computeCorners = function(box, result) {
718
- Check_default.typeOf.object("box", box);
719
- if (!defined_default(result)) {
720
- result = [
721
- new Cartesian3_default(),
722
- new Cartesian3_default(),
723
- new Cartesian3_default(),
724
- new Cartesian3_default(),
725
- new Cartesian3_default(),
726
- new Cartesian3_default(),
727
- new Cartesian3_default(),
728
- new Cartesian3_default()
729
- ];
730
- }
731
- const center = box.center;
732
- const halfAxes = box.halfAxes;
733
- const xAxis = Matrix3_default.getColumn(halfAxes, 0, scratchXAxis);
734
- const yAxis = Matrix3_default.getColumn(halfAxes, 1, scratchYAxis);
735
- const zAxis = Matrix3_default.getColumn(halfAxes, 2, scratchZAxis);
736
- Cartesian3_default.clone(center, result[0]);
737
- Cartesian3_default.subtract(result[0], xAxis, result[0]);
738
- Cartesian3_default.subtract(result[0], yAxis, result[0]);
739
- Cartesian3_default.subtract(result[0], zAxis, result[0]);
740
- Cartesian3_default.clone(center, result[1]);
741
- Cartesian3_default.subtract(result[1], xAxis, result[1]);
742
- Cartesian3_default.subtract(result[1], yAxis, result[1]);
743
- Cartesian3_default.add(result[1], zAxis, result[1]);
744
- Cartesian3_default.clone(center, result[2]);
745
- Cartesian3_default.subtract(result[2], xAxis, result[2]);
746
- Cartesian3_default.add(result[2], yAxis, result[2]);
747
- Cartesian3_default.subtract(result[2], zAxis, result[2]);
748
- Cartesian3_default.clone(center, result[3]);
749
- Cartesian3_default.subtract(result[3], xAxis, result[3]);
750
- Cartesian3_default.add(result[3], yAxis, result[3]);
751
- Cartesian3_default.add(result[3], zAxis, result[3]);
752
- Cartesian3_default.clone(center, result[4]);
753
- Cartesian3_default.add(result[4], xAxis, result[4]);
754
- Cartesian3_default.subtract(result[4], yAxis, result[4]);
755
- Cartesian3_default.subtract(result[4], zAxis, result[4]);
756
- Cartesian3_default.clone(center, result[5]);
757
- Cartesian3_default.add(result[5], xAxis, result[5]);
758
- Cartesian3_default.subtract(result[5], yAxis, result[5]);
759
- Cartesian3_default.add(result[5], zAxis, result[5]);
760
- Cartesian3_default.clone(center, result[6]);
761
- Cartesian3_default.add(result[6], xAxis, result[6]);
762
- Cartesian3_default.add(result[6], yAxis, result[6]);
763
- Cartesian3_default.subtract(result[6], zAxis, result[6]);
764
- Cartesian3_default.clone(center, result[7]);
765
- Cartesian3_default.add(result[7], xAxis, result[7]);
766
- Cartesian3_default.add(result[7], yAxis, result[7]);
767
- Cartesian3_default.add(result[7], zAxis, result[7]);
768
- return result;
769
- };
770
- var scratchRotationScale = new Matrix3_default();
771
- OrientedBoundingBox.computeTransformation = function(box, result) {
772
- Check_default.typeOf.object("box", box);
773
- if (!defined_default(result)) {
774
- result = new Matrix4_default();
775
- }
776
- const translation = box.center;
777
- const rotationScale = Matrix3_default.multiplyByUniformScale(
778
- box.halfAxes,
779
- 2,
780
- scratchRotationScale
781
- );
782
- return Matrix4_default.fromRotationTranslation(rotationScale, translation, result);
783
- };
784
- var scratchBoundingSphere = new BoundingSphere_default();
785
- OrientedBoundingBox.isOccluded = function(box, occluder) {
786
- if (!defined_default(box)) {
787
- throw new DeveloperError_default("box is required.");
788
- }
789
- if (!defined_default(occluder)) {
790
- throw new DeveloperError_default("occluder is required.");
791
- }
792
- const sphere = BoundingSphere_default.fromOrientedBoundingBox(
793
- box,
794
- scratchBoundingSphere
795
- );
796
- return !occluder.isBoundingSphereVisible(sphere);
797
- };
798
- OrientedBoundingBox.prototype.intersectPlane = function(plane) {
799
- return OrientedBoundingBox.intersectPlane(this, plane);
800
- };
801
- OrientedBoundingBox.prototype.distanceSquaredTo = function(cartesian) {
802
- return OrientedBoundingBox.distanceSquaredTo(this, cartesian);
803
- };
804
- OrientedBoundingBox.prototype.computePlaneDistances = function(position, direction, result) {
805
- return OrientedBoundingBox.computePlaneDistances(
806
- this,
807
- position,
808
- direction,
809
- result
810
- );
811
- };
812
- OrientedBoundingBox.prototype.computeCorners = function(result) {
813
- return OrientedBoundingBox.computeCorners(this, result);
814
- };
815
- OrientedBoundingBox.prototype.computeTransformation = function(result) {
816
- return OrientedBoundingBox.computeTransformation(this, result);
817
- };
818
- OrientedBoundingBox.prototype.isOccluded = function(occluder) {
819
- return OrientedBoundingBox.isOccluded(this, occluder);
820
- };
821
- OrientedBoundingBox.equals = function(left, right) {
822
- return left === right || defined_default(left) && defined_default(right) && Cartesian3_default.equals(left.center, right.center) && Matrix3_default.equals(left.halfAxes, right.halfAxes);
823
- };
824
- OrientedBoundingBox.prototype.clone = function(result) {
825
- return OrientedBoundingBox.clone(this, result);
826
- };
827
- OrientedBoundingBox.prototype.equals = function(right) {
828
- return OrientedBoundingBox.equals(this, right);
829
- };
830
- var OrientedBoundingBox_default = OrientedBoundingBox;
831
-
832
- export {
833
- OrientedBoundingBox_default
834
- };