@pggis/pg-sdk 3.3.10 → 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,456 +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
|
-
Cartesian3_default,
|
|
28
|
-
Cartographic_default,
|
|
29
|
-
Ellipsoid_default
|
|
30
|
-
} from "./chunk-OGXZVPPM.js";
|
|
31
|
-
import {
|
|
32
|
-
Math_default
|
|
33
|
-
} from "./chunk-5QULIR53.js";
|
|
34
|
-
import {
|
|
35
|
-
defaultValue_default
|
|
36
|
-
} from "./chunk-BBWDMCVU.js";
|
|
37
|
-
import {
|
|
38
|
-
Check_default,
|
|
39
|
-
DeveloperError_default
|
|
40
|
-
} from "./chunk-XGI5BXZY.js";
|
|
41
|
-
import {
|
|
42
|
-
defined_default
|
|
43
|
-
} from "./chunk-YWTJ2B4B.js";
|
|
44
|
-
|
|
45
|
-
// packages/engine/Source/Core/EllipsoidRhumbLine.js
|
|
46
|
-
function calculateM(ellipticity, major, latitude) {
|
|
47
|
-
if (ellipticity === 0) {
|
|
48
|
-
return major * latitude;
|
|
49
|
-
}
|
|
50
|
-
const e2 = ellipticity * ellipticity;
|
|
51
|
-
const e4 = e2 * e2;
|
|
52
|
-
const e6 = e4 * e2;
|
|
53
|
-
const e8 = e6 * e2;
|
|
54
|
-
const e10 = e8 * e2;
|
|
55
|
-
const e12 = e10 * e2;
|
|
56
|
-
const phi = latitude;
|
|
57
|
-
const sin2Phi = Math.sin(2 * phi);
|
|
58
|
-
const sin4Phi = Math.sin(4 * phi);
|
|
59
|
-
const sin6Phi = Math.sin(6 * phi);
|
|
60
|
-
const sin8Phi = Math.sin(8 * phi);
|
|
61
|
-
const sin10Phi = Math.sin(10 * phi);
|
|
62
|
-
const sin12Phi = Math.sin(12 * phi);
|
|
63
|
-
return major * ((1 - e2 / 4 - 3 * e4 / 64 - 5 * e6 / 256 - 175 * e8 / 16384 - 441 * e10 / 65536 - 4851 * e12 / 1048576) * phi - (3 * e2 / 8 + 3 * e4 / 32 + 45 * e6 / 1024 + 105 * e8 / 4096 + 2205 * e10 / 131072 + 6237 * e12 / 524288) * sin2Phi + (15 * e4 / 256 + 45 * e6 / 1024 + 525 * e8 / 16384 + 1575 * e10 / 65536 + 155925 * e12 / 8388608) * sin4Phi - (35 * e6 / 3072 + 175 * e8 / 12288 + 3675 * e10 / 262144 + 13475 * e12 / 1048576) * sin6Phi + (315 * e8 / 131072 + 2205 * e10 / 524288 + 43659 * e12 / 8388608) * sin8Phi - (693 * e10 / 1310720 + 6237 * e12 / 5242880) * sin10Phi + 1001 * e12 / 8388608 * sin12Phi);
|
|
64
|
-
}
|
|
65
|
-
function calculateInverseM(M, ellipticity, major) {
|
|
66
|
-
const d = M / major;
|
|
67
|
-
if (ellipticity === 0) {
|
|
68
|
-
return d;
|
|
69
|
-
}
|
|
70
|
-
const d2 = d * d;
|
|
71
|
-
const d3 = d2 * d;
|
|
72
|
-
const d4 = d3 * d;
|
|
73
|
-
const e = ellipticity;
|
|
74
|
-
const e2 = e * e;
|
|
75
|
-
const e4 = e2 * e2;
|
|
76
|
-
const e6 = e4 * e2;
|
|
77
|
-
const e8 = e6 * e2;
|
|
78
|
-
const e10 = e8 * e2;
|
|
79
|
-
const e12 = e10 * e2;
|
|
80
|
-
const sin2D = Math.sin(2 * d);
|
|
81
|
-
const cos2D = Math.cos(2 * d);
|
|
82
|
-
const sin4D = Math.sin(4 * d);
|
|
83
|
-
const cos4D = Math.cos(4 * d);
|
|
84
|
-
const sin6D = Math.sin(6 * d);
|
|
85
|
-
const cos6D = Math.cos(6 * d);
|
|
86
|
-
const sin8D = Math.sin(8 * d);
|
|
87
|
-
const cos8D = Math.cos(8 * d);
|
|
88
|
-
const sin10D = Math.sin(10 * d);
|
|
89
|
-
const cos10D = Math.cos(10 * d);
|
|
90
|
-
const sin12D = Math.sin(12 * d);
|
|
91
|
-
return d + d * e2 / 4 + 7 * d * e4 / 64 + 15 * d * e6 / 256 + 579 * d * e8 / 16384 + 1515 * d * e10 / 65536 + 16837 * d * e12 / 1048576 + (3 * d * e4 / 16 + 45 * d * e6 / 256 - d * (32 * d2 - 561) * e8 / 4096 - d * (232 * d2 - 1677) * e10 / 16384 + d * (399985 - 90560 * d2 + 512 * d4) * e12 / 5242880) * cos2D + (21 * d * e6 / 256 + 483 * d * e8 / 4096 - d * (224 * d2 - 1969) * e10 / 16384 - d * (33152 * d2 - 112599) * e12 / 1048576) * cos4D + (151 * d * e8 / 4096 + 4681 * d * e10 / 65536 + 1479 * d * e12 / 16384 - 453 * d3 * e12 / 32768) * cos6D + (1097 * d * e10 / 65536 + 42783 * d * e12 / 1048576) * cos8D + 8011 * d * e12 / 1048576 * cos10D + (3 * e2 / 8 + 3 * e4 / 16 + 213 * e6 / 2048 - 3 * d2 * e6 / 64 + 255 * e8 / 4096 - 33 * d2 * e8 / 512 + 20861 * e10 / 524288 - 33 * d2 * e10 / 512 + d4 * e10 / 1024 + 28273 * e12 / 1048576 - 471 * d2 * e12 / 8192 + 9 * d4 * e12 / 4096) * sin2D + (21 * e4 / 256 + 21 * e6 / 256 + 533 * e8 / 8192 - 21 * d2 * e8 / 512 + 197 * e10 / 4096 - 315 * d2 * e10 / 4096 + 584039 * e12 / 16777216 - 12517 * d2 * e12 / 131072 + 7 * d4 * e12 / 2048) * sin4D + (151 * e6 / 6144 + 151 * e8 / 4096 + 5019 * e10 / 131072 - 453 * d2 * e10 / 16384 + 26965 * e12 / 786432 - 8607 * d2 * e12 / 131072) * sin6D + (1097 * e8 / 131072 + 1097 * e10 / 65536 + 225797 * e12 / 10485760 - 1097 * d2 * e12 / 65536) * sin8D + (8011 * e10 / 2621440 + 8011 * e12 / 1048576) * sin10D + 293393 * e12 / 251658240 * sin12D;
|
|
92
|
-
}
|
|
93
|
-
function calculateSigma(ellipticity, latitude) {
|
|
94
|
-
if (ellipticity === 0) {
|
|
95
|
-
return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude)));
|
|
96
|
-
}
|
|
97
|
-
const eSinL = ellipticity * Math.sin(latitude);
|
|
98
|
-
return Math.log(Math.tan(0.5 * (Math_default.PI_OVER_TWO + latitude))) - ellipticity / 2 * Math.log((1 + eSinL) / (1 - eSinL));
|
|
99
|
-
}
|
|
100
|
-
function calculateHeading(ellipsoidRhumbLine, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
|
|
101
|
-
const sigma1 = calculateSigma(ellipsoidRhumbLine._ellipticity, firstLatitude);
|
|
102
|
-
const sigma2 = calculateSigma(
|
|
103
|
-
ellipsoidRhumbLine._ellipticity,
|
|
104
|
-
secondLatitude
|
|
105
|
-
);
|
|
106
|
-
return Math.atan2(
|
|
107
|
-
Math_default.negativePiToPi(secondLongitude - firstLongitude),
|
|
108
|
-
sigma2 - sigma1
|
|
109
|
-
);
|
|
110
|
-
}
|
|
111
|
-
function calculateArcLength(ellipsoidRhumbLine, major, minor, firstLongitude, firstLatitude, secondLongitude, secondLatitude) {
|
|
112
|
-
const heading = ellipsoidRhumbLine._heading;
|
|
113
|
-
const deltaLongitude = secondLongitude - firstLongitude;
|
|
114
|
-
let distance = 0;
|
|
115
|
-
if (Math_default.equalsEpsilon(
|
|
116
|
-
Math.abs(heading),
|
|
117
|
-
Math_default.PI_OVER_TWO,
|
|
118
|
-
Math_default.EPSILON8
|
|
119
|
-
)) {
|
|
120
|
-
if (major === minor) {
|
|
121
|
-
distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude);
|
|
122
|
-
} else {
|
|
123
|
-
const sinPhi = Math.sin(firstLatitude);
|
|
124
|
-
distance = major * Math.cos(firstLatitude) * Math_default.negativePiToPi(deltaLongitude) / Math.sqrt(1 - ellipsoidRhumbLine._ellipticitySquared * sinPhi * sinPhi);
|
|
125
|
-
}
|
|
126
|
-
} else {
|
|
127
|
-
const M1 = calculateM(
|
|
128
|
-
ellipsoidRhumbLine._ellipticity,
|
|
129
|
-
major,
|
|
130
|
-
firstLatitude
|
|
131
|
-
);
|
|
132
|
-
const M2 = calculateM(
|
|
133
|
-
ellipsoidRhumbLine._ellipticity,
|
|
134
|
-
major,
|
|
135
|
-
secondLatitude
|
|
136
|
-
);
|
|
137
|
-
distance = (M2 - M1) / Math.cos(heading);
|
|
138
|
-
}
|
|
139
|
-
return Math.abs(distance);
|
|
140
|
-
}
|
|
141
|
-
var scratchCart1 = new Cartesian3_default();
|
|
142
|
-
var scratchCart2 = new Cartesian3_default();
|
|
143
|
-
function computeProperties(ellipsoidRhumbLine, start, end, ellipsoid) {
|
|
144
|
-
const firstCartesian = Cartesian3_default.normalize(
|
|
145
|
-
ellipsoid.cartographicToCartesian(start, scratchCart2),
|
|
146
|
-
scratchCart1
|
|
147
|
-
);
|
|
148
|
-
const lastCartesian = Cartesian3_default.normalize(
|
|
149
|
-
ellipsoid.cartographicToCartesian(end, scratchCart2),
|
|
150
|
-
scratchCart2
|
|
151
|
-
);
|
|
152
|
-
Check_default.typeOf.number.greaterThanOrEquals(
|
|
153
|
-
"value",
|
|
154
|
-
Math.abs(
|
|
155
|
-
Math.abs(Cartesian3_default.angleBetween(firstCartesian, lastCartesian)) - Math.PI
|
|
156
|
-
),
|
|
157
|
-
0.0125
|
|
158
|
-
);
|
|
159
|
-
const major = ellipsoid.maximumRadius;
|
|
160
|
-
const minor = ellipsoid.minimumRadius;
|
|
161
|
-
const majorSquared = major * major;
|
|
162
|
-
const minorSquared = minor * minor;
|
|
163
|
-
ellipsoidRhumbLine._ellipticitySquared = (majorSquared - minorSquared) / majorSquared;
|
|
164
|
-
ellipsoidRhumbLine._ellipticity = Math.sqrt(
|
|
165
|
-
ellipsoidRhumbLine._ellipticitySquared
|
|
166
|
-
);
|
|
167
|
-
ellipsoidRhumbLine._start = Cartographic_default.clone(
|
|
168
|
-
start,
|
|
169
|
-
ellipsoidRhumbLine._start
|
|
170
|
-
);
|
|
171
|
-
ellipsoidRhumbLine._start.height = 0;
|
|
172
|
-
ellipsoidRhumbLine._end = Cartographic_default.clone(end, ellipsoidRhumbLine._end);
|
|
173
|
-
ellipsoidRhumbLine._end.height = 0;
|
|
174
|
-
ellipsoidRhumbLine._heading = calculateHeading(
|
|
175
|
-
ellipsoidRhumbLine,
|
|
176
|
-
start.longitude,
|
|
177
|
-
start.latitude,
|
|
178
|
-
end.longitude,
|
|
179
|
-
end.latitude
|
|
180
|
-
);
|
|
181
|
-
ellipsoidRhumbLine._distance = calculateArcLength(
|
|
182
|
-
ellipsoidRhumbLine,
|
|
183
|
-
ellipsoid.maximumRadius,
|
|
184
|
-
ellipsoid.minimumRadius,
|
|
185
|
-
start.longitude,
|
|
186
|
-
start.latitude,
|
|
187
|
-
end.longitude,
|
|
188
|
-
end.latitude
|
|
189
|
-
);
|
|
190
|
-
}
|
|
191
|
-
function interpolateUsingSurfaceDistance(start, heading, distance, major, ellipticity, result) {
|
|
192
|
-
if (distance === 0) {
|
|
193
|
-
return Cartographic_default.clone(start, result);
|
|
194
|
-
}
|
|
195
|
-
const ellipticitySquared = ellipticity * ellipticity;
|
|
196
|
-
let longitude;
|
|
197
|
-
let latitude;
|
|
198
|
-
let deltaLongitude;
|
|
199
|
-
if (Math.abs(Math_default.PI_OVER_TWO - Math.abs(heading)) > Math_default.EPSILON8) {
|
|
200
|
-
const M1 = calculateM(ellipticity, major, start.latitude);
|
|
201
|
-
const deltaM = distance * Math.cos(heading);
|
|
202
|
-
const M2 = M1 + deltaM;
|
|
203
|
-
latitude = calculateInverseM(M2, ellipticity, major);
|
|
204
|
-
if (Math.abs(heading) < Math_default.EPSILON10) {
|
|
205
|
-
longitude = Math_default.negativePiToPi(start.longitude);
|
|
206
|
-
} else {
|
|
207
|
-
const sigma1 = calculateSigma(ellipticity, start.latitude);
|
|
208
|
-
const sigma2 = calculateSigma(ellipticity, latitude);
|
|
209
|
-
deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
|
|
210
|
-
longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
|
|
211
|
-
}
|
|
212
|
-
} else {
|
|
213
|
-
latitude = start.latitude;
|
|
214
|
-
let localRad;
|
|
215
|
-
if (ellipticity === 0) {
|
|
216
|
-
localRad = major * Math.cos(start.latitude);
|
|
217
|
-
} else {
|
|
218
|
-
const sinPhi = Math.sin(start.latitude);
|
|
219
|
-
localRad = major * Math.cos(start.latitude) / Math.sqrt(1 - ellipticitySquared * sinPhi * sinPhi);
|
|
220
|
-
}
|
|
221
|
-
deltaLongitude = distance / localRad;
|
|
222
|
-
if (heading > 0) {
|
|
223
|
-
longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
|
|
224
|
-
} else {
|
|
225
|
-
longitude = Math_default.negativePiToPi(start.longitude - deltaLongitude);
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
if (defined_default(result)) {
|
|
229
|
-
result.longitude = longitude;
|
|
230
|
-
result.latitude = latitude;
|
|
231
|
-
result.height = 0;
|
|
232
|
-
return result;
|
|
233
|
-
}
|
|
234
|
-
return new Cartographic_default(longitude, latitude, 0);
|
|
235
|
-
}
|
|
236
|
-
function EllipsoidRhumbLine(start, end, ellipsoid) {
|
|
237
|
-
const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84);
|
|
238
|
-
this._ellipsoid = e;
|
|
239
|
-
this._start = new Cartographic_default();
|
|
240
|
-
this._end = new Cartographic_default();
|
|
241
|
-
this._heading = void 0;
|
|
242
|
-
this._distance = void 0;
|
|
243
|
-
this._ellipticity = void 0;
|
|
244
|
-
this._ellipticitySquared = void 0;
|
|
245
|
-
if (defined_default(start) && defined_default(end)) {
|
|
246
|
-
computeProperties(this, start, end, e);
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
Object.defineProperties(EllipsoidRhumbLine.prototype, {
|
|
250
|
-
/**
|
|
251
|
-
* Gets the ellipsoid.
|
|
252
|
-
* @memberof EllipsoidRhumbLine.prototype
|
|
253
|
-
* @type {Ellipsoid}
|
|
254
|
-
* @readonly
|
|
255
|
-
*/
|
|
256
|
-
ellipsoid: {
|
|
257
|
-
get: function() {
|
|
258
|
-
return this._ellipsoid;
|
|
259
|
-
}
|
|
260
|
-
},
|
|
261
|
-
/**
|
|
262
|
-
* Gets the surface distance between the start and end point
|
|
263
|
-
* @memberof EllipsoidRhumbLine.prototype
|
|
264
|
-
* @type {number}
|
|
265
|
-
* @readonly
|
|
266
|
-
*/
|
|
267
|
-
surfaceDistance: {
|
|
268
|
-
get: function() {
|
|
269
|
-
Check_default.defined("distance", this._distance);
|
|
270
|
-
return this._distance;
|
|
271
|
-
}
|
|
272
|
-
},
|
|
273
|
-
/**
|
|
274
|
-
* Gets the initial planetodetic point on the path.
|
|
275
|
-
* @memberof EllipsoidRhumbLine.prototype
|
|
276
|
-
* @type {Cartographic}
|
|
277
|
-
* @readonly
|
|
278
|
-
*/
|
|
279
|
-
start: {
|
|
280
|
-
get: function() {
|
|
281
|
-
return this._start;
|
|
282
|
-
}
|
|
283
|
-
},
|
|
284
|
-
/**
|
|
285
|
-
* Gets the final planetodetic point on the path.
|
|
286
|
-
* @memberof EllipsoidRhumbLine.prototype
|
|
287
|
-
* @type {Cartographic}
|
|
288
|
-
* @readonly
|
|
289
|
-
*/
|
|
290
|
-
end: {
|
|
291
|
-
get: function() {
|
|
292
|
-
return this._end;
|
|
293
|
-
}
|
|
294
|
-
},
|
|
295
|
-
/**
|
|
296
|
-
* Gets the heading from the start point to the end point.
|
|
297
|
-
* @memberof EllipsoidRhumbLine.prototype
|
|
298
|
-
* @type {number}
|
|
299
|
-
* @readonly
|
|
300
|
-
*/
|
|
301
|
-
heading: {
|
|
302
|
-
get: function() {
|
|
303
|
-
Check_default.defined("distance", this._distance);
|
|
304
|
-
return this._heading;
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
});
|
|
308
|
-
EllipsoidRhumbLine.fromStartHeadingDistance = function(start, heading, distance, ellipsoid, result) {
|
|
309
|
-
Check_default.defined("start", start);
|
|
310
|
-
Check_default.defined("heading", heading);
|
|
311
|
-
Check_default.defined("distance", distance);
|
|
312
|
-
Check_default.typeOf.number.greaterThan("distance", distance, 0);
|
|
313
|
-
const e = defaultValue_default(ellipsoid, Ellipsoid_default.WGS84);
|
|
314
|
-
const major = e.maximumRadius;
|
|
315
|
-
const minor = e.minimumRadius;
|
|
316
|
-
const majorSquared = major * major;
|
|
317
|
-
const minorSquared = minor * minor;
|
|
318
|
-
const ellipticity = Math.sqrt((majorSquared - minorSquared) / majorSquared);
|
|
319
|
-
heading = Math_default.negativePiToPi(heading);
|
|
320
|
-
const end = interpolateUsingSurfaceDistance(
|
|
321
|
-
start,
|
|
322
|
-
heading,
|
|
323
|
-
distance,
|
|
324
|
-
e.maximumRadius,
|
|
325
|
-
ellipticity
|
|
326
|
-
);
|
|
327
|
-
if (!defined_default(result) || defined_default(ellipsoid) && !ellipsoid.equals(result.ellipsoid)) {
|
|
328
|
-
return new EllipsoidRhumbLine(start, end, e);
|
|
329
|
-
}
|
|
330
|
-
result.setEndPoints(start, end);
|
|
331
|
-
return result;
|
|
332
|
-
};
|
|
333
|
-
EllipsoidRhumbLine.prototype.setEndPoints = function(start, end) {
|
|
334
|
-
Check_default.defined("start", start);
|
|
335
|
-
Check_default.defined("end", end);
|
|
336
|
-
computeProperties(this, start, end, this._ellipsoid);
|
|
337
|
-
};
|
|
338
|
-
EllipsoidRhumbLine.prototype.interpolateUsingFraction = function(fraction, result) {
|
|
339
|
-
return this.interpolateUsingSurfaceDistance(
|
|
340
|
-
fraction * this._distance,
|
|
341
|
-
result
|
|
342
|
-
);
|
|
343
|
-
};
|
|
344
|
-
EllipsoidRhumbLine.prototype.interpolateUsingSurfaceDistance = function(distance, result) {
|
|
345
|
-
Check_default.typeOf.number("distance", distance);
|
|
346
|
-
if (!defined_default(this._distance) || this._distance === 0) {
|
|
347
|
-
throw new DeveloperError_default(
|
|
348
|
-
"EllipsoidRhumbLine must have distinct start and end set."
|
|
349
|
-
);
|
|
350
|
-
}
|
|
351
|
-
return interpolateUsingSurfaceDistance(
|
|
352
|
-
this._start,
|
|
353
|
-
this._heading,
|
|
354
|
-
distance,
|
|
355
|
-
this._ellipsoid.maximumRadius,
|
|
356
|
-
this._ellipticity,
|
|
357
|
-
result
|
|
358
|
-
);
|
|
359
|
-
};
|
|
360
|
-
EllipsoidRhumbLine.prototype.findIntersectionWithLongitude = function(intersectionLongitude, result) {
|
|
361
|
-
Check_default.typeOf.number("intersectionLongitude", intersectionLongitude);
|
|
362
|
-
if (!defined_default(this._distance) || this._distance === 0) {
|
|
363
|
-
throw new DeveloperError_default(
|
|
364
|
-
"EllipsoidRhumbLine must have distinct start and end set."
|
|
365
|
-
);
|
|
366
|
-
}
|
|
367
|
-
const ellipticity = this._ellipticity;
|
|
368
|
-
const heading = this._heading;
|
|
369
|
-
const absHeading = Math.abs(heading);
|
|
370
|
-
const start = this._start;
|
|
371
|
-
intersectionLongitude = Math_default.negativePiToPi(intersectionLongitude);
|
|
372
|
-
if (Math_default.equalsEpsilon(
|
|
373
|
-
Math.abs(intersectionLongitude),
|
|
374
|
-
Math.PI,
|
|
375
|
-
Math_default.EPSILON14
|
|
376
|
-
)) {
|
|
377
|
-
intersectionLongitude = Math_default.sign(start.longitude) * Math.PI;
|
|
378
|
-
}
|
|
379
|
-
if (!defined_default(result)) {
|
|
380
|
-
result = new Cartographic_default();
|
|
381
|
-
}
|
|
382
|
-
if (Math.abs(Math_default.PI_OVER_TWO - absHeading) <= Math_default.EPSILON8) {
|
|
383
|
-
result.longitude = intersectionLongitude;
|
|
384
|
-
result.latitude = start.latitude;
|
|
385
|
-
result.height = 0;
|
|
386
|
-
return result;
|
|
387
|
-
} else if (Math_default.equalsEpsilon(
|
|
388
|
-
Math.abs(Math_default.PI_OVER_TWO - absHeading),
|
|
389
|
-
Math_default.PI_OVER_TWO,
|
|
390
|
-
Math_default.EPSILON8
|
|
391
|
-
)) {
|
|
392
|
-
if (Math_default.equalsEpsilon(
|
|
393
|
-
intersectionLongitude,
|
|
394
|
-
start.longitude,
|
|
395
|
-
Math_default.EPSILON12
|
|
396
|
-
)) {
|
|
397
|
-
return void 0;
|
|
398
|
-
}
|
|
399
|
-
result.longitude = intersectionLongitude;
|
|
400
|
-
result.latitude = Math_default.PI_OVER_TWO * Math_default.sign(Math_default.PI_OVER_TWO - heading);
|
|
401
|
-
result.height = 0;
|
|
402
|
-
return result;
|
|
403
|
-
}
|
|
404
|
-
const phi1 = start.latitude;
|
|
405
|
-
const eSinPhi1 = ellipticity * Math.sin(phi1);
|
|
406
|
-
const leftComponent = Math.tan(0.5 * (Math_default.PI_OVER_TWO + phi1)) * Math.exp((intersectionLongitude - start.longitude) / Math.tan(heading));
|
|
407
|
-
const denominator = (1 + eSinPhi1) / (1 - eSinPhi1);
|
|
408
|
-
let newPhi = start.latitude;
|
|
409
|
-
let phi;
|
|
410
|
-
do {
|
|
411
|
-
phi = newPhi;
|
|
412
|
-
const eSinPhi = ellipticity * Math.sin(phi);
|
|
413
|
-
const numerator = (1 + eSinPhi) / (1 - eSinPhi);
|
|
414
|
-
newPhi = 2 * Math.atan(
|
|
415
|
-
leftComponent * Math.pow(numerator / denominator, ellipticity / 2)
|
|
416
|
-
) - Math_default.PI_OVER_TWO;
|
|
417
|
-
} while (!Math_default.equalsEpsilon(newPhi, phi, Math_default.EPSILON12));
|
|
418
|
-
result.longitude = intersectionLongitude;
|
|
419
|
-
result.latitude = newPhi;
|
|
420
|
-
result.height = 0;
|
|
421
|
-
return result;
|
|
422
|
-
};
|
|
423
|
-
EllipsoidRhumbLine.prototype.findIntersectionWithLatitude = function(intersectionLatitude, result) {
|
|
424
|
-
Check_default.typeOf.number("intersectionLatitude", intersectionLatitude);
|
|
425
|
-
if (!defined_default(this._distance) || this._distance === 0) {
|
|
426
|
-
throw new DeveloperError_default(
|
|
427
|
-
"EllipsoidRhumbLine must have distinct start and end set."
|
|
428
|
-
);
|
|
429
|
-
}
|
|
430
|
-
const ellipticity = this._ellipticity;
|
|
431
|
-
const heading = this._heading;
|
|
432
|
-
const start = this._start;
|
|
433
|
-
if (Math_default.equalsEpsilon(
|
|
434
|
-
Math.abs(heading),
|
|
435
|
-
Math_default.PI_OVER_TWO,
|
|
436
|
-
Math_default.EPSILON8
|
|
437
|
-
)) {
|
|
438
|
-
return;
|
|
439
|
-
}
|
|
440
|
-
const sigma1 = calculateSigma(ellipticity, start.latitude);
|
|
441
|
-
const sigma2 = calculateSigma(ellipticity, intersectionLatitude);
|
|
442
|
-
const deltaLongitude = Math.tan(heading) * (sigma2 - sigma1);
|
|
443
|
-
const longitude = Math_default.negativePiToPi(start.longitude + deltaLongitude);
|
|
444
|
-
if (defined_default(result)) {
|
|
445
|
-
result.longitude = longitude;
|
|
446
|
-
result.latitude = intersectionLatitude;
|
|
447
|
-
result.height = 0;
|
|
448
|
-
return result;
|
|
449
|
-
}
|
|
450
|
-
return new Cartographic_default(longitude, intersectionLatitude, 0);
|
|
451
|
-
};
|
|
452
|
-
var EllipsoidRhumbLine_default = EllipsoidRhumbLine;
|
|
453
|
-
|
|
454
|
-
export {
|
|
455
|
-
EllipsoidRhumbLine_default
|
|
456
|
-
};
|