@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,398 +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
|
-
CylinderGeometryLibrary_default
|
|
28
|
-
} from "./chunk-34FXV7D7.js";
|
|
29
|
-
import {
|
|
30
|
-
GeometryOffsetAttribute_default
|
|
31
|
-
} from "./chunk-F3YA3Y2Z.js";
|
|
32
|
-
import {
|
|
33
|
-
VertexFormat_default
|
|
34
|
-
} from "./chunk-2FWRMUTY.js";
|
|
35
|
-
import {
|
|
36
|
-
IndexDatatype_default
|
|
37
|
-
} from "./chunk-LPR3YNP2.js";
|
|
38
|
-
import {
|
|
39
|
-
GeometryAttributes_default
|
|
40
|
-
} from "./chunk-4H7PY4U5.js";
|
|
41
|
-
import {
|
|
42
|
-
GeometryAttribute_default,
|
|
43
|
-
Geometry_default,
|
|
44
|
-
PrimitiveType_default
|
|
45
|
-
} from "./chunk-7TC63SJW.js";
|
|
46
|
-
import {
|
|
47
|
-
BoundingSphere_default
|
|
48
|
-
} from "./chunk-FJKNFAKQ.js";
|
|
49
|
-
import {
|
|
50
|
-
ComponentDatatype_default
|
|
51
|
-
} from "./chunk-PPH7OFP3.js";
|
|
52
|
-
import {
|
|
53
|
-
Cartesian2_default,
|
|
54
|
-
Cartesian3_default
|
|
55
|
-
} from "./chunk-OGXZVPPM.js";
|
|
56
|
-
import {
|
|
57
|
-
Math_default
|
|
58
|
-
} from "./chunk-5QULIR53.js";
|
|
59
|
-
import {
|
|
60
|
-
defaultValue_default
|
|
61
|
-
} from "./chunk-BBWDMCVU.js";
|
|
62
|
-
import {
|
|
63
|
-
DeveloperError_default
|
|
64
|
-
} from "./chunk-XGI5BXZY.js";
|
|
65
|
-
import {
|
|
66
|
-
defined_default
|
|
67
|
-
} from "./chunk-YWTJ2B4B.js";
|
|
68
|
-
|
|
69
|
-
// packages/engine/Source/Core/CylinderGeometry.js
|
|
70
|
-
var radiusScratch = new Cartesian2_default();
|
|
71
|
-
var normalScratch = new Cartesian3_default();
|
|
72
|
-
var bitangentScratch = new Cartesian3_default();
|
|
73
|
-
var tangentScratch = new Cartesian3_default();
|
|
74
|
-
var positionScratch = new Cartesian3_default();
|
|
75
|
-
function CylinderGeometry(options) {
|
|
76
|
-
options = defaultValue_default(options, defaultValue_default.EMPTY_OBJECT);
|
|
77
|
-
const length = options.length;
|
|
78
|
-
const topRadius = options.topRadius;
|
|
79
|
-
const bottomRadius = options.bottomRadius;
|
|
80
|
-
const vertexFormat = defaultValue_default(options.vertexFormat, VertexFormat_default.DEFAULT);
|
|
81
|
-
const slices = defaultValue_default(options.slices, 128);
|
|
82
|
-
if (!defined_default(length)) {
|
|
83
|
-
throw new DeveloperError_default("options.length must be defined.");
|
|
84
|
-
}
|
|
85
|
-
if (!defined_default(topRadius)) {
|
|
86
|
-
throw new DeveloperError_default("options.topRadius must be defined.");
|
|
87
|
-
}
|
|
88
|
-
if (!defined_default(bottomRadius)) {
|
|
89
|
-
throw new DeveloperError_default("options.bottomRadius must be defined.");
|
|
90
|
-
}
|
|
91
|
-
if (slices < 3) {
|
|
92
|
-
throw new DeveloperError_default(
|
|
93
|
-
"options.slices must be greater than or equal to 3."
|
|
94
|
-
);
|
|
95
|
-
}
|
|
96
|
-
if (defined_default(options.offsetAttribute) && options.offsetAttribute === GeometryOffsetAttribute_default.TOP) {
|
|
97
|
-
throw new DeveloperError_default(
|
|
98
|
-
"GeometryOffsetAttribute.TOP is not a supported options.offsetAttribute for this geometry."
|
|
99
|
-
);
|
|
100
|
-
}
|
|
101
|
-
this._length = length;
|
|
102
|
-
this._topRadius = topRadius;
|
|
103
|
-
this._bottomRadius = bottomRadius;
|
|
104
|
-
this._vertexFormat = VertexFormat_default.clone(vertexFormat);
|
|
105
|
-
this._slices = slices;
|
|
106
|
-
this._offsetAttribute = options.offsetAttribute;
|
|
107
|
-
this._workerName = "createCylinderGeometry";
|
|
108
|
-
}
|
|
109
|
-
CylinderGeometry.packedLength = VertexFormat_default.packedLength + 5;
|
|
110
|
-
CylinderGeometry.pack = function(value, array, startingIndex) {
|
|
111
|
-
if (!defined_default(value)) {
|
|
112
|
-
throw new DeveloperError_default("value is required");
|
|
113
|
-
}
|
|
114
|
-
if (!defined_default(array)) {
|
|
115
|
-
throw new DeveloperError_default("array is required");
|
|
116
|
-
}
|
|
117
|
-
startingIndex = defaultValue_default(startingIndex, 0);
|
|
118
|
-
VertexFormat_default.pack(value._vertexFormat, array, startingIndex);
|
|
119
|
-
startingIndex += VertexFormat_default.packedLength;
|
|
120
|
-
array[startingIndex++] = value._length;
|
|
121
|
-
array[startingIndex++] = value._topRadius;
|
|
122
|
-
array[startingIndex++] = value._bottomRadius;
|
|
123
|
-
array[startingIndex++] = value._slices;
|
|
124
|
-
array[startingIndex] = defaultValue_default(value._offsetAttribute, -1);
|
|
125
|
-
return array;
|
|
126
|
-
};
|
|
127
|
-
var scratchVertexFormat = new VertexFormat_default();
|
|
128
|
-
var scratchOptions = {
|
|
129
|
-
vertexFormat: scratchVertexFormat,
|
|
130
|
-
length: void 0,
|
|
131
|
-
topRadius: void 0,
|
|
132
|
-
bottomRadius: void 0,
|
|
133
|
-
slices: void 0,
|
|
134
|
-
offsetAttribute: void 0
|
|
135
|
-
};
|
|
136
|
-
CylinderGeometry.unpack = function(array, startingIndex, result) {
|
|
137
|
-
if (!defined_default(array)) {
|
|
138
|
-
throw new DeveloperError_default("array is required");
|
|
139
|
-
}
|
|
140
|
-
startingIndex = defaultValue_default(startingIndex, 0);
|
|
141
|
-
const vertexFormat = VertexFormat_default.unpack(
|
|
142
|
-
array,
|
|
143
|
-
startingIndex,
|
|
144
|
-
scratchVertexFormat
|
|
145
|
-
);
|
|
146
|
-
startingIndex += VertexFormat_default.packedLength;
|
|
147
|
-
const length = array[startingIndex++];
|
|
148
|
-
const topRadius = array[startingIndex++];
|
|
149
|
-
const bottomRadius = array[startingIndex++];
|
|
150
|
-
const slices = array[startingIndex++];
|
|
151
|
-
const offsetAttribute = array[startingIndex];
|
|
152
|
-
if (!defined_default(result)) {
|
|
153
|
-
scratchOptions.length = length;
|
|
154
|
-
scratchOptions.topRadius = topRadius;
|
|
155
|
-
scratchOptions.bottomRadius = bottomRadius;
|
|
156
|
-
scratchOptions.slices = slices;
|
|
157
|
-
scratchOptions.offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute;
|
|
158
|
-
return new CylinderGeometry(scratchOptions);
|
|
159
|
-
}
|
|
160
|
-
result._vertexFormat = VertexFormat_default.clone(vertexFormat, result._vertexFormat);
|
|
161
|
-
result._length = length;
|
|
162
|
-
result._topRadius = topRadius;
|
|
163
|
-
result._bottomRadius = bottomRadius;
|
|
164
|
-
result._slices = slices;
|
|
165
|
-
result._offsetAttribute = offsetAttribute === -1 ? void 0 : offsetAttribute;
|
|
166
|
-
return result;
|
|
167
|
-
};
|
|
168
|
-
CylinderGeometry.createGeometry = function(cylinderGeometry) {
|
|
169
|
-
let length = cylinderGeometry._length;
|
|
170
|
-
const topRadius = cylinderGeometry._topRadius;
|
|
171
|
-
const bottomRadius = cylinderGeometry._bottomRadius;
|
|
172
|
-
const vertexFormat = cylinderGeometry._vertexFormat;
|
|
173
|
-
const slices = cylinderGeometry._slices;
|
|
174
|
-
if (length <= 0 || topRadius < 0 || bottomRadius < 0 || topRadius === 0 && bottomRadius === 0) {
|
|
175
|
-
return;
|
|
176
|
-
}
|
|
177
|
-
const twoSlices = slices + slices;
|
|
178
|
-
const threeSlices = slices + twoSlices;
|
|
179
|
-
const numVertices = twoSlices + twoSlices;
|
|
180
|
-
const positions = CylinderGeometryLibrary_default.computePositions(
|
|
181
|
-
length,
|
|
182
|
-
topRadius,
|
|
183
|
-
bottomRadius,
|
|
184
|
-
slices,
|
|
185
|
-
true
|
|
186
|
-
);
|
|
187
|
-
const st = vertexFormat.st ? new Float32Array(numVertices * 2) : void 0;
|
|
188
|
-
const normals = vertexFormat.normal ? new Float32Array(numVertices * 3) : void 0;
|
|
189
|
-
const tangents = vertexFormat.tangent ? new Float32Array(numVertices * 3) : void 0;
|
|
190
|
-
const bitangents = vertexFormat.bitangent ? new Float32Array(numVertices * 3) : void 0;
|
|
191
|
-
let i;
|
|
192
|
-
const computeNormal = vertexFormat.normal || vertexFormat.tangent || vertexFormat.bitangent;
|
|
193
|
-
if (computeNormal) {
|
|
194
|
-
const computeTangent = vertexFormat.tangent || vertexFormat.bitangent;
|
|
195
|
-
let normalIndex = 0;
|
|
196
|
-
let tangentIndex = 0;
|
|
197
|
-
let bitangentIndex = 0;
|
|
198
|
-
const theta = Math.atan2(bottomRadius - topRadius, length);
|
|
199
|
-
const normal = normalScratch;
|
|
200
|
-
normal.z = Math.sin(theta);
|
|
201
|
-
const normalScale = Math.cos(theta);
|
|
202
|
-
let tangent = tangentScratch;
|
|
203
|
-
let bitangent = bitangentScratch;
|
|
204
|
-
for (i = 0; i < slices; i++) {
|
|
205
|
-
const angle = i / slices * Math_default.TWO_PI;
|
|
206
|
-
const x = normalScale * Math.cos(angle);
|
|
207
|
-
const y = normalScale * Math.sin(angle);
|
|
208
|
-
if (computeNormal) {
|
|
209
|
-
normal.x = x;
|
|
210
|
-
normal.y = y;
|
|
211
|
-
if (computeTangent) {
|
|
212
|
-
tangent = Cartesian3_default.normalize(
|
|
213
|
-
Cartesian3_default.cross(Cartesian3_default.UNIT_Z, normal, tangent),
|
|
214
|
-
tangent
|
|
215
|
-
);
|
|
216
|
-
}
|
|
217
|
-
if (vertexFormat.normal) {
|
|
218
|
-
normals[normalIndex++] = normal.x;
|
|
219
|
-
normals[normalIndex++] = normal.y;
|
|
220
|
-
normals[normalIndex++] = normal.z;
|
|
221
|
-
normals[normalIndex++] = normal.x;
|
|
222
|
-
normals[normalIndex++] = normal.y;
|
|
223
|
-
normals[normalIndex++] = normal.z;
|
|
224
|
-
}
|
|
225
|
-
if (vertexFormat.tangent) {
|
|
226
|
-
tangents[tangentIndex++] = tangent.x;
|
|
227
|
-
tangents[tangentIndex++] = tangent.y;
|
|
228
|
-
tangents[tangentIndex++] = tangent.z;
|
|
229
|
-
tangents[tangentIndex++] = tangent.x;
|
|
230
|
-
tangents[tangentIndex++] = tangent.y;
|
|
231
|
-
tangents[tangentIndex++] = tangent.z;
|
|
232
|
-
}
|
|
233
|
-
if (vertexFormat.bitangent) {
|
|
234
|
-
bitangent = Cartesian3_default.normalize(
|
|
235
|
-
Cartesian3_default.cross(normal, tangent, bitangent),
|
|
236
|
-
bitangent
|
|
237
|
-
);
|
|
238
|
-
bitangents[bitangentIndex++] = bitangent.x;
|
|
239
|
-
bitangents[bitangentIndex++] = bitangent.y;
|
|
240
|
-
bitangents[bitangentIndex++] = bitangent.z;
|
|
241
|
-
bitangents[bitangentIndex++] = bitangent.x;
|
|
242
|
-
bitangents[bitangentIndex++] = bitangent.y;
|
|
243
|
-
bitangents[bitangentIndex++] = bitangent.z;
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
for (i = 0; i < slices; i++) {
|
|
248
|
-
if (vertexFormat.normal) {
|
|
249
|
-
normals[normalIndex++] = 0;
|
|
250
|
-
normals[normalIndex++] = 0;
|
|
251
|
-
normals[normalIndex++] = -1;
|
|
252
|
-
}
|
|
253
|
-
if (vertexFormat.tangent) {
|
|
254
|
-
tangents[tangentIndex++] = 1;
|
|
255
|
-
tangents[tangentIndex++] = 0;
|
|
256
|
-
tangents[tangentIndex++] = 0;
|
|
257
|
-
}
|
|
258
|
-
if (vertexFormat.bitangent) {
|
|
259
|
-
bitangents[bitangentIndex++] = 0;
|
|
260
|
-
bitangents[bitangentIndex++] = -1;
|
|
261
|
-
bitangents[bitangentIndex++] = 0;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
for (i = 0; i < slices; i++) {
|
|
265
|
-
if (vertexFormat.normal) {
|
|
266
|
-
normals[normalIndex++] = 0;
|
|
267
|
-
normals[normalIndex++] = 0;
|
|
268
|
-
normals[normalIndex++] = 1;
|
|
269
|
-
}
|
|
270
|
-
if (vertexFormat.tangent) {
|
|
271
|
-
tangents[tangentIndex++] = 1;
|
|
272
|
-
tangents[tangentIndex++] = 0;
|
|
273
|
-
tangents[tangentIndex++] = 0;
|
|
274
|
-
}
|
|
275
|
-
if (vertexFormat.bitangent) {
|
|
276
|
-
bitangents[bitangentIndex++] = 0;
|
|
277
|
-
bitangents[bitangentIndex++] = 1;
|
|
278
|
-
bitangents[bitangentIndex++] = 0;
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
const numIndices = 12 * slices - 12;
|
|
283
|
-
const indices = IndexDatatype_default.createTypedArray(numVertices, numIndices);
|
|
284
|
-
let index = 0;
|
|
285
|
-
let j = 0;
|
|
286
|
-
for (i = 0; i < slices - 1; i++) {
|
|
287
|
-
indices[index++] = j;
|
|
288
|
-
indices[index++] = j + 2;
|
|
289
|
-
indices[index++] = j + 3;
|
|
290
|
-
indices[index++] = j;
|
|
291
|
-
indices[index++] = j + 3;
|
|
292
|
-
indices[index++] = j + 1;
|
|
293
|
-
j += 2;
|
|
294
|
-
}
|
|
295
|
-
indices[index++] = twoSlices - 2;
|
|
296
|
-
indices[index++] = 0;
|
|
297
|
-
indices[index++] = 1;
|
|
298
|
-
indices[index++] = twoSlices - 2;
|
|
299
|
-
indices[index++] = 1;
|
|
300
|
-
indices[index++] = twoSlices - 1;
|
|
301
|
-
for (i = 1; i < slices - 1; i++) {
|
|
302
|
-
indices[index++] = twoSlices + i + 1;
|
|
303
|
-
indices[index++] = twoSlices + i;
|
|
304
|
-
indices[index++] = twoSlices;
|
|
305
|
-
}
|
|
306
|
-
for (i = 1; i < slices - 1; i++) {
|
|
307
|
-
indices[index++] = threeSlices;
|
|
308
|
-
indices[index++] = threeSlices + i;
|
|
309
|
-
indices[index++] = threeSlices + i + 1;
|
|
310
|
-
}
|
|
311
|
-
let textureCoordIndex = 0;
|
|
312
|
-
if (vertexFormat.st) {
|
|
313
|
-
const rad = Math.max(topRadius, bottomRadius);
|
|
314
|
-
for (i = 0; i < numVertices; i++) {
|
|
315
|
-
const position = Cartesian3_default.fromArray(positions, i * 3, positionScratch);
|
|
316
|
-
st[textureCoordIndex++] = (position.x + rad) / (2 * rad);
|
|
317
|
-
st[textureCoordIndex++] = (position.y + rad) / (2 * rad);
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
const attributes = new GeometryAttributes_default();
|
|
321
|
-
if (vertexFormat.position) {
|
|
322
|
-
attributes.position = new GeometryAttribute_default({
|
|
323
|
-
componentDatatype: ComponentDatatype_default.DOUBLE,
|
|
324
|
-
componentsPerAttribute: 3,
|
|
325
|
-
values: positions
|
|
326
|
-
});
|
|
327
|
-
}
|
|
328
|
-
if (vertexFormat.normal) {
|
|
329
|
-
attributes.normal = new GeometryAttribute_default({
|
|
330
|
-
componentDatatype: ComponentDatatype_default.FLOAT,
|
|
331
|
-
componentsPerAttribute: 3,
|
|
332
|
-
values: normals
|
|
333
|
-
});
|
|
334
|
-
}
|
|
335
|
-
if (vertexFormat.tangent) {
|
|
336
|
-
attributes.tangent = new GeometryAttribute_default({
|
|
337
|
-
componentDatatype: ComponentDatatype_default.FLOAT,
|
|
338
|
-
componentsPerAttribute: 3,
|
|
339
|
-
values: tangents
|
|
340
|
-
});
|
|
341
|
-
}
|
|
342
|
-
if (vertexFormat.bitangent) {
|
|
343
|
-
attributes.bitangent = new GeometryAttribute_default({
|
|
344
|
-
componentDatatype: ComponentDatatype_default.FLOAT,
|
|
345
|
-
componentsPerAttribute: 3,
|
|
346
|
-
values: bitangents
|
|
347
|
-
});
|
|
348
|
-
}
|
|
349
|
-
if (vertexFormat.st) {
|
|
350
|
-
attributes.st = new GeometryAttribute_default({
|
|
351
|
-
componentDatatype: ComponentDatatype_default.FLOAT,
|
|
352
|
-
componentsPerAttribute: 2,
|
|
353
|
-
values: st
|
|
354
|
-
});
|
|
355
|
-
}
|
|
356
|
-
radiusScratch.x = length * 0.5;
|
|
357
|
-
radiusScratch.y = Math.max(bottomRadius, topRadius);
|
|
358
|
-
const boundingSphere = new BoundingSphere_default(
|
|
359
|
-
Cartesian3_default.ZERO,
|
|
360
|
-
Cartesian2_default.magnitude(radiusScratch)
|
|
361
|
-
);
|
|
362
|
-
if (defined_default(cylinderGeometry._offsetAttribute)) {
|
|
363
|
-
length = positions.length;
|
|
364
|
-
const offsetValue = cylinderGeometry._offsetAttribute === GeometryOffsetAttribute_default.NONE ? 0 : 1;
|
|
365
|
-
const applyOffset = new Uint8Array(length / 3).fill(offsetValue);
|
|
366
|
-
attributes.applyOffset = new GeometryAttribute_default({
|
|
367
|
-
componentDatatype: ComponentDatatype_default.UNSIGNED_BYTE,
|
|
368
|
-
componentsPerAttribute: 1,
|
|
369
|
-
values: applyOffset
|
|
370
|
-
});
|
|
371
|
-
}
|
|
372
|
-
return new Geometry_default({
|
|
373
|
-
attributes,
|
|
374
|
-
indices,
|
|
375
|
-
primitiveType: PrimitiveType_default.TRIANGLES,
|
|
376
|
-
boundingSphere,
|
|
377
|
-
offsetAttribute: cylinderGeometry._offsetAttribute
|
|
378
|
-
});
|
|
379
|
-
};
|
|
380
|
-
var unitCylinderGeometry;
|
|
381
|
-
CylinderGeometry.getUnitCylinder = function() {
|
|
382
|
-
if (!defined_default(unitCylinderGeometry)) {
|
|
383
|
-
unitCylinderGeometry = CylinderGeometry.createGeometry(
|
|
384
|
-
new CylinderGeometry({
|
|
385
|
-
topRadius: 1,
|
|
386
|
-
bottomRadius: 1,
|
|
387
|
-
length: 1,
|
|
388
|
-
vertexFormat: VertexFormat_default.POSITION_ONLY
|
|
389
|
-
})
|
|
390
|
-
);
|
|
391
|
-
}
|
|
392
|
-
return unitCylinderGeometry;
|
|
393
|
-
};
|
|
394
|
-
var CylinderGeometry_default = CylinderGeometry;
|
|
395
|
-
|
|
396
|
-
export {
|
|
397
|
-
CylinderGeometry_default
|
|
398
|
-
};
|