@pggis/pg-sdk 3.3.9 → 3.5.0
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/README.md +8 -8
- package/dist/index.js +1966 -4
- package/dist/pggis.min.css +1 -1
- package/dist/resources/ThirdParty/Workers/pako_deflate.min.js +1 -2
- package/dist/resources/ThirdParty/Workers/pako_inflate.min.js +1 -2
- package/dist/resources/ThirdParty/Workers/z-worker-pako.js +1 -1
- package/dist/resources/ThirdParty/google-earth-dbroot-parser.js +1 -8337
- package/dist/resources/ThirdParty/wasm_splats_bg.wasm +0 -0
- package/dist/resources/Workers/chunk-35SHYARM.js +26 -0
- package/dist/resources/Workers/chunk-37F5JSTI.js +26 -0
- package/dist/resources/Workers/chunk-3SSKC3VN.js +26 -0
- package/dist/resources/Workers/chunk-3W4GT7KQ.js +26 -0
- package/dist/resources/Workers/chunk-4IW2T6GF.js +26 -0
- package/dist/resources/Workers/chunk-5YEWO3HT.js +26 -0
- package/dist/resources/Workers/chunk-64RSHJUE.js +28 -0
- package/dist/resources/Workers/chunk-77IHZJJ3.js +26 -0
- package/dist/resources/Workers/chunk-7HTKERZY.js +26 -0
- package/dist/resources/Workers/{chunk-F3YA3Y2Z.js → chunk-A56XVLQR.js} +2 -13
- package/dist/resources/Workers/chunk-AJYK4IVJ.js +26 -0
- package/dist/resources/Workers/{chunk-EHWHNOEX.js → chunk-ARG42DC4.js} +2 -31
- package/dist/resources/Workers/chunk-AU7IKHOH.js +26 -0
- package/dist/resources/Workers/chunk-B4AA3ARO.js +26 -0
- package/dist/resources/Workers/chunk-CNCV5UL7.js +26 -0
- package/dist/resources/Workers/chunk-CYCB63OH.js +26 -0
- package/dist/resources/Workers/{chunk-4H7PY4U5.js → chunk-D6AA5QVT.js} +2 -20
- package/dist/resources/Workers/chunk-D6C66QON.js +26 -0
- package/dist/resources/Workers/chunk-DEPHB2WM.js +26 -0
- package/dist/resources/Workers/chunk-DMEY62ID.js +26 -0
- package/dist/resources/Workers/chunk-DQQ63PYM.js +26 -0
- package/dist/resources/Workers/chunk-ED5JPB3S.js +27 -0
- package/dist/resources/Workers/chunk-EZUYS2JF.js +26 -0
- package/dist/resources/Workers/chunk-FEVXJ54I.js +26 -0
- package/dist/resources/Workers/chunk-G5AGHVVC.js +26 -0
- package/dist/resources/Workers/{chunk-BBWDMCVU.js → chunk-GBYLG25F.js} +2 -15
- package/dist/resources/Workers/chunk-GILIDQNQ.js +26 -0
- package/dist/resources/Workers/chunk-HMIYSTF6.js +26 -0
- package/dist/resources/Workers/chunk-HTFSEEMT.js +26 -0
- package/dist/resources/Workers/chunk-HWXX4CWK.js +26 -0
- package/dist/resources/Workers/chunk-IYTZ52EY.js +26 -0
- package/dist/resources/Workers/chunk-J6UP6FLE.js +26 -0
- package/dist/resources/Workers/chunk-LEYMRMBK.js +27 -0
- package/dist/resources/Workers/chunk-M3MGYQSL.js +26 -0
- package/dist/resources/Workers/chunk-N4VJKXZS.js +26 -0
- package/dist/resources/Workers/chunk-NB3ML6JO.js +26 -0
- package/dist/resources/Workers/chunk-OFUUQVMR.js +26 -0
- package/dist/resources/Workers/chunk-OSW76XDF.js +26 -0
- package/dist/resources/Workers/chunk-PSPPBZWI.js +66 -0
- package/dist/resources/Workers/chunk-QN3VOORQ.js +26 -0
- package/dist/resources/Workers/chunk-QOUAJ6TL.js +26 -0
- package/dist/resources/Workers/chunk-RCV6KWXS.js +26 -0
- package/dist/resources/Workers/chunk-TCGIRNHN.js +26 -0
- package/dist/resources/Workers/chunk-U4IEOH5K.js +26 -0
- package/dist/resources/Workers/chunk-UP6I5URU.js +26 -0
- package/dist/resources/Workers/chunk-VTAIKJXX.js +26 -0
- package/dist/resources/Workers/chunk-VTBDSFTG.js +26 -0
- package/dist/resources/Workers/chunk-VW6VD53G.js +26 -0
- package/dist/resources/Workers/chunk-WGGIH7QW.js +26 -0
- package/dist/resources/Workers/chunk-WWA5PL4H.js +26 -0
- package/dist/resources/Workers/chunk-WZDE3RYP.js +28 -0
- package/dist/resources/Workers/chunk-XRL4AVS5.js +26 -0
- package/dist/resources/Workers/combineGeometry.js +2 -44
- package/dist/resources/Workers/createBoxGeometry.js +2 -34
- package/dist/resources/Workers/createBoxOutlineGeometry.js +2 -211
- package/dist/resources/Workers/createCircleGeometry.js +2 -173
- package/dist/resources/Workers/createCircleOutlineGeometry.js +2 -123
- package/dist/resources/Workers/createCoplanarPolygonGeometry.js +2 -482
- package/dist/resources/Workers/createCoplanarPolygonOutlineGeometry.js +2 -201
- package/dist/resources/Workers/createCorridorGeometry.js +2 -1239
- package/dist/resources/Workers/createCorridorOutlineGeometry.js +2 -544
- package/dist/resources/Workers/createCylinderGeometry.js +2 -36
- package/dist/resources/Workers/createCylinderOutlineGeometry.js +2 -207
- package/dist/resources/Workers/createEllipseGeometry.js +2 -47
- package/dist/resources/Workers/createEllipseOutlineGeometry.js +2 -40
- package/dist/resources/Workers/createEllipsoidGeometry.js +2 -35
- package/dist/resources/Workers/createEllipsoidOutlineGeometry.js +2 -37
- package/dist/resources/Workers/createFrustumGeometry.js +2 -34
- package/dist/resources/Workers/createFrustumOutlineGeometry.js +2 -211
- package/dist/resources/Workers/createGeometry.js +2 -147
- package/dist/resources/Workers/createGroundPolylineGeometry.js +2 -1584
- package/dist/resources/Workers/createPlaneGeometry.js +2 -200
- package/dist/resources/Workers/createPlaneOutlineGeometry.js +2 -100
- package/dist/resources/Workers/createPolygonGeometry.js +2 -1387
- package/dist/resources/Workers/createPolygonOutlineGeometry.js +2 -519
- package/dist/resources/Workers/createPolylineGeometry.js +2 -472
- package/dist/resources/Workers/createPolylineVolumeGeometry.js +2 -355
- package/dist/resources/Workers/createPolylineVolumeOutlineGeometry.js +2 -253
- package/dist/resources/Workers/createRectangleGeometry.js +2 -1250
- package/dist/resources/Workers/createRectangleOutlineGeometry.js +2 -455
- package/dist/resources/Workers/createSimplePolylineGeometry.js +2 -376
- package/dist/resources/Workers/createSphereGeometry.js +2 -94
- package/dist/resources/Workers/createSphereOutlineGeometry.js +2 -94
- package/dist/resources/Workers/createTaskProcessorWorker.js +2 -8
- package/dist/resources/Workers/createVectorTileClampedPolylines.js +2 -468
- package/dist/resources/Workers/createVectorTileGeometries.js +2 -363
- package/dist/resources/Workers/createVectorTilePoints.js +2 -88
- package/dist/resources/Workers/createVectorTilePolygons.js +2 -361
- package/dist/resources/Workers/createVectorTilePolylines.js +2 -238
- package/dist/resources/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +2 -545
- package/dist/resources/Workers/createVerticesFromHeightmap.js +2 -2254
- package/dist/resources/Workers/createVerticesFromQuantizedTerrainMesh.js +2 -722
- package/dist/resources/Workers/createWallGeometry.js +2 -466
- package/dist/resources/Workers/createWallOutlineGeometry.js +2 -314
- package/dist/resources/Workers/decodeDraco.js +2 -345
- package/dist/resources/Workers/decodeGoogleEarthEnterprisePacket.js +2 -2626
- package/dist/resources/Workers/decodeI3S.js +2 -1320
- package/dist/resources/Workers/gaussianSplatSorter.js +26 -0
- package/dist/resources/Workers/gaussianSplatTextureGenerator.js +26 -0
- package/dist/resources/Workers/transcodeKTX2.js +29 -3398
- package/dist/resources/Workers/transferTypedArrayTest.js +2 -17
- package/dist/resources/Workers/upsampleQuantizedTerrainMesh.js +2 -795
- package/package.json +9 -8
- package/dist/pggis.min.js +0 -14796
- package/dist/resources/ThirdParty/Workers/basis_transcoder.js +0 -21
- package/dist/resources/Workers/chunk-23UFSGND.js +0 -236
- package/dist/resources/Workers/chunk-2A75IWRS.js +0 -218
- package/dist/resources/Workers/chunk-2FRVPMCS.js +0 -1258
- package/dist/resources/Workers/chunk-2FWRMUTY.js +0 -138
- package/dist/resources/Workers/chunk-2UPKWTMJ.js +0 -117
- package/dist/resources/Workers/chunk-34FXV7D7.js +0 -73
- package/dist/resources/Workers/chunk-3VAZEH7M.js +0 -101
- package/dist/resources/Workers/chunk-4DO5W5XZ.js +0 -196
- package/dist/resources/Workers/chunk-5QULIR53.js +0 -501
- package/dist/resources/Workers/chunk-7TC63SJW.js +0 -302
- package/dist/resources/Workers/chunk-7ZFGPDJA.js +0 -122
- package/dist/resources/Workers/chunk-A5DWLWCY.js +0 -834
- package/dist/resources/Workers/chunk-BG4UCVXN.js +0 -73
- package/dist/resources/Workers/chunk-BIKA3NRA.js +0 -59
- package/dist/resources/Workers/chunk-BROJAZRZ.js +0 -390
- package/dist/resources/Workers/chunk-DDUQAJ4P.js +0 -476
- package/dist/resources/Workers/chunk-EERJKOAF.js +0 -305
- package/dist/resources/Workers/chunk-EG6PTBY2.js +0 -2716
- package/dist/resources/Workers/chunk-F4HFJMGM.js +0 -353
- package/dist/resources/Workers/chunk-FJKNFAKQ.js +0 -8219
- package/dist/resources/Workers/chunk-FNIRWHJB.js +0 -289
- package/dist/resources/Workers/chunk-FZRIVR7Y.js +0 -100
- package/dist/resources/Workers/chunk-G43QFN4Q.js +0 -157
- package/dist/resources/Workers/chunk-GATZHF3K.js +0 -1860
- package/dist/resources/Workers/chunk-GRC2ZTAF.js +0 -398
- package/dist/resources/Workers/chunk-HU6N6EXB.js +0 -767
- package/dist/resources/Workers/chunk-I46ZRR5W.js +0 -1052
- package/dist/resources/Workers/chunk-JURN7NPV.js +0 -1075
- package/dist/resources/Workers/chunk-KKCR2YOP.js +0 -421
- package/dist/resources/Workers/chunk-LPR3YNP2.js +0 -138
- package/dist/resources/Workers/chunk-M7ERACJJ.js +0 -511
- package/dist/resources/Workers/chunk-MDWEGWPA.js +0 -1007
- package/dist/resources/Workers/chunk-OGXZVPPM.js +0 -2365
- package/dist/resources/Workers/chunk-PGSJK77E.js +0 -634
- package/dist/resources/Workers/chunk-PPH7OFP3.js +0 -258
- package/dist/resources/Workers/chunk-SH5USDPI.js +0 -456
- package/dist/resources/Workers/chunk-SOWMRMWA.js +0 -629
- package/dist/resources/Workers/chunk-STW2DGFI.js +0 -58
- package/dist/resources/Workers/chunk-T3XIFPYR.js +0 -1477
- package/dist/resources/Workers/chunk-TTUZP4BO.js +0 -501
- package/dist/resources/Workers/chunk-UEXTBDBE.js +0 -693
- package/dist/resources/Workers/chunk-VOXYEYJT.js +0 -684
- package/dist/resources/Workers/chunk-X4356LRH.js +0 -368
- package/dist/resources/Workers/chunk-XGI5BXZY.js +0 -163
- package/dist/resources/Workers/chunk-Y2ME2IJV.js +0 -781
- package/dist/resources/Workers/chunk-Y5UQJLYE.js +0 -171
- package/dist/resources/Workers/chunk-YJEBABKH.js +0 -2977
- package/dist/resources/Workers/chunk-YWTJ2B4B.js +0 -77
- package/dist/resources/Workers/chunk-Z3TIFFGF.js +0 -430
- package/dist/resources/Workers/chunk-ZT7KWISZ.js +0 -102
|
@@ -1,693 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
-
* Version 1.115
|
|
5
|
-
*
|
|
6
|
-
* Copyright 2011-2022 Cesium Contributors
|
|
7
|
-
*
|
|
8
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
9
|
-
* you may not use this file except in compliance with the License.
|
|
10
|
-
* You may obtain a copy of the License at
|
|
11
|
-
*
|
|
12
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
13
|
-
*
|
|
14
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
15
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
16
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
17
|
-
* See the License for the specific language governing permissions and
|
|
18
|
-
* limitations under the License.
|
|
19
|
-
*
|
|
20
|
-
* Columbus View (Pat. Pend.)
|
|
21
|
-
*
|
|
22
|
-
* Portions licensed separately.
|
|
23
|
-
* See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details.
|
|
24
|
-
*/
|
|
25
|
-
|
|
26
|
-
import {
|
|
27
|
-
PolylinePipeline_default
|
|
28
|
-
} from "./chunk-KKCR2YOP.js";
|
|
29
|
-
import {
|
|
30
|
-
EllipsoidTangentPlane_default
|
|
31
|
-
} from "./chunk-FNIRWHJB.js";
|
|
32
|
-
import {
|
|
33
|
-
Quaternion_default,
|
|
34
|
-
Transforms_default
|
|
35
|
-
} from "./chunk-FJKNFAKQ.js";
|
|
36
|
-
import {
|
|
37
|
-
Cartesian4_default,
|
|
38
|
-
Matrix4_default
|
|
39
|
-
} from "./chunk-YJEBABKH.js";
|
|
40
|
-
import {
|
|
41
|
-
Cartesian2_default,
|
|
42
|
-
Cartesian3_default,
|
|
43
|
-
Cartographic_default,
|
|
44
|
-
Matrix3_default
|
|
45
|
-
} from "./chunk-OGXZVPPM.js";
|
|
46
|
-
import {
|
|
47
|
-
Math_default
|
|
48
|
-
} from "./chunk-5QULIR53.js";
|
|
49
|
-
import {
|
|
50
|
-
defaultValue_default
|
|
51
|
-
} from "./chunk-BBWDMCVU.js";
|
|
52
|
-
import {
|
|
53
|
-
DeveloperError_default
|
|
54
|
-
} from "./chunk-XGI5BXZY.js";
|
|
55
|
-
import {
|
|
56
|
-
defined_default
|
|
57
|
-
} from "./chunk-YWTJ2B4B.js";
|
|
58
|
-
|
|
59
|
-
// packages/engine/Source/Core/CornerType.js
|
|
60
|
-
var CornerType = {
|
|
61
|
-
/**
|
|
62
|
-
* <img src="Images/CornerTypeRounded.png" style="vertical-align: middle;" width="186" height="189" />
|
|
63
|
-
*
|
|
64
|
-
* Corner has a smooth edge.
|
|
65
|
-
* @type {number}
|
|
66
|
-
* @constant
|
|
67
|
-
*/
|
|
68
|
-
ROUNDED: 0,
|
|
69
|
-
/**
|
|
70
|
-
* <img src="Images/CornerTypeMitered.png" style="vertical-align: middle;" width="186" height="189" />
|
|
71
|
-
*
|
|
72
|
-
* Corner point is the intersection of adjacent edges.
|
|
73
|
-
* @type {number}
|
|
74
|
-
* @constant
|
|
75
|
-
*/
|
|
76
|
-
MITERED: 1,
|
|
77
|
-
/**
|
|
78
|
-
* <img src="Images/CornerTypeBeveled.png" style="vertical-align: middle;" width="186" height="189" />
|
|
79
|
-
*
|
|
80
|
-
* Corner is clipped.
|
|
81
|
-
* @type {number}
|
|
82
|
-
* @constant
|
|
83
|
-
*/
|
|
84
|
-
BEVELED: 2
|
|
85
|
-
};
|
|
86
|
-
var CornerType_default = Object.freeze(CornerType);
|
|
87
|
-
|
|
88
|
-
// packages/engine/Source/Core/oneTimeWarning.js
|
|
89
|
-
var warnings = {};
|
|
90
|
-
function oneTimeWarning(identifier, message) {
|
|
91
|
-
if (!defined_default(identifier)) {
|
|
92
|
-
throw new DeveloperError_default("identifier is required.");
|
|
93
|
-
}
|
|
94
|
-
if (!defined_default(warnings[identifier])) {
|
|
95
|
-
warnings[identifier] = true;
|
|
96
|
-
console.warn(defaultValue_default(message, identifier));
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
oneTimeWarning.geometryOutlines = "Entity geometry outlines are unsupported on terrain. Outlines will be disabled. To enable outlines, disable geometry terrain clamping by explicitly setting height to 0.";
|
|
100
|
-
oneTimeWarning.geometryZIndex = "Entity geometry with zIndex are unsupported when height or extrudedHeight are defined. zIndex will be ignored";
|
|
101
|
-
oneTimeWarning.geometryHeightReference = "Entity corridor, ellipse, polygon or rectangle with heightReference must also have a defined height. heightReference will be ignored";
|
|
102
|
-
oneTimeWarning.geometryExtrudedHeightReference = "Entity corridor, ellipse, polygon or rectangle with extrudedHeightReference must also have a defined extrudedHeight. extrudedHeightReference will be ignored";
|
|
103
|
-
var oneTimeWarning_default = oneTimeWarning;
|
|
104
|
-
|
|
105
|
-
// packages/engine/Source/Core/PolylineVolumeGeometryLibrary.js
|
|
106
|
-
var scratch2Array = [new Cartesian3_default(), new Cartesian3_default()];
|
|
107
|
-
var scratchCartesian1 = new Cartesian3_default();
|
|
108
|
-
var scratchCartesian2 = new Cartesian3_default();
|
|
109
|
-
var scratchCartesian3 = new Cartesian3_default();
|
|
110
|
-
var scratchCartesian4 = new Cartesian3_default();
|
|
111
|
-
var scratchCartesian5 = new Cartesian3_default();
|
|
112
|
-
var scratchCartesian6 = new Cartesian3_default();
|
|
113
|
-
var scratchCartesian7 = new Cartesian3_default();
|
|
114
|
-
var scratchCartesian8 = new Cartesian3_default();
|
|
115
|
-
var scratchCartesian9 = new Cartesian3_default();
|
|
116
|
-
var scratch1 = new Cartesian3_default();
|
|
117
|
-
var scratch2 = new Cartesian3_default();
|
|
118
|
-
var PolylineVolumeGeometryLibrary = {};
|
|
119
|
-
var cartographic = new Cartographic_default();
|
|
120
|
-
function scaleToSurface(positions, ellipsoid) {
|
|
121
|
-
const heights = new Array(positions.length);
|
|
122
|
-
for (let i = 0; i < positions.length; i++) {
|
|
123
|
-
const pos = positions[i];
|
|
124
|
-
cartographic = ellipsoid.cartesianToCartographic(pos, cartographic);
|
|
125
|
-
heights[i] = cartographic.height;
|
|
126
|
-
positions[i] = ellipsoid.scaleToGeodeticSurface(pos, pos);
|
|
127
|
-
}
|
|
128
|
-
return heights;
|
|
129
|
-
}
|
|
130
|
-
function subdivideHeights(points, h0, h1, granularity) {
|
|
131
|
-
const p0 = points[0];
|
|
132
|
-
const p1 = points[1];
|
|
133
|
-
const angleBetween = Cartesian3_default.angleBetween(p0, p1);
|
|
134
|
-
const numPoints = Math.ceil(angleBetween / granularity);
|
|
135
|
-
const heights = new Array(numPoints);
|
|
136
|
-
let i;
|
|
137
|
-
if (h0 === h1) {
|
|
138
|
-
for (i = 0; i < numPoints; i++) {
|
|
139
|
-
heights[i] = h0;
|
|
140
|
-
}
|
|
141
|
-
heights.push(h1);
|
|
142
|
-
return heights;
|
|
143
|
-
}
|
|
144
|
-
const dHeight = h1 - h0;
|
|
145
|
-
const heightPerVertex = dHeight / numPoints;
|
|
146
|
-
for (i = 1; i < numPoints; i++) {
|
|
147
|
-
const h = h0 + i * heightPerVertex;
|
|
148
|
-
heights[i] = h;
|
|
149
|
-
}
|
|
150
|
-
heights[0] = h0;
|
|
151
|
-
heights.push(h1);
|
|
152
|
-
return heights;
|
|
153
|
-
}
|
|
154
|
-
var nextScratch = new Cartesian3_default();
|
|
155
|
-
var prevScratch = new Cartesian3_default();
|
|
156
|
-
function computeRotationAngle(start, end, position, ellipsoid) {
|
|
157
|
-
const tangentPlane = new EllipsoidTangentPlane_default(position, ellipsoid);
|
|
158
|
-
const next = tangentPlane.projectPointOntoPlane(
|
|
159
|
-
Cartesian3_default.add(position, start, nextScratch),
|
|
160
|
-
nextScratch
|
|
161
|
-
);
|
|
162
|
-
const prev = tangentPlane.projectPointOntoPlane(
|
|
163
|
-
Cartesian3_default.add(position, end, prevScratch),
|
|
164
|
-
prevScratch
|
|
165
|
-
);
|
|
166
|
-
const angle = Cartesian2_default.angleBetween(next, prev);
|
|
167
|
-
return prev.x * next.y - prev.y * next.x >= 0 ? -angle : angle;
|
|
168
|
-
}
|
|
169
|
-
var negativeX = new Cartesian3_default(-1, 0, 0);
|
|
170
|
-
var transform = new Matrix4_default();
|
|
171
|
-
var translation = new Matrix4_default();
|
|
172
|
-
var rotationZ = new Matrix3_default();
|
|
173
|
-
var scaleMatrix = Matrix3_default.IDENTITY.clone();
|
|
174
|
-
var westScratch = new Cartesian3_default();
|
|
175
|
-
var finalPosScratch = new Cartesian4_default();
|
|
176
|
-
var heightCartesian = new Cartesian3_default();
|
|
177
|
-
function addPosition(center, left, shape, finalPositions, ellipsoid, height, xScalar, repeat) {
|
|
178
|
-
let west = westScratch;
|
|
179
|
-
let finalPosition = finalPosScratch;
|
|
180
|
-
transform = Transforms_default.eastNorthUpToFixedFrame(center, ellipsoid, transform);
|
|
181
|
-
west = Matrix4_default.multiplyByPointAsVector(transform, negativeX, west);
|
|
182
|
-
west = Cartesian3_default.normalize(west, west);
|
|
183
|
-
const angle = computeRotationAngle(west, left, center, ellipsoid);
|
|
184
|
-
rotationZ = Matrix3_default.fromRotationZ(angle, rotationZ);
|
|
185
|
-
heightCartesian.z = height;
|
|
186
|
-
transform = Matrix4_default.multiplyTransformation(
|
|
187
|
-
transform,
|
|
188
|
-
Matrix4_default.fromRotationTranslation(rotationZ, heightCartesian, translation),
|
|
189
|
-
transform
|
|
190
|
-
);
|
|
191
|
-
const scale = scaleMatrix;
|
|
192
|
-
scale[0] = xScalar;
|
|
193
|
-
for (let j = 0; j < repeat; j++) {
|
|
194
|
-
for (let i = 0; i < shape.length; i += 3) {
|
|
195
|
-
finalPosition = Cartesian3_default.fromArray(shape, i, finalPosition);
|
|
196
|
-
finalPosition = Matrix3_default.multiplyByVector(
|
|
197
|
-
scale,
|
|
198
|
-
finalPosition,
|
|
199
|
-
finalPosition
|
|
200
|
-
);
|
|
201
|
-
finalPosition = Matrix4_default.multiplyByPoint(
|
|
202
|
-
transform,
|
|
203
|
-
finalPosition,
|
|
204
|
-
finalPosition
|
|
205
|
-
);
|
|
206
|
-
finalPositions.push(finalPosition.x, finalPosition.y, finalPosition.z);
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
return finalPositions;
|
|
210
|
-
}
|
|
211
|
-
var centerScratch = new Cartesian3_default();
|
|
212
|
-
function addPositions(centers, left, shape, finalPositions, ellipsoid, heights, xScalar) {
|
|
213
|
-
for (let i = 0; i < centers.length; i += 3) {
|
|
214
|
-
const center = Cartesian3_default.fromArray(centers, i, centerScratch);
|
|
215
|
-
finalPositions = addPosition(
|
|
216
|
-
center,
|
|
217
|
-
left,
|
|
218
|
-
shape,
|
|
219
|
-
finalPositions,
|
|
220
|
-
ellipsoid,
|
|
221
|
-
heights[i / 3],
|
|
222
|
-
xScalar,
|
|
223
|
-
1
|
|
224
|
-
);
|
|
225
|
-
}
|
|
226
|
-
return finalPositions;
|
|
227
|
-
}
|
|
228
|
-
function convertShapeTo3DDuplicate(shape2D, boundingRectangle) {
|
|
229
|
-
const length = shape2D.length;
|
|
230
|
-
const shape = new Array(length * 6);
|
|
231
|
-
let index = 0;
|
|
232
|
-
const xOffset = boundingRectangle.x + boundingRectangle.width / 2;
|
|
233
|
-
const yOffset = boundingRectangle.y + boundingRectangle.height / 2;
|
|
234
|
-
let point = shape2D[0];
|
|
235
|
-
shape[index++] = point.x - xOffset;
|
|
236
|
-
shape[index++] = 0;
|
|
237
|
-
shape[index++] = point.y - yOffset;
|
|
238
|
-
for (let i = 1; i < length; i++) {
|
|
239
|
-
point = shape2D[i];
|
|
240
|
-
const x = point.x - xOffset;
|
|
241
|
-
const z = point.y - yOffset;
|
|
242
|
-
shape[index++] = x;
|
|
243
|
-
shape[index++] = 0;
|
|
244
|
-
shape[index++] = z;
|
|
245
|
-
shape[index++] = x;
|
|
246
|
-
shape[index++] = 0;
|
|
247
|
-
shape[index++] = z;
|
|
248
|
-
}
|
|
249
|
-
point = shape2D[0];
|
|
250
|
-
shape[index++] = point.x - xOffset;
|
|
251
|
-
shape[index++] = 0;
|
|
252
|
-
shape[index++] = point.y - yOffset;
|
|
253
|
-
return shape;
|
|
254
|
-
}
|
|
255
|
-
function convertShapeTo3D(shape2D, boundingRectangle) {
|
|
256
|
-
const length = shape2D.length;
|
|
257
|
-
const shape = new Array(length * 3);
|
|
258
|
-
let index = 0;
|
|
259
|
-
const xOffset = boundingRectangle.x + boundingRectangle.width / 2;
|
|
260
|
-
const yOffset = boundingRectangle.y + boundingRectangle.height / 2;
|
|
261
|
-
for (let i = 0; i < length; i++) {
|
|
262
|
-
shape[index++] = shape2D[i].x - xOffset;
|
|
263
|
-
shape[index++] = 0;
|
|
264
|
-
shape[index++] = shape2D[i].y - yOffset;
|
|
265
|
-
}
|
|
266
|
-
return shape;
|
|
267
|
-
}
|
|
268
|
-
var quaterion = new Quaternion_default();
|
|
269
|
-
var startPointScratch = new Cartesian3_default();
|
|
270
|
-
var rotMatrix = new Matrix3_default();
|
|
271
|
-
function computeRoundCorner(pivot, startPoint, endPoint, cornerType, leftIsOutside, ellipsoid, finalPositions, shape, height, duplicatePoints) {
|
|
272
|
-
const angle = Cartesian3_default.angleBetween(
|
|
273
|
-
Cartesian3_default.subtract(startPoint, pivot, scratch1),
|
|
274
|
-
Cartesian3_default.subtract(endPoint, pivot, scratch2)
|
|
275
|
-
);
|
|
276
|
-
const granularity = cornerType === CornerType_default.BEVELED ? 0 : Math.ceil(angle / Math_default.toRadians(5));
|
|
277
|
-
let m;
|
|
278
|
-
if (leftIsOutside) {
|
|
279
|
-
m = Matrix3_default.fromQuaternion(
|
|
280
|
-
Quaternion_default.fromAxisAngle(
|
|
281
|
-
Cartesian3_default.negate(pivot, scratch1),
|
|
282
|
-
angle / (granularity + 1),
|
|
283
|
-
quaterion
|
|
284
|
-
),
|
|
285
|
-
rotMatrix
|
|
286
|
-
);
|
|
287
|
-
} else {
|
|
288
|
-
m = Matrix3_default.fromQuaternion(
|
|
289
|
-
Quaternion_default.fromAxisAngle(pivot, angle / (granularity + 1), quaterion),
|
|
290
|
-
rotMatrix
|
|
291
|
-
);
|
|
292
|
-
}
|
|
293
|
-
let left;
|
|
294
|
-
let surfacePoint;
|
|
295
|
-
startPoint = Cartesian3_default.clone(startPoint, startPointScratch);
|
|
296
|
-
if (granularity > 0) {
|
|
297
|
-
const repeat = duplicatePoints ? 2 : 1;
|
|
298
|
-
for (let i = 0; i < granularity; i++) {
|
|
299
|
-
startPoint = Matrix3_default.multiplyByVector(m, startPoint, startPoint);
|
|
300
|
-
left = Cartesian3_default.subtract(startPoint, pivot, scratch1);
|
|
301
|
-
left = Cartesian3_default.normalize(left, left);
|
|
302
|
-
if (!leftIsOutside) {
|
|
303
|
-
left = Cartesian3_default.negate(left, left);
|
|
304
|
-
}
|
|
305
|
-
surfacePoint = ellipsoid.scaleToGeodeticSurface(startPoint, scratch2);
|
|
306
|
-
finalPositions = addPosition(
|
|
307
|
-
surfacePoint,
|
|
308
|
-
left,
|
|
309
|
-
shape,
|
|
310
|
-
finalPositions,
|
|
311
|
-
ellipsoid,
|
|
312
|
-
height,
|
|
313
|
-
1,
|
|
314
|
-
repeat
|
|
315
|
-
);
|
|
316
|
-
}
|
|
317
|
-
} else {
|
|
318
|
-
left = Cartesian3_default.subtract(startPoint, pivot, scratch1);
|
|
319
|
-
left = Cartesian3_default.normalize(left, left);
|
|
320
|
-
if (!leftIsOutside) {
|
|
321
|
-
left = Cartesian3_default.negate(left, left);
|
|
322
|
-
}
|
|
323
|
-
surfacePoint = ellipsoid.scaleToGeodeticSurface(startPoint, scratch2);
|
|
324
|
-
finalPositions = addPosition(
|
|
325
|
-
surfacePoint,
|
|
326
|
-
left,
|
|
327
|
-
shape,
|
|
328
|
-
finalPositions,
|
|
329
|
-
ellipsoid,
|
|
330
|
-
height,
|
|
331
|
-
1,
|
|
332
|
-
1
|
|
333
|
-
);
|
|
334
|
-
endPoint = Cartesian3_default.clone(endPoint, startPointScratch);
|
|
335
|
-
left = Cartesian3_default.subtract(endPoint, pivot, scratch1);
|
|
336
|
-
left = Cartesian3_default.normalize(left, left);
|
|
337
|
-
if (!leftIsOutside) {
|
|
338
|
-
left = Cartesian3_default.negate(left, left);
|
|
339
|
-
}
|
|
340
|
-
surfacePoint = ellipsoid.scaleToGeodeticSurface(endPoint, scratch2);
|
|
341
|
-
finalPositions = addPosition(
|
|
342
|
-
surfacePoint,
|
|
343
|
-
left,
|
|
344
|
-
shape,
|
|
345
|
-
finalPositions,
|
|
346
|
-
ellipsoid,
|
|
347
|
-
height,
|
|
348
|
-
1,
|
|
349
|
-
1
|
|
350
|
-
);
|
|
351
|
-
}
|
|
352
|
-
return finalPositions;
|
|
353
|
-
}
|
|
354
|
-
PolylineVolumeGeometryLibrary.removeDuplicatesFromShape = function(shapePositions) {
|
|
355
|
-
const length = shapePositions.length;
|
|
356
|
-
const cleanedPositions = [];
|
|
357
|
-
for (let i0 = length - 1, i1 = 0; i1 < length; i0 = i1++) {
|
|
358
|
-
const v0 = shapePositions[i0];
|
|
359
|
-
const v1 = shapePositions[i1];
|
|
360
|
-
if (!Cartesian2_default.equals(v0, v1)) {
|
|
361
|
-
cleanedPositions.push(v1);
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
return cleanedPositions;
|
|
365
|
-
};
|
|
366
|
-
PolylineVolumeGeometryLibrary.angleIsGreaterThanPi = function(forward, backward, position, ellipsoid) {
|
|
367
|
-
const tangentPlane = new EllipsoidTangentPlane_default(position, ellipsoid);
|
|
368
|
-
const next = tangentPlane.projectPointOntoPlane(
|
|
369
|
-
Cartesian3_default.add(position, forward, nextScratch),
|
|
370
|
-
nextScratch
|
|
371
|
-
);
|
|
372
|
-
const prev = tangentPlane.projectPointOntoPlane(
|
|
373
|
-
Cartesian3_default.add(position, backward, prevScratch),
|
|
374
|
-
prevScratch
|
|
375
|
-
);
|
|
376
|
-
return prev.x * next.y - prev.y * next.x >= 0;
|
|
377
|
-
};
|
|
378
|
-
var scratchForwardProjection = new Cartesian3_default();
|
|
379
|
-
var scratchBackwardProjection = new Cartesian3_default();
|
|
380
|
-
PolylineVolumeGeometryLibrary.computePositions = function(positions, shape2D, boundingRectangle, geometry, duplicatePoints) {
|
|
381
|
-
const ellipsoid = geometry._ellipsoid;
|
|
382
|
-
const heights = scaleToSurface(positions, ellipsoid);
|
|
383
|
-
const granularity = geometry._granularity;
|
|
384
|
-
const cornerType = geometry._cornerType;
|
|
385
|
-
const shapeForSides = duplicatePoints ? convertShapeTo3DDuplicate(shape2D, boundingRectangle) : convertShapeTo3D(shape2D, boundingRectangle);
|
|
386
|
-
const shapeForEnds = duplicatePoints ? convertShapeTo3D(shape2D, boundingRectangle) : void 0;
|
|
387
|
-
const heightOffset = boundingRectangle.height / 2;
|
|
388
|
-
const width = boundingRectangle.width / 2;
|
|
389
|
-
let length = positions.length;
|
|
390
|
-
let finalPositions = [];
|
|
391
|
-
let ends = duplicatePoints ? [] : void 0;
|
|
392
|
-
let forward = scratchCartesian1;
|
|
393
|
-
let backward = scratchCartesian2;
|
|
394
|
-
let cornerDirection = scratchCartesian3;
|
|
395
|
-
let surfaceNormal = scratchCartesian4;
|
|
396
|
-
let pivot = scratchCartesian5;
|
|
397
|
-
let start = scratchCartesian6;
|
|
398
|
-
let end = scratchCartesian7;
|
|
399
|
-
let left = scratchCartesian8;
|
|
400
|
-
let previousPosition = scratchCartesian9;
|
|
401
|
-
let position = positions[0];
|
|
402
|
-
let nextPosition = positions[1];
|
|
403
|
-
surfaceNormal = ellipsoid.geodeticSurfaceNormal(position, surfaceNormal);
|
|
404
|
-
forward = Cartesian3_default.subtract(nextPosition, position, forward);
|
|
405
|
-
forward = Cartesian3_default.normalize(forward, forward);
|
|
406
|
-
left = Cartesian3_default.cross(surfaceNormal, forward, left);
|
|
407
|
-
left = Cartesian3_default.normalize(left, left);
|
|
408
|
-
let h0 = heights[0];
|
|
409
|
-
let h1 = heights[1];
|
|
410
|
-
if (duplicatePoints) {
|
|
411
|
-
ends = addPosition(
|
|
412
|
-
position,
|
|
413
|
-
left,
|
|
414
|
-
shapeForEnds,
|
|
415
|
-
ends,
|
|
416
|
-
ellipsoid,
|
|
417
|
-
h0 + heightOffset,
|
|
418
|
-
1,
|
|
419
|
-
1
|
|
420
|
-
);
|
|
421
|
-
}
|
|
422
|
-
previousPosition = Cartesian3_default.clone(position, previousPosition);
|
|
423
|
-
position = nextPosition;
|
|
424
|
-
backward = Cartesian3_default.negate(forward, backward);
|
|
425
|
-
let subdividedHeights;
|
|
426
|
-
let subdividedPositions;
|
|
427
|
-
for (let i = 1; i < length - 1; i++) {
|
|
428
|
-
const repeat = duplicatePoints ? 2 : 1;
|
|
429
|
-
nextPosition = positions[i + 1];
|
|
430
|
-
if (position.equals(nextPosition)) {
|
|
431
|
-
oneTimeWarning_default(
|
|
432
|
-
"Positions are too close and are considered equivalent with rounding error."
|
|
433
|
-
);
|
|
434
|
-
continue;
|
|
435
|
-
}
|
|
436
|
-
forward = Cartesian3_default.subtract(nextPosition, position, forward);
|
|
437
|
-
forward = Cartesian3_default.normalize(forward, forward);
|
|
438
|
-
cornerDirection = Cartesian3_default.add(forward, backward, cornerDirection);
|
|
439
|
-
cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection);
|
|
440
|
-
surfaceNormal = ellipsoid.geodeticSurfaceNormal(position, surfaceNormal);
|
|
441
|
-
const forwardProjection = Cartesian3_default.multiplyByScalar(
|
|
442
|
-
surfaceNormal,
|
|
443
|
-
Cartesian3_default.dot(forward, surfaceNormal),
|
|
444
|
-
scratchForwardProjection
|
|
445
|
-
);
|
|
446
|
-
Cartesian3_default.subtract(forward, forwardProjection, forwardProjection);
|
|
447
|
-
Cartesian3_default.normalize(forwardProjection, forwardProjection);
|
|
448
|
-
const backwardProjection = Cartesian3_default.multiplyByScalar(
|
|
449
|
-
surfaceNormal,
|
|
450
|
-
Cartesian3_default.dot(backward, surfaceNormal),
|
|
451
|
-
scratchBackwardProjection
|
|
452
|
-
);
|
|
453
|
-
Cartesian3_default.subtract(backward, backwardProjection, backwardProjection);
|
|
454
|
-
Cartesian3_default.normalize(backwardProjection, backwardProjection);
|
|
455
|
-
const doCorner = !Math_default.equalsEpsilon(
|
|
456
|
-
Math.abs(Cartesian3_default.dot(forwardProjection, backwardProjection)),
|
|
457
|
-
1,
|
|
458
|
-
Math_default.EPSILON7
|
|
459
|
-
);
|
|
460
|
-
if (doCorner) {
|
|
461
|
-
cornerDirection = Cartesian3_default.cross(
|
|
462
|
-
cornerDirection,
|
|
463
|
-
surfaceNormal,
|
|
464
|
-
cornerDirection
|
|
465
|
-
);
|
|
466
|
-
cornerDirection = Cartesian3_default.cross(
|
|
467
|
-
surfaceNormal,
|
|
468
|
-
cornerDirection,
|
|
469
|
-
cornerDirection
|
|
470
|
-
);
|
|
471
|
-
cornerDirection = Cartesian3_default.normalize(cornerDirection, cornerDirection);
|
|
472
|
-
const scalar = 1 / Math.max(
|
|
473
|
-
0.25,
|
|
474
|
-
Cartesian3_default.magnitude(
|
|
475
|
-
Cartesian3_default.cross(cornerDirection, backward, scratch1)
|
|
476
|
-
)
|
|
477
|
-
);
|
|
478
|
-
const leftIsOutside = PolylineVolumeGeometryLibrary.angleIsGreaterThanPi(
|
|
479
|
-
forward,
|
|
480
|
-
backward,
|
|
481
|
-
position,
|
|
482
|
-
ellipsoid
|
|
483
|
-
);
|
|
484
|
-
if (leftIsOutside) {
|
|
485
|
-
pivot = Cartesian3_default.add(
|
|
486
|
-
position,
|
|
487
|
-
Cartesian3_default.multiplyByScalar(
|
|
488
|
-
cornerDirection,
|
|
489
|
-
scalar * width,
|
|
490
|
-
cornerDirection
|
|
491
|
-
),
|
|
492
|
-
pivot
|
|
493
|
-
);
|
|
494
|
-
start = Cartesian3_default.add(
|
|
495
|
-
pivot,
|
|
496
|
-
Cartesian3_default.multiplyByScalar(left, width, start),
|
|
497
|
-
start
|
|
498
|
-
);
|
|
499
|
-
scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]);
|
|
500
|
-
scratch2Array[1] = Cartesian3_default.clone(start, scratch2Array[1]);
|
|
501
|
-
subdividedHeights = subdivideHeights(
|
|
502
|
-
scratch2Array,
|
|
503
|
-
h0 + heightOffset,
|
|
504
|
-
h1 + heightOffset,
|
|
505
|
-
granularity
|
|
506
|
-
);
|
|
507
|
-
subdividedPositions = PolylinePipeline_default.generateArc({
|
|
508
|
-
positions: scratch2Array,
|
|
509
|
-
granularity,
|
|
510
|
-
ellipsoid
|
|
511
|
-
});
|
|
512
|
-
finalPositions = addPositions(
|
|
513
|
-
subdividedPositions,
|
|
514
|
-
left,
|
|
515
|
-
shapeForSides,
|
|
516
|
-
finalPositions,
|
|
517
|
-
ellipsoid,
|
|
518
|
-
subdividedHeights,
|
|
519
|
-
1
|
|
520
|
-
);
|
|
521
|
-
left = Cartesian3_default.cross(surfaceNormal, forward, left);
|
|
522
|
-
left = Cartesian3_default.normalize(left, left);
|
|
523
|
-
end = Cartesian3_default.add(
|
|
524
|
-
pivot,
|
|
525
|
-
Cartesian3_default.multiplyByScalar(left, width, end),
|
|
526
|
-
end
|
|
527
|
-
);
|
|
528
|
-
if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) {
|
|
529
|
-
computeRoundCorner(
|
|
530
|
-
pivot,
|
|
531
|
-
start,
|
|
532
|
-
end,
|
|
533
|
-
cornerType,
|
|
534
|
-
leftIsOutside,
|
|
535
|
-
ellipsoid,
|
|
536
|
-
finalPositions,
|
|
537
|
-
shapeForSides,
|
|
538
|
-
h1 + heightOffset,
|
|
539
|
-
duplicatePoints
|
|
540
|
-
);
|
|
541
|
-
} else {
|
|
542
|
-
cornerDirection = Cartesian3_default.negate(cornerDirection, cornerDirection);
|
|
543
|
-
finalPositions = addPosition(
|
|
544
|
-
position,
|
|
545
|
-
cornerDirection,
|
|
546
|
-
shapeForSides,
|
|
547
|
-
finalPositions,
|
|
548
|
-
ellipsoid,
|
|
549
|
-
h1 + heightOffset,
|
|
550
|
-
scalar,
|
|
551
|
-
repeat
|
|
552
|
-
);
|
|
553
|
-
}
|
|
554
|
-
previousPosition = Cartesian3_default.clone(end, previousPosition);
|
|
555
|
-
} else {
|
|
556
|
-
pivot = Cartesian3_default.add(
|
|
557
|
-
position,
|
|
558
|
-
Cartesian3_default.multiplyByScalar(
|
|
559
|
-
cornerDirection,
|
|
560
|
-
scalar * width,
|
|
561
|
-
cornerDirection
|
|
562
|
-
),
|
|
563
|
-
pivot
|
|
564
|
-
);
|
|
565
|
-
start = Cartesian3_default.add(
|
|
566
|
-
pivot,
|
|
567
|
-
Cartesian3_default.multiplyByScalar(left, -width, start),
|
|
568
|
-
start
|
|
569
|
-
);
|
|
570
|
-
scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]);
|
|
571
|
-
scratch2Array[1] = Cartesian3_default.clone(start, scratch2Array[1]);
|
|
572
|
-
subdividedHeights = subdivideHeights(
|
|
573
|
-
scratch2Array,
|
|
574
|
-
h0 + heightOffset,
|
|
575
|
-
h1 + heightOffset,
|
|
576
|
-
granularity
|
|
577
|
-
);
|
|
578
|
-
subdividedPositions = PolylinePipeline_default.generateArc({
|
|
579
|
-
positions: scratch2Array,
|
|
580
|
-
granularity,
|
|
581
|
-
ellipsoid
|
|
582
|
-
});
|
|
583
|
-
finalPositions = addPositions(
|
|
584
|
-
subdividedPositions,
|
|
585
|
-
left,
|
|
586
|
-
shapeForSides,
|
|
587
|
-
finalPositions,
|
|
588
|
-
ellipsoid,
|
|
589
|
-
subdividedHeights,
|
|
590
|
-
1
|
|
591
|
-
);
|
|
592
|
-
left = Cartesian3_default.cross(surfaceNormal, forward, left);
|
|
593
|
-
left = Cartesian3_default.normalize(left, left);
|
|
594
|
-
end = Cartesian3_default.add(
|
|
595
|
-
pivot,
|
|
596
|
-
Cartesian3_default.multiplyByScalar(left, -width, end),
|
|
597
|
-
end
|
|
598
|
-
);
|
|
599
|
-
if (cornerType === CornerType_default.ROUNDED || cornerType === CornerType_default.BEVELED) {
|
|
600
|
-
computeRoundCorner(
|
|
601
|
-
pivot,
|
|
602
|
-
start,
|
|
603
|
-
end,
|
|
604
|
-
cornerType,
|
|
605
|
-
leftIsOutside,
|
|
606
|
-
ellipsoid,
|
|
607
|
-
finalPositions,
|
|
608
|
-
shapeForSides,
|
|
609
|
-
h1 + heightOffset,
|
|
610
|
-
duplicatePoints
|
|
611
|
-
);
|
|
612
|
-
} else {
|
|
613
|
-
finalPositions = addPosition(
|
|
614
|
-
position,
|
|
615
|
-
cornerDirection,
|
|
616
|
-
shapeForSides,
|
|
617
|
-
finalPositions,
|
|
618
|
-
ellipsoid,
|
|
619
|
-
h1 + heightOffset,
|
|
620
|
-
scalar,
|
|
621
|
-
repeat
|
|
622
|
-
);
|
|
623
|
-
}
|
|
624
|
-
previousPosition = Cartesian3_default.clone(end, previousPosition);
|
|
625
|
-
}
|
|
626
|
-
backward = Cartesian3_default.negate(forward, backward);
|
|
627
|
-
} else {
|
|
628
|
-
finalPositions = addPosition(
|
|
629
|
-
previousPosition,
|
|
630
|
-
left,
|
|
631
|
-
shapeForSides,
|
|
632
|
-
finalPositions,
|
|
633
|
-
ellipsoid,
|
|
634
|
-
h0 + heightOffset,
|
|
635
|
-
1,
|
|
636
|
-
1
|
|
637
|
-
);
|
|
638
|
-
previousPosition = position;
|
|
639
|
-
}
|
|
640
|
-
h0 = h1;
|
|
641
|
-
h1 = heights[i + 1];
|
|
642
|
-
position = nextPosition;
|
|
643
|
-
}
|
|
644
|
-
scratch2Array[0] = Cartesian3_default.clone(previousPosition, scratch2Array[0]);
|
|
645
|
-
scratch2Array[1] = Cartesian3_default.clone(position, scratch2Array[1]);
|
|
646
|
-
subdividedHeights = subdivideHeights(
|
|
647
|
-
scratch2Array,
|
|
648
|
-
h0 + heightOffset,
|
|
649
|
-
h1 + heightOffset,
|
|
650
|
-
granularity
|
|
651
|
-
);
|
|
652
|
-
subdividedPositions = PolylinePipeline_default.generateArc({
|
|
653
|
-
positions: scratch2Array,
|
|
654
|
-
granularity,
|
|
655
|
-
ellipsoid
|
|
656
|
-
});
|
|
657
|
-
finalPositions = addPositions(
|
|
658
|
-
subdividedPositions,
|
|
659
|
-
left,
|
|
660
|
-
shapeForSides,
|
|
661
|
-
finalPositions,
|
|
662
|
-
ellipsoid,
|
|
663
|
-
subdividedHeights,
|
|
664
|
-
1
|
|
665
|
-
);
|
|
666
|
-
if (duplicatePoints) {
|
|
667
|
-
ends = addPosition(
|
|
668
|
-
position,
|
|
669
|
-
left,
|
|
670
|
-
shapeForEnds,
|
|
671
|
-
ends,
|
|
672
|
-
ellipsoid,
|
|
673
|
-
h1 + heightOffset,
|
|
674
|
-
1,
|
|
675
|
-
1
|
|
676
|
-
);
|
|
677
|
-
}
|
|
678
|
-
length = finalPositions.length;
|
|
679
|
-
const posLength = duplicatePoints ? length + ends.length : length;
|
|
680
|
-
const combinedPositions = new Float64Array(posLength);
|
|
681
|
-
combinedPositions.set(finalPositions);
|
|
682
|
-
if (duplicatePoints) {
|
|
683
|
-
combinedPositions.set(ends, length);
|
|
684
|
-
}
|
|
685
|
-
return combinedPositions;
|
|
686
|
-
};
|
|
687
|
-
var PolylineVolumeGeometryLibrary_default = PolylineVolumeGeometryLibrary;
|
|
688
|
-
|
|
689
|
-
export {
|
|
690
|
-
CornerType_default,
|
|
691
|
-
oneTimeWarning_default,
|
|
692
|
-
PolylineVolumeGeometryLibrary_default
|
|
693
|
-
};
|