deeptwins-cesium-engine 0.0.37 → 0.0.39
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.
- package/Build/ThirdParty/Workers/pako_deflate.min.js +3 -3
- package/Build/ThirdParty/Workers/pako_inflate.min.js +3 -3
- package/Build/ThirdParty/Workers/zip-web-worker.js +2 -2
- package/Build/Workers/chunk-23I6J5G7.js +398 -0
- package/Build/Workers/chunk-2AHRUAHP.js +963 -0
- package/Build/Workers/chunk-2EXJYRVL.js +1800 -0
- package/Build/Workers/chunk-2KZSEMHE.js +368 -0
- package/Build/Workers/chunk-3DT7SFPW.js +959 -0
- package/Build/Workers/chunk-3HAZZIZN.js +435 -0
- package/Build/Workers/chunk-3JNKFBNK.js +287 -0
- package/Build/Workers/chunk-4GPYRP3M.js +157 -0
- package/Build/Workers/chunk-4HWJCCN5.js +1481 -0
- package/Build/Workers/chunk-4UN6DCKS.js +44 -0
- package/Build/Workers/chunk-5AS35AVH.js +101 -0
- package/Build/Workers/chunk-5QBKODYV.js +239 -0
- package/Build/Workers/chunk-7H2S5BNE.js +196 -0
- package/Build/Workers/chunk-7NK5LQGE.js +1055 -0
- package/Build/Workers/chunk-7USIJNJO.js +456 -0
- package/Build/Workers/chunk-A3LZJ465.js +634 -0
- package/Build/Workers/chunk-ACV745U5.js +629 -0
- package/Build/Workers/chunk-AF7CI434.js +476 -0
- package/Build/Workers/chunk-ARYZWDAD.js +157 -0
- package/Build/Workers/chunk-BDVR2XOF.js +305 -0
- package/Build/Workers/chunk-CBSLDU73.js +1481 -0
- package/Build/Workers/chunk-DD3ISUFZ.js +2717 -0
- package/Build/Workers/chunk-DIVAQ6AJ.js +196 -0
- package/Build/Workers/chunk-E2LXRH4B.js +390 -0
- package/Build/Workers/chunk-ESM3ZWV7.js +781 -0
- package/Build/Workers/chunk-EZS63EHQ.js +171 -0
- package/Build/Workers/chunk-F3HA5JVH.js +435 -0
- package/Build/Workers/chunk-FGQQ4BAX.js +684 -0
- package/Build/Workers/chunk-FL4PAMOR.js +100 -0
- package/Build/Workers/chunk-FXZPZ42H.js +122 -0
- package/Build/Workers/chunk-GBACHWVF.js +171 -0
- package/Build/Workers/chunk-GKTDHQWC.js +122 -0
- package/Build/Workers/chunk-HBSMOYMV.js +37 -0
- package/Build/Workers/chunk-HKLYRUUZ.js +691 -0
- package/Build/Workers/chunk-HRSYMVJK.js +511 -0
- package/Build/Workers/chunk-IE4WZF5B.js +220 -0
- package/Build/Workers/chunk-IXVT26OF.js +163 -0
- package/Build/Workers/chunk-IYRRJ6HP.js +262 -0
- package/Build/Workers/chunk-JGB65JJZ.js +58 -0
- package/Build/Workers/chunk-K4MHMSSB.js +1800 -0
- package/Build/Workers/chunk-KZZS6JY6.js +300 -0
- package/Build/Workers/chunk-LBBJTH3K.js +2717 -0
- package/Build/Workers/chunk-LFYSBTBW.js +963 -0
- package/Build/Workers/chunk-LHUR7S4A.js +421 -0
- package/Build/Workers/chunk-LNRTQ27Z.js +59 -0
- package/Build/Workers/chunk-LOR2HRSE.js +1073 -0
- package/Build/Workers/chunk-MCMBUNB4.js +10357 -0
- package/Build/Workers/chunk-NCVCDYTD.js +1258 -0
- package/Build/Workers/chunk-NS3GCKZS.js +102 -0
- package/Build/Workers/chunk-OGSJ5ZP6.js +500 -0
- package/Build/Workers/chunk-OH3VVE2G.js +758 -0
- package/Build/Workers/chunk-OVXKRRSP.js +305 -0
- package/Build/Workers/chunk-OYCWKCSH.js +139 -0
- package/Build/Workers/chunk-P53ISV4G.js +1258 -0
- package/Build/Workers/chunk-P76UBIMX.js +75 -0
- package/Build/Workers/chunk-PPJPELR6.js +834 -0
- package/Build/Workers/chunk-PXMNRFPM.js +691 -0
- package/Build/Workers/chunk-QW5GG3FR.js +59 -0
- package/Build/Workers/chunk-RBFNWURH.js +959 -0
- package/Build/Workers/chunk-RCW2L6C3.js +1055 -0
- package/Build/Workers/chunk-RO6KFQNC.js +287 -0
- package/Build/Workers/chunk-RZIOHE7Z.js +239 -0
- package/Build/Workers/chunk-S7VB62PT.js +511 -0
- package/Build/Workers/chunk-SS4SBY5P.js +421 -0
- package/Build/Workers/chunk-TDUWFVEH.js +300 -0
- package/Build/Workers/chunk-UBCK7AIW.js +39 -0
- package/Build/Workers/chunk-UDSU5OZZ.js +73 -0
- package/Build/Workers/chunk-UWBEXOKK.js +115 -0
- package/Build/Workers/chunk-VMHJ465B.js +781 -0
- package/Build/Workers/chunk-W3SVGQNY.js +353 -0
- package/Build/Workers/chunk-WANNP3AY.js +1073 -0
- package/Build/Workers/chunk-WJT5PV2Q.js +220 -0
- package/Build/Workers/chunk-X2PKPXPZ.js +10357 -0
- package/Build/Workers/chunk-XA76JK4A.js +758 -0
- package/Build/Workers/chunk-XAI7HXKB.js +476 -0
- package/Build/Workers/chunk-XCTF4LFK.js +138 -0
- package/Build/Workers/chunk-XQWSES33.js +55 -0
- package/Build/Workers/chunk-XUDMEXSI.js +834 -0
- package/Build/Workers/chunk-YNTVI3S3.js +390 -0
- package/Build/Workers/chunk-YW6GWBRU.js +368 -0
- package/Build/Workers/chunk-YZUNRTF3.js +398 -0
- package/Build/Workers/chunk-Z26UX5A7.js +684 -0
- package/Build/Workers/chunk-ZPEGWBIN.js +2857 -0
- package/Build/Workers/combineGeometry.js +22 -22
- package/Build/Workers/createBoxGeometry.js +16 -16
- package/Build/Workers/createBoxOutlineGeometry.js +14 -14
- package/Build/Workers/createCircleGeometry.js +24 -24
- package/Build/Workers/createCircleOutlineGeometry.js +17 -17
- package/Build/Workers/createCoplanarPolygonGeometry.js +31 -31
- package/Build/Workers/createCoplanarPolygonOutlineGeometry.js +29 -29
- package/Build/Workers/createCorridorGeometry.js +27 -27
- package/Build/Workers/createCorridorOutlineGeometry.js +26 -26
- package/Build/Workers/createCylinderGeometry.js +18 -18
- package/Build/Workers/createCylinderOutlineGeometry.js +16 -16
- package/Build/Workers/createEllipseGeometry.js +24 -24
- package/Build/Workers/createEllipseOutlineGeometry.js +17 -17
- package/Build/Workers/createEllipsoidGeometry.js +17 -17
- package/Build/Workers/createEllipsoidOutlineGeometry.js +16 -16
- package/Build/Workers/createFrustumGeometry.js +16 -16
- package/Build/Workers/createFrustumOutlineGeometry.js +16 -16
- package/Build/Workers/createGeometry.js +22 -22
- package/Build/Workers/createGroundPolylineGeometry.js +20 -20
- package/Build/Workers/createPlaneGeometry.js +14 -14
- package/Build/Workers/createPlaneOutlineGeometry.js +13 -13
- package/Build/Workers/createPolygonGeometry.js +30 -30
- package/Build/Workers/createPolygonOutlineGeometry.js +28 -28
- package/Build/Workers/createPolylineGeometry.js +23 -23
- package/Build/Workers/createPolylineVolumeGeometry.js +29 -29
- package/Build/Workers/createPolylineVolumeOutlineGeometry.js +25 -25
- package/Build/Workers/createRectangleGeometry.js +25 -25
- package/Build/Workers/createRectangleOutlineGeometry.js +18 -18
- package/Build/Workers/createSimplePolylineGeometry.js +21 -21
- package/Build/Workers/createSphereGeometry.js +17 -17
- package/Build/Workers/createSphereOutlineGeometry.js +16 -16
- package/Build/Workers/createTaskProcessorWorker.js +3 -3
- package/Build/Workers/createVectorTileClampedPolylines.js +13 -13
- package/Build/Workers/createVectorTileGeometries.js +22 -22
- package/Build/Workers/createVectorTilePoints.js +12 -12
- package/Build/Workers/createVectorTilePolygons.js +20 -20
- package/Build/Workers/createVectorTilePolylines.js +13 -13
- package/Build/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +20 -20
- package/Build/Workers/createVerticesFromHeightmap.js +26 -26
- package/Build/Workers/createVerticesFromQuantizedTerrainMesh.js +17 -17
- package/Build/Workers/createWallGeometry.js +22 -22
- package/Build/Workers/createWallOutlineGeometry.js +21 -21
- package/Build/Workers/decodeDraco.js +11 -11
- package/Build/Workers/decodeGoogleEarthEnterprisePacket.js +5 -5
- package/Build/Workers/decodeI3S.js +10 -10
- package/Build/Workers/transcodeKTX2.js +62 -54
- package/Build/Workers/transferTypedArrayTest.js +1 -1
- package/Build/Workers/upsampleQuantizedTerrainMesh.js +20 -20
- package/Source/Renderer/TextureAtlas.js +30 -21
- package/Source/Scene/BillboardTexture.js +99 -12
- package/index.js +46 -46
- package/package.json +1 -1
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
+
* Version 0.0.38
|
|
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
|
+
defaultValue_default
|
|
28
|
+
} from "./chunk-UBCK7AIW.js";
|
|
29
|
+
|
|
30
|
+
// packages/engine/Source/Core/GeometryAttributes.js
|
|
31
|
+
function GeometryAttributes(options) {
|
|
32
|
+
options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT);
|
|
33
|
+
this.position = options.position;
|
|
34
|
+
this.normal = options.normal;
|
|
35
|
+
this.st = options.st;
|
|
36
|
+
this.bitangent = options.bitangent;
|
|
37
|
+
this.tangent = options.tangent;
|
|
38
|
+
this.color = options.color;
|
|
39
|
+
}
|
|
40
|
+
var GeometryAttributes_default = GeometryAttributes;
|
|
41
|
+
|
|
42
|
+
export {
|
|
43
|
+
GeometryAttributes_default
|
|
44
|
+
};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
+
* Version 0.0.38
|
|
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
|
+
defined_default
|
|
28
|
+
} from "./chunk-P76UBIMX.js";
|
|
29
|
+
|
|
30
|
+
// packages/engine/Source/Core/formatError.js
|
|
31
|
+
function formatError(object) {
|
|
32
|
+
let result;
|
|
33
|
+
const name = object.name;
|
|
34
|
+
const message = object.message;
|
|
35
|
+
if (defined_default(name) && defined_default(message)) {
|
|
36
|
+
result = `${name}: ${message}`;
|
|
37
|
+
} else {
|
|
38
|
+
result = object.toString();
|
|
39
|
+
}
|
|
40
|
+
const stack = object.stack;
|
|
41
|
+
if (defined_default(stack)) {
|
|
42
|
+
result += `
|
|
43
|
+
${stack}`;
|
|
44
|
+
}
|
|
45
|
+
return result;
|
|
46
|
+
}
|
|
47
|
+
var formatError_default = formatError;
|
|
48
|
+
|
|
49
|
+
// packages/engine/Source/Workers/createTaskProcessorWorker.js
|
|
50
|
+
function createTaskProcessorWorker(workerFunction) {
|
|
51
|
+
async function onMessageHandler({ data }) {
|
|
52
|
+
const transferableObjects = [];
|
|
53
|
+
const responseMessage = {
|
|
54
|
+
id: data.id,
|
|
55
|
+
result: void 0,
|
|
56
|
+
error: void 0
|
|
57
|
+
};
|
|
58
|
+
self.CESIUM_BASE_URL = data.baseUrl;
|
|
59
|
+
try {
|
|
60
|
+
const result = await workerFunction(data.parameters, transferableObjects);
|
|
61
|
+
responseMessage.result = result;
|
|
62
|
+
} catch (error) {
|
|
63
|
+
if (error instanceof Error) {
|
|
64
|
+
responseMessage.error = {
|
|
65
|
+
name: error.name,
|
|
66
|
+
message: error.message,
|
|
67
|
+
stack: error.stack
|
|
68
|
+
};
|
|
69
|
+
} else {
|
|
70
|
+
responseMessage.error = error;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
if (!data.canTransferArrayBuffer) {
|
|
74
|
+
transferableObjects.length = 0;
|
|
75
|
+
}
|
|
76
|
+
try {
|
|
77
|
+
postMessage(responseMessage, transferableObjects);
|
|
78
|
+
} catch (error) {
|
|
79
|
+
responseMessage.result = void 0;
|
|
80
|
+
responseMessage.error = `postMessage failed with error: ${formatError_default(
|
|
81
|
+
error
|
|
82
|
+
)}
|
|
83
|
+
with responseMessage: ${JSON.stringify(responseMessage)}`;
|
|
84
|
+
postMessage(responseMessage);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function onMessageErrorHandler(event) {
|
|
88
|
+
postMessage({
|
|
89
|
+
id: event.data?.id,
|
|
90
|
+
error: `postMessage failed with error: ${JSON.stringify(event)}`
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
self.onmessage = onMessageHandler;
|
|
94
|
+
self.onmessageerror = onMessageErrorHandler;
|
|
95
|
+
return self;
|
|
96
|
+
}
|
|
97
|
+
var createTaskProcessorWorker_default = createTaskProcessorWorker;
|
|
98
|
+
|
|
99
|
+
export {
|
|
100
|
+
createTaskProcessorWorker_default
|
|
101
|
+
};
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
+
* Version 0.0.37
|
|
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
|
+
GeographicProjection_default
|
|
28
|
+
} from "./chunk-LFYSBTBW.js";
|
|
29
|
+
import {
|
|
30
|
+
Matrix2_default,
|
|
31
|
+
Rectangle_default
|
|
32
|
+
} from "./chunk-X2PKPXPZ.js";
|
|
33
|
+
import {
|
|
34
|
+
Cartesian3_default,
|
|
35
|
+
Cartographic_default,
|
|
36
|
+
Ellipsoid_default
|
|
37
|
+
} from "./chunk-O3PMNFMM.js";
|
|
38
|
+
import {
|
|
39
|
+
Math_default
|
|
40
|
+
} from "./chunk-DVR6JMCT.js";
|
|
41
|
+
import {
|
|
42
|
+
DeveloperError_default
|
|
43
|
+
} from "./chunk-ZQ7S66XP.js";
|
|
44
|
+
import {
|
|
45
|
+
defined_default
|
|
46
|
+
} from "./chunk-5C4JSXR6.js";
|
|
47
|
+
|
|
48
|
+
// packages/engine/Source/Core/RectangleGeometryLibrary.js
|
|
49
|
+
var cos = Math.cos;
|
|
50
|
+
var sin = Math.sin;
|
|
51
|
+
var sqrt = Math.sqrt;
|
|
52
|
+
var RectangleGeometryLibrary = {};
|
|
53
|
+
RectangleGeometryLibrary.computePosition = function(computedOptions, ellipsoid, computeST, row, col, position, st) {
|
|
54
|
+
const radiiSquared = ellipsoid.radiiSquared;
|
|
55
|
+
const nwCorner = computedOptions.nwCorner;
|
|
56
|
+
const rectangle = computedOptions.boundingRectangle;
|
|
57
|
+
let stLatitude = nwCorner.latitude - computedOptions.granYCos * row + col * computedOptions.granXSin;
|
|
58
|
+
const cosLatitude = cos(stLatitude);
|
|
59
|
+
const nZ = sin(stLatitude);
|
|
60
|
+
const kZ = radiiSquared.z * nZ;
|
|
61
|
+
let stLongitude = nwCorner.longitude + row * computedOptions.granYSin + col * computedOptions.granXCos;
|
|
62
|
+
const nX = cosLatitude * cos(stLongitude);
|
|
63
|
+
const nY = cosLatitude * sin(stLongitude);
|
|
64
|
+
const kX = radiiSquared.x * nX;
|
|
65
|
+
const kY = radiiSquared.y * nY;
|
|
66
|
+
const gamma = sqrt(kX * nX + kY * nY + kZ * nZ);
|
|
67
|
+
position.x = kX / gamma;
|
|
68
|
+
position.y = kY / gamma;
|
|
69
|
+
position.z = kZ / gamma;
|
|
70
|
+
if (computeST) {
|
|
71
|
+
const stNwCorner = computedOptions.stNwCorner;
|
|
72
|
+
if (defined_default(stNwCorner)) {
|
|
73
|
+
stLatitude = stNwCorner.latitude - computedOptions.stGranYCos * row + col * computedOptions.stGranXSin;
|
|
74
|
+
stLongitude = stNwCorner.longitude + row * computedOptions.stGranYSin + col * computedOptions.stGranXCos;
|
|
75
|
+
st.x = (stLongitude - computedOptions.stWest) * computedOptions.lonScalar;
|
|
76
|
+
st.y = (stLatitude - computedOptions.stSouth) * computedOptions.latScalar;
|
|
77
|
+
} else {
|
|
78
|
+
st.x = (stLongitude - rectangle.west) * computedOptions.lonScalar;
|
|
79
|
+
st.y = (stLatitude - rectangle.south) * computedOptions.latScalar;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
var rotationMatrixScratch = new Matrix2_default();
|
|
84
|
+
var nwCartesian = new Cartesian3_default();
|
|
85
|
+
var centerScratch = new Cartographic_default();
|
|
86
|
+
var centerCartesian = new Cartesian3_default();
|
|
87
|
+
var proj = new GeographicProjection_default();
|
|
88
|
+
function getRotationOptions(nwCorner, rotation, granularityX, granularityY, center, width, height) {
|
|
89
|
+
const cosRotation = Math.cos(rotation);
|
|
90
|
+
const granYCos = granularityY * cosRotation;
|
|
91
|
+
const granXCos = granularityX * cosRotation;
|
|
92
|
+
const sinRotation = Math.sin(rotation);
|
|
93
|
+
const granYSin = granularityY * sinRotation;
|
|
94
|
+
const granXSin = granularityX * sinRotation;
|
|
95
|
+
proj._ellipsoid = Ellipsoid_default.default;
|
|
96
|
+
nwCartesian = proj.project(nwCorner, nwCartesian);
|
|
97
|
+
nwCartesian = Cartesian3_default.subtract(nwCartesian, centerCartesian, nwCartesian);
|
|
98
|
+
const rotationMatrix = Matrix2_default.fromRotation(rotation, rotationMatrixScratch);
|
|
99
|
+
nwCartesian = Matrix2_default.multiplyByVector(
|
|
100
|
+
rotationMatrix,
|
|
101
|
+
nwCartesian,
|
|
102
|
+
nwCartesian
|
|
103
|
+
);
|
|
104
|
+
nwCartesian = Cartesian3_default.add(nwCartesian, centerCartesian, nwCartesian);
|
|
105
|
+
nwCorner = proj.unproject(nwCartesian, nwCorner);
|
|
106
|
+
width -= 1;
|
|
107
|
+
height -= 1;
|
|
108
|
+
const latitude = nwCorner.latitude;
|
|
109
|
+
const latitude0 = latitude + width * granXSin;
|
|
110
|
+
const latitude1 = latitude - granYCos * height;
|
|
111
|
+
const latitude2 = latitude - granYCos * height + width * granXSin;
|
|
112
|
+
const north = Math.max(latitude, latitude0, latitude1, latitude2);
|
|
113
|
+
const south = Math.min(latitude, latitude0, latitude1, latitude2);
|
|
114
|
+
const longitude = nwCorner.longitude;
|
|
115
|
+
const longitude0 = longitude + width * granXCos;
|
|
116
|
+
const longitude1 = longitude + height * granYSin;
|
|
117
|
+
const longitude2 = longitude + height * granYSin + width * granXCos;
|
|
118
|
+
const east = Math.max(longitude, longitude0, longitude1, longitude2);
|
|
119
|
+
const west = Math.min(longitude, longitude0, longitude1, longitude2);
|
|
120
|
+
return {
|
|
121
|
+
north,
|
|
122
|
+
south,
|
|
123
|
+
east,
|
|
124
|
+
west,
|
|
125
|
+
granYCos,
|
|
126
|
+
granYSin,
|
|
127
|
+
granXCos,
|
|
128
|
+
granXSin,
|
|
129
|
+
nwCorner
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
RectangleGeometryLibrary.computeOptions = function(rectangle, granularity, rotation, stRotation, boundingRectangleScratch, nwCornerResult, stNwCornerResult) {
|
|
133
|
+
let east = rectangle.east;
|
|
134
|
+
let west = rectangle.west;
|
|
135
|
+
let north = rectangle.north;
|
|
136
|
+
let south = rectangle.south;
|
|
137
|
+
let northCap = false;
|
|
138
|
+
let southCap = false;
|
|
139
|
+
if (north === Math_default.PI_OVER_TWO) {
|
|
140
|
+
northCap = true;
|
|
141
|
+
}
|
|
142
|
+
if (south === -Math_default.PI_OVER_TWO) {
|
|
143
|
+
southCap = true;
|
|
144
|
+
}
|
|
145
|
+
let dx;
|
|
146
|
+
const dy = north - south;
|
|
147
|
+
if (west > east) {
|
|
148
|
+
dx = Math_default.TWO_PI - west + east;
|
|
149
|
+
} else {
|
|
150
|
+
dx = east - west;
|
|
151
|
+
}
|
|
152
|
+
const width = Math.ceil(dx / granularity) + 1;
|
|
153
|
+
const height = Math.ceil(dy / granularity) + 1;
|
|
154
|
+
const granularityX = dx / (width - 1);
|
|
155
|
+
const granularityY = dy / (height - 1);
|
|
156
|
+
const nwCorner = Rectangle_default.northwest(rectangle, nwCornerResult);
|
|
157
|
+
const center = Rectangle_default.center(rectangle, centerScratch);
|
|
158
|
+
if (rotation !== 0 || stRotation !== 0) {
|
|
159
|
+
if (center.longitude < nwCorner.longitude) {
|
|
160
|
+
center.longitude += Math_default.TWO_PI;
|
|
161
|
+
}
|
|
162
|
+
proj._ellipsoid = Ellipsoid_default.default;
|
|
163
|
+
centerCartesian = proj.project(center, centerCartesian);
|
|
164
|
+
}
|
|
165
|
+
const granYCos = granularityY;
|
|
166
|
+
const granXCos = granularityX;
|
|
167
|
+
const granYSin = 0;
|
|
168
|
+
const granXSin = 0;
|
|
169
|
+
const boundingRectangle = Rectangle_default.clone(
|
|
170
|
+
rectangle,
|
|
171
|
+
boundingRectangleScratch
|
|
172
|
+
);
|
|
173
|
+
const computedOptions = {
|
|
174
|
+
granYCos,
|
|
175
|
+
granYSin,
|
|
176
|
+
granXCos,
|
|
177
|
+
granXSin,
|
|
178
|
+
nwCorner,
|
|
179
|
+
boundingRectangle,
|
|
180
|
+
width,
|
|
181
|
+
height,
|
|
182
|
+
northCap,
|
|
183
|
+
southCap
|
|
184
|
+
};
|
|
185
|
+
if (rotation !== 0) {
|
|
186
|
+
const rotationOptions = getRotationOptions(
|
|
187
|
+
nwCorner,
|
|
188
|
+
rotation,
|
|
189
|
+
granularityX,
|
|
190
|
+
granularityY,
|
|
191
|
+
center,
|
|
192
|
+
width,
|
|
193
|
+
height
|
|
194
|
+
);
|
|
195
|
+
north = rotationOptions.north;
|
|
196
|
+
south = rotationOptions.south;
|
|
197
|
+
east = rotationOptions.east;
|
|
198
|
+
west = rotationOptions.west;
|
|
199
|
+
if (north < -Math_default.PI_OVER_TWO || north > Math_default.PI_OVER_TWO || south < -Math_default.PI_OVER_TWO || south > Math_default.PI_OVER_TWO) {
|
|
200
|
+
throw new DeveloperError_default(
|
|
201
|
+
"Rotated rectangle is invalid. It crosses over either the north or south pole."
|
|
202
|
+
);
|
|
203
|
+
}
|
|
204
|
+
computedOptions.granYCos = rotationOptions.granYCos;
|
|
205
|
+
computedOptions.granYSin = rotationOptions.granYSin;
|
|
206
|
+
computedOptions.granXCos = rotationOptions.granXCos;
|
|
207
|
+
computedOptions.granXSin = rotationOptions.granXSin;
|
|
208
|
+
boundingRectangle.north = north;
|
|
209
|
+
boundingRectangle.south = south;
|
|
210
|
+
boundingRectangle.east = east;
|
|
211
|
+
boundingRectangle.west = west;
|
|
212
|
+
}
|
|
213
|
+
if (stRotation !== 0) {
|
|
214
|
+
rotation = rotation - stRotation;
|
|
215
|
+
const stNwCorner = Rectangle_default.northwest(boundingRectangle, stNwCornerResult);
|
|
216
|
+
const stRotationOptions = getRotationOptions(
|
|
217
|
+
stNwCorner,
|
|
218
|
+
rotation,
|
|
219
|
+
granularityX,
|
|
220
|
+
granularityY,
|
|
221
|
+
center,
|
|
222
|
+
width,
|
|
223
|
+
height
|
|
224
|
+
);
|
|
225
|
+
computedOptions.stGranYCos = stRotationOptions.granYCos;
|
|
226
|
+
computedOptions.stGranXCos = stRotationOptions.granXCos;
|
|
227
|
+
computedOptions.stGranYSin = stRotationOptions.granYSin;
|
|
228
|
+
computedOptions.stGranXSin = stRotationOptions.granXSin;
|
|
229
|
+
computedOptions.stNwCorner = stNwCorner;
|
|
230
|
+
computedOptions.stWest = stRotationOptions.west;
|
|
231
|
+
computedOptions.stSouth = stRotationOptions.south;
|
|
232
|
+
}
|
|
233
|
+
return computedOptions;
|
|
234
|
+
};
|
|
235
|
+
var RectangleGeometryLibrary_default = RectangleGeometryLibrary;
|
|
236
|
+
|
|
237
|
+
export {
|
|
238
|
+
RectangleGeometryLibrary_default
|
|
239
|
+
};
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
+
* Version 0.0.38
|
|
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
|
+
PolylinePipeline_default
|
|
28
|
+
} from "./chunk-SS4SBY5P.js";
|
|
29
|
+
import {
|
|
30
|
+
arrayRemoveDuplicates_default
|
|
31
|
+
} from "./chunk-FL4PAMOR.js";
|
|
32
|
+
import {
|
|
33
|
+
Cartesian3_default,
|
|
34
|
+
Cartographic_default
|
|
35
|
+
} from "./chunk-ZPEGWBIN.js";
|
|
36
|
+
import {
|
|
37
|
+
Math_default
|
|
38
|
+
} from "./chunk-OGSJ5ZP6.js";
|
|
39
|
+
import {
|
|
40
|
+
defined_default
|
|
41
|
+
} from "./chunk-P76UBIMX.js";
|
|
42
|
+
|
|
43
|
+
// packages/engine/Source/Core/WallGeometryLibrary.js
|
|
44
|
+
var WallGeometryLibrary = {};
|
|
45
|
+
function latLonEquals(c0, c1) {
|
|
46
|
+
return Math_default.equalsEpsilon(c0.latitude, c1.latitude, Math_default.EPSILON10) && Math_default.equalsEpsilon(c0.longitude, c1.longitude, Math_default.EPSILON10);
|
|
47
|
+
}
|
|
48
|
+
var scratchCartographic1 = new Cartographic_default();
|
|
49
|
+
var scratchCartographic2 = new Cartographic_default();
|
|
50
|
+
function removeDuplicates(ellipsoid, positions, topHeights, bottomHeights) {
|
|
51
|
+
positions = arrayRemoveDuplicates_default(positions, Cartesian3_default.equalsEpsilon);
|
|
52
|
+
const length = positions.length;
|
|
53
|
+
if (length < 2) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
const hasBottomHeights = defined_default(bottomHeights);
|
|
57
|
+
const hasTopHeights = defined_default(topHeights);
|
|
58
|
+
const cleanedPositions = new Array(length);
|
|
59
|
+
const cleanedTopHeights = new Array(length);
|
|
60
|
+
const cleanedBottomHeights = new Array(length);
|
|
61
|
+
const v0 = positions[0];
|
|
62
|
+
cleanedPositions[0] = v0;
|
|
63
|
+
const c0 = ellipsoid.cartesianToCartographic(v0, scratchCartographic1);
|
|
64
|
+
if (hasTopHeights) {
|
|
65
|
+
c0.height = topHeights[0];
|
|
66
|
+
}
|
|
67
|
+
cleanedTopHeights[0] = c0.height;
|
|
68
|
+
if (hasBottomHeights) {
|
|
69
|
+
cleanedBottomHeights[0] = bottomHeights[0];
|
|
70
|
+
} else {
|
|
71
|
+
cleanedBottomHeights[0] = 0;
|
|
72
|
+
}
|
|
73
|
+
const startTopHeight = cleanedTopHeights[0];
|
|
74
|
+
const startBottomHeight = cleanedBottomHeights[0];
|
|
75
|
+
let hasAllSameHeights = startTopHeight === startBottomHeight;
|
|
76
|
+
let index = 1;
|
|
77
|
+
for (let i = 1; i < length; ++i) {
|
|
78
|
+
const v1 = positions[i];
|
|
79
|
+
const c1 = ellipsoid.cartesianToCartographic(v1, scratchCartographic2);
|
|
80
|
+
if (hasTopHeights) {
|
|
81
|
+
c1.height = topHeights[i];
|
|
82
|
+
}
|
|
83
|
+
hasAllSameHeights = hasAllSameHeights && c1.height === 0;
|
|
84
|
+
if (!latLonEquals(c0, c1)) {
|
|
85
|
+
cleanedPositions[index] = v1;
|
|
86
|
+
cleanedTopHeights[index] = c1.height;
|
|
87
|
+
if (hasBottomHeights) {
|
|
88
|
+
cleanedBottomHeights[index] = bottomHeights[i];
|
|
89
|
+
} else {
|
|
90
|
+
cleanedBottomHeights[index] = 0;
|
|
91
|
+
}
|
|
92
|
+
hasAllSameHeights = hasAllSameHeights && cleanedTopHeights[index] === cleanedBottomHeights[index];
|
|
93
|
+
Cartographic_default.clone(c1, c0);
|
|
94
|
+
++index;
|
|
95
|
+
} else if (c0.height < c1.height) {
|
|
96
|
+
cleanedTopHeights[index - 1] = c1.height;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (hasAllSameHeights || index < 2) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
cleanedPositions.length = index;
|
|
103
|
+
cleanedTopHeights.length = index;
|
|
104
|
+
cleanedBottomHeights.length = index;
|
|
105
|
+
return {
|
|
106
|
+
positions: cleanedPositions,
|
|
107
|
+
topHeights: cleanedTopHeights,
|
|
108
|
+
bottomHeights: cleanedBottomHeights
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
var positionsArrayScratch = new Array(2);
|
|
112
|
+
var heightsArrayScratch = new Array(2);
|
|
113
|
+
var generateArcOptionsScratch = {
|
|
114
|
+
positions: void 0,
|
|
115
|
+
height: void 0,
|
|
116
|
+
granularity: void 0,
|
|
117
|
+
ellipsoid: void 0
|
|
118
|
+
};
|
|
119
|
+
WallGeometryLibrary.computePositions = function(ellipsoid, wallPositions, maximumHeights, minimumHeights, granularity, duplicateCorners) {
|
|
120
|
+
const o = removeDuplicates(
|
|
121
|
+
ellipsoid,
|
|
122
|
+
wallPositions,
|
|
123
|
+
maximumHeights,
|
|
124
|
+
minimumHeights
|
|
125
|
+
);
|
|
126
|
+
if (!defined_default(o)) {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
wallPositions = o.positions;
|
|
130
|
+
maximumHeights = o.topHeights;
|
|
131
|
+
minimumHeights = o.bottomHeights;
|
|
132
|
+
const length = wallPositions.length;
|
|
133
|
+
const numCorners = length - 2;
|
|
134
|
+
let topPositions;
|
|
135
|
+
let bottomPositions;
|
|
136
|
+
const minDistance = Math_default.chordLength(
|
|
137
|
+
granularity,
|
|
138
|
+
ellipsoid.maximumRadius
|
|
139
|
+
);
|
|
140
|
+
const generateArcOptions = generateArcOptionsScratch;
|
|
141
|
+
generateArcOptions.minDistance = minDistance;
|
|
142
|
+
generateArcOptions.ellipsoid = ellipsoid;
|
|
143
|
+
if (duplicateCorners) {
|
|
144
|
+
let count = 0;
|
|
145
|
+
let i;
|
|
146
|
+
for (i = 0; i < length - 1; i++) {
|
|
147
|
+
count += PolylinePipeline_default.numberOfPoints(
|
|
148
|
+
wallPositions[i],
|
|
149
|
+
wallPositions[i + 1],
|
|
150
|
+
minDistance
|
|
151
|
+
) + 1;
|
|
152
|
+
}
|
|
153
|
+
topPositions = new Float64Array(count * 3);
|
|
154
|
+
bottomPositions = new Float64Array(count * 3);
|
|
155
|
+
const generateArcPositions = positionsArrayScratch;
|
|
156
|
+
const generateArcHeights = heightsArrayScratch;
|
|
157
|
+
generateArcOptions.positions = generateArcPositions;
|
|
158
|
+
generateArcOptions.height = generateArcHeights;
|
|
159
|
+
let offset = 0;
|
|
160
|
+
for (i = 0; i < length - 1; i++) {
|
|
161
|
+
generateArcPositions[0] = wallPositions[i];
|
|
162
|
+
generateArcPositions[1] = wallPositions[i + 1];
|
|
163
|
+
generateArcHeights[0] = maximumHeights[i];
|
|
164
|
+
generateArcHeights[1] = maximumHeights[i + 1];
|
|
165
|
+
const pos = PolylinePipeline_default.generateArc(generateArcOptions);
|
|
166
|
+
topPositions.set(pos, offset);
|
|
167
|
+
generateArcHeights[0] = minimumHeights[i];
|
|
168
|
+
generateArcHeights[1] = minimumHeights[i + 1];
|
|
169
|
+
bottomPositions.set(
|
|
170
|
+
PolylinePipeline_default.generateArc(generateArcOptions),
|
|
171
|
+
offset
|
|
172
|
+
);
|
|
173
|
+
offset += pos.length;
|
|
174
|
+
}
|
|
175
|
+
} else {
|
|
176
|
+
generateArcOptions.positions = wallPositions;
|
|
177
|
+
generateArcOptions.height = maximumHeights;
|
|
178
|
+
topPositions = new Float64Array(
|
|
179
|
+
PolylinePipeline_default.generateArc(generateArcOptions)
|
|
180
|
+
);
|
|
181
|
+
generateArcOptions.height = minimumHeights;
|
|
182
|
+
bottomPositions = new Float64Array(
|
|
183
|
+
PolylinePipeline_default.generateArc(generateArcOptions)
|
|
184
|
+
);
|
|
185
|
+
}
|
|
186
|
+
return {
|
|
187
|
+
bottomPositions,
|
|
188
|
+
topPositions,
|
|
189
|
+
numCorners
|
|
190
|
+
};
|
|
191
|
+
};
|
|
192
|
+
var WallGeometryLibrary_default = WallGeometryLibrary;
|
|
193
|
+
|
|
194
|
+
export {
|
|
195
|
+
WallGeometryLibrary_default
|
|
196
|
+
};
|