deeptwins-cesium-engine 0.1.2 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Build/Workers/chunk-2HWLF3FT.js +837 -0
- package/Build/Workers/chunk-2KXMJ5XS.js +3792 -0
- package/Build/Workers/chunk-2NPCLB3H.js +56 -0
- package/Build/Workers/chunk-2ZHQTIBH.js +1483 -0
- package/Build/Workers/chunk-3GLYOW63.js +352 -0
- package/Build/Workers/chunk-3L22KMPU.js +219 -0
- package/Build/Workers/chunk-3Q6V2B2I.js +73 -0
- package/Build/Workers/chunk-3QOKKRIG.js +387 -0
- package/Build/Workers/chunk-44YZFGRH.js +1800 -0
- package/Build/Workers/chunk-45VV4SBO.js +2342 -0
- package/Build/Workers/chunk-4EJ4AA2S.js +368 -0
- package/Build/Workers/chunk-4IJFHUL6.js +414 -0
- package/Build/Workers/chunk-4K3V5CGW.js +454 -0
- package/Build/Workers/chunk-4M4QL6KJ.js +305 -0
- package/Build/Workers/chunk-4YNRIEQ6.js +288 -0
- package/Build/Workers/chunk-56CVDPH5.js +352 -0
- package/Build/Workers/chunk-5CTAAPXH.js +1483 -0
- package/Build/Workers/chunk-5ISZ6NJD.js +102 -0
- package/Build/Workers/chunk-5SDHYIOS.js +56 -0
- package/Build/Workers/chunk-66TGUMCU.js +2719 -0
- package/Build/Workers/chunk-6EJMTDQJ.js +163 -0
- package/Build/Workers/chunk-6VWXYSMH.js +959 -0
- package/Build/Workers/chunk-6VZ7VB2Q.js +241 -0
- package/Build/Workers/chunk-7AMRE57Q.js +301 -0
- package/Build/Workers/chunk-7DH6C33H.js +398 -0
- package/Build/Workers/chunk-7VUS3FVE.js +38 -0
- package/Build/Workers/chunk-7Y3ZA6H3.js +198 -0
- package/Build/Workers/chunk-A6BMHZNA.js +38 -0
- package/Build/Workers/chunk-A7XY2MN7.js +171 -0
- package/Build/Workers/chunk-AC7ND63S.js +57 -0
- package/Build/Workers/chunk-AHCZ757M.js +9230 -0
- package/Build/Workers/chunk-ANOA7E7F.js +56 -0
- package/Build/Workers/chunk-AYO5HHV6.js +789 -0
- package/Build/Workers/chunk-BE2N56VZ.js +1344 -0
- package/Build/Workers/chunk-BR3BPM64.js +9230 -0
- package/Build/Workers/chunk-BVMRWGOK.js +455 -0
- package/Build/Workers/chunk-BXEL2NX7.js +455 -0
- package/Build/Workers/chunk-C5BO2JCG.js +278 -0
- package/Build/Workers/chunk-CIRQNZVR.js +301 -0
- package/Build/Workers/chunk-CM67CQME.js +305 -0
- package/Build/Workers/chunk-D3QIW4DH.js +630 -0
- package/Build/Workers/chunk-E5W7QIGZ.js +511 -0
- package/Build/Workers/chunk-E6CYGUJI.js +1054 -0
- package/Build/Workers/chunk-EIZ23IOX.js +414 -0
- package/Build/Workers/chunk-EIZJUMQY.js +101 -0
- package/Build/Workers/chunk-EXTMZJXB.js +82 -0
- package/Build/Workers/chunk-EYOOSIBW.js +682 -0
- package/Build/Workers/chunk-F37WADVC.js +1054 -0
- package/Build/Workers/chunk-FIWPJFHX.js +101 -0
- package/Build/Workers/chunk-FM32TNGT.js +198 -0
- package/Build/Workers/chunk-FOMYIEIB.js +476 -0
- package/Build/Workers/chunk-FWYDLSVQ.js +97 -0
- package/Build/Workers/chunk-HGZR6CZF.js +1067 -0
- package/Build/Workers/chunk-HIXHDABG.js +288 -0
- package/Build/Workers/chunk-HMCCZZWE.js +97 -0
- package/Build/Workers/chunk-HW54WHGM.js +2719 -0
- package/Build/Workers/chunk-IHYAI7GF.js +973 -0
- package/Build/Workers/chunk-INLQ7LVK.js +837 -0
- package/Build/Workers/chunk-IQMESTCB.js +124 -0
- package/Build/Workers/chunk-J4PISUNT.js +2342 -0
- package/Build/Workers/chunk-JSWU557I.js +693 -0
- package/Build/Workers/chunk-KHONDSQ7.js +693 -0
- package/Build/Workers/chunk-KLUL2SOE.js +352 -0
- package/Build/Workers/chunk-KMBLKQCC.js +1992 -0
- package/Build/Workers/chunk-KOTWWQN7.js +171 -0
- package/Build/Workers/chunk-KWV6ZTF4.js +163 -0
- package/Build/Workers/chunk-LSEFPQHG.js +476 -0
- package/Build/Workers/chunk-M66X4O24.js +44 -0
- package/Build/Workers/chunk-M6IXKBC7.js +1992 -0
- package/Build/Workers/chunk-MFUC3D5C.js +162 -0
- package/Build/Workers/chunk-MRMNELAH.js +82 -0
- package/Build/Workers/chunk-N3NUA5H2.js +3792 -0
- package/Build/Workers/chunk-NFB2NXJN.js +138 -0
- package/Build/Workers/chunk-NQAXBK4K.js +789 -0
- package/Build/Workers/chunk-NUGQWV6S.js +352 -0
- package/Build/Workers/chunk-O7S7WL7K.js +278 -0
- package/Build/Workers/chunk-ODZYB26X.js +1287 -0
- package/Build/Workers/chunk-OEHJY463.js +3201 -0
- package/Build/Workers/chunk-OMMRNMXF.js +44 -0
- package/Build/Workers/chunk-OZ3CQDO3.js +138 -0
- package/Build/Workers/chunk-PNXBG64I.js +219 -0
- package/Build/Workers/chunk-PYR35GK4.js +973 -0
- package/Build/Workers/chunk-Q4CXGW74.js +57 -0
- package/Build/Workers/chunk-QGISLKCW.js +147 -0
- package/Build/Workers/chunk-QQHVOJW6.js +497 -0
- package/Build/Workers/chunk-QWCMMRJW.js +58 -0
- package/Build/Workers/chunk-RDEZCHF4.js +398 -0
- package/Build/Workers/chunk-SJTE7FVN.js +778 -0
- package/Build/Workers/chunk-SM5T67LR.js +162 -0
- package/Build/Workers/chunk-T27NNXEU.js +58 -0
- package/Build/Workers/chunk-T4J5BWUO.js +511 -0
- package/Build/Workers/chunk-T6JS4BRN.js +140 -0
- package/Build/Workers/chunk-UH6DUQBW.js +140 -0
- package/Build/Workers/chunk-UJAH6XKF.js +73 -0
- package/Build/Workers/chunk-UKSTJ2PH.js +454 -0
- package/Build/Workers/chunk-UQCDCCZ7.js +368 -0
- package/Build/Workers/chunk-UXIFNEA3.js +1287 -0
- package/Build/Workers/chunk-UXJ6J5L7.js +56 -0
- package/Build/Workers/chunk-V4VUAZXI.js +1800 -0
- package/Build/Workers/chunk-VQH2YXO2.js +497 -0
- package/Build/Workers/chunk-VXKCLSE4.js +241 -0
- package/Build/Workers/chunk-W3U6YBEI.js +280 -0
- package/Build/Workers/chunk-W75ZVFKP.js +778 -0
- package/Build/Workers/chunk-WCDFJYFB.js +1344 -0
- package/Build/Workers/chunk-WME5M6W3.js +630 -0
- package/Build/Workers/chunk-XDQBQB64.js +1067 -0
- package/Build/Workers/chunk-Y6HOIWE5.js +959 -0
- package/Build/Workers/chunk-YEMC2ZOR.js +147 -0
- package/Build/Workers/chunk-YWNF3TPE.js +682 -0
- package/Build/Workers/chunk-Z55VGWJP.js +280 -0
- package/Build/Workers/chunk-Z5YWP24C.js +124 -0
- package/Build/Workers/chunk-ZHXCWUJB.js +387 -0
- package/Build/Workers/chunk-ZIMPUF2I.js +102 -0
- package/Build/Workers/chunk-ZKDWYQKC.js +3201 -0
- package/Build/Workers/combineGeometry.js +24 -22
- package/Build/Workers/createBoxGeometry.js +18 -16
- package/Build/Workers/createBoxOutlineGeometry.js +23 -25
- package/Build/Workers/createCircleGeometry.js +29 -27
- package/Build/Workers/createCircleOutlineGeometry.js +22 -20
- package/Build/Workers/createCoplanarPolygonGeometry.js +43 -43
- package/Build/Workers/createCoplanarPolygonOutlineGeometry.js +37 -35
- package/Build/Workers/createCorridorGeometry.js +46 -49
- package/Build/Workers/createCorridorOutlineGeometry.js +40 -43
- package/Build/Workers/createCylinderGeometry.js +20 -18
- package/Build/Workers/createCylinderOutlineGeometry.js +27 -25
- package/Build/Workers/createEllipseGeometry.js +28 -25
- package/Build/Workers/createEllipseOutlineGeometry.js +21 -18
- package/Build/Workers/createEllipsoidGeometry.js +19 -17
- package/Build/Workers/createEllipsoidOutlineGeometry.js +18 -16
- package/Build/Workers/createFrustumGeometry.js +18 -16
- package/Build/Workers/createFrustumOutlineGeometry.js +21 -21
- package/Build/Workers/createGeometry.js +31 -26
- package/Build/Workers/createGroundPolylineGeometry.js +188 -135
- package/Build/Workers/createPlaneGeometry.js +22 -21
- package/Build/Workers/createPlaneOutlineGeometry.js +15 -13
- package/Build/Workers/createPolygonGeometry.js +51 -52
- package/Build/Workers/createPolygonOutlineGeometry.js +43 -44
- package/Build/Workers/createPolylineGeometry.js +37 -40
- package/Build/Workers/createPolylineVolumeGeometry.js +41 -44
- package/Build/Workers/createPolylineVolumeOutlineGeometry.js +36 -39
- package/Build/Workers/createRectangleGeometry.js +47 -53
- package/Build/Workers/createRectangleOutlineGeometry.js +32 -33
- package/Build/Workers/createSimplePolylineGeometry.js +33 -34
- package/Build/Workers/createSphereGeometry.js +20 -20
- package/Build/Workers/createSphereOutlineGeometry.js +19 -19
- package/Build/Workers/createTaskProcessorWorker.js +3 -3
- package/Build/Workers/createVectorTileClampedPolylines.js +16 -14
- package/Build/Workers/createVectorTileGeometries.js +24 -22
- package/Build/Workers/createVectorTilePoints.js +15 -13
- package/Build/Workers/createVectorTilePolygons.js +24 -21
- package/Build/Workers/createVectorTilePolylines.js +16 -14
- package/Build/Workers/createVerticesFromCesium3DTilesTerrain.js +25 -25
- package/Build/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +29 -27
- package/Build/Workers/createVerticesFromHeightmap.js +42 -63
- package/Build/Workers/createVerticesFromQuantizedTerrainMesh.js +26 -280
- package/Build/Workers/createWallGeometry.js +35 -36
- package/Build/Workers/createWallOutlineGeometry.js +33 -34
- package/Build/Workers/decodeDraco.js +10 -11
- package/Build/Workers/decodeGoogleEarthEnterprisePacket.js +5 -5
- package/Build/Workers/decodeI3S.js +16 -20
- package/Build/Workers/gaussianSplatSorter.js +4 -4
- package/Build/Workers/gaussianSplatTextureGenerator.js +4 -4
- package/Build/Workers/incrementallyBuildTerrainPicker.js +20 -12
- package/Build/Workers/transcodeKTX2.js +42 -14
- package/Build/Workers/transferTypedArrayTest.js +1 -1
- package/Build/Workers/upsampleQuantizedTerrainMesh.js +24 -21
- package/Build/Workers/upsampleVerticesFromCesium3DTilesTerrain.js +25 -25
- package/Source/Shaders/BillboardCollectionFS.js +85 -81
- package/Source/Shaders/BillboardCollectionVS.js +60 -118
- package/Source/Shaders/Builtin/Constants/passCesium3DTile.js +1 -1
- package/Source/Shaders/Builtin/Constants/passCesium3DTileClassification.js +1 -1
- package/Source/Shaders/Builtin/Constants/passCesium3DTileClassificationIgnoreShow.js +1 -1
- package/Source/Shaders/Builtin/Constants/passCesium3DTileEdges.js +12 -0
- package/Source/Shaders/Builtin/Constants/passCesium3DTileEdgesDirect.js +11 -0
- package/Source/Shaders/Builtin/Constants/passGaussianSplats.js +11 -0
- package/Source/Shaders/Builtin/Constants/passOpaque.js +1 -1
- package/Source/Shaders/Builtin/Constants/passOverlay.js +1 -1
- package/Source/Shaders/Builtin/Constants/passTranslucent.js +1 -1
- package/Source/Shaders/Builtin/Constants/passVoxels.js +1 -1
- package/Source/Shaders/Builtin/CzmBuiltins.js +12 -0
- package/Source/Shaders/Builtin/Functions/columbusViewMorph.js +8 -1
- package/Source/Shaders/Builtin/Functions/computeTextureTransform.js +25 -0
- package/Source/Shaders/Builtin/Functions/decodeRGB8.js +24 -0
- package/Source/Shaders/Builtin/Functions/modelToWindowCoordinates.js +2 -1
- package/Source/Shaders/Builtin/Functions/unpackTexture.js +37 -0
- package/Source/Shaders/Builtin/Functions/windowToEyeCoordinates.js +0 -1
- package/Source/Shaders/EllipsoidVS.js +4 -4
- package/Source/Shaders/FXAA3_11.js +2 -0
- package/Source/Shaders/GlobeFS.js +22 -0
- package/Source/Shaders/GlobeVS.js +3 -2
- package/Source/Shaders/Model/MaterialStageFS.js +50 -20
- package/Source/Shaders/Model/MetadataStageFS.js +2 -1
- package/Source/Shaders/Model/MetadataStageVS.js +2 -1
- package/Source/Shaders/Model/ModelFS.js +32 -2
- package/Source/Shaders/Model/ModelVS.js +15 -1
- package/Source/Shaders/Model/PointCloudStylingStageVS.js +2 -1
- package/Source/Shaders/Model/PrimitiveOutlineStageFS.js +0 -1
- package/Source/Shaders/PointPrimitiveCollectionVS.js +8 -39
- package/Source/Shaders/PolygonSignedDistanceFS.js +64 -33
- package/Source/Shaders/PolylineCommon.js +1 -1
- package/Source/Shaders/ShadowVolumeAppearanceFS.js +7 -15
- package/Source/Shaders/SkyAtmosphereVS.js +2 -1
- package/Source/Shaders/Voxels/IntersectBox.js +20 -33
- package/Source/Shaders/Voxels/IntersectCylinder.js +28 -32
- package/Source/Shaders/Voxels/IntersectDepth.js +10 -6
- package/Source/Shaders/Voxels/IntersectEllipsoid.js +12 -20
- package/Source/Shaders/Voxels/IntersectLongitude.js +21 -9
- package/Source/Shaders/Voxels/Intersection.js +3 -5
- package/Source/Shaders/Voxels/IntersectionUtils.js +2 -1
- package/Source/Shaders/Voxels/Megatexture.js +15 -83
- package/Source/Shaders/Voxels/Octree.js +53 -61
- package/Source/Shaders/Voxels/VoxelFS.js +67 -52
- package/Source/Shaders/Voxels/VoxelUtils.js +0 -19
- package/index.js +346 -261
- package/package.json +1 -1
- package/Source/Shaders/Voxels/IntersectClippingPlanes.js +0 -80
- package/Source/Shaders/Voxels/convertUvToBox.js +0 -46
- package/Source/Shaders/Voxels/convertUvToCylinder.js +0 -101
- package/Source/Shaders/Voxels/convertUvToEllipsoid.js +0 -141
|
@@ -0,0 +1,3792 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
|
4
|
+
* Version 0.1.4
|
|
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
|
+
TerrainProvider_default
|
|
28
|
+
} from "./chunk-56CVDPH5.js";
|
|
29
|
+
import {
|
|
30
|
+
EllipsoidalOccluder_default,
|
|
31
|
+
TerrainEncoding_default,
|
|
32
|
+
VerticalExaggeration_default
|
|
33
|
+
} from "./chunk-NQAXBK4K.js";
|
|
34
|
+
import {
|
|
35
|
+
WebMercatorProjection_default
|
|
36
|
+
} from "./chunk-QGISLKCW.js";
|
|
37
|
+
import {
|
|
38
|
+
OrientedBoundingBox_default
|
|
39
|
+
} from "./chunk-2HWLF3FT.js";
|
|
40
|
+
import {
|
|
41
|
+
AttributeCompression_default
|
|
42
|
+
} from "./chunk-4K3V5CGW.js";
|
|
43
|
+
import {
|
|
44
|
+
AxisAlignedBoundingBox_default
|
|
45
|
+
} from "./chunk-MFUC3D5C.js";
|
|
46
|
+
import {
|
|
47
|
+
IntersectionTests_default,
|
|
48
|
+
Ray_default
|
|
49
|
+
} from "./chunk-BE2N56VZ.js";
|
|
50
|
+
import {
|
|
51
|
+
BoundingSphere_default,
|
|
52
|
+
Interval_default
|
|
53
|
+
} from "./chunk-ODZYB26X.js";
|
|
54
|
+
import {
|
|
55
|
+
Event_default,
|
|
56
|
+
Rectangle_default,
|
|
57
|
+
Resource_default,
|
|
58
|
+
Transforms_default,
|
|
59
|
+
binarySearch_default,
|
|
60
|
+
buildModuleUrl_default,
|
|
61
|
+
isCrossOriginUrl_default,
|
|
62
|
+
require_URI
|
|
63
|
+
} from "./chunk-BR3BPM64.js";
|
|
64
|
+
import {
|
|
65
|
+
Matrix4_default
|
|
66
|
+
} from "./chunk-OEHJY463.js";
|
|
67
|
+
import {
|
|
68
|
+
ComponentDatatype_default
|
|
69
|
+
} from "./chunk-C5BO2JCG.js";
|
|
70
|
+
import {
|
|
71
|
+
RuntimeError_default
|
|
72
|
+
} from "./chunk-T27NNXEU.js";
|
|
73
|
+
import {
|
|
74
|
+
Cartesian2_default,
|
|
75
|
+
Cartographic_default,
|
|
76
|
+
Ellipsoid_default,
|
|
77
|
+
FeatureDetection_default
|
|
78
|
+
} from "./chunk-M6IXKBC7.js";
|
|
79
|
+
import {
|
|
80
|
+
Cartesian3_default,
|
|
81
|
+
Frozen_default,
|
|
82
|
+
Matrix3_default
|
|
83
|
+
} from "./chunk-J4PISUNT.js";
|
|
84
|
+
import {
|
|
85
|
+
Math_default
|
|
86
|
+
} from "./chunk-VQH2YXO2.js";
|
|
87
|
+
import {
|
|
88
|
+
Check_default,
|
|
89
|
+
DeveloperError_default
|
|
90
|
+
} from "./chunk-KWV6ZTF4.js";
|
|
91
|
+
import {
|
|
92
|
+
__toESM,
|
|
93
|
+
defined_default
|
|
94
|
+
} from "./chunk-MRMNELAH.js";
|
|
95
|
+
|
|
96
|
+
// packages/engine/node_modules/meshoptimizer/meshopt_encoder.js
|
|
97
|
+
var MeshoptEncoder = (function() {
|
|
98
|
+
var wasm = "b9H79Tebbbe9ok9Geueu9Geub9Gbb9Gruuuuuuueu9Gvuuuuueu9Gduueu9Gluuuueu9Gvuuuuub9Gouuuuuub9Gluuuub9GiuuueuiE8AdilveoveovrrwrrrDDoDrbqqbelve9Weiiviebeoweuecj:Gdkr:PlCo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9mW4W2be8A9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWVbd8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9c9V919U9KbiE9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949wWV79P9V9UblY9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWVbv8E9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWV9c9V919U9Kbo8A9TW79O9V9Wt9FW9U9J9V9KW69U9KW949wWV79P9V9UbrE9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JWbwa9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JW9c9V919U9KbDL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9p9JtbqK9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9r919HtbkL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVT949WbxY9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVJ9V29VVbmE9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OWbza9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OW9ttV9P9WbHa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9WbOK9TW79O9V9Wt9F79W9Ht9P9H29t9VVt9sW9T9H9WbAl79IV9RbXDwebcekdKYq:zf8Adbk;wadhud9:8Jjjjjbc;qw9Rgr8KjjjjbcbhwdnaeTmbabcbyd;i:I:cjbaoaocb9iEgDc:GeV86bbarc;adfcbcjdz:xjjjb8AdnaiTmbarc;adfadalz:wjjjb8Akarc;abfalfcbcbcjdal9RalcFe0Ez:xjjjb8Aarc;abfarc;adfalz:wjjjb8Aar9cb83iUar9cb83i8War9cb83iyar9cb83iaar9cb83iKar9cb83izar9cb83iwar9cb83ibcj;abal9Uc;WFbGcjdalca0Ehqdnaicd6mbavcd9imbaDTmbadcefhkaqci2gxal2hmarc;alfclfhParc;qlfceVhsarc;qofclVhzcbhHincdhOcbhAdnavci6mbar9cb83i;Ooar9cb83i;Goar9cb83i;yoar9cb83i;qoadaHfgoybbhCcbhXincbhwcbhQdninaoalfhLaoybbgKaC7aQVhQawcP0meaLhoaKhCawcefgwaXfai6mbkkcbhCarc;qofhwincwhYcwh8AdnaQaC93gocFeGgEcs0mbclh8AaEci0mbcdcbaEEh8Akdnaocw4cFeGgEcs0mbclhYaEci0mbcdcbaEEhYkaYa8AfhEawydbh3cwhYcwh8Adnaocz4cFeGg5cs0mbclh8Aa5ci0mbcdcba5Eh8AkaEa3fhEdnaocFFFFb0mbclhYaocFFF8F0mbcbcdaocjjjw6EhYkawaEa8AfaYfBdbawclfhwaCcefgCcw9hmbkaLhoaKhCaXczfgXai6mbkcbhocehwazhQinawaoaQydbarc;qofaocdtfydb6EhoaQclfhQawcefgwcw9hmbkaoclthAcihOkcbhEarc;qlfcbcjdz:xjjjb8AarcbBd;ilar9cb83i;aladh8Eaqh8Fakh3inarc;qlfadaEaEcb9h9Ral2falz:wjjjb8Aaia8Faia8F6EhadnaqaiaE9RaEaqfai6EgKcsfc9WGgoaK9nmbarc;qofaKfcbaoaK9Rz:xjjjb8AkadaEal2fhhcbhginagaAVcl4hXarc;alfagcdtfh8JaHh8Kcbh8Lina8LaHfhwdndndndndndndnagPlbedibkaKTmvahawfhoarc;qlfawfRbbhQarc;qofhwaahCinawaoRbbgYaQ9RgQcetaQcKtc8F91786bbawcefhwaoalfhoaYhQaEaCcufgC9hmbxvkkaKTmla8Kc9:Ghoa8LcitcwGh8Aarc;qlfawceVfRbbcwtarc;qlfawc9:GfRbbVhQarc;qofhwaahCinawa3aofRbbcwta8EaofRbbVgYaQ9RgQcetaQcztc8F917cFFiGa8A486bbaoalfhoawcefhwaYhQaEaCcufgC9hmbxlkkasa8Kc98GgQfhoa3aQfhYarc;qlfawc98GgQfRbbhCcwhwinaoRbbawtaCVhCaocefhoawcwfgwca9hmbxdkkaKTmdxekaKTmea8Lcith5ahaQfh8AcbhLina8ARbbhQcwhoaYhwinawRbbaotaQVhQawcefhwaocwfgoca9hmbkarc;qofaLfaQaC7aX93a5486bbaYalfhYa8Aalfh8AaQhCaLcefgLaK9hmbkka8Jydbh8AcbhLarc;qofhoincdhQcbhwinaQaoawfRbbcb9hfhQawcefgwcz9hmbkclhCcbhwinaCaoawfRbbcd0fhCawcefgwcz9hmbkcwhYcbhwinaYaoawfRbbcP0fhYawcefgwcz9hmbkaQaCaQaC6EgwaYawaY6Egwczawcz6Ea8Afh8AaoczfhoaLczfgLaK6mbka8Ja8ABdbka8Kcefh8Ka8Lcefg8Lcl9hmbkagcefggaO9hmbka8Eamfh8Ea8Faxfh8Fa3amfh3aEaxfgEai6mbkcbhocehwaPhQinawaoaQydbarc;alfaocdtfydb6EhoaQclfhQaOawcefgw9hmbkaraHcd4faAcdVaoaocdSE86bbaHclfgHal6mbkkabaefhgabcefhoalcd4g8McbaDEhkadcefh8Narc;abfceVhecbhmdndninaiam9nmearc;qofcbcjdz:xjjjb8Aagao9Rak6mdadamal2gwfhxcbhHa8Nawfhzaocbakz:xjjjbg8Fakfh3aqaiam9Ramaqfai6Egscsfgocl4cifcd4hOaoc9WGg8JThPindndndndndndndndndndnaDTmbaraHcd4fRbbgQciGPlbedlbkasTmdaxaHfhoarc;abfaHfRbbhQarc;qofhwashCinawaoRbbgYaQ9RgQcetaQcKtc8F91786bbawcefhwaoalfhoaYhQaCcufgCmbxikkasTmiaHcitcwGh8Aarc;abfaHceVfRbbcwtarc;abfaHc9:GgofRbbVhQaxaofhoarc;qofhwashCinawao8VbbgYaQ9RgQcetaQcztc8F917cFFiGa8A486bbawcefhwaoalfhoaYhQaCcufgCmbxikkaeaHc98Gg8Afhoaza8AfhYarc;abfa8AfRbbhCcwhwinaoRbbawtaCVhCaocefhoawcwfgwca9hmbkasTmdaQcl4hKaHcitcKGhEaxa8Afh8AcbhLina8ARbbhQcwhoaYhwinawRbbaotaQVhQawcefhwaocwfgoca9hmbkarc;qofaLfaQaC7aK93aE486bbaYalfhYa8Aalfh8AaQhCaLcefgLas9hmbkkaDmbcbhoxlka8JTmbcbhodninarc;qofaofgwcwf8Pibaw8Pib:e9qTmeaoczfgoa8J9pmdxbkkdnavmbcehoxikcbh8AaOhLaOhKinarc;qofa8Afgocwf8Pibhyao8Pibh8PcdhQcbhwinaQaoawfRbbcb9hfhQawcefgwcz9hmbkclhCcbhwinaCaoawfRbbcd0fhCawcefgwcz9hmbkcwhYcbhwinaYaoawfRbbcP0fhYawcefgwcz9hmbkaQaCaQaC6EgoaYaoaY6Egoczaocz6EaKfhKaocucbaya8P:e9cb9sEgwaoaw6EaLfhLa8Aczfg8Aa8J9pmdxbkka8FaHcd4fgoaoRbbcdaHcetcoGtV86bbxikdnaLas6mbaKas6mba8FaHcd4fgoaoRbbciaHcetcoGtV86bbaga39Ras6mra3arc;qofasz:wjjjbasfh3xikaLaK9phoka8FaHcd4fgwawRbbaoaHcetcoGtV86bbkaga39RaO6mla3cbaOz:xjjjbgaaOfhKdndna8JmbaPhoxekdnagaK9RcK9pmbaPhoxekaocdtc:q:G:cjbfcj:G:cjbaDEg3ydxghcetc;:FFFeGhAcuhEcuahtcu7cFeGh8Ecbh8Karc;qofhQinarc;qofa8KfhXczh8AdndndnahPDbeeeeeeedekcucbaXcwf8PibaX8Pib:e9cb9sEh8AxekcbhoaAh8Aina8Aa8EaQaofRbb9nfh8Aaocefgocz9hmbkkcih5cbhYinczhwdndndna3aYcdtfydbgLPDbeeeeeeedekcucbaXcwf8PibaX8Pib:e9cb9sEhwxekaLcetc;:FFFeGhwcuaLtcu7cFeGhCcbhoinawaCaQaofRbb9nfhwaocefgocz9hmbkkdndnawa8A6mbaLaE9hmeawa8A9hmea3a5cdtfydbcwSmekaYh5awh8AkaYcefgYci9hmbkaaa8Kco4fgoaoRbba5a8Kci4coGtV86bbdndndna3a5cdtfydbgEPDdbbbbbbbebkdncwaE9Tg5TmbcuaEtcu7hwdndnaEceSmbcbh8LaQhXinaXhoa5hYcbhCinaoRbbg8AawcFeGgLa8AaL6EaCaEtVhCaocefhoaYcufgYmbkaKaC86bbaXa5fhXaKcefhKa8La5fg8Lcz6mbxdkkcbh8LaQhXinaXhoa5hYcbhCinaoRbbg8AawcFeGgLa8AaL6EaCcetVhCaocefhoaYcufgYmbkaKaC:T9cFe:d9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:9ca188bbaXa5fhXaKcefhKa8La5fg8Lcz6mbkkcbhoinaKaQaofRbbgC86bbaKaCawcFeG9pfhKaocefgocz9hmbxikkdnaEceSmbinaKcb86bbaKcefhKxbkkinaKcb86bbaKcefhKxbkkaKaX8Pbw83bwaKaX8Pbb83bbaKczfhKka8Kczfg8Ka8J9pgomeaQczfhQagaK9RcK9pmbkkaoTmlaKh3aKTmlkaHcefgHal9hmbkarc;abfaxascufal2falz:wjjjb8Aasamfhma3hoa3mbkcbhwxdkdnagao9RakalfgwcKcaaDEgQawaQ0EgC9pmbcbhwxdkdnawaQ9pmbaocbaCaw9Rgwz:xjjjbawfhokaoarc;adfalz:wjjjbalfhodnaDTmbaoara8Mz:wjjjba8Mfhokaoab9Rhwxekcbhwkarc;qwf8Kjjjjbawk5babaeadaialcdcbyd;i:I:cjbz:bjjjbk9reduaecd4gdaefgicaaica0Eabcj;abae9Uc;WFbGcjdaeca0Egifcufai9Uae2aiadfaicl4cifcd4f2fcefkmbcbabBd;i:I:cjbk;HPeLu8Jjjjjbc;ae9Rgl8Kjjjjbcbhvdnaeaici9UgocHf6mbabcbyd;m:I:cjbgrc;GeV86bbalc;abfcFecjez:xjjjb8Aal9cu83iUal9cu83i8Wal9cu83iyal9cu83iaal9cu83iKal9cu83izal9cu83iwal9cu83ibabaefc9WfhwabcefgDaofhednaiTmbcmcsarcb9kgqEhkcbhxcbhmcbhPcbhscbhzindnaeaw9nmbcbhvxikazcufhvadaPcdtfgHydbhOaHcwfydbhAaHclfydbhCcbhXdndndninalc;abfavcsGcitfgoydlhQdndndnaoydbgoaO9hmbaQaCSmekdnaoaC9hmbaQaA9hmbaXcefhXxekaoaA9hmeaQaO9hmeaXcdfhXkaXc870mdascufhvaHaXcdtgAcxGgoyd:4:G:cjbcdtfydbhQaHaoyd:0:G:cjbcdtfydbhCaHaoyd:W:G:cjbcdtfydbhOcbhodnindnalavcsGcdtfydbaQ9hmbaohXxdkcuhXavcufhvaocefgocz9hmbkkaxaQaxSgvaXce9iaXak9oVgoGfhxdndndncbcsavEaXaoEgvcs9hmbarce9imbaQaQamaQcefamSgvEgmcefSmecmcsavEhvkaDavaAc;WeGV86bbavcs9hmeaQam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaQhmxvkcPhvaDaAcPV86bbaQhmkavTmiavak9omicdhocehXazhAxlkavcufhvaXclfgXc;ab9hmbkkdnaHcecdcbaAaxSEaCaxSEcdtgvyd:W:G:cjbcdtfydbgOTaHavyd:0:G:cjbcdtfydbgCceSGaHavyd:4:G:cjbcdtfydbgQcdSGaxcb9hGaqGgLce9hmbal9cu83iUal9cu83i8Wal9cu83iyal9cu83iaal9cu83iKal9cu83izal9cu83iwal9cu83ibcbhxkcbhXascufgvhodnindnalaocsGcdtfydbaC9hmbaXhAxdkcuhAaocufhoaXcefgXcz9hmbkkcbhodnindnalavcsGcdtfydbaQ9hmbaohXxdkcuhXavcufhvaocefgocz9hmbkkaxaOaxSgKfhHdndnaAcm0mbaAcefhAxekcbcsaCaHSgvEhAaHavfhHkdndnaXcm0mbaXcefhXxekcbcsaQaHSgvEhXaHavfhHkc9:cuaKEhYcbhvaXaAcltVg8AcFeGhodndndninavc;q:G:cjbfRbbaoSmeavcefgvcz9hmbxdkkaLaOax9havcm0VVmbaDavc;WeV86bbxekaDaY86bbaea8A86bbaecefhekdnaKmbaOam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaOhmkdnaAcs9hmbaCam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaChmkdnaXcs9hmbaQam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaQhmkalascdtfaOBdbascefcsGhvdndnaAPzbeeeeeeeeeeeeeebekalavcdtfaCBdbascdfcsGhvkdndnaXPzbeeeeeeeeeeeeeebekalavcdtfaQBdbavcefcsGhvkcihoalc;abfazcitfgXaOBdlaXaCBdbazcefcsGhAcdhXavhsaHhxxekcdhoalascdtfaQBdbcehXascefcsGhsazhAkalc;abfaAcitfgvaCBdlavaQBdbalc;abfazaXfcsGcitfgvaQBdlavaOBdbaDcefhDazaofcsGhzaPcifgPai6mbkkdnaeaw9nmbcbhvxekcbhvinaeavfavc;q:G:cjbfRbb86bbavcefgvcz9hmbkaeab9Ravfhvkalc;aef8KjjjjbavkZeeucbhddninadcefgdc8F0meaeceadt0mbkkadcrfcFeGcr9Uci2cdfabci9U2cHfkmbcbabBd;m:I:cjbk:zderu8Jjjjjbcz9Rhlcbhvdnaeaicvf6mbabcbRb;m:I:cjbc;qeV86bbal9cb83iwabcefhvabaefc98fhodnaiTmbcbhecbhrcbhwindnavao6mbcbskadawcdtfydbgDalcwfaraDae9Rgeaec8F91ge7ae9Rc507grcdtfgqydb9Rgec8E91c9:Gaecdt7arVheinavcbcjeaecje6EaecFbGV86bbavcefhvaecr4gembkaqaDBdbaDheawcefgwai9hmbkkdnavao9nmbcbskavcbBbbavab9RclfhvkavkBeeucbhddninadcefgdc8F0meaeceadt0mbkkabadcwfcFeGcr9U2cvfk:dvli99dui99ludnaeTmbcuadcetcuftcu7:Zhvdndncuaicuftcu7:ZgoJbbbZMgr:lJbbb9p9DTmbar:Ohwxekcjjjj94hwkcbhicbhDinalclfIdbgrJbbbbJbbjZalIdbgq:lar:lMalcwfIdbgk:lMgr:varJbbbb9BEgrNhxaqarNhralcxfIdbhqdndnakJbbbb9GTmbaxhkxekJbbjZar:l:tgkak:maxJbbbb9GEhkJbbjZax:l:tgxax:marJbbbb9GEhrkdndnaqJbbj:;aqJbbj:;9GEgxJbbjZaxJbbjZ9FEavNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohmxekcjjjj94hmkdndnakJbbj:;akJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;akJbbbb9GEMgq:lJbbb9p9DTmbaq:OhPxekcjjjj94hPkdndnarJbbj:;arJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;arJbbbb9GEMgr:lJbbb9p9DTmbar:Ohsxekcjjjj94hskdndnadcl9hmbabaDfgzas86bbazcifam86bbazcdfaw86bbazcefaP86bbxekabaifgzas87ebazcofam87ebazclfaw87ebazcdfaP87ebkaicwfhiaDclfhDalczfhlaecufgembkkk;hlld99eud99eudnaeTmbdndncuaicuftcu7:ZgvJbbbZMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikaic;8FiGhrinabcofcicdalclfIdb:lalIdb:l9EgialcwfIdb:lalaicdtfIdb:l9EEgialcxfIdb:lalaicdtfIdb:l9EEgiarV87ebdndnJbbj:;JbbjZalaicdtfIdbJbbbb9DEgoalaicd7cdtfIdbJ;Zl:1ZNNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabcdfaq87ebdndnalaicefciGcdtfIdbJ;Zl:1ZNaoNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabaq87ebdndnaoalaicufciGcdtfIdbJ;Zl:1ZNNgoJbbj:;aoJbbj:;9GEgwJbbjZawJbbjZ9FEavNJbbbZJbbb:;aoJbbbb9GEMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikabclfai87ebabcwfhbalczfhlaecufgembkkk;gvdDue998Jjjjjbcjd9Rgo8Kjjjjbdndndnadcd4grTmbc:CucbavEhwaohdarhDinadawBdbadclfhdaDcufgDmbkavcd9hmbaeTmbarcdthqcbhkalhxinaohdaxhDarhwinadadydbgmaDydbcL4cFeGc:cufgPamaP9kEBdbaDclfhDadclfhdawcufgwmbkaxaqfhxakcefgkae9hmbxdkkaeTmekarcdthxavce9hhqcbhkindndndnaqmbarTmdc:CuhDalhdarhwinaDadydbcL4cFeGc:cufgmaDam9kEhDadclfhdawcufgwmbxdkkdndndndnavPleddbdkarTmlaohdalhDarhwinadcbaDydbcL4cFeGgmc:cufgPaPam0EBdbadclfhdaDclfhDawcufgwmbxikkarTmicbhdarhDindnaladfIdbgsJbbbb9Bmbaoadfas:8cL4cFeGgwc8Aawc8A0Ec:cufBdbkadclfhdaDcufgDmbxdkkarTmdkc:CuhDkcbhdarhminaDhwdnavceSmbaoadfydbhwkdndnaladfIdbgscjjj;8iawai9RcefgwcLt9R::NJbbbZJbbb:;asJbbbb9GEMgs:lJbbb9p9DTmbas:OhPxekcjjjj94hPkabadfaPcFFFrGawcKtVBdbadclfhdamcufgmmbkkabaxfhbalaxfhlakcefgkae9hmbkkaocjdf8Kjjjjbk:Olveue99iue99iudnaeTmbceaicufthvcuaitcu7:Zhocbhradcl9hhwcbhDindndnalcwfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohixekcjjjj94hikdndnalIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkadai9Rcd9TgkaifhidndnalclfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkadai9Rcd9ThddndnalcxfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohxxekcjjjj94hxkadaifhiaxce91avVhxdndnawmbabaDfgmai86bbamcifax86bbamcdfad86bbamcefak86bbxekabarfgmai87ebamcofax87ebamclfad87ebamcdfak87ebkarcwfhraDclfhDalczfhlaecufgembkkk;mqdQui998Jjjjjbc:qd9Rgv8Kjjjjbavc:Sefcbc;Kbz:xjjjb8AdnadTmbaiTmbdndnabaeSmbaehoxekavcuadcdtgradcFFFFi0Ecbyd;q:I:cjbHjjjjbbgoBd:SeavceBd:mdaoaearz:wjjjb8AkavcbBd:Oeav9cb83i:Geavc:Gefaoadaiavc:Sefz:pjjjbavyd:Gehwadci9UgDcbyd;q:I:cjbHjjjjbbheavc:Sefavyd:mdgqcdtfaeBdbavaqcefgrBd:mdaecbaDz:xjjjbhkavc:SefarcdtfcuaicdtaicFFFFi0Ecbyd;q:I:cjbHjjjjbbgxBdbavaqcdfgmBd:mdalc;ebfhPawheaxhrinaralIdbaPaeydbgscwascw6EcdtfIdbMUdbaeclfhearclfhraicufgimbkavc:SefamcdtfcuaDcdtadcFFFF970Ecbyd;q:I:cjbHjjjjbbgmBdbdnadci6mbaoheamhraDhiinaraxaeydbcdtfIdbaxaeclfydbcdtfIdbMaxaecwfydbcdtfIdbMUdbaecxfhearclfhraicufgimbkkaqcifhzalc;ebfhHavc;qbfhOavheavyd:KehAavyd:OehCcbhscbhrcbhXcehQinaehLaoarcx2fgKydbhPaKclfydbhdabaXcx2fgecwfaKcwfydbgYBdbaeclfadBdbaeaPBdbakarfce86bbaOaYBdwaOadBdlaOaPBdbamarcdtfcbBdbcih8AdnasTmbaLhiinaOa8AcdtfaiydbgeBdba8AaeaY9haeaP9haead9hGGfh8AaiclfhiascufgsmbkkaXcefhXcbhsinaCaAaKascdtfydbcdtgifydbcdtfgYheawaifgdydbgPhidnaPTmbdninaeydbarSmeaeclfheaicufgiTmdxbkkaeaYaPcdtfc98fydbBdbadadydbcufBdbkascefgsci9hmbkdndndna8ATmbcuhrJbbbbhEcbhdavyd:KehYavyd:OehKindnawaOadcdtfydbcdtgsfydbgeTmbaxasfgiIdbh3aialcuadadcs0EcdtfclfIdbaHaecwaecw6EcdtfIdbMg5Udba5a3:th5aecdthiaKaYasfydbcdtfheinamaeydbgscdtfgPa5aPIdbMg3Udba3aEaEa39DgPEhEasaraPEhraeclfheaic98fgimbkkadcefgda8A9hmbkarcu9hmekaQaD9pmeindnakaQfRbbmbaQhrxdkaDaQcefgQ9hmbxdkka8Acza8Acz6EhsaOheaLhOarcu9hmekkazTmbaqcdtavc:Seffcwfheinaeydbcbyd;u:I:cjbH:bjjjbbaec98fheazcufgzmbkkavc:qdf8Kjjjjbk:0leoucuaicdtgvaicFFFFi0Egocbyd;q:I:cjbHjjjjbbhralalyd9GgwcdtfarBdbalawcefBd9GabarBdbaocbyd;q:I:cjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdlcuadcdtadcFFFFi0Ecbyd;q:I:cjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdwabydbcbavz:xjjjb8AabydbhraehladhvinaralydbcdtfgoaoydbcefBdbalclfhlavcufgvmbkcbhvabydlglhoarhwaihDinaoavBdbaoclfhoawydbavfhvawclfhwaDcufgDmbkadci9Uhqdnadcd9nmbabydwhocbhvinaecwfydbhwaeclfydbhDalaeydbcdtfgbabydbgbcefBdbaoabcdtfavBdbalaDcdtfgDaDydbgDcefBdbaoaDcdtfavBdbalawcdtfgwawydbgwcefBdbaoawcdtfavBdbaecxfheaqavcefgv9hmbkkinalalydbarydb9RBdbarclfhralclfhlaicufgimbkkQbabaeadaic;G:G:cjbz:ojjjbkQbabaeadaic;i:H:cjbz:ojjjbk9DeeuabcFeaicdtz:xjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk:3vioud9:du8Jjjjjbc;Wa9Rgl8Kjjjjbcbhvalcxfcbc;Kbz:xjjjb8AalcuadcitgoadcFFFFe0Ecbyd;q:I:cjbHjjjjbbgrBdxalceBd2araeadaicezNjjjbalcuaoadcjjjjoGEcbyd;q:I:cjbHjjjjbbgwBdzadcdthednadTmbabhiinaiavBdbaiclfhiadavcefgv9hmbkkawaefhDalabBdwalawBdl9cbhqindnadTmbaq9cq9:hkarhvaDhiadheinaiav8Pibak1:NcFrG87ebavcwfhvaicdfhiaecufgembkkalclfaq:NceGcdtfydbhxalclfaq9ce98gq:NceGcdtfydbhmalc;Wbfcbcjaz:xjjjb8AaDhvadhidnadTmbinalc;Wbfav8VebcdtfgeaeydbcefBdbavcdfhvaicufgimbkkcbhvcbhiinalc;WbfavfgeydbhoaeaiBdbaoaifhiavclfgvcja9hmbkadhvdndnadTmbinalc;WbfaDamydbgicetf8VebcdtfgeaeydbgecefBdbaxaecdtfaiBdbamclfhmavcufgvmbkaq9cv9smdcbhvinabawydbcdtfavBdbawclfhwadavcefgv9hmbxdkkaq9cv9smekkcwhvcbhiinalcxfavfc98fydbcbyd;u:I:cjbH:bjjjbbaiceGheclhvcehiaeTmbkalc;Waf8Kjjjjbk:Awliuo99iud9:cbhv8Jjjjjbca9Rgocbyd:4:I:cjbBdKaocb8Pd:W:I:cjb83izaocbyd;e:I:cjbBdwaocb8Pd:8:I:cjb83ibaicd4hrdndnadmbJFFuFhwJFFuuhDJFFuuhqJFFuFhkJFFuuhxJFFuFhmxekarcdthPaehsincbhiinaoczfaifgzasaifIdbgwazIdbgDaDaw9EEUdbaoaifgzawazIdbgDaDaw9DEUdbaiclfgicx9hmbkasaPfhsavcefgvad9hmbkaoIdKhDaoIdwhwaoIdChqaoIdlhkaoIdzhxaoIdbhmkdnadTmbJbbbbJbFu9hJbbbbamax:tgmamJbbbb9DEgmakaq:tgkakam9DEgkawaD:tgwawak9DEgw:vawJbbbb9BEhwdnalmbarcdthoindndnaeclfIdbaq:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:S9cC:ghHdndnaeIdbax:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikaHai:S:ehHdndnaecwfIdbaD:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabaHai:T9cy:g:e83ibaeaofheabcwfhbadcufgdmbxdkkarcdthoindndnaeIdbax:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cv9:9c;j:KM;j:KM;j:Kd:dhOdndnaeclfIdbaq:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cq9:9cM;j:KM;j:KM;jl:daO:ehOdndnaecwfIdbaD:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabaOai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cC9:9c:KM;j:KM;j:KMD:d:e83ibaeaofheabcwfhbadcufgdmbkkk9teiucbcbyd;y:I:cjbgeabcifc98GfgbBd;y:I:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd;y:I:cjbgeabcrfc94GfgbBd;y:I:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd;y:I:cjbge9Rcifc98GaefgbBd;y:I:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk;Sddbcj:Gdk;idbbbbdbbblbbbwbbbbbbbebbbdbbblbbbwbbbbbbbbbbbbbbbbbbbebbbdbbbbbbbebbbbbbbbbbbbbbbb4:h9w9N94:P:gW:j9O:ye9Pbbbbbb:l29hZ;69:9kZ;N;76Z;rg97Z;z;o9xZ8J;B85Z;:;u9yZ;b;k9HZ:2;Z9DZ9e:l9mZ59A8KZ:r;T3Z:A:zYZ79OHZ;j4::8::Y:D9V8:bbbb9s:49:Z8R:hBZ9M9M;M8:L;z;o8:;8:PG89q;x:J878R:hQ8::M:B;e87bbbbbbjZbbjZbbjZ:E;V;N8::Y:DsZ9i;H;68:xd;R8:;h0838:;W:NoZbbbb:WV9O8:uf888:9i;H;68:9c9G;L89;n;m9m89;D8Ko8:bbbbf:8tZ9m836ZS:2AZL;zPZZ818EZ9e:lxZ;U98F8:819E;68:FFuuFFuuFFuuFFuFFFuFFFuFbc;i:IdkCebbbebbbebbbdbbb9G:rbb";
|
|
99
|
+
var wasmpack = new Uint8Array([
|
|
100
|
+
32,
|
|
101
|
+
0,
|
|
102
|
+
65,
|
|
103
|
+
2,
|
|
104
|
+
1,
|
|
105
|
+
106,
|
|
106
|
+
34,
|
|
107
|
+
33,
|
|
108
|
+
3,
|
|
109
|
+
128,
|
|
110
|
+
11,
|
|
111
|
+
4,
|
|
112
|
+
13,
|
|
113
|
+
64,
|
|
114
|
+
6,
|
|
115
|
+
253,
|
|
116
|
+
10,
|
|
117
|
+
7,
|
|
118
|
+
15,
|
|
119
|
+
116,
|
|
120
|
+
127,
|
|
121
|
+
5,
|
|
122
|
+
8,
|
|
123
|
+
12,
|
|
124
|
+
40,
|
|
125
|
+
16,
|
|
126
|
+
19,
|
|
127
|
+
54,
|
|
128
|
+
20,
|
|
129
|
+
9,
|
|
130
|
+
27,
|
|
131
|
+
255,
|
|
132
|
+
113,
|
|
133
|
+
17,
|
|
134
|
+
42,
|
|
135
|
+
67,
|
|
136
|
+
24,
|
|
137
|
+
23,
|
|
138
|
+
146,
|
|
139
|
+
148,
|
|
140
|
+
18,
|
|
141
|
+
14,
|
|
142
|
+
22,
|
|
143
|
+
45,
|
|
144
|
+
70,
|
|
145
|
+
69,
|
|
146
|
+
56,
|
|
147
|
+
114,
|
|
148
|
+
101,
|
|
149
|
+
21,
|
|
150
|
+
25,
|
|
151
|
+
63,
|
|
152
|
+
75,
|
|
153
|
+
136,
|
|
154
|
+
108,
|
|
155
|
+
28,
|
|
156
|
+
118,
|
|
157
|
+
29,
|
|
158
|
+
73,
|
|
159
|
+
115
|
|
160
|
+
]);
|
|
161
|
+
if (typeof WebAssembly !== "object") {
|
|
162
|
+
return {
|
|
163
|
+
supported: false
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
var instance;
|
|
167
|
+
var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
|
|
168
|
+
instance = result.instance;
|
|
169
|
+
instance.exports.__wasm_call_ctors();
|
|
170
|
+
instance.exports.meshopt_encodeVertexVersion(1);
|
|
171
|
+
instance.exports.meshopt_encodeIndexVersion(1);
|
|
172
|
+
});
|
|
173
|
+
function unpack(data) {
|
|
174
|
+
var result = new Uint8Array(data.length);
|
|
175
|
+
for (var i = 0; i < data.length; ++i) {
|
|
176
|
+
var ch = data.charCodeAt(i);
|
|
177
|
+
result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
|
|
178
|
+
}
|
|
179
|
+
var write = 0;
|
|
180
|
+
for (var i = 0; i < data.length; ++i) {
|
|
181
|
+
result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
|
|
182
|
+
}
|
|
183
|
+
return result.buffer.slice(0, write);
|
|
184
|
+
}
|
|
185
|
+
function assert(cond) {
|
|
186
|
+
if (!cond) {
|
|
187
|
+
throw new Error("Assertion failed");
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
function bytes(view) {
|
|
191
|
+
return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
|
|
192
|
+
}
|
|
193
|
+
function reorder(fun, indices, vertices, optf) {
|
|
194
|
+
var sbrk = instance.exports.sbrk;
|
|
195
|
+
var ip = sbrk(indices.length * 4);
|
|
196
|
+
var rp = sbrk(vertices * 4);
|
|
197
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
198
|
+
var indices8 = bytes(indices);
|
|
199
|
+
heap.set(indices8, ip);
|
|
200
|
+
if (optf) {
|
|
201
|
+
optf(ip, ip, indices.length, vertices);
|
|
202
|
+
}
|
|
203
|
+
var unique = fun(rp, ip, indices.length, vertices);
|
|
204
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
205
|
+
var remap = new Uint32Array(vertices);
|
|
206
|
+
new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
|
|
207
|
+
indices8.set(heap.subarray(ip, ip + indices.length * 4));
|
|
208
|
+
sbrk(ip - sbrk(0));
|
|
209
|
+
for (var i = 0; i < indices.length; ++i) indices[i] = remap[indices[i]];
|
|
210
|
+
return [remap, unique];
|
|
211
|
+
}
|
|
212
|
+
function spatialsort(fun, positions, count, stride) {
|
|
213
|
+
var sbrk = instance.exports.sbrk;
|
|
214
|
+
var ip = sbrk(count * 4);
|
|
215
|
+
var sp = sbrk(count * stride);
|
|
216
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
217
|
+
heap.set(bytes(positions), sp);
|
|
218
|
+
fun(ip, sp, count, stride);
|
|
219
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
220
|
+
var remap = new Uint32Array(count);
|
|
221
|
+
new Uint8Array(remap.buffer).set(heap.subarray(ip, ip + count * 4));
|
|
222
|
+
sbrk(ip - sbrk(0));
|
|
223
|
+
return remap;
|
|
224
|
+
}
|
|
225
|
+
function encode(fun, bound, source, count, size, level, version) {
|
|
226
|
+
var sbrk = instance.exports.sbrk;
|
|
227
|
+
var tp = sbrk(bound);
|
|
228
|
+
var sp = sbrk(count * size);
|
|
229
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
230
|
+
heap.set(bytes(source), sp);
|
|
231
|
+
var res = fun(tp, bound, sp, count, size, level, version);
|
|
232
|
+
var target = new Uint8Array(res);
|
|
233
|
+
target.set(heap.subarray(tp, tp + res));
|
|
234
|
+
sbrk(tp - sbrk(0));
|
|
235
|
+
return target;
|
|
236
|
+
}
|
|
237
|
+
function maxindex(source) {
|
|
238
|
+
var result = 0;
|
|
239
|
+
for (var i = 0; i < source.length; ++i) {
|
|
240
|
+
var index = source[i];
|
|
241
|
+
result = result < index ? index : result;
|
|
242
|
+
}
|
|
243
|
+
return result;
|
|
244
|
+
}
|
|
245
|
+
function index32(source, size) {
|
|
246
|
+
assert(size == 2 || size == 4);
|
|
247
|
+
if (size == 4) {
|
|
248
|
+
return new Uint32Array(source.buffer, source.byteOffset, source.byteLength / 4);
|
|
249
|
+
} else {
|
|
250
|
+
var view = new Uint16Array(source.buffer, source.byteOffset, source.byteLength / 2);
|
|
251
|
+
return new Uint32Array(view);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
function filter(fun, source, count, stride, bits, insize, mode) {
|
|
255
|
+
var sbrk = instance.exports.sbrk;
|
|
256
|
+
var tp = sbrk(count * stride);
|
|
257
|
+
var sp = sbrk(count * insize);
|
|
258
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
259
|
+
heap.set(bytes(source), sp);
|
|
260
|
+
fun(tp, count, stride, bits, sp, mode);
|
|
261
|
+
var target = new Uint8Array(count * stride);
|
|
262
|
+
target.set(heap.subarray(tp, tp + count * stride));
|
|
263
|
+
sbrk(tp - sbrk(0));
|
|
264
|
+
return target;
|
|
265
|
+
}
|
|
266
|
+
return {
|
|
267
|
+
ready,
|
|
268
|
+
supported: true,
|
|
269
|
+
reorderMesh: function(indices, triangles, optsize) {
|
|
270
|
+
assert(indices instanceof Uint32Array || indices instanceof Int32Array);
|
|
271
|
+
assert(!triangles || indices.length % 3 == 0);
|
|
272
|
+
var optf = triangles ? optsize ? instance.exports.meshopt_optimizeVertexCacheStrip : instance.exports.meshopt_optimizeVertexCache : void 0;
|
|
273
|
+
return reorder(instance.exports.meshopt_optimizeVertexFetchRemap, indices, maxindex(indices) + 1, optf);
|
|
274
|
+
},
|
|
275
|
+
reorderPoints: function(positions, positions_stride) {
|
|
276
|
+
assert(positions instanceof Float32Array);
|
|
277
|
+
assert(positions.length % positions_stride == 0);
|
|
278
|
+
assert(positions_stride >= 3);
|
|
279
|
+
return spatialsort(instance.exports.meshopt_spatialSortRemap, positions, positions.length / positions_stride, positions_stride * 4);
|
|
280
|
+
},
|
|
281
|
+
encodeVertexBuffer: function(source, count, size) {
|
|
282
|
+
assert(size > 0 && size <= 256);
|
|
283
|
+
assert(size % 4 == 0);
|
|
284
|
+
var bound = instance.exports.meshopt_encodeVertexBufferBound(count, size);
|
|
285
|
+
return encode(instance.exports.meshopt_encodeVertexBuffer, bound, source, count, size);
|
|
286
|
+
},
|
|
287
|
+
encodeVertexBufferLevel: function(source, count, size, level, version) {
|
|
288
|
+
assert(size > 0 && size <= 256);
|
|
289
|
+
assert(size % 4 == 0);
|
|
290
|
+
assert(level >= 0 && level <= 3);
|
|
291
|
+
assert(version === void 0 || version == 0 || version == 1);
|
|
292
|
+
var bound = instance.exports.meshopt_encodeVertexBufferBound(count, size);
|
|
293
|
+
return encode(instance.exports.meshopt_encodeVertexBufferLevel, bound, source, count, size, level, version === void 0 ? -1 : version);
|
|
294
|
+
},
|
|
295
|
+
encodeIndexBuffer: function(source, count, size) {
|
|
296
|
+
assert(size == 2 || size == 4);
|
|
297
|
+
assert(count % 3 == 0);
|
|
298
|
+
var indices = index32(source, size);
|
|
299
|
+
var bound = instance.exports.meshopt_encodeIndexBufferBound(count, maxindex(indices) + 1);
|
|
300
|
+
return encode(instance.exports.meshopt_encodeIndexBuffer, bound, indices, count, 4);
|
|
301
|
+
},
|
|
302
|
+
encodeIndexSequence: function(source, count, size) {
|
|
303
|
+
assert(size == 2 || size == 4);
|
|
304
|
+
var indices = index32(source, size);
|
|
305
|
+
var bound = instance.exports.meshopt_encodeIndexSequenceBound(count, maxindex(indices) + 1);
|
|
306
|
+
return encode(instance.exports.meshopt_encodeIndexSequence, bound, indices, count, 4);
|
|
307
|
+
},
|
|
308
|
+
encodeGltfBuffer: function(source, count, size, mode, version) {
|
|
309
|
+
var table = {
|
|
310
|
+
ATTRIBUTES: this.encodeVertexBufferLevel,
|
|
311
|
+
TRIANGLES: this.encodeIndexBuffer,
|
|
312
|
+
INDICES: this.encodeIndexSequence
|
|
313
|
+
};
|
|
314
|
+
assert(table[mode]);
|
|
315
|
+
return table[mode](
|
|
316
|
+
source,
|
|
317
|
+
count,
|
|
318
|
+
size,
|
|
319
|
+
/* level= */
|
|
320
|
+
2,
|
|
321
|
+
version === void 0 ? 0 : version
|
|
322
|
+
);
|
|
323
|
+
},
|
|
324
|
+
encodeFilterOct: function(source, count, stride, bits) {
|
|
325
|
+
assert(stride == 4 || stride == 8);
|
|
326
|
+
assert(bits >= 2 && bits <= 16);
|
|
327
|
+
return filter(instance.exports.meshopt_encodeFilterOct, source, count, stride, bits, 16);
|
|
328
|
+
},
|
|
329
|
+
encodeFilterQuat: function(source, count, stride, bits) {
|
|
330
|
+
assert(stride == 8);
|
|
331
|
+
assert(bits >= 4 && bits <= 16);
|
|
332
|
+
return filter(instance.exports.meshopt_encodeFilterQuat, source, count, stride, bits, 16);
|
|
333
|
+
},
|
|
334
|
+
encodeFilterExp: function(source, count, stride, bits, mode) {
|
|
335
|
+
assert(stride > 0 && stride % 4 == 0);
|
|
336
|
+
assert(bits >= 1 && bits <= 24);
|
|
337
|
+
var table = {
|
|
338
|
+
Separate: 0,
|
|
339
|
+
SharedVector: 1,
|
|
340
|
+
SharedComponent: 2,
|
|
341
|
+
Clamped: 3
|
|
342
|
+
};
|
|
343
|
+
assert(!mode || mode in table);
|
|
344
|
+
return filter(instance.exports.meshopt_encodeFilterExp, source, count, stride, bits, stride, mode ? table[mode] : 1);
|
|
345
|
+
},
|
|
346
|
+
encodeFilterColor: function(source, count, stride, bits) {
|
|
347
|
+
assert(stride == 4 || stride == 8);
|
|
348
|
+
assert(bits >= 2 && bits <= 16);
|
|
349
|
+
return filter(instance.exports.meshopt_encodeFilterColor, source, count, stride, bits, 16);
|
|
350
|
+
}
|
|
351
|
+
};
|
|
352
|
+
})();
|
|
353
|
+
|
|
354
|
+
// packages/engine/node_modules/meshoptimizer/meshopt_decoder.mjs
|
|
355
|
+
var MeshoptDecoder = (function() {
|
|
356
|
+
var wasm_base = "b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuixkbeeeddddillviebeoweuecj:Gdkr;Neqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949WboY9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVJ9V29VVbrl79IV9Rbwq1Zkdbk:kYi5ud9:du8Jjjjjbcjq9Rgv8Kjjjjbc9:hodnalTmbcuhoaiRbbgrc;WeGc:Ge9hmbarcsGgwce0mbc9:hoalcufadcd4cbawEgDadfgrcKcaawEgqaraq0Egk6mbaicefhxcj;abad9Uc;WFbGcjdadca0EhmaialfgPar9Rgoadfhsavaoadz:jjjjbgzceVhHcbhOdndninaeaO9nmeaPax9RaD6mdamaeaO9RaOamfgoae6EgAcsfglc9WGhCaAcethXaxaDfhiaOaeaoaeao6E9RhQalcl4cifcd4hLazcjdfaAfhKcbhYabaOad2fg8AhEaHh3incbh5dnawTmbaxaYcd4fRbbh5kcbh8Eazcjdfhqinaih8Fdndndndna5a8Ecet4ciGgoc9:fPdebdkaPa8F9RaA6mrazcjdfa8EaA2fa8FaAz:jjjjb8Aa8FaAfhixdkazcjdfa8EaA2fcbaAz:kjjjb8Aa8FhixekaPa8F9RaL6mva8FaLfhidnaCTmbaPai9RcK6mbaocdtc:q:G:cjbfcj:G:cjbawEhaczhrcbhlinargoc9Wfghaqfhrdndndndndndnaaa8Fahco4fRbbalcoG4ciGcdtfydbPDbedvivvvlvkar9cb83bwar9cb83bbxlkarcbaiRbdai8Xbb9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:gg9cjjjjjz:dg8J9qE86bbaqaofgrcGfcbaicdfa8J9c8N1:NfghRbbag9cjjjjjw:dg8J9qE86bbarcVfcbaha8J9c8M1:NfghRbbag9cjjjjjl:dg8J9qE86bbarc7fcbaha8J9c8L1:NfghRbbag9cjjjjjd:dg8J9qE86bbarctfcbaha8J9c8K1:NfghRbbag9cjjjjje:dg8J9qE86bbarc91fcbaha8J9c8J1:NfghRbbag9cjjjj;ab:dg8J9qE86bbarc4fcbaha8J9cg1:NfghRbbag9cjjjja:dg8J9qE86bbarc93fcbaha8J9ch1:NfghRbbag9cjjjjz:dgg9qE86bbarc94fcbahag9ca1:NfghRbbai8Xbe9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:gg9cjjjjjz:dg8J9qE86bbarc95fcbaha8J9c8N1:NfgiRbbag9cjjjjjw:dg8J9qE86bbarc96fcbaia8J9c8M1:NfgiRbbag9cjjjjjl:dg8J9qE86bbarc97fcbaia8J9c8L1:NfgiRbbag9cjjjjjd:dg8J9qE86bbarc98fcbaia8J9c8K1:NfgiRbbag9cjjjjje:dg8J9qE86bbarc99fcbaia8J9c8J1:NfgiRbbag9cjjjj;ab:dg8J9qE86bbarc9:fcbaia8J9cg1:NfgiRbbag9cjjjja:dg8J9qE86bbarcufcbaia8J9ch1:NfgiRbbag9cjjjjz:dgg9qE86bbaiag9ca1:NfhixikaraiRblaiRbbghco4g8Ka8KciSg8KE86bbaqaofgrcGfaiclfa8Kfg8KRbbahcl4ciGg8La8LciSg8LE86bbarcVfa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc7fa8Ka8Lfg8KRbbahciGghahciSghE86bbarctfa8Kahfg8KRbbaiRbeghco4g8La8LciSg8LE86bbarc91fa8Ka8Lfg8KRbbahcl4ciGg8La8LciSg8LE86bbarc4fa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc93fa8Ka8Lfg8KRbbahciGghahciSghE86bbarc94fa8Kahfg8KRbbaiRbdghco4g8La8LciSg8LE86bbarc95fa8Ka8Lfg8KRbbahcl4ciGg8La8LciSg8LE86bbarc96fa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc97fa8Ka8Lfg8KRbbahciGghahciSghE86bbarc98fa8KahfghRbbaiRbigico4g8Ka8KciSg8KE86bbarc99faha8KfghRbbaicl4ciGg8Ka8KciSg8KE86bbarc9:faha8KfghRbbaicd4ciGg8Ka8KciSg8KE86bbarcufaha8KfgrRbbaiciGgiaiciSgiE86bbaraifhixdkaraiRbwaiRbbghcl4g8Ka8KcsSg8KE86bbaqaofgrcGfaicwfa8Kfg8KRbbahcsGghahcsSghE86bbarcVfa8KahfghRbbaiRbeg8Kcl4g8La8LcsSg8LE86bbarc7faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarctfaha8KfghRbbaiRbdg8Kcl4g8La8LcsSg8LE86bbarc91faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc4faha8KfghRbbaiRbig8Kcl4g8La8LcsSg8LE86bbarc93faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc94faha8KfghRbbaiRblg8Kcl4g8La8LcsSg8LE86bbarc95faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc96faha8KfghRbbaiRbvg8Kcl4g8La8LcsSg8LE86bbarc97faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc98faha8KfghRbbaiRbog8Kcl4g8La8LcsSg8LE86bbarc99faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc9:faha8KfghRbbaiRbrgicl4g8Ka8KcsSg8KE86bbarcufaha8KfgrRbbaicsGgiaicsSgiE86bbaraifhixekarai8Pbw83bwarai8Pbb83bbaiczfhikdnaoaC9pmbalcdfhlaoczfhraPai9RcL0mekkaoaC6moaimexokaCmva8FTmvkaqaAfhqa8Ecefg8Ecl9hmbkdndndndnawTmbasaYcd4fRbbgociGPlbedrbkaATmdazaYfh8Fazcjdfhhcbh8EaEhaina8FRbbhraahocbhlinaoahalfRbbgqce4cbaqceG9R7arfgr86bbaoadfhoaAalcefgl9hmbkaacefhaa8Fcefh8FahaAfhha8Ecefg8Ecl9hmbxikkaATmeazaYfhaazcjdfhhcbhoceh8EaKh8FinaEaofhlaa8Vbbhrcbhoinala8FaofRbbcwtahaofRbbgqVc;:FiGce4cbaqceG9R7arfgr87bbaladfhlaQaocefgofmbka8FaXfh8FcdhoaacdfhaahaXfhha8EceGhlcbh8EalmbxdkkaATmbaocl4h8EazaYfRbbhqcwhoa3hlinalRbbaotaqVhqalcefhlaocwfgoca9hmbkcbhhaEh8FaKhainazcjdfahfRbbhrcwhoaahlinalRbbaotarVhralaAfhlaocwfgoca9hmbkara8E94aq7hqcbhoa8Fhlinalaqao486bbalcefhlaocwfgoca9hmbka8Fadfh8FaacefhaahcefghaA9hmbkkaEclfhEa3clfh3aYclfgYad6mbkaza8AaAcufad2fadz:jjjjb8AaAaOfhOaihxaimbkc9:hoxdkcbc99aPax9RakSEhoxekc9:hokavcjqf8Kjjjjbaok:ysezu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnalaeci9UgrcHf6mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:kjjjb8Aav9cu83iUav9cu83i8Wav9cu83iyav9cu83iaav9cu83iKav9cu83izav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhldnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhoindnalaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfaoaDcu7gPcl4fcsGcitfgsydlhzasydbhHdndnaDcsGgsak9pmbavaiaPfcsGcdtfydbaxasEhDaxasTgOfhxxekdndnascsSmbcehOasc987asamffcefhDxekalcefhDal8SbbgscFeGhPdndnascu9mmbaDhlxekalcvfhlaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhlkcehOaPce4cbaPceG9R7amfhDkaDhmkavc;abfaocitfgsaDBdbasazBdlavaicdtfaDBdbavc;abfaocefcsGcitfgsaHBdbasaDBdlaocdfhoaOaifhidnadcd9hmbabarcetfgsaH87ebasclfaD87ebascdfaz87ebxdkabarcdtfgsaHBdbascwfaDBdbasclfazBdbxekdnaDcpe0mbavaiaqaDcsGfRbbgscl4gP9RcsGcdtfydbaxcefgOaPEhDavaias9RcsGcdtfydbaOaPTgzfgOascsGgPEhsaPThPdndnadcd9hmbabarcetfgHax87ebaHclfas87ebaHcdfaD87ebxekabarcdtfgHaxBdbaHcwfasBdbaHclfaDBdbkavaicdtfaxBdbavc;abfaocitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfaocefcsGcitfgHasBdbaHaDBdlavaiazfgicsGcdtfasBdbavc;abfaocdfcsGcitfgDaxBdbaDasBdlaocifhoaiaPfhiaOaPfhxxekaxcbalRbbgsEgHaDc;:eSgDfhOascsGhAdndnascl4gCmbaOcefhzxekaOhzavaiaC9RcsGcdtfydbhOkdndnaAmbazcefhxxekazhxavaias9RcsGcdtfydbhzkdndnaDTmbalcefhDxekalcdfhDal8SbegPcFeGhsdnaPcu9kmbalcofhHascFbGhscrhldninaD8SbbgPcFbGaltasVhsaPcu9kmeaDcefhDalcrfglc8J9hmbkaHhDxekaDcefhDkasce4cbasceG9R7amfgmhHkdndnaCcsSmbaDhsxekaDcefhsaD8SbbglcFeGhPdnalcu9kmbaDcvfhOaPcFbGhPcrhldninas8SbbgDcFbGaltaPVhPaDcu9kmeascefhsalcrfglc8J9hmbkaOhsxekascefhskaPce4cbaPceG9R7amfgmhOkdndnaAcsSmbashlxekascefhlas8SbbgDcFeGhPdnaDcu9kmbascvfhzaPcFbGhPcrhDdninal8SbbgscFbGaDtaPVhPascu9kmealcefhlaDcrfgDc8J9hmbkazhlxekalcefhlkaPce4cbaPceG9R7amfgmhzkdndnadcd9hmbabarcetfgDaH87ebaDclfaz87ebaDcdfaO87ebxekabarcdtfgDaHBdbaDcwfazBdbaDclfaOBdbkavc;abfaocitfgDaOBdbaDaHBdlavaicdtfaHBdbavc;abfaocefcsGcitfgDazBdbaDaOBdlavaicefgicsGcdtfaOBdbavc;abfaocdfcsGcitfgDaHBdbaDazBdlavaiaCTaCcsSVfgicsGcdtfazBdbaiaATaAcsSVfhiaocifhokawcefhwaocsGhoaicsGhiarcifgrae6mbkkcbc99alaqSEhokavc;aef8Kjjjjbaok:clevu8Jjjjjbcz9Rhvdnalaecvf9pmbc9:skdnaiRbbc;:eGc;qeSmbcuskav9cb83iwaicefhoaialfc98fhrdnaeTmbdnadcdSmbcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcdtfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgiBdbalaiBdbawcefgwae9hmbxdkkcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcetfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgi87ebalaiBdbawcefgwae9hmbkkcbc99aoarSEk:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk:4ioiue99dud99dud99dnaeTmbcbhiabhlindndnal8Uebgv:YgoJ:ji:1Salcof8UebgrciVgw:Y:vgDNJbbbZJbbb:;avcu9kEMgq:lJbbb9p9DTmbaq:Ohkxekcjjjj94hkkalclf8Uebhvalcdf8UebhxalarcefciGcetfak87ebdndnax:YgqaDNJbbbZJbbb:;axcu9kEMgm:lJbbb9p9DTmbam:Ohxxekcjjjj94hxkabaiarciGgkfcd7cetfax87ebdndnav:YgmaDNJbbbZJbbb:;avcu9kEMgP:lJbbb9p9DTmbaP:Ohvxekcjjjj94hvkalarcufciGcetfav87ebdndnawaw2:ZgPaPMaoaoN:taqaqN:tamamN:tgoJbbbbaoJbbbb9GE:raDNJbbbZMgD:lJbbb9p9DTmbaD:Ohrxekcjjjj94hrkalakcetfar87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj98Gcjjj;8if::NUdbabclfhbadcufgdmbkkk:Tvirud99eudndnadcl9hmbaeTmeindndnabRbbgiabcefgl8Sbbgvabcdfgo8Sbbgrf9R:YJbbuJabcifgwRbbgdce4adVgDcd4aDVgDcl4aDVgD:Z:vgqNJbbbZMgk:lJbbb9p9DTmbak:Ohxxekcjjjj94hxkaoax86bbdndnaraif:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohoxekcjjjj94hokalao86bbdndnavaifar9R:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabai86bbdndnaDadcetGadceGV:ZaqNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkawad86bbabclfhbaecufgembxdkkaeTmbindndnab8Vebgiabcdfgl8Uebgvabclfgo8Uebgrf9R:YJbFu9habcofgw8Vebgdce4adVgDcd4aDVgDcl4aDVgDcw4aDVgD:Z:vgqNJbbbZMgk:lJbbb9p9DTmbak:Ohxxekcjjjj94hxkaoax87ebdndnaraif:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohoxekcjjjj94hokalao87ebdndnavaifar9R:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabai87ebdndnaDadcetGadceGV:ZaqNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkawad87ebabcwfhbaecufgembkkk9teiucbcbyd:K:G:cjbgeabcifc98GfgbBd:K:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkk83dbcj:Gdk8Kbbbbdbbblbbbwbbbbbbbebbbdbbblbbbwbbbbc:K:Gdkl8W:qbb";
|
|
357
|
+
var wasm_simd = "b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuixkbbebeeddddilve9Weeeviebeoweuecj:Gdkr;Neqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949WbwY9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVJ9V29VVbDl79IV9Rbqq:59Dklbzik94evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaeai86b:q:W:cjbaecitab8Piw83i:q:G:cjbaecefgecjd9hmbkk:SBlEud97dur978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnalTmbcuhoaiRbbgrc;WeGc:Ge9hmbarcsGgwce0mbc9:hoalcufadcd4cbawEgDadfgrcKcaawEgqaraq0Egk6mbaialfgxar9RhodnadTgmmbavaoad;8qbbkaicefhPcj;abad9Uc;WFbGcjdadca0EhsdndndnadTmbaoadfhzcbhHinaeaH9nmdaxaP9RaD6miabaHad2fgOavcjdfasaeaH9RaHasfae6EgAaAcsfgoc9WGgCSEhXaPaDfhQaocl4cifcd4hLavcj;cbfaCcetfhKavcj;cbfaCci2fhYavcj;cbfaCfh8AcbhEaoc;ab6h3incbh5dnawTmbaPaEcd4fRbbh5kcbh8Eavcj;cbfh8Findndndndna5a8Ecet4ciGgoc9:fPdebdkaxaQ9RaC6mwdnaCTmbavcj;cbfa8EaC2faQaC;8qbbkaQaAfhQxdkaCTmeavcj;cbfa8EaC2fcbaC;8kbxekaxaQ9RaL6moaoclVcbawEhraQaLfhocbhidna3mbaxao9Rc;Gb6mbcbhlina8FalfhidndndndndndnaQalco4fRbbgqciGarfPDbedibledibkaipxbbbbbbbbbbbbbbbbpklbxlkaiaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaiaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaiaopbbbpklbaoczfhoxekaiaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqcd4ciGarfPDbedibledibkaiczfpxbbbbbbbbbbbbbbbbpklbxlkaiczfaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaiczfaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaiczfaopbbbpklbaoczfhoxekaiczfaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqcl4ciGarfPDbedibledibkaicafpxbbbbbbbbbbbbbbbbpklbxlkaicafaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaicafaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaicafaopbbbpklbaoczfhoxekaicafaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqco4arfPDbedibledibkaic8Wfpxbbbbbbbbbbbbbbbbpklbxlkaic8Wfaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Ngicitpbi:q:G:cjbaiRb:q:W:cjbgipsaap5e9cjF;8;4;W;G;ab9:9cU1:Ngqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbaiaoclffaqRb:q:W:cjbfhoxikaic8Wfaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Ngicitpbi:q:G:cjbaiRb:q:W:cjbgipsaap5e9cjF;8;4;W;G;ab9:9cU1:Ngqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbaiaocwffaqRb:q:W:cjbfhoxdkaic8Wfaopbbbpklbaoczfhoxekaic8WfaopbbdaoRbbgicitpbi:q:G:cjbaiRb:q:W:cjbgipsaoRbegqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbaiaocdffaqRb:q:W:cjbfhokalc;abfhialcjefaC0meaihlaxao9Rc;Fb0mbkkdnaiaC9pmbaici4hlinaxao9RcK6mwa8FaifhqdndndndndndnaQaico4fRbbalcoG4ciGarfPDbedibledibkaqpxbbbbbbbbbbbbbbbbpkbbxlkaqaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spkbbagaoclffa8JRb:q:W:cjbfhoxikaqaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spkbbagaocwffa8JRb:q:W:cjbfhoxdkaqaopbbbpkbbaoczfhoxekaqaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpkbbagaocdffa8JRb:q:W:cjbfhokalcdfhlaiczfgiaC6mbkkaohQaoTmoka8FaCfh8Fa8Ecefg8Ecl9hmbkdndndndnawTmbazaEcd4fRbbglciGPlbedwbkaCTmdaXaEfhlavaEfpbdbh8Kcbhoinalavcj;cbfaofpblbg8La8Aaofpblbg8MpmbzeHdOiAlCvXoQrLg8NaKaofpblbgyaYaofpblbg8PpmbzeHdOiAlCvXoQrLgIpmbezHdiOAlvCXorQLgacep9Taapxeeeeeeeeeeeeeeeeghp9op9Hp9rgaa8Kp9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8NaIpmwDKYqk8AExm35Ps8E8Fgacep9Taaahp9op9Hp9rgap9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8La8MpmwKDYq8AkEx3m5P8Es8Fg8Laya8PpmwKDYq8AkEx3m5P8Es8Fg8MpmbezHdiOAlvCXorQLgacep9Taaahp9op9Hp9rgap9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8La8MpmwDKYqk8AExm35Ps8E8Fgacep9Taaahp9op9Hp9rgap9Ughp9Abbbaladfglahaaaapmlvorlvorlvorlvorp9Ughp9AbbbaladfglahaaaapmwDqkwDqkwDqkwDqkp9Ughp9AbbbaladfglahaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9AbbbaladfhlaoczfgoaC6mbxikkaCTmeaXaEfhlavaEfpbdbh8Kcbhoinalavcj;cbfaofpblbg8La8Aaofpblbg8MpmbzeHdOiAlCvXoQrLg8NaKaofpblbgyaYaofpblbg8PpmbzeHdOiAlCvXoQrLgIpmbezHdiOAlvCXorQLgacep:neaapxebebebebebebebebghp9op:bep9rgaa8Kp:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8NaIpmwDKYqk8AExm35Ps8E8Fgacep:neaaahp9op:bep9rgap:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8La8MpmwKDYq8AkEx3m5P8Es8Fg8Laya8PpmwKDYq8AkEx3m5P8Es8Fg8MpmbezHdiOAlvCXorQLgacep:neaaahp9op:bep9rgap:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8La8MpmwDKYqk8AExm35Ps8E8Fgacep:neaaahp9op:bep9rgap:oeghp9Abbbaladfglahaaaapmlvorlvorlvorlvorp:oeghp9AbbbaladfglahaaaapmwDqkwDqkwDqkwDqkp:oeghp9AbbbaladfglahaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9AbbbaladfhlaoczfgoaC6mbxdkkaCTmbaXaEfhrcbhocbalcl4gl9Rc8FGhiavaEfpbdbhhinaravcj;cbfaofpblbg8Ka8Aaofpblbg8LpmbzeHdOiAlCvXoQrLg8MaKaofpblbg8NaYaofpblbgypmbzeHdOiAlCvXoQrLg8PpmbezHdiOAlvCXorQLgaaip:Reaaalp:Tep9qgaahp9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ma8PpmwDKYqk8AExm35Ps8E8Fgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ka8LpmwKDYq8AkEx3m5P8Es8Fg8Ka8NaypmwKDYq8AkEx3m5P8Es8Fg8LpmbezHdiOAlvCXorQLgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ka8LpmwDKYqk8AExm35Ps8E8Fgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9AbbbaradfhraoczfgoaC6mbkkaEclfgEad6mbkdnaXavcjdf9hmbaAad2goTmbaOavcjdfao;8qbbkdnammbavaXaAcufad2fad;8qbbkaAaHfhHc9:hoaQhPaQmbxlkkaeTmbaDalfhrcbhocuhlinaralaD9RglfaD6mdasaeao9Raoasfae6Eaofgoae6mbkaial9RhPkcbc99axaP9RakSEhoxekc9:hokavcj;kbf8Kjjjjbaokwbz:bjjjbkNsezu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnalaeci9UgrcHf6mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbav9cu83iUav9cu83i8Wav9cu83iyav9cu83iaav9cu83iKav9cu83izav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhldnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhoindnalaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfaoaDcu7gPcl4fcsGcitfgsydlhzasydbhHdndnaDcsGgsak9pmbavaiaPfcsGcdtfydbaxasEhDaxasTgOfhxxekdndnascsSmbcehOasc987asamffcefhDxekalcefhDal8SbbgscFeGhPdndnascu9mmbaDhlxekalcvfhlaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhlkcehOaPce4cbaPceG9R7amfhDkaDhmkavc;abfaocitfgsaDBdbasazBdlavaicdtfaDBdbavc;abfaocefcsGcitfgsaHBdbasaDBdlaocdfhoaOaifhidnadcd9hmbabarcetfgsaH87ebasclfaD87ebascdfaz87ebxdkabarcdtfgsaHBdbascwfaDBdbasclfazBdbxekdnaDcpe0mbavaiaqaDcsGfRbbgscl4gP9RcsGcdtfydbaxcefgOaPEhDavaias9RcsGcdtfydbaOaPTgzfgOascsGgPEhsaPThPdndnadcd9hmbabarcetfgHax87ebaHclfas87ebaHcdfaD87ebxekabarcdtfgHaxBdbaHcwfasBdbaHclfaDBdbkavaicdtfaxBdbavc;abfaocitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfaocefcsGcitfgHasBdbaHaDBdlavaiazfgicsGcdtfasBdbavc;abfaocdfcsGcitfgDaxBdbaDasBdlaocifhoaiaPfhiaOaPfhxxekaxcbalRbbgsEgHaDc;:eSgDfhOascsGhAdndnascl4gCmbaOcefhzxekaOhzavaiaC9RcsGcdtfydbhOkdndnaAmbazcefhxxekazhxavaias9RcsGcdtfydbhzkdndnaDTmbalcefhDxekalcdfhDal8SbegPcFeGhsdnaPcu9kmbalcofhHascFbGhscrhldninaD8SbbgPcFbGaltasVhsaPcu9kmeaDcefhDalcrfglc8J9hmbkaHhDxekaDcefhDkasce4cbasceG9R7amfgmhHkdndnaCcsSmbaDhsxekaDcefhsaD8SbbglcFeGhPdnalcu9kmbaDcvfhOaPcFbGhPcrhldninas8SbbgDcFbGaltaPVhPaDcu9kmeascefhsalcrfglc8J9hmbkaOhsxekascefhskaPce4cbaPceG9R7amfgmhOkdndnaAcsSmbashlxekascefhlas8SbbgDcFeGhPdnaDcu9kmbascvfhzaPcFbGhPcrhDdninal8SbbgscFbGaDtaPVhPascu9kmealcefhlaDcrfgDc8J9hmbkazhlxekalcefhlkaPce4cbaPceG9R7amfgmhzkdndnadcd9hmbabarcetfgDaH87ebaDclfaz87ebaDcdfaO87ebxekabarcdtfgDaHBdbaDcwfazBdbaDclfaOBdbkavc;abfaocitfgDaOBdbaDaHBdlavaicdtfaHBdbavc;abfaocefcsGcitfgDazBdbaDaOBdlavaicefgicsGcdtfaOBdbavc;abfaocdfcsGcitfgDaHBdbaDazBdlavaiaCTaCcsSVfgicsGcdtfazBdbaiaATaAcsSVfhiaocifhokawcefhwaocsGhoaicsGhiarcifgrae6mbkkcbc99alaqSEhokavc;aef8Kjjjjbaok:clevu8Jjjjjbcz9Rhvdnalaecvf9pmbc9:skdnaiRbbc;:eGc;qeSmbcuskav9cb83iwaicefhoaialfc98fhrdnaeTmbdnadcdSmbcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcdtfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgiBdbalaiBdbawcefgwae9hmbxdkkcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcetfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgi87ebalaiBdbawcefgwae9hmbkkcbc99aoarSEk;Toio97eue97aec98Ghedndnadcl9hmbaeTmecbhdinababpbbbgicKp:RecKp:Sep;6eglaicwp:RecKp:Sep;6ealp;Geaiczp:RecKp:Sep;6egvp;Gep;Kep;Legopxbbbbbbbbbbbbbbbbp:2egralpxbbbjbbbjbbbjbbbjgwp9op9rp;Keglpxbb;:9cbb;:9cbb;:9cbb;:9calalp;Meaoaop;Meavaravawp9op9rp;Keglalp;Mep;Kep;Kep;Jep;Negvp;Mepxbbn0bbn0bbn0bbn0grp;KepxFbbbFbbbFbbbFbbbp9oaipxbbbFbbbFbbbFbbbFp9op9qalavp;Mearp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaoavp;Mearp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbabczfhbadclfgdae6mbxdkkaeTmbcbhdinabczfgDaDpbbbgipxbbbbbbFFbbbbbbFFgwp9oabpbbbgoaipmbediwDqkzHOAKY8AEgvczp:Reczp:Sep;6eglaoaipmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eavczp:Sep;6egvp;Gealp;Gep;Kep;Legipxbbbbbbbbbbbbbbbbp:2egralpxbbbjbbbjbbbjbbbjgqp9op9rp;Keglpxb;:FSb;:FSb;:FSb;:FSalalp;Meaiaip;Meavaravaqp9op9rp;Keglalp;Mep;Kep;Kep;Jep;Negvp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbp9oaiavp;Mearp;Keczp:Rep9qgialavp;Mearp;KepxFFbbFFbbFFbbFFbbp9oglpmwDKYqk8AExm35Ps8E8Fp9qpkbbabaoawp9oaialpmbezHdiOAlvCXorQLp9qpkbbabcafhbadclfgdae6mbkkk;2ileue97euo97dnaec98GgiTmbcbheinabcKfpx:ji:1S:ji:1S:ji:1S:ji:1SabpbbbglabczfgvpbbbgopmlvorxmPsCXQL358E8Fgrczp:Segwpxibbbibbbibbbibbbp9qp;6egDp;NegqaDaDp;MegDaDp;KealaopmbediwDqkzHOAKY8AEgDczp:Reczp:Sep;6eglalp;MeaDczp:Sep;6egoaop;Mearczp:Reczp:Sep;6egrarp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jep;Mepxbbn0bbn0bbn0bbn0gDp;KepxFFbbFFbbFFbbFFbbgkp9oaqaop;MeaDp;Keczp:Rep9qgoaqalp;MeaDp;Keakp9oaqarp;MeaDp;Keczp:Rep9qgDpmwDKYqk8AExm35Ps8E8Fglp5eawclp:RegqpEi:T:j83ibavalp5baqpEd:T:j83ibabcwfaoaDpmbezHdiOAlvCXorQLgDp5eaqpEe:T:j83ibabaDp5baqpEb:T:j83ibabcafhbaeclfgeai6mbkkkuee97dnadcd4ae2c98GgeTmbcbhdinababpbbbgicwp:Recwp:Sep;6eaicep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepkbbabczfhbadclfgdae6mbkkk:Sodw97euaec98Ghedndnadcl9hmbaeTmecbhdinabpxbbuJbbuJbbuJbbuJabpbbbgicKp:TeglaicYp:Tep9qgvcdp:Teavp9qgvclp:Teavp9qgop;6ep;Negvaicwp:RecKp:SegraipxFbbbFbbbFbbbFbbbgwp9ogDp:Uep;6ep;Mepxbbn0bbn0bbn0bbn0gqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9oavaDarp:Xeaiczp:RecKp:Segip:Uep;6ep;Meaqp;Keawp9op9qavaDaraip:Uep:Xep;6ep;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qavaoalcep:Rep9oalpxebbbebbbebbbebbbp9op9qp;6ep;Meaqp;KecKp:Rep9qpkbbabczfhbadclfgdae6mbxdkkaeTmbcbhdinabczfgkpxbFu9hbFu9hbFu9hbFu9habpbbbglakpbbbgrpmlvorxmPsCXQL358E8Fgvczp:TegqavcHp:Tep9qgicdp:Teaip9qgiclp:Teaip9qgicwp:Teaip9qgop;6ep;NegialarpmbediwDqkzHOAKY8AEgDpxFFbbFFbbFFbbFFbbglp9ograDczp:Segwp:Ueavczp:Reczp:SegDp:Xep;6ep;Mepxbbn0bbn0bbn0bbn0gvp;Kealp9oaiarawaDp:Uep:Xep;6ep;Meavp;Keczp:Rep9qgwaiaoaqcep:Rep9oaqpxebbbebbbebbbebbbp9op9qp;6ep;Meavp;Keczp:ReaiaDarp:Uep;6ep;Meavp;Kealp9op9qgipmwDKYqk8AExm35Ps8E8FpkbbabawaipmbezHdiOAlvCXorQLpkbbabcafhbadclfgdae6mbkkk9teiucbcbydj:G:cjbgeabcifc98GfgbBdj:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkxebcj:Gdklz:zbb";
|
|
358
|
+
var detector = new Uint8Array([
|
|
359
|
+
0,
|
|
360
|
+
97,
|
|
361
|
+
115,
|
|
362
|
+
109,
|
|
363
|
+
1,
|
|
364
|
+
0,
|
|
365
|
+
0,
|
|
366
|
+
0,
|
|
367
|
+
1,
|
|
368
|
+
4,
|
|
369
|
+
1,
|
|
370
|
+
96,
|
|
371
|
+
0,
|
|
372
|
+
0,
|
|
373
|
+
3,
|
|
374
|
+
3,
|
|
375
|
+
2,
|
|
376
|
+
0,
|
|
377
|
+
0,
|
|
378
|
+
5,
|
|
379
|
+
3,
|
|
380
|
+
1,
|
|
381
|
+
0,
|
|
382
|
+
1,
|
|
383
|
+
12,
|
|
384
|
+
1,
|
|
385
|
+
0,
|
|
386
|
+
10,
|
|
387
|
+
22,
|
|
388
|
+
2,
|
|
389
|
+
12,
|
|
390
|
+
0,
|
|
391
|
+
65,
|
|
392
|
+
0,
|
|
393
|
+
65,
|
|
394
|
+
0,
|
|
395
|
+
65,
|
|
396
|
+
0,
|
|
397
|
+
252,
|
|
398
|
+
10,
|
|
399
|
+
0,
|
|
400
|
+
0,
|
|
401
|
+
11,
|
|
402
|
+
7,
|
|
403
|
+
0,
|
|
404
|
+
65,
|
|
405
|
+
0,
|
|
406
|
+
253,
|
|
407
|
+
15,
|
|
408
|
+
26,
|
|
409
|
+
11
|
|
410
|
+
]);
|
|
411
|
+
var wasmpack = new Uint8Array([
|
|
412
|
+
32,
|
|
413
|
+
0,
|
|
414
|
+
65,
|
|
415
|
+
2,
|
|
416
|
+
1,
|
|
417
|
+
106,
|
|
418
|
+
34,
|
|
419
|
+
33,
|
|
420
|
+
3,
|
|
421
|
+
128,
|
|
422
|
+
11,
|
|
423
|
+
4,
|
|
424
|
+
13,
|
|
425
|
+
64,
|
|
426
|
+
6,
|
|
427
|
+
253,
|
|
428
|
+
10,
|
|
429
|
+
7,
|
|
430
|
+
15,
|
|
431
|
+
116,
|
|
432
|
+
127,
|
|
433
|
+
5,
|
|
434
|
+
8,
|
|
435
|
+
12,
|
|
436
|
+
40,
|
|
437
|
+
16,
|
|
438
|
+
19,
|
|
439
|
+
54,
|
|
440
|
+
20,
|
|
441
|
+
9,
|
|
442
|
+
27,
|
|
443
|
+
255,
|
|
444
|
+
113,
|
|
445
|
+
17,
|
|
446
|
+
42,
|
|
447
|
+
67,
|
|
448
|
+
24,
|
|
449
|
+
23,
|
|
450
|
+
146,
|
|
451
|
+
148,
|
|
452
|
+
18,
|
|
453
|
+
14,
|
|
454
|
+
22,
|
|
455
|
+
45,
|
|
456
|
+
70,
|
|
457
|
+
69,
|
|
458
|
+
56,
|
|
459
|
+
114,
|
|
460
|
+
101,
|
|
461
|
+
21,
|
|
462
|
+
25,
|
|
463
|
+
63,
|
|
464
|
+
75,
|
|
465
|
+
136,
|
|
466
|
+
108,
|
|
467
|
+
28,
|
|
468
|
+
118,
|
|
469
|
+
29,
|
|
470
|
+
73,
|
|
471
|
+
115
|
|
472
|
+
]);
|
|
473
|
+
if (typeof WebAssembly !== "object") {
|
|
474
|
+
return {
|
|
475
|
+
supported: false
|
|
476
|
+
};
|
|
477
|
+
}
|
|
478
|
+
var wasm = WebAssembly.validate(detector) ? unpack(wasm_simd) : unpack(wasm_base);
|
|
479
|
+
var instance;
|
|
480
|
+
var ready = WebAssembly.instantiate(wasm, {}).then(function(result) {
|
|
481
|
+
instance = result.instance;
|
|
482
|
+
instance.exports.__wasm_call_ctors();
|
|
483
|
+
});
|
|
484
|
+
function unpack(data) {
|
|
485
|
+
var result = new Uint8Array(data.length);
|
|
486
|
+
for (var i = 0; i < data.length; ++i) {
|
|
487
|
+
var ch = data.charCodeAt(i);
|
|
488
|
+
result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
|
|
489
|
+
}
|
|
490
|
+
var write = 0;
|
|
491
|
+
for (var i = 0; i < data.length; ++i) {
|
|
492
|
+
result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
|
|
493
|
+
}
|
|
494
|
+
return result.buffer.slice(0, write);
|
|
495
|
+
}
|
|
496
|
+
function decode(instance2, fun, target, count, size, source, filter) {
|
|
497
|
+
var sbrk = instance2.exports.sbrk;
|
|
498
|
+
var count4 = count + 3 & ~3;
|
|
499
|
+
var tp = sbrk(count4 * size);
|
|
500
|
+
var sp = sbrk(source.length);
|
|
501
|
+
var heap = new Uint8Array(instance2.exports.memory.buffer);
|
|
502
|
+
heap.set(source, sp);
|
|
503
|
+
var res = fun(tp, count, size, sp, source.length);
|
|
504
|
+
if (res == 0 && filter) {
|
|
505
|
+
filter(tp, count4, size);
|
|
506
|
+
}
|
|
507
|
+
target.set(heap.subarray(tp, tp + count * size));
|
|
508
|
+
sbrk(tp - sbrk(0));
|
|
509
|
+
if (res != 0) {
|
|
510
|
+
throw new Error("Malformed buffer data: " + res);
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
var filters = {
|
|
514
|
+
NONE: "",
|
|
515
|
+
OCTAHEDRAL: "meshopt_decodeFilterOct",
|
|
516
|
+
QUATERNION: "meshopt_decodeFilterQuat",
|
|
517
|
+
EXPONENTIAL: "meshopt_decodeFilterExp",
|
|
518
|
+
COLOR: "meshopt_decodeFilterColor"
|
|
519
|
+
};
|
|
520
|
+
var decoders = {
|
|
521
|
+
ATTRIBUTES: "meshopt_decodeVertexBuffer",
|
|
522
|
+
TRIANGLES: "meshopt_decodeIndexBuffer",
|
|
523
|
+
INDICES: "meshopt_decodeIndexSequence"
|
|
524
|
+
};
|
|
525
|
+
var workers = [];
|
|
526
|
+
var requestId = 0;
|
|
527
|
+
function createWorker2(url) {
|
|
528
|
+
var worker = {
|
|
529
|
+
object: new Worker(url),
|
|
530
|
+
pending: 0,
|
|
531
|
+
requests: {}
|
|
532
|
+
};
|
|
533
|
+
worker.object.onmessage = function(event) {
|
|
534
|
+
var data = event.data;
|
|
535
|
+
worker.pending -= data.count;
|
|
536
|
+
worker.requests[data.id][data.action](data.value);
|
|
537
|
+
delete worker.requests[data.id];
|
|
538
|
+
};
|
|
539
|
+
return worker;
|
|
540
|
+
}
|
|
541
|
+
function initWorkers(count) {
|
|
542
|
+
var source = "self.ready = WebAssembly.instantiate(new Uint8Array([" + new Uint8Array(wasm) + "]), {}).then(function(result) { result.instance.exports.__wasm_call_ctors(); return result.instance; });self.onmessage = " + workerProcess.name + ";" + decode.toString() + workerProcess.toString();
|
|
543
|
+
var blob = new Blob([source], { type: "text/javascript" });
|
|
544
|
+
var url = URL.createObjectURL(blob);
|
|
545
|
+
for (var i = workers.length; i < count; ++i) {
|
|
546
|
+
workers[i] = createWorker2(url);
|
|
547
|
+
}
|
|
548
|
+
for (var i = count; i < workers.length; ++i) {
|
|
549
|
+
workers[i].object.postMessage({});
|
|
550
|
+
}
|
|
551
|
+
workers.length = count;
|
|
552
|
+
URL.revokeObjectURL(url);
|
|
553
|
+
}
|
|
554
|
+
function decodeWorker(count, size, source, mode, filter) {
|
|
555
|
+
var worker = workers[0];
|
|
556
|
+
for (var i = 1; i < workers.length; ++i) {
|
|
557
|
+
if (workers[i].pending < worker.pending) {
|
|
558
|
+
worker = workers[i];
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
return new Promise(function(resolve, reject) {
|
|
562
|
+
var data = new Uint8Array(source);
|
|
563
|
+
var id = ++requestId;
|
|
564
|
+
worker.pending += count;
|
|
565
|
+
worker.requests[id] = { resolve, reject };
|
|
566
|
+
worker.object.postMessage({ id, count, size, source: data, mode, filter }, [data.buffer]);
|
|
567
|
+
});
|
|
568
|
+
}
|
|
569
|
+
function workerProcess(event) {
|
|
570
|
+
var data = event.data;
|
|
571
|
+
self.ready.then(function(instance2) {
|
|
572
|
+
if (!data.id) {
|
|
573
|
+
return self.close();
|
|
574
|
+
}
|
|
575
|
+
try {
|
|
576
|
+
var target = new Uint8Array(data.count * data.size);
|
|
577
|
+
decode(instance2, instance2.exports[data.mode], target, data.count, data.size, data.source, instance2.exports[data.filter]);
|
|
578
|
+
self.postMessage({ id: data.id, count: data.count, action: "resolve", value: target }, [target.buffer]);
|
|
579
|
+
} catch (error) {
|
|
580
|
+
self.postMessage({ id: data.id, count: data.count, action: "reject", value: error });
|
|
581
|
+
}
|
|
582
|
+
});
|
|
583
|
+
}
|
|
584
|
+
return {
|
|
585
|
+
ready,
|
|
586
|
+
supported: true,
|
|
587
|
+
useWorkers: function(count) {
|
|
588
|
+
initWorkers(count);
|
|
589
|
+
},
|
|
590
|
+
decodeVertexBuffer: function(target, count, size, source, filter) {
|
|
591
|
+
decode(instance, instance.exports.meshopt_decodeVertexBuffer, target, count, size, source, instance.exports[filters[filter]]);
|
|
592
|
+
},
|
|
593
|
+
decodeIndexBuffer: function(target, count, size, source) {
|
|
594
|
+
decode(instance, instance.exports.meshopt_decodeIndexBuffer, target, count, size, source);
|
|
595
|
+
},
|
|
596
|
+
decodeIndexSequence: function(target, count, size, source) {
|
|
597
|
+
decode(instance, instance.exports.meshopt_decodeIndexSequence, target, count, size, source);
|
|
598
|
+
},
|
|
599
|
+
decodeGltfBuffer: function(target, count, size, source, mode, filter) {
|
|
600
|
+
decode(instance, instance.exports[decoders[mode]], target, count, size, source, instance.exports[filters[filter]]);
|
|
601
|
+
},
|
|
602
|
+
decodeGltfBufferAsync: function(count, size, source, mode, filter) {
|
|
603
|
+
if (workers.length > 0) {
|
|
604
|
+
return decodeWorker(count, size, source, decoders[mode], filters[filter]);
|
|
605
|
+
}
|
|
606
|
+
return ready.then(function() {
|
|
607
|
+
var target = new Uint8Array(count * size);
|
|
608
|
+
decode(instance, instance.exports[decoders[mode]], target, count, size, source, instance.exports[filters[filter]]);
|
|
609
|
+
return target;
|
|
610
|
+
});
|
|
611
|
+
}
|
|
612
|
+
};
|
|
613
|
+
})();
|
|
614
|
+
|
|
615
|
+
// packages/engine/node_modules/meshoptimizer/meshopt_simplifier.js
|
|
616
|
+
var MeshoptSimplifier = (function() {
|
|
617
|
+
var wasm = "b9H79Tebbbe:6eO9Geueu9Geub9Gbb9Gsuuuuuuuuuuuu99uueu9Gvuuuuub9Gruuuuuuub9Gouuuuuue999Gvuuuuueu9Gzuuuuuuuuuuu99uuuub9Gquuuuuuu99uueu9GPuuuuuuuuuuu99uueu9Gquuuuuuuu99ueu9Gruuuuuu99eu9Gwuuuuuu99ueu9Giuuue999Gluuuueu9Gluuuub9GiuuueuiLQdilvorlwDiqkxmPszbHHbelve9Weiiviebeoweuecj:Gdkr:Bdxo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbz9TW79O9V9Wt9F79P9T9W29P9M95bw8E9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9OcttV9P9I91tW7bD8A9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9O9v9W9K9HtWbqQ9TW79O9V9Wt9F79P9T9W29P9M959t29V9W9W95bkX9TW79O9V9Wt9F79P9T9W29P9M959qV919UWbxQ9TW79O9V9Wt9F79P9T9W29P9M959q9V9P9Ut7bmX9TW79O9V9Wt9F79P9T9W29P9M959t9J9H2WbPa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9Wbs59TW79O9V9Wt9F9NW9UWV9HtW9q9V79Pt9P9V9U9sW9T9H9Wbzl79IV9RbHDwebcekdCXq;y;WeQdbk;r:herYue99iuY99Xue9:D998Jjjjjbcj;sb9Rgs8Kjjjjbcbhzasc:Cefcbc;Kbz:tjjjb8AdnabaeSmbabaeadcdtzMjjjb8AkdnamcdGTmbalcrfci4cbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egecdtfaHBdbasaecefBd;8ecbhlcbhednadTmbabheadhOinaHaeydbci4fcb86bbaeclfheaOcufgOmbkcbhlabheadhOinaHaeydbgAci4fgCaCRbbgCceaAcrGgAtV86bbaCcu7aA4ceGalfhlaeclfheaOcufgOmbkcualcdtalcFFFFi0Ehekaecbyd1:H:cjbHjjjjbbhzasc:Cefasyd;8egecdtfazBdbasaecefBd;8ealcd4alfhOcehHinaHgecethHaeaO6mbkcbhXcuaecdtgOaecFFFFi0Ecbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egAcdtfaHBdbasaAcefBd;8eaHcFeaOz:tjjjbhQdnadTmbaecufhLcbhKindndnaQabaKcdtfgYydbgAc:v;t;h;Ev2aLGgOcdtfgCydbgHcuSmbceheinazaHcdtfydbaASmdaOaefhHaecefheaQaHaLGgOcdtfgCydbgHcu9hmbkkazaXcdtfaABdbaCaXBdbaXhHaXcefhXkaYaHBdbaKcefgKad9hmbkkaQcbyd:m:H:cjbH:bjjjbbasasyd;8ecufBd;8ekcbh8AcualcefgecdtaecFFFFi0Ecbyd1:H:cjbHjjjjbbhLasc:Cefasyd;8egecdtfaLBdbasaLBdNeasaecefBd;8ecuadcitadcFFFFe0Ecbyd1:H:cjbHjjjjbbhEasc:Cefasyd;8egecdtfaEBdbasaEBd:yeasaecefBd;8eascNefabadalcbz:cjjjbcualcdtgealcFFFFi0Eg3cbyd1:H:cjbHjjjjbbhOasc:Cefasyd;8egHcdtfaOBdbasaHcefBd;8ea3cbyd1:H:cjbHjjjjbbhQasc:Cefasyd;8egHcdtfaQBdbasaHcefBd;8eaOaQaialavazasc:Cefz:djjjbalcbyd1:H:cjbHjjjjbbhYasc:Cefasyd;8egHcdtfaYBdbasaHcefBd;8ea3cbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egAcdtfaHBdbasaAcefBd;8ea3cbyd1:H:cjbHjjjjbbhAasc:Cefasyd;8egCcdtfaABdbasaCcefBd;8eaHcFeaez:tjjjbh5aAcFeaez:tjjjbh8EdnalTmbindnaLa8AgAcefg8AcdtfydbgCaLaAcdtgefydbgHSmbaCaH9Rh8FaEaHcitfhaa8Eaefhha5aefhKcbhCindndnaaaCcitfydbgXaA9hmbaKaABdbahaABdbxekdnaLaXcdtggfgeclfydbgHaeydbgeSmbaHae9RhHaEaecitfheinaeydbaASmdaecwfheaHcufgHmbkka8EagfgeaAaXaeydbcuSEBdbaKaXaAaKydbcuSEBdbkaCcefgCa8F9hmbkka8Aal9hmbkaOhHaQhAa5hXa8EhCcbheindndnaeaHydbgK9hmbdnaeaAydbgK9hmbaXydbhKdnaCydbg8Fcu9hmbaKcu9hmbaYaefcb86bbxikdna8FcuSmbaKcuSmbaea8FSmbaOa8FcdtfydbaOaKcdtfydb9hmbaYaefcd86bbxikaYaefhadnaea8FSmbaeaKSmbaace86bbxikaacl86bbxdkdnaeaQaKcdtg8Ffydb9hmbdnaCydbgacuSmbaeaaSmbaXydbggcuSmbaeagSmba8Ea8FfydbghcuSmbahaKSmba5a8Ffydbg8FcuSmba8FaKSmbdnaOaacdtfydbgKaOa8Fcdtfydb9hmbaKaOagcdtfydbg8FSmba8FaOahcdtfydb9hmbaYaefcd86bbxlkaYaefcl86bbxikaYaefcl86bbxdkaYaefcl86bbxekaYaefaYaKfRbb86bbkaHclfhHaAclfhAaXclfhXaCclfhCalaecefge9hmbkdnamcaGTmbcbh8JindndnaYa8Jfg8KRbbg8Lc9:fPibebekdndndnaOa8Jcdtfydbgea8J9hmbdnaqmbcbh8FxdkdnazTmbcbh8Fa8JheinaqazaecdtgefydbfRbbce4a8FVceGh8FaQaefydbgea8J9hmbxikkcbh8Fa8JheinaqaefRbbce4a8FVceGh8FaQaecdtfydbgea8J9hmbxdkkaYaefRbbhexeka8JheindnaLaecdtg8AfgeclfydbgHaeydbgeSmbaHae9RhgaEaecitfhhaOa8AfhacbhKinahaKcitfydbgXhednindnaLaecdtgCfgeclfydbgHaeydbgeSmbaHae9RhHaEaecitfheaaydbhAdninaOaeydbcdtfydbaASmeaecwfheaHcufgHTmdxbkkcbhexdkaQaCfydbgeaX9hmbkceheka8FaeVh8FaKcefgKag9hmbkkaQa8Afydbgea8J9hmbka8Lcia8FceGEheka8Kae86bbka8Jcefg8Jal9hmbkkdnaqTmbdndnazTmbazheaOhHalhAindnaqaeydbfRbbceGTmbaYaHydbfcl86bbkaeclfheaHclfhHaAcufgAmbxdkkaqheaOhHalhAindnaeRbbceGTmbaYaHydbfcl86bbkaecefheaHclfhHaAcufgAmbkkaOhealhAaYhHindnaYaeydbfRbbcl9hmbaHcl86bbkaeclfheaHcefhHaAcufgAmbkkamceGTmbaYhealhHindnaeRbbce9hmbaecl86bbkaecefheaHcufgHmbkkcbh8Mcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbh8Nasc:Cefasyd;8egecdtfa8NBdbasaecefBd;8eascbBd:qeas9cb83i1ea8Naialavazasc1efz:ejjjbhydndnaDmbcbh8PcbhCxekcbhCawhecbhHindnaeIdbJbbbb9ETmbasaCcdtfaHBdbaCcefhCkaeclfheaDaHcefgH9hmbkcuaCal2gecdtaecFFFFi0Ecbyd1:H:cjbHjjjjbbh8Pasc:Cefasyd;8egecdtfa8PBdbasaecefBd;8ealTmbdnaCmbcbhCxekarcd4hgdnazTmbaCcdthhcbh8Fa8Phainaoaza8Fcdtfydbag2cdtfhKasheaahHaChAinaHaKaeydbcdtgXfIdbawaXfIdbNUdbaeclfheaHclfhHaAcufgAmbkaaahfhaa8Fcefg8Fal9hmbxdkkaCcdthhcbh8Fa8Phainaoa8Fag2cdtfhKasheaahHaChAinaHaKaeydbcdtgXfIdbawaXfIdbNUdbaeclfheaHclfhHaAcufgAmbkaaahfhaa8Fcefg8Fal9hmbkkcualc8S2gHalc;D;O;f8U0EgXcbyd1:H:cjbHjjjjbbheasc:Cefasyd;8egAcdtfaeBdbasaAcefBd;8eaecbaHz:tjjjbhIcbh8RcbhgdnaCTmbcbh8MaXcbyd1:H:cjbHjjjjbbhgasc:Cefasyd;8egecdtfagBdbasaecefBd;8eagcbaHz:tjjjb8AcuaCal2gecltgHaecFFFFb0Ecbyd1:H:cjbHjjjjbbh8Rasc:Cefasyd;8egecdtfa8RBdbasaecefBd;8ea8RcbaHz:tjjjb8AamcjjjjdGTmbcualcltgealcFFFFb0Ecbyd1:H:cjbHjjjjbbh8Masc:Cefasyd;8egHcdtfa8MBdbasaHcefBd;8ea8Mcbaez:tjjjb8AkdnadTmbcbhKabhHina8NaHclfydbg8Fcx2fgeIdba8NaHydbgacx2fgAIdbg8S:tgRa8NaHcwfydbghcx2fgXIdlaAIdlg8U:tg8VNaeIdla8U:tg8WaXIdba8S:tg8XN:tg8Ya8YNa8WaXIdwaAIdwg8Z:tg80NaeIdwa8Z:tg8Wa8VN:tg81a81Na8Wa8XNaRa80N:tg80a80NMMg8V:rhBa8Yh8Xa80h8Wa81hRdna8VJbbbb9EgATmba8YaB:vh8Xa80aB:vh8Wa81aB:vhRkaIaOaacdtfydbgXc8S2fgeaRaB:rg8VaRNNg83aeIdbMUdbaea8Wa8Va8WNgUNg85aeIdlMUdlaea8Xa8Va8XNg86Ng87aeIdwMUdwaeaRaUNgUaeIdxMUdxaea86aRNg88aeIdzMUdzaea8Wa86Ng89aeIdCMUdCaeaRa8Va8Xa8ZNaRa8SNa8Ua8WNMM:mg8:Ng86NgRaeIdKMUdKaea8Wa86Ng8WaeId3MUd3aea8Xa86Ng8XaeIdaMUdaaea86a8:Ng86aeId8KMUd8Kaea8VaeIdyMUdyaIaOa8Fcdtfydbg8Fc8S2fgea83aeIdbMUdbaea85aeIdlMUdlaea87aeIdwMUdwaeaUaeIdxMUdxaea88aeIdzMUdzaea89aeIdCMUdCaeaRaeIdKMUdKaea8WaeId3MUd3aea8XaeIdaMUdaaea86aeId8KMUd8Kaea8VaeIdyMUdyaIaOahcdtfydbgac8S2fgea83aeIdbMUdbaea85aeIdlMUdlaea87aeIdwMUdwaeaUaeIdxMUdxaea88aeIdzMUdzaea89aeIdCMUdCaeaRaeIdKMUdKaea8WaeId3MUd3aea8XaeIdaMUdaaea86aeId8KMUd8Kaea8VaeIdyMUdydna8MTmbdnaATmba8YaB:vh8Ya80aB:vh80a81aB:vh81ka8MaXcltfgeaBJbbbZNgRa80Ng8VaeIdlMUdlaeaRa8YNg8WaeIdwMUdwaeaRa81Ng8XaeIdbMUdbaeaRa8S:ma81Na8Ua80N:ta8Za8YN:tNgRaeIdxMUdxa8Ma8Fcltfgea8VaeIdlMUdlaea8WaeIdwMUdwaea8XaeIdbMUdbaeaRaeIdxMUdxa8Maacltfgea8VaeIdlMUdlaea8WaeIdwMUdwaea8XaeIdbMUdbaeaRaeIdxMUdxkaHcxfhHaKcifgKad6mbkkdnalTmbJq;x8J88J;n;m;m89J:v:;;w8ZamczGEamc;abGEh80cbhHaOhXazhKaIhea8NhAindnaHaXydb9hmbaHh8FdnazTmbaKydbh8Fka80hRdnaqTmbJbbjZa80aqa8FfRbbclGEhRkaecxfg8Fa8FIdbJbbbbMUdbaeczfg8Fa8FIdbJbbbbMUdbaecCfg8Fa8FIdbJbbbbMUdbaeaRaecyfg8FIdbg8YNgRaeIdbMUdbaeclfgaaRaaIdbMUdbaecwfgaaRaaIdbMUdbaecKfgaaaIdbaAIdbg8WaRN:tUdbaAcwfIdbh8Vaec3fgaaaIdbaRaAclfIdbg8XN:tUdbaecafgaaaIdbaRa8VN:tUdbaec8KfgaIdbh81a8Fa8YaRMUdbaaa81aRa8Va8VNa8Wa8WNa8Xa8XNMMNMUdbkaXclfhXaKclfhKaec8SfheaAcxfhAalaHcefgH9hmbkkdnadTmbcbh8Aabhainaba8Acdtfh8FcbhHinaYa8FaHc:G:G:cjbfydbcdtfydbgAfRbbhedndnaYaaaHfydbgXfRbbgKc99fcFeGcpe0mbaec99fcFeGc;:e6mekdnaKcufcFeGce0mba5aXcdtfydbaA9hmekdnaecufcFeGce0mba8EaAcdtfydbaX9hmekJbbacJbbacJbbbZaecFeGceSEaKcFeGceSEhUdna8Na8FaHc:K:G:cjbfydbcdtfydbcx2fgeIdwa8NaXcx2fgKIdwg86:tg8Sa8NaAcx2fghIdwa86:tg8Xa8XNahIdbaKIdbg8U:tg80a80NahIdlaKIdlg8Z:tg8Va8VNMMg81Na8Xa8Sa8XNaeIdba8U:tg83a80Na8VaeIdla8Z:tg85NMMg8WN:tg8Ya8YNa83a81Na80a8WN:tgRaRNa85a81Na8Va8WN:tg8Wa8WNMMgBJbbbb9ETmba8YaB:rgB:vh8Ya8WaB:vh8WaRaB:vhRkaUa81:rNgBa8Ya86NaRa8UNa8Za8WNMM:mg81Ng87a81Nh88a80a85Na8Va83N:tg81a81Na8Va8SNa8Xa85N:tg8Va8VNa8Xa83Na80a8SN:tg8Xa8XNMMg83:rh80a8Ya87Nh85a8Wa87Nh89aRa87Nh87a8WaBa8YNg8SNh8:a8SaRNhZaRaBa8WNgnNhca8Ya8SNh8Ya8WanNh8WaRaBaRNNh8Sdna83Jbbbb9ETmba81a80:vh81a8Xa80:vh8Xa8Va80:vh8VkaIaOaXcdtfydbc8S2fgeaeIdba8Sa8VaUa80:rNgRa8VNNMg80MUdbaea8Wa8XaRa8XNg8SNMg83aeIdlMUdlaea8Ya81aRa81Ng8WNMg8YaeIdwMUdwaeaca8Va8SNMg8SaeIdxMUdxaeaZa8Wa8VNMgUaeIdzMUdzaea8:a8Xa8WNMg8WaeIdCMUdCaea87a8VaRa81a86Na8Va8UNa8Za8XNMMg86:mNgRNMg8VaeIdKMUdKaea89a8XaRNMg8XaeId3MUd3aea85a81aRNMg81aeIdaMUdaaea88a86aRN:tgRaeId8KMUd8KaeaBaeIdyMUdyaIaOaAcdtfydbc8S2fgea80aeIdbMUdbaea83aeIdlMUdlaea8YaeIdwMUdwaea8SaeIdxMUdxaeaUaeIdzMUdzaea8WaeIdCMUdCaea8VaeIdKMUdKaea8XaeId3MUd3aea81aeIdaMUdaaeaRaeId8KMUd8KaeaBaeIdyMUdykaHclfgHcx9hmbkaacxfhaa8Acifg8Aad6mbkaCTmbcbhainJbbbbh80a8Nabaacdtfgeclfydbg8Fcx2fgHIdwa8Naeydbghcx2fgAIdwg8Z:tg8Va8VNaHIdbaAIdbg83:tg8Wa8WNaHIdlaAIdlg85:tg8Xa8XNMMg8Sa8Naecwfydbg8Acx2fgeIdwa8Z:tg8YNa8Va8YNa8WaeIdba83:tg81Na8XaeIdla85:tgBNMMgRa8VN:tJbbbbJbbjZa8Sa8Ya8YNa81a81NaBaBNMMg8UNaRaRN:tg86:va86Jbbbb9BEg86Nh88a8Ua8VNaRa8YN:ta86Nh89a8SaBNaRa8XN:ta86Nh8:a8Ua8XNaRaBN:ta86NhZa8Sa81NaRa8WN:ta86Nhna8Ua8WNaRa81N:ta86Nhca8WaBNa8Xa81N:tgRaRNa8Xa8YNa8VaBN:tgRaRNa8Va81Na8Wa8YN:tgRaRNMM:rJbbbZNhRa8PahaC2g8JcdtfhHa8Pa8AaC2gDcdtfhAa8Pa8FaC2g8KcdtfhXa8Z:mh9ca85:mhJa83:mh9eascjdfheaChKJbbbbhBJbbbbh86Jbbbbh8SJbbbbh8UJbbbbh8ZJbbbbh83Jbbbbh85Jbbbbh87JbbbbhUinaecwfaRa89aXIdbaHIdbg8Y:tg8XNa88aAIdba8Y:tg81NMg8VNUdbaeclfaRaZa8XNa8:a81NMg8WNUdbaeaRaca8XNana81NMg8XNUdbaecxfaRa9ca8VNaJa8WNa8Ya9ea8XNMMMg8YNUdbaRa8Va8WNNa8ZMh8ZaRa8Va8XNNa8UMh8UaRa8Wa8XNNa8SMh8SaRa8Ya8YNNaUMhUaRa8Va8YNNa87Mh87aRa8Wa8YNNa85Mh85aRa8Xa8YNNa83Mh83aRa8Va8VNNa86Mh86aRa8Wa8WNNaBMhBaRa8Xa8XNNa80Mh80aHclfhHaXclfhXaAclfhAaeczfheaKcufgKmbkagahc8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdyaga8Fc8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdyaga8Ac8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdya8Ra8Jcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8Ra8Kcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8RaDcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbkaacifgaad6mbkkcbhAdndnamcwGgTmbJbbbbh8ScbhScbh9hcbh9ixekcbhSa3cbyd1:H:cjbHjjjjbbh9iasc:Cefasyd;8egecdtfa9iBdbasaecefBd;8ecua9ialabadaOz:fjjjbgXcltaXcjjjjiGEcbyd1:H:cjbHjjjjbbh9hasc:Cefasyd;8egecdtfa9hBdbasaecefBd;8ea9haXa9ia8Nalz:gjjjbJFFuuh8SaXTmba9hheaXhHinaeIdbgRa8Sa8SaR9EEh8SaeclfheaHcufgHmbkaXhSkdnalTmbaLclfheaLydbhXaYhHalhKcbhAincbaeydbg8FaX9RaHRbbcpeGEaAfhAaHcefhHaeclfhea8FhXaKcufgKmbkaAce4hAkcuadaA9Rcifg6cx2a6c;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbh9kasc:Cefasyd;8egecdtfa9kBdbasaecefBd;8ecua6cdta6cFFFFi0Ecbyd1:H:cjbHjjjjbbh0asc:Cefasyd;8egecdtfa0BdbasaecefBd;8ea3cbyd1:H:cjbHjjjjbbh9masc:Cefasyd;8egecdtfa9mBdbasaecefBd;8ealcbyd1:H:cjbHjjjjbbh9nasc:Cefasyd;8egecdtfa9nBdbasaecefBd;8eaxaxNayJbbjZamclGEgZaZN:vh87JbbbbhUdnadak9nmbdna6ci6mbaCclth9oa9kcwfh9pJbbbbh85JbbbbhUinascNefabadalaOz:cjjjbabh8Acbh9qcbh9rinaba9rcdtfhDcbheindnaOa8AaefydbgAcdtghfydbgXaOaDaec:W:G:cjbfydbcdtfydbgHcdtg8JfydbgKSmbaYaHfRbbgacv2aYaAfRbbg8FfRb;a:G:cjbg8La8Fcv2aafg8KRb;a:G:cjbg3VcFeGTmbdnaKaX9nmba8KRb;G:G:cjbcFeGmekdna8FcufcFeGce0mbaaTmba5ahfydbaH9hmekdna8FTmbaacufcFeGce0mba8Ea8JfydbaA9hmeka9ka9qcx2fgXaHaAa3cFeGgKEBdlaXaAaHaKEBdbaXaKa8LGcb9hBdwa9qcefh9qkaeclfgecx9hmbkdna9rcifg9rad9pmba8Acxfh8Aa9qcifa69nmekka9qTmdcbh8KinaIaOa9ka8Kcx2fghydbgKcdtgXfydbg8Ac8S2fgeIdwa8Nahydlg8Fcx2fgHIdwg8WNaeIdzaHIdbg8XNaeIdaMgRaRMMa8WNaeIdlaHIdlg8YNaeIdCa8WNaeId3MgRaRMMa8YNaeIdba8XNaeIdxa8YNaeIdKMgRaRMMa8XNaeId8KMMM:lhRJbbbbJbbjZaeIdyg8V:va8VJbbbb9BEh8VdndnahydwgDmbJFFuuh86xekJbbbbJbbjZaIaOa8Fcdtfydbc8S2fgeIdyg81:va81Jbbbb9BEaeIdwa8NaKcx2fgHIdwg81NaeIdzaHIdbg80NaeIdaMgBaBMMa81NaeIdlaHIdlgBNaeIdCa81NaeId3Mg81a81MMaBNaeIdba80NaeIdxaBNaeIdKMg81a81MMa80NaeId8KMMM:lNh86ka8VaRNhBdnaCTmbagaKc8S2fgAIdwa8WNaAIdza8XNaAIdaMgRaRMMa8WNaAIdla8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8Pa8FaC2gacdtfhHa8RaKaC2g8JcltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkdndnaDmbJbbbbh8Vxekaga8Fc8S2fgAIdwa8NaKcx2fgeIdwg8XNaAIdzaeIdbg8YNaAIdaMg8Va8VMMa8XNaAIdlaeIdlg81NaAIdCa8XNaAId3Mg8Va8VMMa81NaAIdba8YNaAIdxa81NaAIdKMg8Va8VMMa8YNaAId8KMMMh8Va8Pa8JcdtfhHa8RaacltfheaAIdyh80aChAinaHIdbg8Wa8Wa80NaecxfIdba8XaecwfIdbNa8YaeIdbNa81aeclfIdbNMMMg8Wa8WM:tNa8VMh8VaHclfhHaeczfheaAcufgAmbka8V:lh8VkaBaR:lMhBa86a8VMh86dndndnaYaKfRbbc9:fPddbekaQaXfydbgXaKSmbaOa8Fcdtfydbh8Jindndna5aXcdtgafydbgecuSmbaOaecdtfydba8JSmekdna8EaafydbgecuSmbaOaecdtfydba8JSmeka8FhekagaXc8S2fgAIdwa8Naecx2fgHIdwg8WNaAIdzaHIdbg8XNaAIdaMgRaRMMa8WNaAIdlaHIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaeaC2cdtfhHa8RaXaC2cltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkaBaR:lMhBaQaafydbgXaK9hmbkkaYa8FfRbbci9hmeaDTmeaQa8FcdtfydbgXa8FSmeindndna5aXcdtgafydbgecuSmbaOaecdtfydba8ASmekdna8EaafydbgecuSmbaOaecdtfydba8ASmekaKhekagaXc8S2fgAIdwa8Naecx2fgHIdwg8WNaAIdzaHIdbg8XNaAIdaMgRaRMMa8WNaAIdlaHIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaeaC2cdtfhHa8RaXaC2cltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbka86aR:lMh86aQaafydbgXa8F9hmbxdkkdna8Ea5a5aXfydba8FSEaQaXfydbgacdtfydbgXcu9hmbaQa8FcdtfydbhXkagaac8S2fgAIdwa8NaXcx2fgeIdwg8WNaAIdzaeIdbg8XNaAIdaMgRaRMMa8WNaAIdlaeIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaXaC2g8AcdtfhHa8RaaaC2g8JcltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkdndnaDmbJbbbbh8VxekagaXc8S2fgAIdwa8Naacx2fgeIdwg8XNaAIdzaeIdbg8YNaAIdaMg8Va8VMMa8XNaAIdlaeIdlg81NaAIdCa8XNaAId3Mg8Va8VMMa81NaAIdba8YNaAIdxa81NaAIdKMg8Va8VMMa8YNaAId8KMMMh8Va8Pa8JcdtfhHa8Ra8AcltfheaAIdyh80aChAinaHIdbg8Wa8Wa80NaecxfIdba8XaecwfIdbNa8YaeIdbNa81aeclfIdbNMMMg8Wa8WM:tNa8VMh8VaHclfhHaeczfheaAcufgAmbka8V:lh8VkaBaR:lMhBa86a8VMh86kaha86aBa86aB9DgeEUdwahaKa8FaeaDcb9hGgeEBdlaha8FaKaeEBdba8Kcefg8Ka9q9hmbkascjdfcbcj;qbz:tjjjb8Aa9phea9qhHinascjdfaeydbcA4cF8FGgAcFAaAcFA6EcdtfgAaAydbcefBdbaecxfheaHcufgHmbkcbhecbhHinascjdfaefgAydbhXaAaHBdbaXaHfhHaeclfgecj;qb9hmbkcbhea9phHinascjdfaHydbcA4cF8FGgAcFAaAcFA6EcdtfgAaAydbgAcefBdba0aAcdtfaeBdbaHcxfhHa9qaecefge9hmbkadak9RgAci9Uh9sdnalTmbcbhea9mhHinaHaeBdbaHclfhHalaecefge9hmbkkcbh9ta9ncbalz:tjjjbh3aAcO9Uh9ua9sce4h9rcbh8Lcbh8Kdnina9ka0a8Kcdtfydbcx2fg8JIdwgRa879Emea8La9s9pmeJFFuuh8Vdna9ra9q9pmba9ka0a9rcdtfydbcx2fIdwJbb;aZNh8VkdnaRa8V9ETmbaRaU9ETmba8La9u0mdkdna3aOa8JydlgDcdtg9vfg8AydbgAfg9wRbba3aOa8Jydbghcdtg9xfydbgefg9yRbbVmbaYahfRbbh9zdndnaLaecdtfgHclfydbgXaHydbgHSmbaXaH9RhXa8NaAcx2fh8Fa8Naecx2fhaaEaHcitfheindna9maeydbcdtfydbgHaASmba9maeclfydbcdtfydbgKaASmbaHaKSmba8NaKcx2fgKIdba8NaHcx2fgHIdbg8W:tgRaaIdlaHIdlg8X:tg80NaKIdla8X:tg8VaaIdba8W:tgBN:tg8YaRa8FIdla8X:tg86Na8Va8FIdba8W:tg8UN:tg8XNa8VaaIdwaHIdwg81:tg8ZNaKIdwa81:tg8Wa80N:tg80a8Va8FIdwa81:tg83Na8Wa86N:tg8VNa8WaBNaRa8ZN:tg81a8Wa8UNaRa83N:tgRNMMa8Ya8YNa80a80Na81a81NMMa8Xa8XNa8Va8VNaRaRNMMN:rJbbj8:N9FmikaecwfheaXcufgXmbkkdndndndna9zc9:fPdebdkahheina8AydbhAdndna5aecdtgHfydbgecuSmbaOaecdtfydbaASmekdna8EaHfydbgecuSmbaOaecdtfydbaASmekaDheka9maHfaeBdbaQaHfydbgeah9hmbxikkdna8Ea5a5a9xfydbaDSEaQa9xfydbghcdtfydbgecu9hmbaQa9vfydbheka9ma9xfaDBdbaehDka9mahcdtfaDBdbka9yce86bba9wce86bba8JIdwgRaUaUaR9DEhUa9tcefh9tcecda9zceSEa8Lfh8Lxeka9rcefh9rka8Kcefg8Ka9q9hmbkka9tTmddnalTmbcbh8Fcbhhindna9mahcdtgefydbgAahSmbaOaAcdtfydbh8AdnahaOaefydb9hg8JmbaIa8Ac8S2fgeaIahc8S2fgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxaeaHIdzaeIdzMUdzaeaHIdCaeIdCMUdCaeaHIdKaeIdKMUdKaeaHId3aeId3MUd3aeaHIdaaeIdaMUdaaeaHId8KaeId8KMUd8KaeaHIdyaeIdyMUdya8MTmba8Ma8Acltfgea8MahcltfgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxkaCTmbagaAc8S2fgeagahc8S2gDfgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxaeaHIdzaeIdzMUdzaeaHIdCaeIdCMUdCaeaHIdKaeIdKMUdKaeaHId3aeId3MUd3aeaHIdaaeIdaMUdaaeaHId8KaeId8KMUd8KaeaHIdyaeIdyMUdya9oaA2haa8RhHaChXinaHaafgeaHa8FfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8JmbJbbbbJbbjZaIaDfgeIdygR:vaRJbbbb9BEaeIdwa8Na8Acx2fgHIdwgRNaeIdzaHIdbg8VNaeIdaMg8Wa8WMMaRNaeIdlaHIdlg8WNaeIdCaRNaeId3MgRaRMMa8WNaeIdba8VNaeIdxa8WNaeIdKMgRaRMMa8VNaeId8KMMM:lNgRa85a85aR9DEh85ka8Fa9ofh8Fahcefghal9hmbkcbhHa5heindnaeydbgAcuSmbdnaHa9maAcdtgXfydbgA9hmbcuhAa5aXfydbgXcuSmba9maXcdtfydbhAkaeaABdbkaeclfhealaHcefgH9hmbkcbhHa8EheindnaeydbgAcuSmbdnaHa9maAcdtgXfydbgA9hmbcuhAa8EaXfydbgXcuSmba9maXcdtfydbhAkaeaABdbkaeclfhealaHcefgH9hmbkka85aUaCEh85cbhHabhecbhAindnaOa9maeydbcdtfydbg8FcdtfydbgXaOa9maeclfydbcdtfydbgacdtfydbgKSmbaXaOa9maecwfydbcdtfydbg8AcdtfydbghSmbaKahSmbabaHcdtfgXa8FBdbaXcwfa8ABdbaXclfaaBdbaHcifhHkaecxfheaAcifgAad6mbkdndnaTmbaHhdxekdnaHak0mbaHhdxekdna8Sa859FmbaHhdxekJFFuuh8ScbhdabhecbhAindna9ha9iaeydbgXcdtfydbcdtfIdbgRa859ETmbaeclf8Pdbh9AabadcdtfgKaXBdbaKclfa9A83dbaRa8Sa8SaR9EEh8SadcifhdkaecxfheaAcifgAaH6mbkkadak0mbxdkkascNefabadalaOz:cjjjbkdndnadak0mbadhaxekdnaTmbadhaxekdna8Sa879FmbadhaxekcehKina8SJbb;aZNgRa87aRa879DEh8WJbbbbhRdnaSTmba9hheaShHinaeIdbg8VaRa8Va8W9FEaRa8VaR9EEhRaeclfheaHcufgHmbkkJFFuuh8ScbhaabhecbhHindna9ha9iaeydbgAcdtfydbcdtfIdbg8Va8W9ETmbaeclf8Pdbh9AabaacdtfgXaABdbaXclfa9A83dba8Va8Sa8Sa8V9EEh8SaacifhakaecxfheaHcifgHad6mbkdnaKaaad9hVceGmbadhaxdkaRaUaUaR9DEhUaaak9nmecbhKaahda8Sa879FmbkkdnamcjjjjdGTmba9ncbalz:tjjjbh8AdnaaTmbabheaahHina8AaeydbgAfce86bba8AaOaAcdtfydbfce86bbaeclfheaHcufgHmbkkascNefabaaalaOz:cjjjbdndnalTmbcbhXindna8AaXfRbbTmbdnaYaXfRbbgecl0mbceaetcQGmekdnaOaXcdtg8FfydbgeaXSmba8NaXcx2fgHa8Naecx2fgeydwBdwaHae8Pdb83dbxekaIaXc8S2fgKIdygcacJL:3;rUNgRMh87aKIdwg9BaRMh8SaKIdlg9CaRMh8UaKIdbg9DaRMh81aKIdag9EaRa8NaXcx2fg8JIdwg88N:th8ZaKId3g9FaRa8JIdlg89N:th83aKIdKg9Ga8JIdbg8:aRN:th80JbbbbhnaKIdCg9HJbbbbMh85aKIdzg9IJbbbbMhBaKIdxg9JJbbbbMh86dndnaCTmbaXhAinJbbbba87agaAc8S2fgHIdygR:vaRJbbbb9BEhRa8RaAaC2cltfheaHIdaa87Na8ZMh8ZaHId3a87Na83Mh83aHIdKa87Na80Mh80aHIdCa87Na85Mh85aHIdza87NaBMhBaHIdxa87Na86Mh86aHIdwa87Na8SMh8SaHIdla87Na8UMh8UaHIdba87Na81Mh81aChHina8ZaecwfIdbg8VaecxfIdbg8YNaRN:th8Za83aeclfIdbg8Wa8YNaRN:th83a85a8Wa8VNaRN:th85a81aeIdbg8Xa8XNaRN:th81a80a8Xa8YNaRN:th80aBa8Xa8VNaRN:thBa86a8Xa8WNaRN:th86a8Sa8Va8VNaRN:th8Sa8Ua8Wa8WNaRN:th8UaeczfheaHcufgHmbkaQaAcdtfydbgAaX9hmbka8MTmba8MaXcltfgeIdxhxaeIdwh9caeIdlhJaeIdbhRxekJbbbbhxJbbbbh9cJbbbbhJJbbbbhRkaBa81:vg8Wa80Na8Z:ta85aBa86a81:vg8VN:tg8Za8Ua86a8VN:tg8Y:vg8Xa8Va80Na83:tg8UN:th83a9caRa8WN:taJaRa8VN:tg86a8XN:tg85a8SaBa8WN:ta8Za8XN:tgB:vg8S:mh8Za86a8Y:vg9c:mhJdnJbbbbaRaRa81:vg9eN:ta86a9cN:ta85a8SN:tg86:la87J:983:g81NgR9ETmba8Za83NaJa8UNa9ea80Nax:tMMa86:vhnka81:laR9ETmba8Y:laR9ETmbaB:laR9ETmba9e:manNa8W:ma8ZanNa83aB:vMgBNa8V:maJanNa8X:maBNa8Ua8Y:vMMg85Na80:ma81:vMMMh87aLa8FfgeclfydbgHaeydbge9RhhaEaecitfh8FJbbbbhRdnaHaeSgDmbJbbbbhRa8FheahhAina8Naeclfydbcx2fgHIdwa88:tg8Va8VNaHIdba8::tg8Va8VNaHIdla89:tg8Va8VNMMg8Va8Naeydbcx2fgHIdwa88:tg8Wa8WNaHIdba8::tg8Wa8WNaHIdla89:tg8Wa8WNMMg8WaRaRa8W9DEgRaRa8V9DEhRaecwfheaAcufgAmbkaR:rgRaRNhRkaBa88:tg8Va8VNa87a8::tg8Va8VNa85a89:tg8Va8VNMMaR9EmbaKId8KhndnaDmbina8Na8Fclfydbcx2fgeIdba8Na8Fydbcx2fgHIdbg8W:tgRa89aHIdlg8X:tg80NaeIdla8X:tg8Va8:a8W:tg86N:tg8YaRa85a8X:tg8SNa8Va87a8W:tg8UN:tg8XNa8Va88aHIdwg81:tg8ZNaeIdwa81:tg8Wa80N:tg80a8VaBa81:tg83Na8Wa8SN:tg8VNa8Wa86NaRa8ZN:tg81a8Wa8UNaRa83N:tgRNMMa8Ya8YNa80a80Na81a81NMMa8Xa8XNa8Va8VNaRaRNMMN:rJbbj8:N9Fmda8Fcwfh8FahcufghmbkkJbbbbJbbjZac:vacJbbbb9BEgRa9BaBNa9Ia87Na9EMg8Va8VMMaBNa9Ca85Na9HaBNa9FMg8Va8VMMa85Na9Da87Na9Ja85Na9GMg8Va8VMMa87NanMMM:lNaRa9Ba88Na9Ia8:Na9EMg8Va8VMMa88Na9Ca89Na9Ha88Na9FMg8Va8VMMa89Na9Da8:Na9Ja89Na9GMg8Va8VMMa8:NanMMM:lNJbb;aZNJ:983:g81M9Emba8JaBUdwa8Ja85Udla8Ja87UdbkaXcefgXal9hmbkdnaCmbcbhCxdkcbhXindna8AaXfRbbTmbaOaXcdtgefydbaX9hmbaYaXfhhaQaefh8Ja8NaXcx2fhAa8PaXaC2cdtfhDcbhEincuhLdnahRbbci9hmbaXhLa8JydbgeaXSmba8PaEcdtgHfhKaDaHfIdbhRaXhLinaLhHcuhLdnaKaeaC2cdtfIdbaR9CmbaHcuSmbaHhLagaec8S2fIdyagaHc8S2fIdy9ETmbaehLkaQaecdtfydbgeaX9hmbkka8PaEcdtfhKa8RaEcltfh8FaXheinaKaeaC2cdtfJbbbbJbbjZagaeaLaLcuSEgHc8S2fIdygR:vaRJbbbb9BEa8FaHaC2cltfgHIdwaAIdwNaHIdbaAIdbNaHIdlaAIdlNMMaHIdxMNUdbaQaecdtfydbgeaX9hmbkaEcefgEaC9hmbkkaXcefgXal9hmbxdkkaCmbcbhCkaiavaoarawaCala8Na8Pazasayasc1efaYa8Aaqz:hjjjbkdnamcjjjjlGTmbazmbaaTmbabhecbhLinaYaeydbgAfRbbc3thQaecwfgXydbhHcjjjj94hCdna5aAcdtgEfydbaeclfgKydbgOSmbcjjjj94cba8EaOcdtfydbaASEhCkaeaQaCVaAVBdbaYaOfRbbc3th8Fcjjjj94hCcjjjj94hQdna5aOcdtfydbaHSmbcjjjj94cba8EaHcdtfydbaOSEhQkaKa8FaQVaOVBdbaYaHfRbbc3thOdna5aHcdtfydbaASmbcjjjj94cba8EaEfydbaHSEhCkaXaOaCVaHVBdbaecxfheaLcifgLaa6mbkkdnazTmbaaTmbaaheinabazabydbcdtfydbBdbabclfhbaecufgembkkdnaPTmbaPaZaU:rNUdbkdnasyd;8egHTmbaHcdtasc:Ceffc98fheinaeydbcbyd:m:H:cjbH:bjjjbbaec98fheaHcufgHmbkkascj;sbf8Kjjjjbaak;Yieouabydlhvabydbclfcbaicdtz:tjjjbhoadci9UhrdnadTmbdnalTmbaehwadhDinaoalawydbcdtfydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbxdkkaehwadhDinaoawydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbkkdnaiTmbcbhDaohwinawydbhqawaDBdbawclfhwaqaDfhDaicufgimbkkdnadci6mbinaecwfydbhwaeclfydbhDaeydbhidnalTmbalawcdtfydbhwalaDcdtfydbhDalaicdtfydbhikavaoaicdtfgqydbcitfaDBdbavaqydbcitfawBdlaqaqydbcefBdbavaoaDcdtfgqydbcitfawBdbavaqydbcitfaiBdlaqaqydbcefBdbavaoawcdtfgwydbcitfaiBdbavawydbcitfaDBdlawawydbcefBdbaecxfhearcufgrmbkkabydbcbBdbk:todDue99aicd4aifhrcehwinawgDcethwaDar6mbkcuaDcdtgraDcFFFFi0Ecbyd1:H:cjbHjjjjbbhwaoaoyd9GgqcefBd9GaoaqcdtfawBdbawcFearz:tjjjbhkdnaiTmbalcd4hlaDcufhxcbhminamhDdnavTmbavamcdtfydbhDkcbadaDal2cdtfgDydlgwawcjjjj94SEgwcH4aw7c:F:b:DD2cbaDydbgwawcjjjj94SEgwcH4aw7c;D;O:B8J27cbaDydwgDaDcjjjj94SEgDcH4aD7c:3F;N8N27axGhwamcdthPdndndnavTmbakawcdtfgrydbgDcuSmeadavaPfydbal2cdtfgsIdbhzcehqinaqhrdnadavaDcdtfydbal2cdtfgqIdbaz9CmbaqIdlasIdl9CmbaqIdwasIdw9BmlkarcefhqakawarfaxGgwcdtfgrydbgDcu9hmbxdkkakawcdtfgrydbgDcuSmbadamal2cdtfgsIdbhzcehqinaqhrdnadaDal2cdtfgqIdbaz9CmbaqIdlasIdl9CmbaqIdwasIdw9BmikarcefhqakawarfaxGgwcdtfgrydbgDcu9hmbkkaramBdbamhDkabaPfaDBdbamcefgmai9hmbkkakcbyd:m:H:cjbH:bjjjbbaoaoyd9GcufBd9GdnaeTmbaiTmbcbhDaehwinawaDBdbawclfhwaiaDcefgD9hmbkcbhDaehwindnaDabydbgrSmbawaearcdtfgrydbBdbaraDBdbkabclfhbawclfhwaiaDcefgD9hmbkkk;:odvuv998Jjjjjbca9Rgocbyd1:G:cjbBdKaocb8Pdj:G:cjb83izaocbydN:G:cjbBdwaocb8Pd:m:G:cjb83ibdnadTmbaicd4hrdnabmbdnalTmbcbhwinaealawcdtfydbar2cdtfhDcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkawcefgwad9hmbxikkarcdthwcbhDincbhiinaoczfaifgqaeaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkaeawfheaDcefgDad9hmbxdkkdnalTmbcbhwinabawcx2fgiaealawcdtfydbar2cdtfgDIdbUdbaiaDIdlUdlaiaDIdwUdwcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkawcefgwad9hmbxdkkarcdthlcbhwaehDinabawcx2fgiaeawar2cdtfgqIdbUdbaiaqIdlUdlaiaqIdwUdwcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkaDalfhDawcefgwad9hmbkkJbbbbaoIdbaoIdzgx:tgkakJbbbb9DEgkaoIdlaoIdCgm:tgPaPak9DEgkaoIdwaoIdKgP:tgsasak9DEhsdnabTmbadTmbJbbbbJbbjZas:vasJbbbb9BEhkinabakabIdbax:tNUdbabclfgoakaoIdbam:tNUdbabcwfgoakaoIdbaP:tNUdbabcxfhbadcufgdmbkkdnavTmbavaPUdwavamUdlavaxUdbkask:WlewudnaeTmbcbhvabhoinaoavBdbaoclfhoaeavcefgv9hmbkkdnaiTmbcbhrinadarcdtfhwcbhDinalawaDcdtgvyd:G:G:cjbcdtfydbcdtfydbhodnalawavfydbcdtfydbgqabaqcdtfgkydbgvSmbinakabavgqcdtfgxydbgvBdbaxhkaqav9hmbkkdnaoabaocdtfgkydbgvSmbinakabavgocdtfgxydbgvBdbaxhkaoav9hmbkkdnaqaoSmbabaqaoaqao0Ecdtfaqaoaqao6EBdbkaDcefgDci9hmbkarcifgrai6mbkkdnaembcbskcbhxindnalaxcdtgvfydbax9hmbaxhodnaxabavfgDydbgvSmbaDhqinaqabavgocdtfgkydbgvBdbakhqaoav9hmbkkaDaoBdbkaxcefgxae9hmbkcbhkabhvcbhoindndnaoalydbgq9hmbdnaoavydbgq9hmbavakBdbakcefhkxdkavabaqcdtfydbBdbxekavabaqcdtfydbBdbkalclfhlavclfhvaeaocefgo9hmbkakk;jiilud99euabcbaecltz:tjjjbhvdnalTmbadhoaihralhwinarcwfIdbhDarclfIdbhqavaoydbcltfgkarIdbakIdbMUdbakaqakIdlMUdlakaDakIdwMUdwakakIdxJbbjZMUdxaoclfhoarcxfhrawcufgwmbkkdnaeTmbavhkaehrinakcxfgoIdbhDaocbBdbakakIdbJbbbbJbbjZaD:vaDJbbbb9BEgDNUdbakclfgoaDaoIdbNUdbakcwfgoaDaoIdbNUdbakczfhkarcufgrmbkkdnalTmbinavadydbcltfgkaicwfIdbakIdw:tgDaDNaiIdbakIdb:tgDaDNaiclfIdbakIdl:tgDaDNMMgDakIdxgqaqaD9DEUdxadclfhdaicxfhialcufglmbkkdnaeTmbavcxfhkinabakIdbUdbakczfhkabclfhbaecufgembkkk:moerudnaoTmbaecd4hzdnavTmbaicd4hHavcdthOcbhAindnaPaAfRbbTmbaAhednaDTmbaDaAcdtfydbhekdnasTmbasaefRbbceGmekdnamaAfRbbclSmbabaeaz2cdtfgiaraAcx2fgCIdbakNaxIdbMUdbaiaCIdlakNaxIdlMUdlaiaCIdwakNaxIdwMUdwkadaeaH2cdtfhXaqheawhiavhCinaXaeydbcdtgQfaiIdbalaQfIdb:vUdbaeclfheaiclfhiaCcufgCmbkkawaOfhwaAcefgAao9hmbxdkkdnasmbcbheaDhiindnaPaefRbbTmbaehCdnaDTmbaiydbhCkamaefRbbclSmbabaCaz2cdtfgCarIdbakNaxIdbMUdbaCarclfIdbakNaxIdlMUdlaCarcwfIdbakNaxIdwMUdwkaiclfhiarcxfhraoaecefge9hmbxdkkdnaDTmbindnaPRbbTmbasaDydbgefRbbceGmbamRbbclSmbabaeaz2cdtfgearIdbakNaxIdbMUdbaearclfIdbakNaxIdlMUdlaearcwfIdbakNaxIdwMUdwkaPcefhPaDclfhDamcefhmarcxfhraocufgombxdkkazcdthicbheindnaPaefRbbTmbasaefRbbceGmbamaefRbbclSmbabarIdbakNaxIdbMUdbabclfarclfIdbakNaxIdlMUdbabcwfarcwfIdbakNaxIdwMUdbkarcxfhrabaifhbaoaecefge9hmbkkk8MbabaeadaialavcbcbcbcbcbaoarawaDz:bjjjbk8MbabaeadaialavaoarawaDaqakaxamaPz:bjjjbkRbababaeadaialavaoarawaDaqakaxcjjjjdVamz:bjjjbk:g8Koque99due99duq998Jjjjjbc;Wb9Rgq8Kjjjjbcbhkaqcxfcbc;Kbz:tjjjb8Aaqcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbgxBdxaqceBd2axaialavcbcbz:ejjjb8AaqcualcdtalcFFFFi0Egmcbyd1:H:cjbHjjjjbbgiBdzaqcdBd2dndnJFF959eJbbjZawJbbjZawJbbjZ9DE:vawJ9VO:d869DEgw:lJbbb9p9DTmbaw:OhPxekcjjjj94hPkadci9Uhsarco9UhzdndnaombaPcd9imekdnalTmbaPcuf:YhwdnaoTmbcbhvaihHaxhOindndnaoavfRbbceGTmbavcjjjjlVhAxekdndnaOclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcqthAdndnaOcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXVhAdndnaOIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXcCtVhAkaHaABdbaHclfhHaOcxfhOalavcefgv9hmbxdkkaxhvaihOalhHindndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcCthAdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqtaAVhAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaOaAaXVBdbavcxfhvaOclfhOaHcufgHmbkkadTmbcbhkaehvcbhOinakaiavclfydbcdtfydbgHaiavcwfydbcdtfydbgA9haiavydbcdtfydbgXaH9haXaA9hGGfhkavcxfhvaOcifgOad6mbkkarci9UhQdndnaz:Z:rJbbbZMgw:lJbbb9p9DTmbaw:Ohvxekcjjjj94hvkaQ:ZhLcbhKc:bwhzdninakaQ9pmeazaP9Rcd9imeavazcufgOavaO9iEaPcefavaP9kEhYdnalTmbaYcuf:YhwdnaoTmbcbhOaihHaxhvindndnaoaOfRbbceGTmbaOcjjjjlVhAxekdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcqthAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXVhAdndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXcCtVhAkaHaABdbaHclfhHavcxfhvalaOcefgO9hmbxdkkaxhvaihOalhHindndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcCthAdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqtaAVhAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaOaAaXVBdbavcxfhvaOclfhOaHcufgHmbkkcbhOdnadTmbaehvcbhHinaOaiavclfydbcdtfydbgAaiavcwfydbcdtfydbgX9haiavydbcdtfydbgraA9haraX9hGGfhOavcxfhvaHcifgHad6mbkkdnas:ZgCaL:taY:Ygwaz:Y:tg8ANak:ZgEaO:Zg3:tNaEaL:tawaP:Y:tg5Na3aC:tNMg8EJbbbb9BmbaCaE:ta5a8Aa3aL:tNNNa8E:vawMhwkdndnaOaQ0mbaOhkaYhPxekaOhsaYhzkdndnaKcl0mbdnawJbbbZMgw:lJbbb9p9DTmbaw:Ohvxdkcjjjj94hvxekaPazfcd9ThvkaKcefgKcs9hmbkkdndndnakmbJbbjZhwcbhOcdhvaDmexdkalcd4alfhHcehOinaOgvcethOavaH6mbkcbhOaqcuavcdtgYavcFFFFi0Ecbyd1:H:cjbHjjjjbbgKBdCaqciBd2aqamcbyd1:H:cjbHjjjjbbgzBdKaqclBd2dndndndnalTmbaPcuf:YhwaoTmecbhOaihAaxhHindndnaoaOfRbbceGTmbaOcjjjjlVhXxekdndnaHclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqthXdndnaHcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaXarVhXdndnaHIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaXarcCtVhXkaAaXBdbaAclfhAaHcxfhHalaOcefgO9hmbxikkaKcFeaYz:tjjjb8AcbhPcbhvxdkaxhOaihHalhAindndnaOIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcCthXdndnaOclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkarcqtaXVhXdndnaOcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaHaXarVBdbaOcxfhOaHclfhHaAcufgAmbkkaKcFeaYz:tjjjbhravcufhocbhPcbhYindndndnaraiaYcdtgKfydbgAcm4aA7c:v;t;h;Ev2gvcs4av7aoGgHcdtfgXydbgOcuSmbcehvinaiaOcdtgOfydbaASmdaHavfhOavcefhvaraOaoGgHcdtfgXydbgOcu9hmbkkaXaYBdbaPhvaPcefhPxekazaOfydbhvkazaKfavBdbaYcefgYal9hmbkcuaPc8S2gOaPc;D;O;f8U0EhvkcbhXaqavcbyd1:H:cjbHjjjjbbgvBd3aqcvBd2avcbaOz:tjjjbhOdnadTmbaehiinaxaiclfydbgrcx2fgvIdbaxaiydbgocx2fgHIdbg3:tgCaxaicwfydbgYcx2fgAIdlaHIdlg8A:tgwNavIdla8A:tgEaAIdba3:tg8EN:tgLaLNaEaAIdwaHIdwg5:tg8FNavIdwa5:tgEawN:tgwawNaEa8ENaCa8FN:tgCaCNMMg8E:rhEJbbnnJbbjZazaocdtfydbgvazarcdtfydbgASavazaYcdtfydbgrSGgHEh8Fdna8EJbbbb9ETmbaLaE:vhLaCaE:vhCawaE:vhwkaOavc8S2fgvavIdbawa8FaE:rNgEawNNg8FMUdbavaCaEaCNgaNghavIdlMUdlavaLaEaLNg8ENggavIdwMUdwavawaaNgaavIdxMUdxava8EawNg8JavIdzMUdzavaCa8ENg8EavIdCMUdCavawaEaLa5Nawa3Na8AaCNMM:mg8ANg3NgwavIdKMUdKavaCa3NgCavId3MUd3avaLa3NgLavIdaMUdaava3a8ANg3avId8KMUd8KavaEavIdyMUdydnaHmbaOaAc8S2fgva8FavIdbMUdbavahavIdlMUdlavagavIdwMUdwavaaavIdxMUdxava8JavIdzMUdzava8EavIdCMUdCavawavIdKMUdKavaCavId3MUd3avaLavIdaMUdaava3avId8KMUd8KavaEavIdyMUdyaOarc8S2fgva8FavIdbMUdbavahavIdlMUdlavagavIdwMUdwavaaavIdxMUdxava8JavIdzMUdzava8EavIdCMUdCavawavIdKMUdKavaCavId3MUd3avaLavIdaMUdaava3avId8KMUd8KavaEavIdyMUdykaicxfhiaXcifgXad6mbkkcbhAaqcuaPcdtgvaPcFFFFi0Egicbyd1:H:cjbHjjjjbbgHBdaaqcoBd2aqaicbyd1:H:cjbHjjjjbbgiBd8KaqcrBd2aHcFeavz:tjjjbhYdnalTmbazhHinJbbbbJbbjZaOaHydbgXc8S2fgvIdygw:vawJbbbb9BEavIdwaxcwfIdbgwNavIdzaxIdbgCNavIdaMgLaLMMawNavIdlaxclfIdbgLNavIdCawNavId3MgwawMMaLNavIdbaCNavIdxaLNavIdKMgwawMMaCNavId8KMMM:lNhwdndnaYaXcdtgvfgXydbcuSmbaiavfIdbaw9ETmekaXaABdbaiavfawUdbkaHclfhHaxcxfhxalaAcefgA9hmbkkdndnaPmbJbbbbhwxekJbbbbhwinaiIdbgCawawaC9DEhwaiclfhiaPcufgPmbkaw:rhwkakcd4akfhOcehiinaigvcethiavaO6mbkcbhOaqcuavcdtgiavcFFFFi0Ecbyd1:H:cjbHjjjjbbgHBdyaHcFeaiz:tjjjbhXdnadTmbavcufhrcbhPcbhxindnazaeaxcdtfgvydbcdtfydbgiazavclfydbcdtfydbgOSmbaiazavcwfydbcdtfydbgvSmbaOavSmbaYavcdtfydbhAdndnaYaOcdtfydbgvaYaicdtfydbgi9pmbavaA9pmbaAhlaihoavhAxekdnaAai9pmbaAav9pmbaihlavhoxekavhlaAhoaihAkabaPcx2fgvaABdbavcwfaoBdbavclfalBdbdnaXaoc:3F;N8N2alc:F:b:DD27aAc;D;O:B8J27arGgOcdtfgvydbgicuSmbcehHinaHhvdnabaicx2fgiydbaA9hmbaiydlal9hmbaiydwaoSmikavcefhHaXaOavfarGgOcdtfgvydbgicu9hmbkkavaPBdbaPcefhPkaxcifgxad6mbkaPci2hOkcwhvaDTmekaDawUdbkavcdthvaqcxfc98fhiinaiavfydbcbyd:m:H:cjbH:bjjjbbavc98fgvmbkaqc;Wbf8KjjjjbaOk:3ldrue9:8Jjjjjbc;Wb9Rgr8Kjjjjbcbhwarcxfcbc;Kbz:tjjjb8AdnabaeSmbabaeadcdtzMjjjb8AkarcualcdtalcFFFFi0EgDcbyd1:H:cjbHjjjjbbgqBdxarceBd2aqcbaialavcbarcxfz:djjjbcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbhkarcxfaryd2gxcdtfakBdbaraxcefgmBd2akaialavcbcbz:ejjjb8AarcxfamcdtfaDcbyd1:H:cjbHjjjjbbgiBdbaraxcdfgvBd2arcxfavcdtfcuaialaeadaqz:fjjjbgecltaecjjjjiGEcbyd1:H:cjbHjjjjbbgqBdbaqaeaiakalz:gjjjbaxcifhkdnadTmbaoaoNhocbhwabhlcbheindnaqaialydbgvcdtfydbcdtfIdbao9ETmbalclf8PdbhPabawcdtfgDavBdbaDclfaP83dbawcifhwkalcxfhlaecifgead6mbkkdnakTmbaxcdtarcxffcwfhlinalydbcbyd:m:H:cjbH:bjjjbbalc98fhlakcufgkmbkkarc;Wbf8Kjjjjbawk:WCoDud99vue99vuv998Jjjjjbc;Wb9Rgw8KjjjjbdndnarmbcbhDxekawcxfcbc;Kbz:tjjjb8Aawcuadcx2adc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbgqBdxawceBd2aqaeadaicbcbz:ejjjb8AawcuadcdtadcFFFFi0Egkcbyd1:H:cjbHjjjjbbgxBdzawcdBd2adcd4adfhmceheinaegicetheaiam6mbkcbhPawcuaicdtgsaicFFFFi0Ecbyd1:H:cjbHjjjjbbgzBdCawciBd2dndnar:ZgH:rJbbbZMgO:lJbbb9p9DTmbaO:Ohexekcjjjj94hekaicufhAc:bwhCcbhXadhQcbhLinaeaCcufgiaeai9iEaPcefaeaP9kEhDdndnadTmbaDcuf:YhOaqhiaxheadhmindndnaiIdbaONJbbbZMgK:lJbbb9p9DTmbaK:OhYxekcjjjj94hYkaYcCthYdndnaiclfIdbaONJbbbZMgK:lJbbb9p9DTmbaK:Oh8Axekcjjjj94h8Aka8AcqtaYVhYdndnaicwfIdbaONJbbbZMgK:lJbbb9p9DTmbaK:Oh8Axekcjjjj94h8AkaeaYa8AVBdbaicxfhiaeclfheamcufgmmbkazcFeasz:tjjjbhEcbh3cbh5indnaEaxa5cdtfydbgYcm4aY7c:v;t;h;Ev2gics4ai7aAGgmcdtfg8AydbgecuSmbaeaYSmbcehiinaEamaifaAGgmcdtfg8AydbgecuSmeaicefhiaeaY9hmbkka8AaYBdba3aecuSfh3a5cefg5ad9hmbxdkkazcFeasz:tjjjb8Acbh3kdnaQ:ZgKaH:taD:YgOaC:Y:tg8ENaX:Zg8Fa3:Zga:tNa8FaH:taOaP:Y:tghNaaaK:tNMggJbbbb9BmbaKa8F:taha8EaaaH:tNNNag:vaOMhOkaPaDa3ar0giEhPaXa3aiEhXdna3arSmbaDaCaiEgCaP9Rcd9imbdndnaLcl0mbdnaOJbbbZMgO:lJbbb9p9DTmbaO:Ohexdkcjjjj94hexekaPaCfcd9Theka3aQaiEhQaLcefgLcs9hmekkdndnaXmbcihicbhDxekcbhiawakcbyd1:H:cjbHjjjjbbg5BdKawclBd2aPcuf:YhKdndnadTmbaqhiaxheadhmindndnaiIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:OhYxekcjjjj94hYkaYcCthYdndnaiclfIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:Oh8Axekcjjjj94h8Aka8AcqtaYVhYdndnaicwfIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:Oh8Axekcjjjj94h8AkaeaYa8AVBdbaicxfhiaeclfheamcufgmmbkazcFeasz:tjjjbhEcbhDcbh3indndndnaEaxa3cdtgCfydbgYcm4aY7c:v;t;h;Ev2gics4ai7aAGgmcdtfg8AydbgecuSmbcehiinaxaecdtgefydbaYSmdamaifheaicefhiaEaeaAGgmcdtfg8Aydbgecu9hmbkka8Aa3BdbaDhiaDcefhDxeka5aefydbhika5aCfaiBdba3cefg3ad9hmbkcuaDc32giaDc;j:KM;jb0EhexekazcFeasz:tjjjb8AcbhDcbhekawaecbyd1:H:cjbHjjjjbbgeBd3awcvBd2aecbaiz:tjjjbh8Aavcd4hxdnadTmbdnalTmbaxcdthEa5hYaqhealhmadhAina8AaYydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiamIdbaiIdxMUdxaiamclfIdbaiIdzMUdzaiamcwfIdbaiIdCMUdCaiaiIdKJbbjZMUdKaYclfhYaecxfheamaEfhmaAcufgAmbxdkka5hmaqheadhYina8Aamydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiaiIdxJbbbbMUdxaiaiIdzJbbbbMUdzaiaiIdCJbbbbMUdCaiaiIdKJbbjZMUdKamclfhmaecxfheaYcufgYmbkkdnaDTmba8AhiaDheinaiaiIdbJbbbbJbbjZaicKfIdbgO:vaOJbbbb9BEgONUdbaiclfgmaOamIdbNUdbaicwfgmaOamIdbNUdbaicxfgmaOamIdbNUdbaiczfgmaOamIdbNUdbaicCfgmaOamIdbNUdbaic3fhiaecufgembkkcbhYawcuaDcdtgCaDcFFFFi0Egicbyd1:H:cjbHjjjjbbgeBdaawcoBd2awaicbyd1:H:cjbHjjjjbbgEBd8KaecFeaCz:tjjjbh3dnadTmbaoJbbjZJbbjZaK:vaPceSENgOaONhKaxcdthxalheinaKaec;8:G:cjbalEgmIdwa8Aa5ydbgAc32fgiIdC:tgOaONamIdbaiIdx:tgOaONamIdlaiIdz:tgOaONMMNaqcwfIdbaiIdw:tgOaONaqIdbaiIdb:tgOaONaqclfIdbaiIdl:tgOaONMMMhOdndna3aAcdtgifgmydbcuSmbaEaifIdbaO9ETmekamaYBdbaEaifaOUdbka5clfh5aqcxfhqaeaxfheadaYcefgY9hmbkkaba3aCzMjjjb8Acrhikaicdthiawcxfc98fheinaeaifydbcbyd:m:H:cjbH:bjjjbbaic98fgimbkkawc;Wbf8KjjjjbaDk:Pdidui99ducbhi8Jjjjjbca9Rglcbyd1:G:cjbBdKalcb8Pdj:G:cjb83izalcbydN:G:cjbBdwalcb8Pd:m:G:cjb83ibdndnaembJbbjFhvJbbjFhoJbbjFhrxekadcd4cdthwincbhdinalczfadfgDabadfIdbgvaDIdbgoaoav9EEUdbaladfgDavaDIdbgoaoav9DEUdbadclfgdcx9hmbkabawfhbaicefgiae9hmbkalIdwalIdK:thralIdlalIdC:thoalIdbalIdz:thvkJbbbbavavJbbbb9DEgvaoaoav9DEgvararav9DEk9DeeuabcFeaicdtz:tjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk;Bidqui998Jjjjjbc;Wb9Rgl8Kjjjjbalcxfcbc;Kbz:tjjjb8Aadcd4adfhvcehoinaogrcethoarav6mbkalcuarcdtgoarcFFFFi0Ecbyd1:H:cjbHjjjjbbgvBdxavcFeaoz:tjjjbhwdnadTmbaicd4hDarcufhqcbhkindndnawcbaeakaD2cdtfgrydlgiaicjjjj94SEgocH4ao7c:F:b:DD2cbarydbgxaxcjjjj94SEgocH4ao7c;D;O:B8J27cbarydwgmamcjjjj94SEgrcH4ar7c:3F;N8N27aqGgvcdtfgrydbgocuSmbam::hPai::hsax::hzcehiinaihrdnaeaoaD2cdtfgiIdbaz9CmbaiIdlas9CmbaiIdwaP9BmikarcefhiawavarfaqGgvcdtfgrydbgocu9hmbkkarakBdbakhokabakcdtfaoBdbakcefgkad9hmbkkalydxcbyd:m:H:cjbH:bjjjbbalc;Wbf8Kjjjjbk9teiucbcbyd:q:H:cjbgeabcifc98GfgbBd:q:H:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:q:H:cjbgeabcrfc94GfgbBd:q:H:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd:q:H:cjbge9Rcifc98GaefgbBd:q:H:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk:Kedbcj:Gdk1eFFuuFFuuFFuuFFuFFFuFFFuFbbbbbbbbebbbdbbbbbbbebbbebbbdbbbbbbbbbbbeeeeebebbebbebebbbeebbbbbbbbbbbbeeeeeebebbeeebeebbbbebebbbbbbbbbbbbbbbbbbc1:Hdkxebbbdbbb:G:qbb";
|
|
618
|
+
var wasmpack = new Uint8Array([
|
|
619
|
+
32,
|
|
620
|
+
0,
|
|
621
|
+
65,
|
|
622
|
+
2,
|
|
623
|
+
1,
|
|
624
|
+
106,
|
|
625
|
+
34,
|
|
626
|
+
33,
|
|
627
|
+
3,
|
|
628
|
+
128,
|
|
629
|
+
11,
|
|
630
|
+
4,
|
|
631
|
+
13,
|
|
632
|
+
64,
|
|
633
|
+
6,
|
|
634
|
+
253,
|
|
635
|
+
10,
|
|
636
|
+
7,
|
|
637
|
+
15,
|
|
638
|
+
116,
|
|
639
|
+
127,
|
|
640
|
+
5,
|
|
641
|
+
8,
|
|
642
|
+
12,
|
|
643
|
+
40,
|
|
644
|
+
16,
|
|
645
|
+
19,
|
|
646
|
+
54,
|
|
647
|
+
20,
|
|
648
|
+
9,
|
|
649
|
+
27,
|
|
650
|
+
255,
|
|
651
|
+
113,
|
|
652
|
+
17,
|
|
653
|
+
42,
|
|
654
|
+
67,
|
|
655
|
+
24,
|
|
656
|
+
23,
|
|
657
|
+
146,
|
|
658
|
+
148,
|
|
659
|
+
18,
|
|
660
|
+
14,
|
|
661
|
+
22,
|
|
662
|
+
45,
|
|
663
|
+
70,
|
|
664
|
+
69,
|
|
665
|
+
56,
|
|
666
|
+
114,
|
|
667
|
+
101,
|
|
668
|
+
21,
|
|
669
|
+
25,
|
|
670
|
+
63,
|
|
671
|
+
75,
|
|
672
|
+
136,
|
|
673
|
+
108,
|
|
674
|
+
28,
|
|
675
|
+
118,
|
|
676
|
+
29,
|
|
677
|
+
73,
|
|
678
|
+
115
|
|
679
|
+
]);
|
|
680
|
+
if (typeof WebAssembly !== "object") {
|
|
681
|
+
return {
|
|
682
|
+
supported: false
|
|
683
|
+
};
|
|
684
|
+
}
|
|
685
|
+
var instance;
|
|
686
|
+
var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
|
|
687
|
+
instance = result.instance;
|
|
688
|
+
instance.exports.__wasm_call_ctors();
|
|
689
|
+
});
|
|
690
|
+
function unpack(data) {
|
|
691
|
+
var result = new Uint8Array(data.length);
|
|
692
|
+
for (var i = 0; i < data.length; ++i) {
|
|
693
|
+
var ch = data.charCodeAt(i);
|
|
694
|
+
result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
|
|
695
|
+
}
|
|
696
|
+
var write = 0;
|
|
697
|
+
for (var i = 0; i < data.length; ++i) {
|
|
698
|
+
result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
|
|
699
|
+
}
|
|
700
|
+
return result.buffer.slice(0, write);
|
|
701
|
+
}
|
|
702
|
+
function assert(cond) {
|
|
703
|
+
if (!cond) {
|
|
704
|
+
throw new Error("Assertion failed");
|
|
705
|
+
}
|
|
706
|
+
}
|
|
707
|
+
function bytes(view) {
|
|
708
|
+
return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
|
|
709
|
+
}
|
|
710
|
+
function genremap(fun, positions, vertices, stride) {
|
|
711
|
+
var sbrk = instance.exports.sbrk;
|
|
712
|
+
var rp = sbrk(vertices * 4);
|
|
713
|
+
var sp = sbrk(vertices * stride * 4);
|
|
714
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
715
|
+
heap.set(bytes(positions), sp);
|
|
716
|
+
fun(rp, sp, vertices, stride * 4);
|
|
717
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
718
|
+
var remap = new Uint32Array(vertices);
|
|
719
|
+
new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
|
|
720
|
+
sbrk(rp - sbrk(0));
|
|
721
|
+
return remap;
|
|
722
|
+
}
|
|
723
|
+
function reorder(fun, indices, vertices) {
|
|
724
|
+
var sbrk = instance.exports.sbrk;
|
|
725
|
+
var ip = sbrk(indices.length * 4);
|
|
726
|
+
var rp = sbrk(vertices * 4);
|
|
727
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
728
|
+
var indices8 = bytes(indices);
|
|
729
|
+
heap.set(indices8, ip);
|
|
730
|
+
var unique = fun(rp, ip, indices.length, vertices);
|
|
731
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
732
|
+
var remap = new Uint32Array(vertices);
|
|
733
|
+
new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
|
|
734
|
+
sbrk(ip - sbrk(0));
|
|
735
|
+
for (var i = 0; i < indices.length; ++i) indices[i] = remap[indices[i]];
|
|
736
|
+
return [remap, unique];
|
|
737
|
+
}
|
|
738
|
+
function maxindex(source) {
|
|
739
|
+
var result = 0;
|
|
740
|
+
for (var i = 0; i < source.length; ++i) {
|
|
741
|
+
var index = source[i];
|
|
742
|
+
result = result < index ? index : result;
|
|
743
|
+
}
|
|
744
|
+
return result;
|
|
745
|
+
}
|
|
746
|
+
function simplify(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_index_count, target_error, options) {
|
|
747
|
+
var sbrk = instance.exports.sbrk;
|
|
748
|
+
var te = sbrk(4);
|
|
749
|
+
var ti = sbrk(index_count * 4);
|
|
750
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
751
|
+
var si = sbrk(index_count * 4);
|
|
752
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
753
|
+
heap.set(bytes(vertex_positions), sp);
|
|
754
|
+
heap.set(bytes(indices), si);
|
|
755
|
+
var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, target_index_count, target_error, options, te);
|
|
756
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
757
|
+
var target = new Uint32Array(result);
|
|
758
|
+
bytes(target).set(heap.subarray(ti, ti + result * 4));
|
|
759
|
+
var error = new Float32Array(1);
|
|
760
|
+
bytes(error).set(heap.subarray(te, te + 4));
|
|
761
|
+
sbrk(te - sbrk(0));
|
|
762
|
+
return [target, error[0]];
|
|
763
|
+
}
|
|
764
|
+
function simplifyAttr(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, options) {
|
|
765
|
+
var sbrk = instance.exports.sbrk;
|
|
766
|
+
var te = sbrk(4);
|
|
767
|
+
var ti = sbrk(index_count * 4);
|
|
768
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
769
|
+
var sa = sbrk(vertex_count * vertex_attributes_stride);
|
|
770
|
+
var sw = sbrk(attribute_weights.length * 4);
|
|
771
|
+
var si = sbrk(index_count * 4);
|
|
772
|
+
var vl = vertex_lock ? sbrk(vertex_count) : 0;
|
|
773
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
774
|
+
heap.set(bytes(vertex_positions), sp);
|
|
775
|
+
heap.set(bytes(vertex_attributes), sa);
|
|
776
|
+
heap.set(bytes(attribute_weights), sw);
|
|
777
|
+
heap.set(bytes(indices), si);
|
|
778
|
+
if (vertex_lock) {
|
|
779
|
+
heap.set(bytes(vertex_lock), vl);
|
|
780
|
+
}
|
|
781
|
+
var result = fun(
|
|
782
|
+
ti,
|
|
783
|
+
si,
|
|
784
|
+
index_count,
|
|
785
|
+
sp,
|
|
786
|
+
vertex_count,
|
|
787
|
+
vertex_positions_stride,
|
|
788
|
+
sa,
|
|
789
|
+
vertex_attributes_stride,
|
|
790
|
+
sw,
|
|
791
|
+
attribute_weights.length,
|
|
792
|
+
vl,
|
|
793
|
+
target_index_count,
|
|
794
|
+
target_error,
|
|
795
|
+
options,
|
|
796
|
+
te
|
|
797
|
+
);
|
|
798
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
799
|
+
var target = new Uint32Array(result);
|
|
800
|
+
bytes(target).set(heap.subarray(ti, ti + result * 4));
|
|
801
|
+
var error = new Float32Array(1);
|
|
802
|
+
bytes(error).set(heap.subarray(te, te + 4));
|
|
803
|
+
sbrk(te - sbrk(0));
|
|
804
|
+
return [target, error[0]];
|
|
805
|
+
}
|
|
806
|
+
function simplifyUpdate(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, options) {
|
|
807
|
+
var sbrk = instance.exports.sbrk;
|
|
808
|
+
var te = sbrk(4);
|
|
809
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
810
|
+
var sa = sbrk(vertex_count * vertex_attributes_stride);
|
|
811
|
+
var sw = sbrk(attribute_weights.length * 4);
|
|
812
|
+
var si = sbrk(index_count * 4);
|
|
813
|
+
var vl = vertex_lock ? sbrk(vertex_count) : 0;
|
|
814
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
815
|
+
heap.set(bytes(vertex_positions), sp);
|
|
816
|
+
heap.set(bytes(vertex_attributes), sa);
|
|
817
|
+
heap.set(bytes(attribute_weights), sw);
|
|
818
|
+
heap.set(bytes(indices), si);
|
|
819
|
+
if (vertex_lock) {
|
|
820
|
+
heap.set(bytes(vertex_lock), vl);
|
|
821
|
+
}
|
|
822
|
+
var result = fun(
|
|
823
|
+
si,
|
|
824
|
+
index_count,
|
|
825
|
+
sp,
|
|
826
|
+
vertex_count,
|
|
827
|
+
vertex_positions_stride,
|
|
828
|
+
sa,
|
|
829
|
+
vertex_attributes_stride,
|
|
830
|
+
sw,
|
|
831
|
+
attribute_weights.length,
|
|
832
|
+
vl,
|
|
833
|
+
target_index_count,
|
|
834
|
+
target_error,
|
|
835
|
+
options,
|
|
836
|
+
te
|
|
837
|
+
);
|
|
838
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
839
|
+
bytes(indices).set(heap.subarray(si, si + result * 4));
|
|
840
|
+
bytes(vertex_positions).set(heap.subarray(sp, sp + vertex_count * vertex_positions_stride));
|
|
841
|
+
bytes(vertex_attributes).set(heap.subarray(sa, sa + vertex_count * vertex_attributes_stride));
|
|
842
|
+
var error = new Float32Array(1);
|
|
843
|
+
bytes(error).set(heap.subarray(te, te + 4));
|
|
844
|
+
sbrk(te - sbrk(0));
|
|
845
|
+
return [result, error[0]];
|
|
846
|
+
}
|
|
847
|
+
function simplifyScale(fun, vertex_positions, vertex_count, vertex_positions_stride) {
|
|
848
|
+
var sbrk = instance.exports.sbrk;
|
|
849
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
850
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
851
|
+
heap.set(bytes(vertex_positions), sp);
|
|
852
|
+
var result = fun(sp, vertex_count, vertex_positions_stride);
|
|
853
|
+
sbrk(sp - sbrk(0));
|
|
854
|
+
return result;
|
|
855
|
+
}
|
|
856
|
+
function simplifyPoints(fun, vertex_positions, vertex_count, vertex_positions_stride, vertex_colors, vertex_colors_stride, color_weight, target_vertex_count) {
|
|
857
|
+
var sbrk = instance.exports.sbrk;
|
|
858
|
+
var ti = sbrk(target_vertex_count * 4);
|
|
859
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
860
|
+
var sc = vertex_colors ? sbrk(vertex_count * vertex_colors_stride) : 0;
|
|
861
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
862
|
+
heap.set(bytes(vertex_positions), sp);
|
|
863
|
+
if (vertex_colors) {
|
|
864
|
+
heap.set(bytes(vertex_colors), sc);
|
|
865
|
+
}
|
|
866
|
+
var result = fun(ti, sp, vertex_count, vertex_positions_stride, sc, vertex_colors_stride, color_weight, target_vertex_count);
|
|
867
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
868
|
+
var target = new Uint32Array(result);
|
|
869
|
+
bytes(target).set(heap.subarray(ti, ti + result * 4));
|
|
870
|
+
sbrk(ti - sbrk(0));
|
|
871
|
+
return target;
|
|
872
|
+
}
|
|
873
|
+
function simplifySloppy(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_lock, target_index_count, target_error) {
|
|
874
|
+
var sbrk = instance.exports.sbrk;
|
|
875
|
+
var te = sbrk(4);
|
|
876
|
+
var ti = sbrk(index_count * 4);
|
|
877
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
878
|
+
var si = sbrk(index_count * 4);
|
|
879
|
+
var vl = vertex_lock ? sbrk(vertex_count) : 0;
|
|
880
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
881
|
+
heap.set(bytes(vertex_positions), sp);
|
|
882
|
+
heap.set(bytes(indices), si);
|
|
883
|
+
if (vertex_lock) {
|
|
884
|
+
heap.set(bytes(vertex_lock), vl);
|
|
885
|
+
}
|
|
886
|
+
var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, vl, target_index_count, target_error, te);
|
|
887
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
888
|
+
var target = new Uint32Array(result);
|
|
889
|
+
bytes(target).set(heap.subarray(ti, ti + result * 4));
|
|
890
|
+
var error = new Float32Array(1);
|
|
891
|
+
bytes(error).set(heap.subarray(te, te + 4));
|
|
892
|
+
sbrk(te - sbrk(0));
|
|
893
|
+
return [target, error[0]];
|
|
894
|
+
}
|
|
895
|
+
function simplifyPrune(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_error) {
|
|
896
|
+
var sbrk = instance.exports.sbrk;
|
|
897
|
+
var ti = sbrk(index_count * 4);
|
|
898
|
+
var sp = sbrk(vertex_count * vertex_positions_stride);
|
|
899
|
+
var si = sbrk(index_count * 4);
|
|
900
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
901
|
+
heap.set(bytes(vertex_positions), sp);
|
|
902
|
+
heap.set(bytes(indices), si);
|
|
903
|
+
var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, target_error);
|
|
904
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
905
|
+
var target = new Uint32Array(result);
|
|
906
|
+
bytes(target).set(heap.subarray(ti, ti + result * 4));
|
|
907
|
+
sbrk(ti - sbrk(0));
|
|
908
|
+
return target;
|
|
909
|
+
}
|
|
910
|
+
var simplifyOptions = {
|
|
911
|
+
LockBorder: 1,
|
|
912
|
+
Sparse: 2,
|
|
913
|
+
ErrorAbsolute: 4,
|
|
914
|
+
Prune: 8,
|
|
915
|
+
Regularize: 16,
|
|
916
|
+
Permissive: 32,
|
|
917
|
+
RegularizeLight: 64,
|
|
918
|
+
_InternalDebug: 1 << 30
|
|
919
|
+
// internal, don't use!
|
|
920
|
+
};
|
|
921
|
+
return {
|
|
922
|
+
ready,
|
|
923
|
+
supported: true,
|
|
924
|
+
compactMesh: function(indices) {
|
|
925
|
+
assert(
|
|
926
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
927
|
+
);
|
|
928
|
+
assert(indices.length % 3 == 0);
|
|
929
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
930
|
+
var result = reorder(instance.exports.meshopt_optimizeVertexFetchRemap, indices32, maxindex(indices) + 1);
|
|
931
|
+
if (indices !== indices32) {
|
|
932
|
+
for (var i = 0; i < indices32.length; ++i) {
|
|
933
|
+
indices[i] = indices32[i];
|
|
934
|
+
}
|
|
935
|
+
}
|
|
936
|
+
return result;
|
|
937
|
+
},
|
|
938
|
+
generatePositionRemap: function(vertex_positions, vertex_positions_stride) {
|
|
939
|
+
assert(vertex_positions instanceof Float32Array);
|
|
940
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
941
|
+
assert(vertex_positions_stride >= 3);
|
|
942
|
+
return genremap(
|
|
943
|
+
instance.exports.meshopt_generatePositionRemap,
|
|
944
|
+
vertex_positions,
|
|
945
|
+
vertex_positions.length / vertex_positions_stride,
|
|
946
|
+
vertex_positions_stride
|
|
947
|
+
);
|
|
948
|
+
},
|
|
949
|
+
simplify: function(indices, vertex_positions, vertex_positions_stride, target_index_count, target_error, flags) {
|
|
950
|
+
assert(
|
|
951
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
952
|
+
);
|
|
953
|
+
assert(indices.length % 3 == 0);
|
|
954
|
+
assert(vertex_positions instanceof Float32Array);
|
|
955
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
956
|
+
assert(vertex_positions_stride >= 3);
|
|
957
|
+
assert(target_index_count >= 0 && target_index_count <= indices.length);
|
|
958
|
+
assert(target_index_count % 3 == 0);
|
|
959
|
+
assert(target_error >= 0);
|
|
960
|
+
var options = 0;
|
|
961
|
+
for (var i = 0; i < (flags ? flags.length : 0); ++i) {
|
|
962
|
+
assert(flags[i] in simplifyOptions);
|
|
963
|
+
options |= simplifyOptions[flags[i]];
|
|
964
|
+
}
|
|
965
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
966
|
+
var result = simplify(
|
|
967
|
+
instance.exports.meshopt_simplify,
|
|
968
|
+
indices32,
|
|
969
|
+
indices.length,
|
|
970
|
+
vertex_positions,
|
|
971
|
+
vertex_positions.length / vertex_positions_stride,
|
|
972
|
+
vertex_positions_stride * 4,
|
|
973
|
+
target_index_count,
|
|
974
|
+
target_error,
|
|
975
|
+
options
|
|
976
|
+
);
|
|
977
|
+
result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
|
|
978
|
+
return result;
|
|
979
|
+
},
|
|
980
|
+
simplifyWithAttributes: function(indices, vertex_positions, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, flags) {
|
|
981
|
+
assert(
|
|
982
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
983
|
+
);
|
|
984
|
+
assert(indices.length % 3 == 0);
|
|
985
|
+
assert(vertex_positions instanceof Float32Array);
|
|
986
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
987
|
+
assert(vertex_positions_stride >= 3);
|
|
988
|
+
assert(vertex_attributes instanceof Float32Array);
|
|
989
|
+
assert(vertex_attributes.length == vertex_attributes_stride * (vertex_positions.length / vertex_positions_stride));
|
|
990
|
+
assert(vertex_attributes_stride >= 0);
|
|
991
|
+
assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
|
|
992
|
+
assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
|
|
993
|
+
assert(target_index_count >= 0 && target_index_count <= indices.length);
|
|
994
|
+
assert(target_index_count % 3 == 0);
|
|
995
|
+
assert(target_error >= 0);
|
|
996
|
+
assert(Array.isArray(attribute_weights));
|
|
997
|
+
assert(vertex_attributes_stride >= attribute_weights.length);
|
|
998
|
+
assert(attribute_weights.length <= 32);
|
|
999
|
+
for (var i = 0; i < attribute_weights.length; ++i) {
|
|
1000
|
+
assert(attribute_weights[i] >= 0);
|
|
1001
|
+
}
|
|
1002
|
+
var options = 0;
|
|
1003
|
+
for (var i = 0; i < (flags ? flags.length : 0); ++i) {
|
|
1004
|
+
assert(flags[i] in simplifyOptions);
|
|
1005
|
+
options |= simplifyOptions[flags[i]];
|
|
1006
|
+
}
|
|
1007
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1008
|
+
var result = simplifyAttr(
|
|
1009
|
+
instance.exports.meshopt_simplifyWithAttributes,
|
|
1010
|
+
indices32,
|
|
1011
|
+
indices.length,
|
|
1012
|
+
vertex_positions,
|
|
1013
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1014
|
+
vertex_positions_stride * 4,
|
|
1015
|
+
vertex_attributes,
|
|
1016
|
+
vertex_attributes_stride * 4,
|
|
1017
|
+
new Float32Array(attribute_weights),
|
|
1018
|
+
vertex_lock,
|
|
1019
|
+
target_index_count,
|
|
1020
|
+
target_error,
|
|
1021
|
+
options
|
|
1022
|
+
);
|
|
1023
|
+
result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
|
|
1024
|
+
return result;
|
|
1025
|
+
},
|
|
1026
|
+
simplifyWithUpdate: function(indices, vertex_positions, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, flags) {
|
|
1027
|
+
assert(
|
|
1028
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
1029
|
+
);
|
|
1030
|
+
assert(indices.length % 3 == 0);
|
|
1031
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1032
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1033
|
+
assert(vertex_positions_stride >= 3);
|
|
1034
|
+
assert(vertex_attributes instanceof Float32Array);
|
|
1035
|
+
assert(vertex_attributes.length == vertex_attributes_stride * (vertex_positions.length / vertex_positions_stride));
|
|
1036
|
+
assert(vertex_attributes_stride >= 0);
|
|
1037
|
+
assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
|
|
1038
|
+
assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
|
|
1039
|
+
assert(target_index_count >= 0 && target_index_count <= indices.length);
|
|
1040
|
+
assert(target_index_count % 3 == 0);
|
|
1041
|
+
assert(target_error >= 0);
|
|
1042
|
+
assert(Array.isArray(attribute_weights));
|
|
1043
|
+
assert(vertex_attributes_stride >= attribute_weights.length);
|
|
1044
|
+
assert(attribute_weights.length <= 32);
|
|
1045
|
+
for (var i = 0; i < attribute_weights.length; ++i) {
|
|
1046
|
+
assert(attribute_weights[i] >= 0);
|
|
1047
|
+
}
|
|
1048
|
+
var options = 0;
|
|
1049
|
+
for (var i = 0; i < (flags ? flags.length : 0); ++i) {
|
|
1050
|
+
assert(flags[i] in simplifyOptions);
|
|
1051
|
+
options |= simplifyOptions[flags[i]];
|
|
1052
|
+
}
|
|
1053
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1054
|
+
var result = simplifyUpdate(
|
|
1055
|
+
instance.exports.meshopt_simplifyWithUpdate,
|
|
1056
|
+
indices32,
|
|
1057
|
+
indices.length,
|
|
1058
|
+
vertex_positions,
|
|
1059
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1060
|
+
vertex_positions_stride * 4,
|
|
1061
|
+
vertex_attributes,
|
|
1062
|
+
vertex_attributes_stride * 4,
|
|
1063
|
+
new Float32Array(attribute_weights),
|
|
1064
|
+
vertex_lock,
|
|
1065
|
+
target_index_count,
|
|
1066
|
+
target_error,
|
|
1067
|
+
options
|
|
1068
|
+
);
|
|
1069
|
+
if (indices !== indices32) {
|
|
1070
|
+
for (var i = 0; i < result[0]; ++i) {
|
|
1071
|
+
indices[i] = indices32[i];
|
|
1072
|
+
}
|
|
1073
|
+
}
|
|
1074
|
+
return result;
|
|
1075
|
+
},
|
|
1076
|
+
getScale: function(vertex_positions, vertex_positions_stride) {
|
|
1077
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1078
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1079
|
+
assert(vertex_positions_stride >= 3);
|
|
1080
|
+
return simplifyScale(
|
|
1081
|
+
instance.exports.meshopt_simplifyScale,
|
|
1082
|
+
vertex_positions,
|
|
1083
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1084
|
+
vertex_positions_stride * 4
|
|
1085
|
+
);
|
|
1086
|
+
},
|
|
1087
|
+
simplifyPoints: function(vertex_positions, vertex_positions_stride, target_vertex_count, vertex_colors, vertex_colors_stride, color_weight) {
|
|
1088
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1089
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1090
|
+
assert(vertex_positions_stride >= 3);
|
|
1091
|
+
assert(target_vertex_count >= 0 && target_vertex_count <= vertex_positions.length / vertex_positions_stride);
|
|
1092
|
+
if (vertex_colors) {
|
|
1093
|
+
assert(vertex_colors instanceof Float32Array);
|
|
1094
|
+
assert(vertex_colors.length % vertex_colors_stride == 0);
|
|
1095
|
+
assert(vertex_colors_stride >= 3);
|
|
1096
|
+
assert(vertex_positions.length / vertex_positions_stride == vertex_colors.length / vertex_colors_stride);
|
|
1097
|
+
return simplifyPoints(
|
|
1098
|
+
instance.exports.meshopt_simplifyPoints,
|
|
1099
|
+
vertex_positions,
|
|
1100
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1101
|
+
vertex_positions_stride * 4,
|
|
1102
|
+
vertex_colors,
|
|
1103
|
+
vertex_colors_stride * 4,
|
|
1104
|
+
color_weight || 0,
|
|
1105
|
+
target_vertex_count
|
|
1106
|
+
);
|
|
1107
|
+
} else {
|
|
1108
|
+
return simplifyPoints(
|
|
1109
|
+
instance.exports.meshopt_simplifyPoints,
|
|
1110
|
+
vertex_positions,
|
|
1111
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1112
|
+
vertex_positions_stride * 4,
|
|
1113
|
+
void 0,
|
|
1114
|
+
0,
|
|
1115
|
+
0,
|
|
1116
|
+
target_vertex_count
|
|
1117
|
+
);
|
|
1118
|
+
}
|
|
1119
|
+
},
|
|
1120
|
+
simplifySloppy: function(indices, vertex_positions, vertex_positions_stride, vertex_lock, target_index_count, target_error) {
|
|
1121
|
+
assert(
|
|
1122
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
1123
|
+
);
|
|
1124
|
+
assert(indices.length % 3 == 0);
|
|
1125
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1126
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1127
|
+
assert(vertex_positions_stride >= 3);
|
|
1128
|
+
assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
|
|
1129
|
+
assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
|
|
1130
|
+
assert(target_index_count >= 0 && target_index_count <= indices.length);
|
|
1131
|
+
assert(target_index_count % 3 == 0);
|
|
1132
|
+
assert(target_error >= 0);
|
|
1133
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1134
|
+
var result = simplifySloppy(
|
|
1135
|
+
instance.exports.meshopt_simplifySloppy,
|
|
1136
|
+
indices32,
|
|
1137
|
+
indices.length,
|
|
1138
|
+
vertex_positions,
|
|
1139
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1140
|
+
vertex_positions_stride * 4,
|
|
1141
|
+
vertex_lock,
|
|
1142
|
+
target_index_count,
|
|
1143
|
+
target_error
|
|
1144
|
+
);
|
|
1145
|
+
result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
|
|
1146
|
+
return result;
|
|
1147
|
+
},
|
|
1148
|
+
simplifyPrune: function(indices, vertex_positions, vertex_positions_stride, target_error) {
|
|
1149
|
+
assert(
|
|
1150
|
+
indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
1151
|
+
);
|
|
1152
|
+
assert(indices.length % 3 == 0);
|
|
1153
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1154
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1155
|
+
assert(vertex_positions_stride >= 3);
|
|
1156
|
+
assert(target_error >= 0);
|
|
1157
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1158
|
+
var result = simplifyPrune(
|
|
1159
|
+
instance.exports.meshopt_simplifyPrune,
|
|
1160
|
+
indices32,
|
|
1161
|
+
indices.length,
|
|
1162
|
+
vertex_positions,
|
|
1163
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1164
|
+
vertex_positions_stride * 4,
|
|
1165
|
+
target_error
|
|
1166
|
+
);
|
|
1167
|
+
result = indices instanceof Uint32Array ? result : new indices.constructor(result);
|
|
1168
|
+
return result;
|
|
1169
|
+
}
|
|
1170
|
+
};
|
|
1171
|
+
})();
|
|
1172
|
+
|
|
1173
|
+
// packages/engine/node_modules/meshoptimizer/meshopt_clusterizer.js
|
|
1174
|
+
var MeshoptClusterizer = (function() {
|
|
1175
|
+
var wasm = "b9H79Tebbbe:neP9Geueu9Geub9Gbb9Giuuueu9Gmuuuuuuuuuuu9999eu9Gouuuuuueu9Gruuuuuuub9Gxuuuuuuuuuuuueu9Gxuuuuuuuuuuu99eu9GPuuuuuuuuuuuuu99b9Gouuuuuub9Gwuuuuuuuub9Gvuuuuub9GluuuubiQXdilvorwDqokoqxmbiibeilve9Weiiviebeoweuecj:Gdkr;Zeqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9I919P29K9nW79O2Wt79c9V919U9KbeY9TW79O9V9Wt9F9I919P29K9nW79O2Wt7S2W94bd39TW79O9V9Wt9F9I919P29K9nW79O2Wt79t9W9Ht9P9H2bo39TW79O9V9Wt9F9J9V9T9W91tWJ2917tWV9c9V919U9K7bw39TW79O9V9Wt9F9J9V9T9W91tW9nW79O2Wt9c9V919U9K7bkE9TW79O9V9Wt9F9J9V9T9W91tW9t9W9OWVW9c9V919U9K7bxL9TW79O9V9Wt9F9V9Wt9P9T9P96W9nW79O2WtbPl79IV9RbsDwebcekdOAq;W:leXdbkIbabaec9:fgefcufae9Ugeabci9Uadfcufad9Ugbaeab0Ek:88JDPue99eux99due99euo99iu8Jjjjjbc:WD9Rgm8KjjjjbdndnalmbcbhPxekamc:Cwfcbc;Kbz:rjjjb8AcuaocdtgsaocFFFFi0Ehzcbyd;0:G:cjbhHdndnalcb9imbaoal9nmbamazaHHjjjjbbgHBd:CwamceBd;8wamazcbyd;0:G:cjbHjjjjbbgOBd:GwamcdBd;8wamcualcdtalcFFFFi0Ecbyd;0:G:cjbHjjjjbbgABd:KwamciBd;8waihzalhsinaHazydbcdtfcbBdbazclfhzascufgsmbkaihzalhsinaHazydbcdtfgCaCydbcefBdbazclfhzascufgsmbkaihzalhCcbhXindnaHazydbcdtgQfgsydbcb9imbaOaQfaXBdbasasydbgQcjjjj94VBdbaQaXfhXkazclfhzaCcufgCmbkalci9UhLdnalci6mbcbhzaihsinascwfydbhCasclfydbhXaOasydbcdtfgQaQydbgQcefBdbaAaQcdtfazBdbaOaXcdtfgXaXydbgXcefBdbaAaXcdtfazBdbaOaCcdtfgCaCydbgCcefBdbaAaCcdtfazBdbascxfhsaLazcefgz9hmbkkaihzalhsindnaHazydbcdtgCfgXydbgQcu9kmbaXaQcFFFFrGgQBdbaOaCfgCaCydbaQ9RBdbkazclfhzascufgsmbxdkkamazaHHjjjjbbgHBd:CwamceBd;8wamazcbyd;0:G:cjbHjjjjbbgOBd:GwamcdBd;8wamcualcdtalcFFFFi0Ecbyd;0:G:cjbHjjjjbbgABd:KwamciBd;8waHcbasz:rjjjbhXaihzalhsinaXazydbcdtfgCaCydbcefBdbazclfhzascufgsmbkalci9UhLdnaoTmbcbhzaOhsaXhCaohQinasazBdbasclfhsaCydbazfhzaCclfhCaQcufgQmbkkdnalci6mbcbhzaihsinascwfydbhCasclfydbhQaOasydbcdtfgKaKydbgKcefBdbaAaKcdtfazBdbaOaQcdtfgQaQydbgQcefBdbaAaQcdtfazBdbaOaCcdtfgCaCydbgCcefBdbaAaCcdtfazBdbascxfhsaLazcefgz9hmbkkaoTmbcbhzaohsinaOazfgCaCydbaXazfydb9RBdbazclfhzascufgsmbkkamaLcbyd;0:G:cjbHjjjjbbgzBd:OwamclBd;8wazcbaLz:rjjjbhYamcuaLcK2alcjjjjd0Ecbyd;0:G:cjbHjjjjbbg8ABd:SwamcvBd;8wJbbbbhEdnalci6g3mbarcd4hKaihsa8AhzaLhrJbbbbh5inavasclfydbaK2cdtfgCIdlh8EavasydbaK2cdtfgXIdlhEavascwfydbaK2cdtfgQIdlh8FaCIdwhaaXIdwhhaQIdwhgazaCIdbg8JaXIdbg8KMaQIdbg8LMJbbnn:vUdbazclfaXIdlaCIdlMaQIdlMJbbnn:vUdbaQIdwh8MaCIdwh8NaXIdwhyazcxfa8EaE:tg8Eagah:tggNaaah:tgaa8FaE:tghN:tgEJbbbbJbbjZa8Ja8K:tg8FahNa8Ea8La8K:tg8KN:tghahNaEaENaaa8KNa8FagN:tgEaENMMg8K:rg8E:va8KJbbbb9BEg8KNUdbazczfaEa8KNUdbazcCfaha8KNUdbazcwfa8Maya8NMMJbbnn:vUdba5a8EMh5ascxfhsazcKfhzarcufgrmbka5aL:Z:vJbbbZNhEkamcuaLcdtalcFFFF970Ecbyd;0:G:cjbHjjjjbbgCBd:WwamcoBd;8waq:Zhhdna3mbcbhzaChsinasazBdbasclfhsaLazcefgz9hmbkkaEahNhhamcuaLcltalcFFFFd0Ecbyd;0:G:cjbHjjjjbbg8PBd:0wamcrBd;8wcba8Pa8AaCaLcbz:djjjb8AJFFuuh8MJFFuuh8NJFFuuhydnalci6mbJFFuuhya8AhzaLhsJFFuuh8NJFFuuh8MinazcwfIdbgEa8Ma8MaE9EEh8MazclfIdbgEa8Na8NaE9EEh8NazIdbgEayayaE9EEhyazcKfhzascufgsmbkkah:rhEamaocetgzcuaocu9kEcbyd;0:G:cjbHjjjjbbgCBd:4wdndnaoal9nmbaihzalhsinaCazydbcetfcFFi87ebazclfhzascufgsmbxdkkaCcFeazz:rjjjb8AkaEJbbbZNh8JcuhIdnalci6mbcbhsJFFuuhEa8AhzcuhIinazcwfIdba8M:tghahNazIdbay:tghahNazclfIdba8N:tghahNMM:rghaEaIcuSahaE9DVgXEhEasaIaXEhIazcKfhzaLascefgs9hmbkkamczfcbcjwz:rjjjb8Aam9cb83iwam9cb83ibaxa8JNh8RJbbjZak:th8Lcbh8SJbbbbhRJbbbbh8UJbbbbh8VJbbbbh8WJbbbbh8XJbbbbh8Ycbh8ZcbhPinJbbbbhEdna8STmbJbbjZa8S:Z:vhEkJbbbbhhdna8Ya8YNa8Wa8WNa8Xa8XNMMg8KJbbbb9BmbJbbjZa8K:r:vhhka8VaENh8Ka8UaENh5aRaENh8EaIhLdndndndndna8SaPVTmbamydwg80Tmea8YahNh8Fa8XahNhaa8WahNhgaeamydbcdtfh81cbh3JFFuuhEcvhQcuhLindnaHa81a3cdtfydbcdtgzfydbgvTmbaAaOazfydbcdtfhsindndnaCaiasydbgKcx2fgzclfydbgrcetf8Vebcs4aCazydbgXcetf8Vebcs4faCazcwfydbglcetf8Vebcs4fgombcbhzxekcehzaHaXcdtfydbgXceSmbcehzaHarcdtfydbgrceSmbcehzaHalcdtfydbglceSmbdnarcdSaXcdSfalcdSfcd6mbaocefhzxekaocdfhzkdnazaQ9kmba8AaKcK2fgXIdwa8K:tghahNaXIdba8E:tghahNaXIdla5:tghahNMM:ra8J:va8LNJbbjZMJ9VO:d86JbbjZaXIdCa8FNaXIdxagNaaaXIdzNMMakN:tghahJ9VO:d869DENghaEazaQ6ahaE9DVgXEhEaKaLaXEhLazaQaXEhQkasclfhsavcufgvmbkka3cefg3a809hmbkkaLcu9hmekama8KUd:ODama5Ud:KDama8EUd:GDamcuBd:qDamcFFF;7rBdjDa8Pcba8AaYamc:GDfamc:qDfamcjDfz:ejjjbamyd:qDhLdndnaxJbbbb9ETmba8SaD6mbaLcuSmeceh3amIdjDa8R9EmixdkaLcu9hmekdna8STmbabaPcltfgHam8Piw83dwaHam8Pib83dbaPcefhPkc3hHinamc:CwfaHfydbcbyd;4:G:cjbH:bjjjbbaHc98fgHc989hmbxvkkcbh3a8Saq9pmbamydwaCaiaLcx2fgzydbcetf8Vebcs4aCazcwfydbcetf8Vebcs4faCazclfydbcetf8Vebcs4ffaw9nmekcbhzcbhsdna8ZTmbcbhsamczfhXinamczfascdtfaXydbgQBdbaXclfhXasaYaQfRbbTfhsa8Zcufg8ZmbkkamydwhlamydbhXam9cu83i:GDam9cu83i:ODam9cu83i:qDam9cu83i:yDinamcjDfazfcFFF;7rBdbazclfgzcz9hmbkasc;8easclfc:bd6Eg8Zcdth80dnalTmbaeaXcdtfhocbhrindnaHaoarcdtfydbcdtgzfydbgvTmbaAaOazfydbcdtfhscuhQcuhzinaHaiasydbgKcx2fgXclfydbcdtfydbaHaXydbcdtfydbfaHaXcwfydbcdtfydbfgXazaXaz6gXEhzaKaQaXEhQasclfhsavcufgvmbkaQcuSmba8AaQcK2fgsIdwa8M:tgEaENasIdbay:tgEaENasIdla8N:tgEaENMM:rhEcbhsindndnazamc:qDfasfgvydbgX6mbazaX9hmeaEamcjDfasfIdb9FTmekavazBdbamc:GDfasfaQBdbamcjDfasfaEUdbxdkasclfgscz9hmbkkarcefgral9hmbkkamczfa80fhQcbhzcbhsindnamc:GDfazfydbgXcuSmbaQascdtfaXBdbascefhskazclfgzcz9hmbkasa8Zfg8ZTmbJFFuuhhcuhKamczfhza8ZhvcuhQina8AazydbgXcK2fgsIdwa8M:tgEaENasIdbay:tgEaENasIdla8N:tgEaENMM:rhEdndnaHaiaXcx2fgsclfydbcdtfydbaHasydbcdtfydbfaHascwfydbcdtfydbfgsaQ6mbasaQ9hmeaEah9DTmekaEhhashQaXhKkazclfhzavcufgvmbkaKcuSmbaKhLkdnamaiaLcx2fgrydbarclfydbarcwfydbaCabaeadaPawaqa3z:fjjjbTmbaPcefhPJbbbbhRJbbbbh8UJbbbbh8VJbbbbh8WJbbbbh8XJbbbbh8YkcbhXinaAaOaraXcdtfydbcdtgsfydbcdtfgKhzaHasfgvydbgQhsdnaQTmbdninazydbaLSmeazclfhzascufgsTmdxbkkazaKaQcdtfc98fydbBdbavavydbcufBdbkaXcefgXci9hmbka8AaLcK2fgzIdbhEazIdlhhazIdwh8KazIdxh5azIdzh8EazIdCh8FaYaLfce86bba8Ya8FMh8Ya8Xa8EMh8Xa8Wa5Mh8Wa8Va8KMh8Va8UahMh8UaRaEMhRamydxh8Sxbkkamc:WDf8KjjjjbaPkjoivuv99lu8Jjjjjbca9Rgo8Kjjjjbdndnalcw0mbaiydbhraeabcitfgwalcdtciVBdlawarBdbdnalcd6mbaiclfhralcufhDawcxfhwinarydbhqawcuBdbawc98faqBdbawcwfhwarclfhraDcufgDmbkkalabfhwxekcbhqaocbBdKao9cb83izaocbBdwao9cb83ibJbbjZhkJbbjZhxinadaiaqcdtfydbcK2fhDcbhwinaoczfawfgraDawfIdbgmarIdbgP:tgsaxNaPMgPUdbaoawfgrasamaP:tNarIdbMUdbawclfgwcx9hmbkJbbjZakJbbjZMgk:vhxaqcefgqal9hmbkcbhradcbcecdaoIdlgmaoIdwgP9GEgwaoIdbgsaP9GEawasam9GEgzcdtgwfhHaoczfawfIdbhmaihwalhDinaiarcdtfgqydbhOaqawydbgABdbawaOBdbawclfhwaraHaAcK2fIdbam9DfhraDcufgDmbkdndnarcv6mbavc8X9kmbaralc98f6mekaiydbhraeabcitfgwalcdtciVBdlawarBdbaiclfhralcufhDawcxfhwinarydbhqawcuBdbawc98faqBdbawcwfhwarclfhraDcufgDmbkalabfhwxekaeabcitfgwamUdbawawydlc98GazVBdlabcefaeadaiaravcefgqz:djjjbhDawawydlciGaDabcu7fcdtVBdlaDaeadaiarcdtfalar9Raqz:djjjbhwkaocaf8Kjjjjbawk;Oddvue99dninabaecitfgrydlgwcd4gDTmednawciGgqci9hmbcihqdnawcl6mbabaecitfhbcbheawhqcehkindnaiabydbgDfRbbmbcbhkadaDcK2fgwIdwalIdw:tgxaxNawIdbalIdb:tgxaxNawIdlalIdl:tgxaxNMM:rgxaoIdb9DTmbaoaxUdbavaDBdbarydlhqkabcwfhbaecefgeaqcd46mbkakceGTmikaraqciGBdlskdnabcbaDalaqcdtfIdbarIdb:tgxJbbbb9FEgwaD7aecefgDfgecitfydlabawaDfgDcitfydlVci0mbaraqBdlkabaDadaialavaoz:ejjjbax:laoIdb9Fmbkkkjlevudndnabydwgxaladcetfgm8Vebcs4alaecetfgP8Vebgscs4falaicetfgz8Vebcs4ffaD0mbakmbcbhDabydxaq6mekavawcltfgxab8Pdw83dwaxab8Pdb83dbabydbhDdnabydwgwTmbaoaDcdtfhxawhsinalaxydbcetfcFFi87ebaxclfhxascufgsmbkkabaDawfBdbabydxhxab9cb83dwababydlaxci2fBdlaP8VebhscehDcbhxkdnascztcz91cu9kmbabaxcefBdwaPax87ebaoabydbcdtfaxcdtfaeBdbkdnam8Uebcu9kmbababydwgxcefBdwamax87ebaoabydbcdtfaxcdtfadBdbkdnaz8Uebcu9kmbababydwgxcefBdwazax87ebaoabydbcdtfaxcdtfaiBdbkarabydlfabydxci2faPRbb86bbarabydlfabydxci2fcefamRbb86bbarabydlfabydxci2fcdfazRbb86bbababydxcefBdxaDk:mPrHue99eue99eue99iu8Jjjjjbc;W;Gb9Rgx8KjjjjbdndnalmbcbhmxekcbhPaxc:m;Gbfcbc;Kbz:rjjjb8Aaxcualci9UgscltascjjjjiGEcbyd;0:G:cjbHjjjjbbgzBd:m9GaxceBd;S9GaxcuascK2gHcKfalcpFFFe0Ecbyd;0:G:cjbHjjjjbbgOBd:q9GaxcdBd;S9Gdnalci6gAmbarcd4hCascdthXaOhQazhLinavaiaPcx2fgrydwaC2cdtfhKavarydlaC2cdtfhYavarydbaC2cdtfh8AcbhraLhEinaQarfgma8Aarfg3Idbg5aYarfg8EIdbg8Fa5a8F9DEg5UdbamaKarfgaIdbg8Fa5a8Fa59DEg8FUdbamcxfgma3Idbg5a8EIdbgha5ah9EEg5UdbamaaIdbgha5aha59EEg5UdbaEa8Fa5MJbbbZNUdbaEaXfhEarclfgrcx9hmbkaQcKfhQaLclfhLaPcefgPas9hmbkkaOaHfgr9cb83dbar9cb83dzar9cb83dwaxcuascx2gralc:bjjjl0Ecbyd;0:G:cjbHjjjjbbgHBdN9GaxciBd;S9GascdthgazarfhvaxcwVhPaxclVhCaHh8Jazh8KcbhLinaxcbcj;Gbz:rjjjbhEaLas2cdthadnaAmba8Khrash3inaEarydbgmc8F91cjjjj94Vam7gmcQ4cx2fg8Ea8EydwcefBdwaEamcd4cFrGcx2fg8Ea8EydbcefBdbaEamcx4cFrGcx2fgmamydlcefBdlarclfhra3cufg3mbkkazaafh8AaHaafhXcbhmcbh3cbh8EcbhainaEamfgrydbhQara3BdbarcwfgKydbhYaKaaBdbarclfgrydbhKara8EBdbaQa3fh3aYaafhaaKa8Efh8Eamcxfgmcj;Gb9hmbkdnaAmbcbhravhminamarBdbamclfhmasarcefgr9hmbkavhrashminaEa8Aarydbg3cdtfydbg8Ec8F91a8E7cd4cFrGcx2fg8Ea8Eydbg8EcefBdbaXa8Ecdtfa3Bdbarclfhramcufgmmbka8JhrashminaCa8Aarydbg3cdtfydbg8Ec8F91a8E7cx4cFrGcx2fg8Ea8Eydbg8EcefBdbava8Ecdtfa3BdbarclfhramcufgmmbkavhrashminaPa8Aarydbg3cdtfydbg8Ec8F91cjjjj94Va8E7cQ4cx2fg8Ea8Eydbg8EcefBdbaXa8Ecdtfa3Bdbarclfhramcufgmmbkka8Jagfh8Ja8Kagfh8KaLcefgLci9hmbkaEaocetgrcuaocu9kEcbyd;0:G:cjbHjjjjbbgKBd:y9GaEclBd;S9Gdndnaoal9nmbaihralhminaKarydbcetfcFFi87ebarclfhramcufgmmbxdkkaKcFearz:rjjjb8Akcbh8EaEascbyd;0:G:cjbHjjjjbbg8ABd:C9GaOaHaHascdtfaHascitfa8AascbazaKaiawaDaqakz:hjjjbdndnalci6mba8Ahrashmina8EarRbbfh8EarcefhramcufgmmbkaE9cb83iwaE9cb83ibalawc9:fgrfcufar9UgrasaDfcufaD9Ugmaram0EhYcbhmcbhra8Ehaincbh3dnarTmba8AarfRbbceSh3kamaEaiaHydbcx2fgQydbaQclfydbaQcwfydbaKabaeadamawaqa3a3ce7a8EaY9nVaaamfaY6VGz:fjjjbfhmaHclfhHaaa8AarfRbb9Rhaasarcefgr9hmbkaEydxTmeabamcltfgraE8Piw83dwaraE8Pib83dbamcefhmxekaE9cb83iwaE9cb83ibcbhmkczhrinaEc:m;Gbfarfydbcbyd;4:G:cjbH:bjjjbbarc98fgrc989hmbkkaxc;W;Gbf8Kjjjjbamk:wKDQue99iue99iul9:euw99iu8Jjjjjbc;qb9RgP8Kjjjjbaxhsaxhzdndnavax0gHmbdnavTmbcbhOaehzavhAinawaDazydbcx2fgCcwfydbcetfgX8VebhQawaCclfydbcetfgL8VebhKawaCydbcetfgC8VebhYaXce87ebaLce87ebaCce87ebaOaKcs4aYcs4faQcs4ffhOazclfhzaAcufgAmbkaehzavhAinawaDazydbcx2fgCcwfydbcetfcFFi87ebawaCclfydbcetfcFFi87ebawaCydbcetfcFFi87ebazclfhzaAcufgAmbkcehzaqhsaOaq0mekalce86bbalcefcbavcufz:rjjjb8AxekaPaiBdxaPadBdwaPaeBdlavakaqci9Ug8Aaka8Aak6EaHEgK9RhEaxaK9Rh3aKcufh5aKceth8EaKcdtgCc98fh8FavcitgOaC9Rarfc98fhaascufhhavcufhgaraOfh8JJbbjZas:Y:vh8KcbazceakaxSEg8Lcdtg8M9Rh8NJFFuuhycuh8PcbhIcbh8RinaPclfa8RcdtfydbhQaPcb8Pd:y:G:cjbg8S83i9iaPcb8Pd:q:G:cjbgR83inaPcb8Pd1:G:cjbg8U83iUaPcb8Pdj:G:cjbg8V83i8WaPa8S83iyaPaR83iaaPa8U83iKaPa8V83izaQavcdtgYfh8WcbhXinabaQaXcdtgLfydbcK2fhAcbhzinaPc8WfazfgCaAazfgOIdbg8XaCIdbg8Ya8Xa8Y9DEUdbaCczfgCaOcxfIdbg8XaCIdbg8Ya8Xa8Y9EEUdbazclfgzcx9hmbkaba8WaXcu7cdtfydbcK2fhAcbhzaPIdUh8ZaPId9ih80aPId80h81aPId9ehBaPId8Wh83aPIdnhUinaPczfazfgCaAazfgOIdbg8XaCIdbg8Ya8Xa8Y9DEUdbaCczfgCaOcxfIdbg8XaCIdbg8Ya8Xa8Y9EEUdbazclfgzcx9hmbkaraLfgza80a8Z:tg8XaUa83:tg8YNa8YaBa81:tg8ZNa8Za8XNMMUdbazaYfaPIdyaPIdK:tg8XaPIdaaPIdz:tg8YNa8YaPId8KaPIdC:tg8ZNa8Za8XNMMUdbaXcefgXav9hmbkcbh85dnaHmbcbhAaQhza8JhCavhXinawaDazydbcx2fgOcwfydbcetfgL8Vebh8WawaOclfydbcetfg858Vebh86awaOydbcetfgO8Vebh87aLce87eba85ce87ebaOce87ebaCaAa86cs4a87cs4fa8Wcs4ffgABdbazclfhzaCclfhCaXcufgXmbkavhCinawaDaQydbcx2fgzcwfydbcetfcFFi87ebawazclfydbcetfcFFi87ebawazydbcetfcFFi87ebaQclfhQaCcufgCmbka8Jh85kdndndndndndndndndndndnava8E6mba8Eax9nmeavavaK9UgzaK29Raza320mda5aE9pmqa85Th87ceh8WaEhQxwka5ag9pmDa8Eax9nmixokavaK6mea5aE9pmwcehQaEhXa85Tmixlka5ag6mlxrka5ag9pmokcbhQaghXa85mekJFFuuh8XcbhLa5hzindnazcefgCaK6mbaQavaC9RgOaK6GmbarazcdtfIdbg8YaC:YNaravaz9RcdtfaYfc94fIdbg8ZaO:YNMg80a8X9Embdndna8KaOahf:YNg81:lJbbb9p9DTmba81:OhAxekcjjjj94hAka8ZasaA2aO9R:YNh8Zdndna8Kazasf:YNg81:lJbbb9p9DTmba81:OhOxekcjjjj94hOkamasaO2aC9R:Ya8YNa8ZMNa80Mg8Ya8Xa8Ya8X9DgOEh8XaCaLaOEhLkaza8LfgzaX6mbxlkkJFFuuh8XcbhLaEhCaahAa8FhOaKhzindnazaK6mbaQaCaK6GmbaraOfIdbg8Yaz:YNaAIdbg8ZaC:YNMg80a8X9Embdndna8Ka85aOfydbgYahf:YNg81:lJbbb9p9DTmba81:Oh8Wxekcjjjj94h8Wkamasa8W2aY9R:Yg81a8YNa8Za81NMNa80Mg8Ya8Xa8Ya8X9DgYEh8XazaLaYEhLkaCa8L9RhCaAa8NfhAaOa8MfhOaza8LfgzcufaX6mbxikka85Th87cbh8WaghQkJFFuuh8XcbhLaEhCaahAa8FhOaKhzindnazazaK9UgXaK29RaXa320mbdna8WTmbaCaCaK9UgXaK29RaXa320mekaraOfIdbg8Yaz:YNaAIdbg8ZaC:YNMg80a8X9EmbazhXaChYdna87mba85aOfydbgXhYkdndna8KaYahf:YNg81:lJbbb9p9DTmba81:Oh86xekcjjjj94h86ka8Zasa862aY9R:YNh8Zdndna8KaXahf:YNg81:lJbbb9p9DTmba81:OhYxekcjjjj94hYkamasaY2aX9R:Ya8YNa8ZMNa80Mg8Ya8Xa8Ya8X9DgXEh8XazaLaXEhLkaCa8L9RhCaAa8NfhAaOa8MfhOaza8LfgzcufaQ6mbkkaLTmba8Xay9DTmba8XhyaLhIa8Rh8Pka8Rcefg8Rci9hmbkdndnaoc8X9kmba8Pcb9omeka8Acufh85cbhYindndndnavaY9RaxaYaxfav0Eg8WTmbcbhAaeaYcdtfgzhCa8WhXinawaDaCydbcx2fgOcwfydbcetfgQ8VebhbawaOclfydbcetfgL8VebhrawaOydbcetfgO8VebhKaQce87ebaLce87ebaOce87ebaAarcs4aKcs4fabcs4ffhAaCclfhCaXcufgXmbka8WhOinawaDazydbcx2fgCcwfydbcetfcFFi87ebawaCclfydbcetfcFFi87ebawaCydbcetfcFFi87ebazclfhzaOcufgOmbkaAaq0mekalaYfgzce86bbazcefcba8Wcufz:rjjjb8AxekalaYfgzce86bbazcefcba85z:rjjjb8Aa8Ah8Wka8WaYfgYav9pmdxbkkaravcdtg8WfhLdnaITmbaPclfa8PcdtfydbhzaIhCinaLazydbfcb86bbazclfhzaCcufgCmbkkdnavaI9nmbaPclfa8PcdtfydbaIcdtfhzavaI9RhCinaLazydbfce86bbazclfhzaCcufgCmbkkcbhYindnaYa8PSmbcbhzaraPclfaYcdtfydbgKa8Wz:qjjjbhCavhXaIhOinaKaOazaLaCydbgQfRbbgAEcdtfaQBdbaCclfhCaOaAfhOazaA9RcefhzaXcufgXmbkkaYcefgYci9hmbkabaeadaialaIaocefgCarawaDaqakaxamz:hjjjbabaeaIcdtgzfadazfaiazfalaIfavaI9RaCarawaDaqakaxamz:hjjjbkaPc;qbf8Kjjjjbk:Seeru8Jjjjjbc:q;ab9Rgo8Kjjjjbaoc:q8WfcFecjzz:rjjjb8AcbhrdnadTmbaehwadhDinaoarcdtfawydbgqBdbaoc:q8WfaqcFiGcdtfgkydbhxakaqBdbawclfhwaraxaq9hfhraDcufgDmbkkabaeadaoaraiavz:jjjjbaoc:q;abf8Kjjjjbk;Sqloud99euD998Jjjjjbc:W;ab9Rgr8KjjjjbdndnadTmbaocd4hwcbhDcbhqindnavaeclfydbaw2cdtfgkIdbavaeydbaw2cdtfgxIdbgm:tgPavaecwfydbaw2cdtfgsIdlaxIdlgz:tgHNakIdlaz:tgOasIdbam:tgAN:tgCaCNaOasIdwaxIdwgX:tgQNakIdwaX:tgOaHN:tgHaHNaOaANaPaQN:tgPaPNMMgOJbbbb9Bmbarc8WfaDcltfgkaCaO:rgO:vgCUdwakaPaO:vgPUdlakaHaO:vgHUdbakaCaXNaHamNazaPNMM:mUdxaDcefhDkaecxfheaqcifgqad6mbkab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbaDTmearcbBd8Sar9cb83iKar9cb83izarczfavalaoarc8Sfcbcraiz:kjjjbarIdKhQarIdChLarIdzhKar9cb83iwar9cb83ibararc8WfaDczarc8Sfcbcicbz:kjjjbJbbbbhmdnarIdwgzazNarIdbgHaHNarIdlgXaXNMMgCJbbbb9BmbJbbjZaC:r:vhmkazamNhCaXamNhXaHamNhHJbbjZhmarc8WfheaDhvinaecwfIdbaCNaeIdbaHNaXaeclfIdbNMMgzamazam9DEhmaeczfheavcufgvmbkabaQUdwabaLUdlabaKUdbabarId3UdxdndnamJ;n;m;m899FmbJbbbbhzarc8WfheinaecxfIdbaQaecwfIdbgPNaKaeIdbgONaLaeclfIdbgANMMMaCaPNaHaONaXaANMM:vgPazaPaz9EEhzaeczfheaDcufgDmbkabaCUd8KabaXUdaabaHUd3abaQaCazN:tUdKabaLaXazN:tUdCabaKaHazN:tUdzabJbbjZamamN:t:rgmUdydndnaCJbbj:;aCJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aCJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohexekcjjjj94hekabae86b8UdndnaXJbbj:;aXJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aXJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohvxekcjjjj94hvkabav86bRdndnaHJbbj:;aHJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aHJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohwxekcjjjj94hwkabaw86b8SdndnaecKtcK91:YJbb;:9c:vaC:t:lavcKtcK91:YJbb;:9c:vaX:t:lawcKtcK91:YJbb;:9c:vaH:t:lamMMMJbb;:9cNJbbjZMgm:lJbbb9p9DTmbam:Ohexekcjjjj94hekaecFbaecFb9iEhexekabcjjj;8iBdycFbhekabae86b8Vxekab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbkarc:W;abf8Kjjjjbk;7woDuo99eue99euv998Jjjjjbcje9Rgw8Kjjjjbawc;abfcbaocdtgDz:rjjjb8Aawc;GbfcbaDz:rjjjb8AawcafhDawhqaohkinaqcFFF97BdbaDcFFF;7rBdbaqclfhqaDclfhDakcufgkmbkavcd4hxaicd4hmdnadTmbaocx2hPcbhsinashzdnarTmbarascdtfydbhzkaeazam2cdtfgDIdwhHaDIdlhOaDIdbhAalazax2cdtfIdbhCcbhDawcafhqawc;Gbfhvawhkawc;abfhiinaCaDc:O:G:cjbfIdbaHNaDc:G:G:cjbfIdbaANaDc:K:G:cjbfIdbaONMMgXMhQazhLdnaXaC:tgXaqIdbgK9DgYmbavydbhLkavaLBdbazhLdnaQakIdbg8A9EmbaiydbhLa8AhQkaiaLBdbakaQUdbaqaXaKaYEUdbaiclfhiakclfhkavclfhvaqclfhqaPaDcxfgD9hmbkascefgsad9hmbkkJbbbbhQcbhLawc;GbfhDawc;abfhqcbhkinalaqydbgvax2cdtfIdbalaDydbgiax2cdtfIdbaeavam2cdtfgvIdwaeaiam2cdtfgiIdw:tgCaCNavIdbaiIdb:tgCaCNavIdlaiIdl:tgCaCNMM:rMMgCaQaCaQ9EgvEhQakaLavEhLaqclfhqaDclfhDaoakcefgk9hmbkJbbbbhCdnaeawc;abfaLcdtgqfydbgkam2cdtfgDIdwaeawc;Gbfaqfydbgvam2cdtfgqIdwgH:tgXaXNaDIdbaqIdbgA:tg8Aa8ANaDIdlaqIdlgE:tgOaONMMgKJbbbb9ETmbaK:rgCalakax2cdtfIdbMalavax2cdtfIdb:taCaCM:vhCkaQJbbbZNhKaXaCNaHMhHaOaCNaEMhOa8AaCNaAMhAdnadTmbcbhqarhkinaqhDdnarTmbakydbhDkdnalaDax2cdtfIdbg3aeaDam2cdtfgDIdwaH:tgQaQNaDIdbaA:tgCaCNaDIdlaO:tgXaXNMMg5:rgEMg8EaK9ETmbJbbbbh8Adna5Jbbbb9ETmba8EaK:taEaEM:vh8Aka8AaQNaHMhHa8AaXNaOMhOa8AaCNaAMhAa3aKaEMMJbbbZNhKkakclfhkadaqcefgq9hmbkkabaKUdxabaHUdwabaOUdlabaAUdbawcjef8Kjjjjbk:reevu8Jjjjjbcj8W9Rgr8Kjjjjbaici2hwcbhDdnaiTmbarhiawhqinaiaeadRbbgkcdtfydbBdbaDakcefgkaDak0EhDaiclfhiadcefhdaqcufgqmbkkabarawaeaDalaoz:jjjjbarcj8Wf8Kjjjjbk:Eeeeu8Jjjjjbca9Rgo8Kjjjjbab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbdnadTmbaocbBd3ao9cb83iwao9cb83ibaoaeadaialaoc3falEavcbalEcrcbz:kjjjbabao8Pib83dbabao8Piw83dwkaocaf8Kjjjjbk::meQu8Jjjjjbcjz9Rgv8KjjjjbcbhoavcjPfcbaez:rjjjb8Aavcjxfcbaez:rjjjb8AdnaiTmbadhoaihrinavcjxfaoRbbfgwawRbbcef86bbavcjxfaocefRbbfgwawRbbcef86bbavcjxfaocdfRbbfgwawRbbcef86bbaocifhoarcufgrmbkcbhDcjehoadhqcehkindndnalTmbcbhxcuhmaqhrakhwcuhPinawcufamaoavcjPfarcefRbbgsfRbb9RcFeGgzci6aoavcjPfarRbbgHfRbb9RcFeGgOci6faoavcjPfarcdfRbbgAfRbb9RcFeGgCci6fgXcOtaOcFr7azaCf9RcwtVavcjxfaAfRbbgzavcjxfaHfRbbgHavcjxfasfRbbgsaHas6Egsazas6EcFe7VgsaP9kgzEhmaXcd6gHaxcefgOal9iVce9hmdasaPazEhPaxaOaHEhxarcifhrawai6hsawcefhwasmbxdkkcuhmaqhrakhwcuhxinawcufamaoavcjPfarcefRbbfRbb9RcFeGci6aoavcjPfarRbbfRbb9RcFeGci6faoavcjPfarcdfRbbfRbb9RcFeGci6fgPax9kgsEhmaPce0meaPaxasEhxarcifhrawai6hPawcefhwaPmbkkadamci2fgrcdfRbbhwarcefRbbhxarRbbhPadaDci2fgrcifaramaD9Rci2zNjjjb8AaPavcjPffaocefgo86bbaPavcjxffgmamRbbcuf86bbaxavcjPffao86bbaxavcjxffgmamRbbcuf86bbarcdfaw86bbarcefax86bbaraP86bbawavcjPffao86bbawavcjxffgrarRbbcuf86bbaqcifhqakcefhkaDcefgDai9hmbkcbhzdnalcb9mmbcbhsavcjPfcbaez:rjjjb8Aadcvfhlinadasci2fgxcefgDRbbhoaxcdfgqRbbhrdndnavcjPfaxRbbgmfRbbmbavcjPfarfRbbhwdndndnavcjPfaofRbbTmbawcFeGTmexikawcFeGmdascefgAai9pmdasc980mdascifhQcbhLarcFeGhCamcFeGhXalhwcbhKcbhYinawcufRbbhPawRbbhOcehkdndnawc9:fRbbgHao9hmbaPcFeGamSmekdnaPcFeGao9hmbaOcFeGamSmekaHamSaOcFeGaoSGhkkceh8AaYceGhYdndnaHar9hmbaPcFeGaoSmekdnaPcFeGar9hmbaOcFeGaoSmekaHaoSaOcFeGarSGh8AkakaYVhYaLaHcFeGgHaXSaPcFeGgPaCSGaPaXSaOcFeGgPaCSGVaHaCSaPaXSGVVhLa8AaKceGVhKdnaAcefgPai9pmbawcifhwaAaQ6hHaPhAaHmekkaYTmeaKmekarhwaohPaohHarhOamhrxdkdnaYTaLVceGTmbaYaKTVaLVceGmekamhwarhParhHamhOaohrxekaohwamhPamhHaohOkavcjPfarfce86bbavcjPfawfce86bbaxaH86bbaqar86bbaDaO86bbavcjPfaPfce86bbalcifhlascefgsai9hmbkkavcFeaecetz:rjjjbhwaici2hrindnawadRbbgmcetfgx8Uebgocu9kmbaxaz87ebawcjlfazcdtfabamcdtfydbBdbazhoazcefhzkadao86bbadcefhdarcufgrmbkazcdthokabavcjlfaoz:qjjjb8Aavcjzf8KjjjjbkObabaiaeadcbz:njjjbk9teiucbcbyd;8:G:cjbgeabcifc98GfgbBd;8:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd;8:G:cjbgeabcrfc94GfgbBd;8:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd;8:G:cjbge9Rcifc98GaefgbBd;8:G:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akk:3qeludndnadch6mbadTmeabaead;8qbbabskabaeSmbdnaeadabfgi9Rcbadcet9R0mbadTmeabaead;8qbbabskaeab7ciGhldndndnabae9pmbdnalTmbadhvabhixikdnabciGmbadhvabhixdkadTmiabaeRbb86bbadcufhvdnabcefgiciGmbaecefhexdkavTmiabaeRbe86beadc9:fhvdnabcdfgiciGmbaecdfhexdkavTmiabaeRbd86bdadc99fhvdnabcifgiciGmbaecifhexdkavTmiabaeRbi86biabclfhiaeclfheadc98fhvxekdnalmbdnaiciGTmbadTmlabadcufgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc9:fgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc99fgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc98fgdfaeadfRbb86bbkadcl6mbdnadc98fgocxGcxSmbaocd4cefciGhiaec98fhlabc98fhvinavadfaladfydbBdbadc98fhdaicufgimbkkaocx6mbaec9Wfhvabc9WfhoinaoadfgicxfavadfglcxfydbBdbaicwfalcwfydbBdbaiclfalclfydbBdbaialydbBdbadc9Wfgdci0mbkkadTmdadhidnadciGglTmbaecufhvabcufhoadhiinaoaifavaifRbb86bbaicufhialcufglmbkkadcl6mdaec98fhlabc98fhvinavaifgecifalaifgdcifRbb86bbaecdfadcdfRbb86bbaecefadcefRbb86bbaeadRbb86bbaic98fgimbxikkavcl6mbdnavc98fglc3Gc3Smbavalcd4cefcrGgdcdt9RhvinaiaeydbBdbaeclfheaiclfhiadcufgdmbkkalc36mbinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaiczfaeczfydbBdbaicCfaecCfydbBdbaicKfaecKfydbBdbaic3faec3fydbBdbaecafheaicafhiavc9Gfgvci0mbkkavTmbdndnavcrGgdmbavhlxekavc94GhlinaiaeRbb86bbaicefhiaecefheadcufgdmbkkavcw6mbinaiaeRbb86bbaicefaecefRbb86bbaicdfaecdfRbb86bbaicifaecifRbb86bbaiclfaeclfRbb86bbaicvfaecvfRbb86bbaicofaecofRbb86bbaicrfaecrfRbb86bbaicwfhiaecwfhealc94fglmbkkabkk:pedbcj:GdktFFuuFFuuFFuubbbbFFuFFFuFFFuFbbbbbbjZbbbbbbbbbbbbbbjZbbbbbbbbbbbbbbjZ86;nAZ86;nAZ86;nAZ86;nA:;86;nAZ86;nAZ86;nAZ86;nA:;86;nAZ86;nAZ86;nAZ86;nA:;bc;0:Gdkxebbbdbbbj:qbb";
|
|
1176
|
+
var wasmpack = new Uint8Array([
|
|
1177
|
+
32,
|
|
1178
|
+
0,
|
|
1179
|
+
65,
|
|
1180
|
+
2,
|
|
1181
|
+
1,
|
|
1182
|
+
106,
|
|
1183
|
+
34,
|
|
1184
|
+
33,
|
|
1185
|
+
3,
|
|
1186
|
+
128,
|
|
1187
|
+
11,
|
|
1188
|
+
4,
|
|
1189
|
+
13,
|
|
1190
|
+
64,
|
|
1191
|
+
6,
|
|
1192
|
+
253,
|
|
1193
|
+
10,
|
|
1194
|
+
7,
|
|
1195
|
+
15,
|
|
1196
|
+
116,
|
|
1197
|
+
127,
|
|
1198
|
+
5,
|
|
1199
|
+
8,
|
|
1200
|
+
12,
|
|
1201
|
+
40,
|
|
1202
|
+
16,
|
|
1203
|
+
19,
|
|
1204
|
+
54,
|
|
1205
|
+
20,
|
|
1206
|
+
9,
|
|
1207
|
+
27,
|
|
1208
|
+
255,
|
|
1209
|
+
113,
|
|
1210
|
+
17,
|
|
1211
|
+
42,
|
|
1212
|
+
67,
|
|
1213
|
+
24,
|
|
1214
|
+
23,
|
|
1215
|
+
146,
|
|
1216
|
+
148,
|
|
1217
|
+
18,
|
|
1218
|
+
14,
|
|
1219
|
+
22,
|
|
1220
|
+
45,
|
|
1221
|
+
70,
|
|
1222
|
+
69,
|
|
1223
|
+
56,
|
|
1224
|
+
114,
|
|
1225
|
+
101,
|
|
1226
|
+
21,
|
|
1227
|
+
25,
|
|
1228
|
+
63,
|
|
1229
|
+
75,
|
|
1230
|
+
136,
|
|
1231
|
+
108,
|
|
1232
|
+
28,
|
|
1233
|
+
118,
|
|
1234
|
+
29,
|
|
1235
|
+
73,
|
|
1236
|
+
115
|
|
1237
|
+
]);
|
|
1238
|
+
if (typeof WebAssembly !== "object") {
|
|
1239
|
+
return {
|
|
1240
|
+
supported: false
|
|
1241
|
+
};
|
|
1242
|
+
}
|
|
1243
|
+
var instance;
|
|
1244
|
+
var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
|
|
1245
|
+
instance = result.instance;
|
|
1246
|
+
instance.exports.__wasm_call_ctors();
|
|
1247
|
+
});
|
|
1248
|
+
function unpack(data) {
|
|
1249
|
+
var result = new Uint8Array(data.length);
|
|
1250
|
+
for (var i = 0; i < data.length; ++i) {
|
|
1251
|
+
var ch = data.charCodeAt(i);
|
|
1252
|
+
result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
|
|
1253
|
+
}
|
|
1254
|
+
var write = 0;
|
|
1255
|
+
for (var i = 0; i < data.length; ++i) {
|
|
1256
|
+
result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
|
|
1257
|
+
}
|
|
1258
|
+
return result.buffer.slice(0, write);
|
|
1259
|
+
}
|
|
1260
|
+
function assert(cond) {
|
|
1261
|
+
if (!cond) {
|
|
1262
|
+
throw new Error("Assertion failed");
|
|
1263
|
+
}
|
|
1264
|
+
}
|
|
1265
|
+
function bytes(view) {
|
|
1266
|
+
return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
|
|
1267
|
+
}
|
|
1268
|
+
var BOUNDS_SIZE = 48;
|
|
1269
|
+
var MESHLET_SIZE = 16;
|
|
1270
|
+
function extractMeshlet(buffers, index) {
|
|
1271
|
+
var vertex_offset = buffers.meshlets[index * 4 + 0];
|
|
1272
|
+
var triangle_offset = buffers.meshlets[index * 4 + 1];
|
|
1273
|
+
var vertex_count = buffers.meshlets[index * 4 + 2];
|
|
1274
|
+
var triangle_count = buffers.meshlets[index * 4 + 3];
|
|
1275
|
+
return {
|
|
1276
|
+
vertices: buffers.vertices.subarray(vertex_offset, vertex_offset + vertex_count),
|
|
1277
|
+
triangles: buffers.triangles.subarray(triangle_offset, triangle_offset + triangle_count * 3)
|
|
1278
|
+
};
|
|
1279
|
+
}
|
|
1280
|
+
function buildMeshlets(fun, indices, vertex_positions, vertex_count, vertex_positions_stride, max_vertices, min_triangles, max_triangles, parama, paramb) {
|
|
1281
|
+
var sbrk = instance.exports.sbrk;
|
|
1282
|
+
var max_meshlets = instance.exports.meshopt_buildMeshletsBound(indices.length, max_vertices, min_triangles);
|
|
1283
|
+
var meshletsp = sbrk(max_meshlets * MESHLET_SIZE);
|
|
1284
|
+
var meshlet_verticesp = sbrk(indices.length * 4);
|
|
1285
|
+
var meshlet_trianglesp = sbrk(indices.length);
|
|
1286
|
+
var indicesp = sbrk(indices.byteLength);
|
|
1287
|
+
var verticesp = sbrk(vertex_positions.byteLength);
|
|
1288
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1289
|
+
heap.set(bytes(indices), indicesp);
|
|
1290
|
+
heap.set(bytes(vertex_positions), verticesp);
|
|
1291
|
+
var count = fun(
|
|
1292
|
+
meshletsp,
|
|
1293
|
+
meshlet_verticesp,
|
|
1294
|
+
meshlet_trianglesp,
|
|
1295
|
+
indicesp,
|
|
1296
|
+
indices.length,
|
|
1297
|
+
verticesp,
|
|
1298
|
+
vertex_count,
|
|
1299
|
+
vertex_positions_stride,
|
|
1300
|
+
max_vertices,
|
|
1301
|
+
min_triangles,
|
|
1302
|
+
max_triangles,
|
|
1303
|
+
parama,
|
|
1304
|
+
paramb
|
|
1305
|
+
);
|
|
1306
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1307
|
+
var meshletBytes = heap.subarray(meshletsp, meshletsp + count * MESHLET_SIZE);
|
|
1308
|
+
var meshlets = new Uint32Array(meshletBytes.buffer, meshletBytes.byteOffset, meshletBytes.byteLength / 4).slice();
|
|
1309
|
+
for (var i = 0; i < count; ++i) {
|
|
1310
|
+
var vertex_offset = meshlets[i * 4 + 0];
|
|
1311
|
+
var triangle_offset = meshlets[i * 4 + 1];
|
|
1312
|
+
var vertex_count = meshlets[i * 4 + 2];
|
|
1313
|
+
var triangle_count = meshlets[i * 4 + 3];
|
|
1314
|
+
instance.exports.meshopt_optimizeMeshlet(
|
|
1315
|
+
meshlet_verticesp + vertex_offset * 4,
|
|
1316
|
+
meshlet_trianglesp + triangle_offset,
|
|
1317
|
+
triangle_count,
|
|
1318
|
+
vertex_count
|
|
1319
|
+
);
|
|
1320
|
+
}
|
|
1321
|
+
var used_vertices = count ? meshlets[(count - 1) * 4 + 0] + meshlets[(count - 1) * 4 + 2] : 0;
|
|
1322
|
+
var used_triangles = count ? meshlets[(count - 1) * 4 + 1] + meshlets[(count - 1) * 4 + 3] * 3 : 0;
|
|
1323
|
+
var result = {
|
|
1324
|
+
meshlets,
|
|
1325
|
+
vertices: new Uint32Array(heap.buffer, meshlet_verticesp, used_vertices).slice(),
|
|
1326
|
+
triangles: new Uint8Array(heap.buffer, meshlet_trianglesp, used_triangles).slice(),
|
|
1327
|
+
meshletCount: count
|
|
1328
|
+
};
|
|
1329
|
+
sbrk(meshletsp - sbrk(0));
|
|
1330
|
+
return result;
|
|
1331
|
+
}
|
|
1332
|
+
function extractBounds(boundsp) {
|
|
1333
|
+
var bounds_floats = new Float32Array(instance.exports.memory.buffer, boundsp, BOUNDS_SIZE / 4);
|
|
1334
|
+
return {
|
|
1335
|
+
centerX: bounds_floats[0],
|
|
1336
|
+
centerY: bounds_floats[1],
|
|
1337
|
+
centerZ: bounds_floats[2],
|
|
1338
|
+
radius: bounds_floats[3],
|
|
1339
|
+
coneApexX: bounds_floats[4],
|
|
1340
|
+
coneApexY: bounds_floats[5],
|
|
1341
|
+
coneApexZ: bounds_floats[6],
|
|
1342
|
+
coneAxisX: bounds_floats[7],
|
|
1343
|
+
coneAxisY: bounds_floats[8],
|
|
1344
|
+
coneAxisZ: bounds_floats[9],
|
|
1345
|
+
coneCutoff: bounds_floats[10]
|
|
1346
|
+
};
|
|
1347
|
+
}
|
|
1348
|
+
function computeMeshletBounds(buffers, vertex_positions, vertex_count, vertex_positions_stride) {
|
|
1349
|
+
var sbrk = instance.exports.sbrk;
|
|
1350
|
+
var results = [];
|
|
1351
|
+
var verticesp = sbrk(vertex_positions.byteLength);
|
|
1352
|
+
var meshlet_verticesp = sbrk(buffers.vertices.byteLength);
|
|
1353
|
+
var meshlet_trianglesp = sbrk(buffers.triangles.byteLength);
|
|
1354
|
+
var resultp = sbrk(BOUNDS_SIZE);
|
|
1355
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1356
|
+
heap.set(bytes(vertex_positions), verticesp);
|
|
1357
|
+
heap.set(bytes(buffers.vertices), meshlet_verticesp);
|
|
1358
|
+
heap.set(bytes(buffers.triangles), meshlet_trianglesp);
|
|
1359
|
+
for (var i = 0; i < buffers.meshletCount; ++i) {
|
|
1360
|
+
var vertex_offset = buffers.meshlets[i * 4 + 0];
|
|
1361
|
+
var triangle_offset = buffers.meshlets[i * 4 + 1];
|
|
1362
|
+
var triangle_count = buffers.meshlets[i * 4 + 3];
|
|
1363
|
+
instance.exports.meshopt_computeMeshletBounds(
|
|
1364
|
+
resultp,
|
|
1365
|
+
meshlet_verticesp + vertex_offset * 4,
|
|
1366
|
+
meshlet_trianglesp + triangle_offset,
|
|
1367
|
+
triangle_count,
|
|
1368
|
+
verticesp,
|
|
1369
|
+
vertex_count,
|
|
1370
|
+
vertex_positions_stride
|
|
1371
|
+
);
|
|
1372
|
+
results.push(extractBounds(resultp));
|
|
1373
|
+
}
|
|
1374
|
+
sbrk(verticesp - sbrk(0));
|
|
1375
|
+
return results;
|
|
1376
|
+
}
|
|
1377
|
+
function computeClusterBounds(indices, vertex_positions, vertex_count, vertex_positions_stride) {
|
|
1378
|
+
var sbrk = instance.exports.sbrk;
|
|
1379
|
+
var resultp = sbrk(BOUNDS_SIZE);
|
|
1380
|
+
var indicesp = sbrk(indices.byteLength);
|
|
1381
|
+
var verticesp = sbrk(vertex_positions.byteLength);
|
|
1382
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1383
|
+
heap.set(bytes(indices), indicesp);
|
|
1384
|
+
heap.set(bytes(vertex_positions), verticesp);
|
|
1385
|
+
instance.exports.meshopt_computeClusterBounds(resultp, indicesp, indices.length, verticesp, vertex_count, vertex_positions_stride);
|
|
1386
|
+
var result = extractBounds(resultp);
|
|
1387
|
+
sbrk(resultp - sbrk(0));
|
|
1388
|
+
return result;
|
|
1389
|
+
}
|
|
1390
|
+
function computeSphereBounds(positions, count, positions_stride, radii, radii_stride) {
|
|
1391
|
+
var sbrk = instance.exports.sbrk;
|
|
1392
|
+
var resultp = sbrk(BOUNDS_SIZE);
|
|
1393
|
+
var positionsp = sbrk(positions.byteLength);
|
|
1394
|
+
var radiip = radii ? sbrk(radii.byteLength) : 0;
|
|
1395
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1396
|
+
heap.set(bytes(positions), positionsp);
|
|
1397
|
+
if (radii) {
|
|
1398
|
+
heap.set(bytes(radii), radiip);
|
|
1399
|
+
}
|
|
1400
|
+
instance.exports.meshopt_computeSphereBounds(resultp, positionsp, count, positions_stride, radiip, radii ? radii_stride : 0);
|
|
1401
|
+
var result = extractBounds(resultp);
|
|
1402
|
+
sbrk(resultp - sbrk(0));
|
|
1403
|
+
return result;
|
|
1404
|
+
}
|
|
1405
|
+
return {
|
|
1406
|
+
ready,
|
|
1407
|
+
supported: true,
|
|
1408
|
+
buildMeshlets: function(indices, vertex_positions, vertex_positions_stride, max_vertices, max_triangles, cone_weight) {
|
|
1409
|
+
assert(indices.length % 3 == 0);
|
|
1410
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1411
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1412
|
+
assert(vertex_positions_stride >= 3);
|
|
1413
|
+
assert(max_vertices >= 3 && max_vertices <= 256);
|
|
1414
|
+
assert(max_triangles >= 1 && max_triangles <= 512);
|
|
1415
|
+
cone_weight = cone_weight || 0;
|
|
1416
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1417
|
+
return buildMeshlets(
|
|
1418
|
+
instance.exports.meshopt_buildMeshletsFlex,
|
|
1419
|
+
indices32,
|
|
1420
|
+
vertex_positions,
|
|
1421
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1422
|
+
vertex_positions_stride * 4,
|
|
1423
|
+
max_vertices,
|
|
1424
|
+
max_triangles,
|
|
1425
|
+
max_triangles,
|
|
1426
|
+
cone_weight,
|
|
1427
|
+
0
|
|
1428
|
+
);
|
|
1429
|
+
},
|
|
1430
|
+
buildMeshletsFlex: function(indices, vertex_positions, vertex_positions_stride, max_vertices, min_triangles, max_triangles, cone_weight, split_factor) {
|
|
1431
|
+
assert(indices.length % 3 == 0);
|
|
1432
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1433
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1434
|
+
assert(vertex_positions_stride >= 3);
|
|
1435
|
+
assert(max_vertices >= 3 && max_vertices <= 256);
|
|
1436
|
+
assert(min_triangles >= 1 && max_triangles <= 512);
|
|
1437
|
+
assert(min_triangles <= max_triangles);
|
|
1438
|
+
cone_weight = cone_weight || 0;
|
|
1439
|
+
split_factor = split_factor || 0;
|
|
1440
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1441
|
+
return buildMeshlets(
|
|
1442
|
+
instance.exports.meshopt_buildMeshletsFlex,
|
|
1443
|
+
indices32,
|
|
1444
|
+
vertex_positions,
|
|
1445
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1446
|
+
vertex_positions_stride * 4,
|
|
1447
|
+
max_vertices,
|
|
1448
|
+
min_triangles,
|
|
1449
|
+
max_triangles,
|
|
1450
|
+
cone_weight,
|
|
1451
|
+
split_factor
|
|
1452
|
+
);
|
|
1453
|
+
},
|
|
1454
|
+
buildMeshletsSpatial: function(indices, vertex_positions, vertex_positions_stride, max_vertices, min_triangles, max_triangles, fill_weight) {
|
|
1455
|
+
assert(indices.length % 3 == 0);
|
|
1456
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1457
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1458
|
+
assert(vertex_positions_stride >= 3);
|
|
1459
|
+
assert(max_vertices >= 3 && max_vertices <= 256);
|
|
1460
|
+
assert(min_triangles >= 1 && max_triangles <= 512);
|
|
1461
|
+
assert(min_triangles <= max_triangles);
|
|
1462
|
+
fill_weight = fill_weight || 0;
|
|
1463
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1464
|
+
return buildMeshlets(
|
|
1465
|
+
instance.exports.meshopt_buildMeshletsSpatial,
|
|
1466
|
+
indices32,
|
|
1467
|
+
vertex_positions,
|
|
1468
|
+
vertex_positions.length / vertex_positions_stride,
|
|
1469
|
+
vertex_positions_stride * 4,
|
|
1470
|
+
max_vertices,
|
|
1471
|
+
min_triangles,
|
|
1472
|
+
max_triangles,
|
|
1473
|
+
fill_weight
|
|
1474
|
+
);
|
|
1475
|
+
},
|
|
1476
|
+
extractMeshlet: function(buffers, index) {
|
|
1477
|
+
assert(index >= 0 && index < buffers.meshletCount);
|
|
1478
|
+
return extractMeshlet(buffers, index);
|
|
1479
|
+
},
|
|
1480
|
+
computeClusterBounds: function(indices, vertex_positions, vertex_positions_stride) {
|
|
1481
|
+
assert(indices.length % 3 == 0);
|
|
1482
|
+
assert(indices.length / 3 <= 512);
|
|
1483
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1484
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1485
|
+
assert(vertex_positions_stride >= 3);
|
|
1486
|
+
var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1487
|
+
return computeClusterBounds(indices32, vertex_positions, vertex_positions.length / vertex_positions_stride, vertex_positions_stride * 4);
|
|
1488
|
+
},
|
|
1489
|
+
computeMeshletBounds: function(buffers, vertex_positions, vertex_positions_stride) {
|
|
1490
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1491
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1492
|
+
assert(vertex_positions_stride >= 3);
|
|
1493
|
+
return computeMeshletBounds(buffers, vertex_positions, vertex_positions.length / vertex_positions_stride, vertex_positions_stride * 4);
|
|
1494
|
+
},
|
|
1495
|
+
computeSphereBounds: function(positions, positions_stride, radii, radii_stride) {
|
|
1496
|
+
assert(positions instanceof Float32Array);
|
|
1497
|
+
assert(positions.length % positions_stride == 0);
|
|
1498
|
+
assert(positions_stride >= 3);
|
|
1499
|
+
assert(!radii || radii instanceof Float32Array);
|
|
1500
|
+
assert(!radii || radii.length % radii_stride == 0);
|
|
1501
|
+
assert(!radii || radii_stride >= 1);
|
|
1502
|
+
assert(!radii || positions.length / positions_stride == radii.length / radii_stride);
|
|
1503
|
+
radii_stride = radii_stride || 0;
|
|
1504
|
+
return computeSphereBounds(positions, positions.length / positions_stride, positions_stride * 4, radii, radii_stride * 4);
|
|
1505
|
+
}
|
|
1506
|
+
};
|
|
1507
|
+
})();
|
|
1508
|
+
|
|
1509
|
+
// packages/engine/node_modules/meshoptimizer/meshopt_tangents.js
|
|
1510
|
+
var MeshoptTangents = (function() {
|
|
1511
|
+
var wasm = "b9H79Tebbbegv9Geueu9Geub9Gbb9Gkuuuuuuuuuuub9Giuuueuirodiblbelve9Weiiviebeoweuecj:Gdkrnlo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbK9TW79O9V9Wt9F9NW9UWV9HtW9u9H9U9NW9Ut7bel79IV9RbdDwebcekdlvq;m8Lodbk:wgvOuw99iuv99vu8Jjjjjbc;Wb9Rgk8Kjjjjbakcxfcbc;Kbz:djjjb8AakcualcdtgxalcFFFFi0Ecbyd:q:G:cjbHjjjjbbgmBdxakceBd2adci9UhPalcd4alfhscehzinazgHcethzaHas6mbkakcuaHcdtgzaHcFFFFi0Ecbyd:q:G:cjbHjjjjbbgsBdzakcdBd2ascFeazz:djjjbhOaDcd4hAarcd4hCavcd4hXdnalTmbaHcufhrcbhvindndnaOcbaiavaX2cdtfgHydlgDaDcjjjj94SEgscH4cbaoavaC2cdtfgzydlgQcs4aQcjjjj94SE7as7c:F:b:DD2cbaHydbgLaLcjjjj94SEgscH4cbazydbgKcs4aKcjjjj94SE7as7c;D;O:B8J27cbaHydwgYaYcjjjj94SEgHcH4cbazydwg8Acs4a8Acjjjj94SE7aH7c:3F;N8N27awavaA2cdtfgHydlgEaHydbg37cFFFFrGgHcm4aH7c:fjjK27arGgscdtfgHydbgzcuSmbaE::h5a3::h8Ea8A::h8FaQ::haaK::hhaY::hgaD::h8JaL::h8KcehDinaDhHdnaiazaX2cdtfgDIdba8K9CmbaDIdla8J9CmbaDIdwag9CmbaoazaC2cdtfgDIdbah9CmbaDIdlaa9CmbaDIdwa8F9CmbawazaA2cdtfgDIdba8E9CmbaDIdla59BmikaHcefhDaOasaHfarGgscdtfgHydbgzcu9hmbkkaHavBdbavhzkamavcdtfazBdbavcefgval9hmbkkaOcbydN:G:cjbH:bjjjbbakceBd2akcualcefgHcdtaHcFFFFi0Ecbyd:q:G:cjbHjjjjbbg8LBdzakcdBd2akcuadcdtadcFFFFi0EgYcbyd:q:G:cjbHjjjjbbg8MBdCakciBd2a8Lclfcbaxz:djjjbhzdnadTmbdnaeTmbaehHadhsinazamaHydbcdtfydbcdtfgDaDydbcefBdbaHclfhHascufgsmbxdkkamhHadhsinazaHydbcdtfgDaDydbcefBdbaHclfhHascufgsmbkkdnalTmbcbhsazhHalhDinaHydbhOaHasBdbaHclfhHaOasfhsaDcufgDmbkkdnadci6gQmbcbhscdhHaPhOindndnaeTmbamaeasfgvydbcdtfhDamavcwfydbcdtfhramavclfydbcdtfhvxekamasfgDcwfhraDclfhvkarydbhravydbhvazaDydbcdtfgDaDydbgDcefBdba8MaDcdtfaHc9:fBdbazavcdtfgDaDydbgDcefBdba8MaDcdtfaHcufBdbazarcdtfgDaDydbgDcefBdba8MaDcdtfaHBdbascxfhsaHclfhHaOcufgOmbkkcbhsa8LcbBdbakcuaPcltadcFFFFd0Ecbyd:q:G:cjbHjjjjbbg8NBdKakclBd2dnaQmbaehza8NhHaPhvindndnaeTmbazcwfydbhDazclfydbhOazydbhrxekascdfhDascefhOashrkJbbbbh8KJbbbbJbbbbJbbbbJbbbbJbbjZJbbj:;awaOaA2cdtfgQIdbawaraA2cdtfgLIdbgh:tawaDaA2cdtfgKIdlaLIdlgg:tg8JNaQIdlag:tggaKIdbah:tN:tghJbbbb9EEahJbbbb9BEg8EaiaraX2cdtfgrIdwghaiaOaX2cdtfgOIdwg59BEa8EarIdlgaaOIdlgy9BEa8EarIdbg8FaOIdbg8P9BEg8EahaiaDaX2cdtfgDIdwgI9BEa8EaaaDIdlg8R9BEa8Ea8FaDIdbg8S9BEg8Ea5aI9BEa8Eaya8R9BEa8Ea8Pa8S9BEh8Edna8Ja5ah:tNagaIah:tN:tghahNa8Ja8Pa8F:tNaga8Sa8F:tN:tg8Fa8FNa8Jayaa:tNaga8Raa:tN:tg8Ja8JNMMggJbbbb9Bmba8Eag:r:vh8KkaHcxfa8EUdbaHcwfaha8KNUdbaHclfa8Ja8KNUdbaHa8Fa8KNUdbazcxfhzaHczfhHascifhsavcufgvmbkkcbhHakaYcbyd:q:G:cjbHjjjjbbgDBd3akcvBd2dnadTmbaDhzinazaHBdbazclfhzadaHcefgH9hmbkkakcuaPcdtadcFFFF970Ecbyd:q:G:cjbHjjjjbbgvBdaakcoBd2akaPcbyd:q:G:cjbHjjjjbbg8ABd8KakcrBd2dnadci6mba8NcxfhzavhscbhHinasaHBdba8AaHfcdcbazIdbg8KJbbbb9DEa8KJbbbb9EV86bbasclfhsazczfhzaPaHcefgH9hmbkkdnalTmbcbhRinaRcdthHdna8LaRcefgRcdtfydbgza8LaHfydbgHSmbazaH9RhLa8MaHcdtfhKcbh8UinaKa8Ucdtfg8VydbgHcd4g8Wci2gxaHciGcdtgzyd:e:G:cjbfhHaxazydj:G:cjbfhzdnaeTmbaeaHcdtfydbhHaeazcdtfydbhzkdna8Ucefg8UaL9pmbamaHcdtfydbhYamazcdtfydbh3a8Aa8WfhEava8Wcdtfh8Xa8UhwinaKawcdtfgQydbgHcd4gzci2gAaHciGcdtgHyd:e:G:cjbfhsaAaHydj:G:cjbfhHdnaeTmbaeascdtfydbhsaeaHcdtfydbhHkdndnamaHcdtfydbaYSmbamascdtfydba39hmeka8AazfRbbgHaERbbgsVciSmbdnaHasGmba8Whsdna8Wa8XydbgHSmba8XhOinaOavaHgscdtfgrydbgHBdbarhOasaH9hmbkkdnazavazcdtfgOydbgHSmbinaOavaHgzcdtfgrydbgHBdbarhOazaH9hmbkkasazSmba8AazfgORbba8AasfgHRbbVciSmeavazcdtfasBdbaHaHRbbaORbbV86bbkdna8VydbciGaxfgzaDazcdtfgsydbgHSmbinasaDaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkdnaQydbciGaAfgsaDascdtfgOydbgHSmbinaOaDaHgscdtfgrydbgHBdbarhOasaH9hmbkkazasSmbaDascdtfazBdbkawcefgwaL9hmbkka8UaL9hmbkkaRal9hmbkkdnadTmbcbhrinarhzdnaraDarcdtfgwydbgHSmbawhsinasaDaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkawazBdbarcefgrad9hmbkcbh8Vabcbadcltz:djjjbhKdnadci6mbaqceGhEaDhYaeh3cbh8Windna8Na8WcltfgsIdxJbbbb9Bmbama8Wcx2gHfhxaeaHfhLcbhza8VhwinaKaYazfydbcltfhHdndnaeTmbamaLazc:e:G:cjbfydbcdtfydbcdtfhAamaLazcj:G:cjbfydbcdtfydbcdtfhra3azfydbhOxekaxazc:e:G:cjbfydbcdtfhAaxazcj:G:cjbfydbcdtfhrawhOkaHasIdbggaoamaOcdtfydbgQaC2cdtfgOIdbg8KasIdwg8FaOIdwg8JNaga8KNasIdlg8EaOIdlggNMMghN:tgaJbbbbJbbjZa8Fa8JahN:tg8Fa8FNaaaaNa8EagahN:tghahNMMga:r:vaaJbbbb9BEJ;As6nJbbjZaiarydbaX2cdtfgOIdwaiaQaX2cdtfgrIdwg5:tgaa8Jaaa8JNaOIdbarIdbgy:tg8Pa8KNagaOIdlarIdlgI:tg8RNMMgaN:tg8EaiaAydbaX2cdtfgOIdwa5:tg5a8Ja5a8JNaOIdbay:tg8Sa8KNagaOIdlaI:tgINMMg5N:tg8JNa8Pa8KaaN:tgya8Sa8Ka5N:tg8KNa8RagaaN:tgaaIaga5N:tggNMMJbbbbJbbjZa8Ea8ENayayNaaaaNMMa8Ja8JNa8Ka8KNagagNMMNg8K:rg8J:va8KJbbbb9BENgg:lg8Ka8KJbbjZ9EEg8Ka8KJ7;A9s89NJ:L9t9s::MNJ;ob;jZMJbbjZa8K:t:rNg8K:ta8KagJbbbb9DENg8Ka8Ja8KNaEEg8KNaHIdbMUdbaHaha8KNaHIdlMUdlaHa8Fa8KNaHIdwMUdwawcefhwazclfgzcx9hmbkkaYcxfhYa3cxfh3a8Vcifh8Va8Wcefg8WaP9hmbkcbhrinarhzdnaravarcdtfgsydbgHSmbinasavaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkaKarc8W2fgHc3fJbbjZJbbj:;a8AazfRbbceGEg8KUdbaHc8Sfa8KUdbaHa8KUdxarcefgraP9hmbkkaqcdGhvcbhzaDhsaKhHindnazasydb9hmbJbbbbh8KdnaHcwfgOIdbg8Ja8JNaHIdbggagNaHclfgrIdbghahNMMgaJbbbb9BmbJbbjZaa:r:vh8KkaOa8Ja8KNUdbaraha8KNUdbaHaga8KNg8JUdbavmbaHJbbjZa8Ja8KJbbbb9BEUdbkasclfhsaHczfhHadazcefgz9hmbkcbhHaKhzindnaHaDydbgsSmbazaKascltfgsydwBdwazas8Pdb83dbkaDclfhDazczfhzadaHcefgH9hmbkkdnakyd2gzTmbazcdtakcxffc98fhHinaHydbcbydN:G:cjbH:bjjjbbaHc98fhHazcufgzmbkkakc;Wbf8Kjjjjbk9teiucbcbyd:y:G:cjbgeabcifc98GfgbBd:y:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:y:G:cjbgeabcrfc94GfgbBd:y:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd:y:G:cjbge9Rcifc98GaefgbBd:y:G:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk8Rdbcj:Gdkzebbbdbbbbbbbebbbbc:q:Gdkxebbbdbbba:qbb";
|
|
1512
|
+
var wasmpack = new Uint8Array([
|
|
1513
|
+
32,
|
|
1514
|
+
0,
|
|
1515
|
+
65,
|
|
1516
|
+
2,
|
|
1517
|
+
1,
|
|
1518
|
+
106,
|
|
1519
|
+
34,
|
|
1520
|
+
33,
|
|
1521
|
+
3,
|
|
1522
|
+
128,
|
|
1523
|
+
11,
|
|
1524
|
+
4,
|
|
1525
|
+
13,
|
|
1526
|
+
64,
|
|
1527
|
+
6,
|
|
1528
|
+
253,
|
|
1529
|
+
10,
|
|
1530
|
+
7,
|
|
1531
|
+
15,
|
|
1532
|
+
116,
|
|
1533
|
+
127,
|
|
1534
|
+
5,
|
|
1535
|
+
8,
|
|
1536
|
+
12,
|
|
1537
|
+
40,
|
|
1538
|
+
16,
|
|
1539
|
+
19,
|
|
1540
|
+
54,
|
|
1541
|
+
20,
|
|
1542
|
+
9,
|
|
1543
|
+
27,
|
|
1544
|
+
255,
|
|
1545
|
+
113,
|
|
1546
|
+
17,
|
|
1547
|
+
42,
|
|
1548
|
+
67,
|
|
1549
|
+
24,
|
|
1550
|
+
23,
|
|
1551
|
+
146,
|
|
1552
|
+
148,
|
|
1553
|
+
18,
|
|
1554
|
+
14,
|
|
1555
|
+
22,
|
|
1556
|
+
45,
|
|
1557
|
+
70,
|
|
1558
|
+
69,
|
|
1559
|
+
56,
|
|
1560
|
+
114,
|
|
1561
|
+
101,
|
|
1562
|
+
21,
|
|
1563
|
+
25,
|
|
1564
|
+
63,
|
|
1565
|
+
75,
|
|
1566
|
+
136,
|
|
1567
|
+
108,
|
|
1568
|
+
28,
|
|
1569
|
+
118,
|
|
1570
|
+
29,
|
|
1571
|
+
73,
|
|
1572
|
+
115
|
|
1573
|
+
]);
|
|
1574
|
+
if (typeof WebAssembly !== "object") {
|
|
1575
|
+
return {
|
|
1576
|
+
supported: false
|
|
1577
|
+
};
|
|
1578
|
+
}
|
|
1579
|
+
var instance;
|
|
1580
|
+
var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
|
|
1581
|
+
instance = result.instance;
|
|
1582
|
+
instance.exports.__wasm_call_ctors();
|
|
1583
|
+
});
|
|
1584
|
+
function unpack(data) {
|
|
1585
|
+
var result = new Uint8Array(data.length);
|
|
1586
|
+
for (var i = 0; i < data.length; ++i) {
|
|
1587
|
+
var ch = data.charCodeAt(i);
|
|
1588
|
+
result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
|
|
1589
|
+
}
|
|
1590
|
+
var write = 0;
|
|
1591
|
+
for (var i = 0; i < data.length; ++i) {
|
|
1592
|
+
result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
|
|
1593
|
+
}
|
|
1594
|
+
return result.buffer.slice(0, write);
|
|
1595
|
+
}
|
|
1596
|
+
function assert(cond) {
|
|
1597
|
+
if (!cond) {
|
|
1598
|
+
throw new Error("Assertion failed");
|
|
1599
|
+
}
|
|
1600
|
+
}
|
|
1601
|
+
function bytes(view) {
|
|
1602
|
+
return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
|
|
1603
|
+
}
|
|
1604
|
+
function generate(indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_normals, vertex_normals_stride, vertex_uvs, vertex_uvs_stride, options) {
|
|
1605
|
+
var sbrk = instance.exports.sbrk;
|
|
1606
|
+
var resultp = sbrk(index_count * 16);
|
|
1607
|
+
var indicesp = indices ? sbrk(indices.byteLength) : 0;
|
|
1608
|
+
var positionsp = sbrk(vertex_positions.byteLength);
|
|
1609
|
+
var normalsp = sbrk(vertex_normals.byteLength);
|
|
1610
|
+
var uvsp = sbrk(vertex_uvs.byteLength);
|
|
1611
|
+
var heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1612
|
+
if (indices) heap.set(bytes(indices), indicesp);
|
|
1613
|
+
heap.set(bytes(vertex_positions), positionsp);
|
|
1614
|
+
heap.set(bytes(vertex_normals), normalsp);
|
|
1615
|
+
heap.set(bytes(vertex_uvs), uvsp);
|
|
1616
|
+
instance.exports.meshopt_generateTangents(
|
|
1617
|
+
resultp,
|
|
1618
|
+
indicesp,
|
|
1619
|
+
index_count,
|
|
1620
|
+
positionsp,
|
|
1621
|
+
vertex_count,
|
|
1622
|
+
vertex_positions_stride * 4,
|
|
1623
|
+
normalsp,
|
|
1624
|
+
vertex_normals_stride * 4,
|
|
1625
|
+
uvsp,
|
|
1626
|
+
vertex_uvs_stride * 4,
|
|
1627
|
+
options
|
|
1628
|
+
);
|
|
1629
|
+
heap = new Uint8Array(instance.exports.memory.buffer);
|
|
1630
|
+
var result = new Float32Array(heap.buffer, resultp, index_count * 4).slice();
|
|
1631
|
+
sbrk(resultp - sbrk(0));
|
|
1632
|
+
return result;
|
|
1633
|
+
}
|
|
1634
|
+
var tangentOptions = {
|
|
1635
|
+
Compatible: 1,
|
|
1636
|
+
ZeroFallback: 2
|
|
1637
|
+
};
|
|
1638
|
+
return {
|
|
1639
|
+
ready,
|
|
1640
|
+
supported: true,
|
|
1641
|
+
generateTangents: function(indices, vertex_positions, vertex_positions_stride, vertex_normals, vertex_normals_stride, vertex_uvs, vertex_uvs_stride, flags) {
|
|
1642
|
+
assert(
|
|
1643
|
+
indices === null || indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
|
|
1644
|
+
);
|
|
1645
|
+
assert(indices === null || indices.length % 3 == 0);
|
|
1646
|
+
assert(vertex_positions instanceof Float32Array);
|
|
1647
|
+
assert(vertex_positions.length % vertex_positions_stride == 0);
|
|
1648
|
+
assert(vertex_positions_stride >= 3);
|
|
1649
|
+
assert(vertex_normals instanceof Float32Array);
|
|
1650
|
+
assert(vertex_normals.length % vertex_normals_stride == 0);
|
|
1651
|
+
assert(vertex_normals_stride >= 3);
|
|
1652
|
+
assert(vertex_uvs instanceof Float32Array);
|
|
1653
|
+
assert(vertex_uvs.length % vertex_uvs_stride == 0);
|
|
1654
|
+
assert(vertex_uvs_stride >= 2);
|
|
1655
|
+
assert(vertex_positions.length / vertex_positions_stride == vertex_normals.length / vertex_normals_stride);
|
|
1656
|
+
assert(vertex_positions.length / vertex_positions_stride == vertex_uvs.length / vertex_uvs_stride);
|
|
1657
|
+
assert(indices !== null || vertex_positions.length / vertex_positions_stride % 3 == 0);
|
|
1658
|
+
var options = 0;
|
|
1659
|
+
for (var i = 0; i < (flags ? flags.length : 0); ++i) {
|
|
1660
|
+
assert(flags[i] in tangentOptions);
|
|
1661
|
+
options |= tangentOptions[flags[i]];
|
|
1662
|
+
}
|
|
1663
|
+
var vertex_count = vertex_positions.length / vertex_positions_stride;
|
|
1664
|
+
var index_count = indices ? indices.length : vertex_count;
|
|
1665
|
+
var indices32 = indices === null || indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
|
|
1666
|
+
return generate(
|
|
1667
|
+
indices32,
|
|
1668
|
+
index_count,
|
|
1669
|
+
vertex_positions,
|
|
1670
|
+
vertex_count,
|
|
1671
|
+
vertex_positions_stride,
|
|
1672
|
+
vertex_normals,
|
|
1673
|
+
vertex_normals_stride,
|
|
1674
|
+
vertex_uvs,
|
|
1675
|
+
vertex_uvs_stride,
|
|
1676
|
+
options
|
|
1677
|
+
);
|
|
1678
|
+
}
|
|
1679
|
+
};
|
|
1680
|
+
})();
|
|
1681
|
+
|
|
1682
|
+
// packages/engine/Source/Scene/Axis.js
|
|
1683
|
+
var Axis = {
|
|
1684
|
+
/**
|
|
1685
|
+
* Denotes the x-axis.
|
|
1686
|
+
*
|
|
1687
|
+
* @type {number}
|
|
1688
|
+
* @constant
|
|
1689
|
+
*/
|
|
1690
|
+
X: 0,
|
|
1691
|
+
/**
|
|
1692
|
+
* Denotes the y-axis.
|
|
1693
|
+
*
|
|
1694
|
+
* @type {number}
|
|
1695
|
+
* @constant
|
|
1696
|
+
*/
|
|
1697
|
+
Y: 1,
|
|
1698
|
+
/**
|
|
1699
|
+
* Denotes the z-axis.
|
|
1700
|
+
*
|
|
1701
|
+
* @type {number}
|
|
1702
|
+
* @constant
|
|
1703
|
+
*/
|
|
1704
|
+
Z: 2
|
|
1705
|
+
};
|
|
1706
|
+
Axis.Y_UP_TO_Z_UP = Matrix4_default.fromRotationTranslation(
|
|
1707
|
+
// Rotation about PI/2 around the X-axis
|
|
1708
|
+
Matrix3_default.fromArray([1, 0, 0, 0, 0, 1, 0, -1, 0])
|
|
1709
|
+
);
|
|
1710
|
+
Axis.Z_UP_TO_Y_UP = Matrix4_default.fromRotationTranslation(
|
|
1711
|
+
// Rotation about -PI/2 around the X-axis
|
|
1712
|
+
Matrix3_default.fromArray([1, 0, 0, 0, 0, -1, 0, 1, 0])
|
|
1713
|
+
);
|
|
1714
|
+
Axis.X_UP_TO_Z_UP = Matrix4_default.fromRotationTranslation(
|
|
1715
|
+
// Rotation about -PI/2 around the Y-axis
|
|
1716
|
+
Matrix3_default.fromArray([0, 0, 1, 0, 1, 0, -1, 0, 0])
|
|
1717
|
+
);
|
|
1718
|
+
Axis.Z_UP_TO_X_UP = Matrix4_default.fromRotationTranslation(
|
|
1719
|
+
// Rotation about PI/2 around the Y-axis
|
|
1720
|
+
Matrix3_default.fromArray([0, 0, -1, 0, 1, 0, 1, 0, 0])
|
|
1721
|
+
);
|
|
1722
|
+
Axis.X_UP_TO_Y_UP = Matrix4_default.fromRotationTranslation(
|
|
1723
|
+
// Rotation about PI/2 around the Z-axis
|
|
1724
|
+
Matrix3_default.fromArray([0, 1, 0, -1, 0, 0, 0, 0, 1])
|
|
1725
|
+
);
|
|
1726
|
+
Axis.Y_UP_TO_X_UP = Matrix4_default.fromRotationTranslation(
|
|
1727
|
+
// Rotation about -PI/2 around the Z-axis
|
|
1728
|
+
Matrix3_default.fromArray([0, -1, 0, 1, 0, 0, 0, 0, 1])
|
|
1729
|
+
);
|
|
1730
|
+
Axis.fromName = function(name) {
|
|
1731
|
+
Check_default.typeOf.string("name", name);
|
|
1732
|
+
return Axis[name];
|
|
1733
|
+
};
|
|
1734
|
+
Object.freeze(Axis);
|
|
1735
|
+
var Axis_default = Axis;
|
|
1736
|
+
|
|
1737
|
+
// packages/engine/Source/Scene/SceneMode.js
|
|
1738
|
+
var SceneMode = {
|
|
1739
|
+
/**
|
|
1740
|
+
* Morphing between mode, e.g., 3D to 2D.
|
|
1741
|
+
*
|
|
1742
|
+
* @type {number}
|
|
1743
|
+
* @constant
|
|
1744
|
+
*/
|
|
1745
|
+
MORPHING: 0,
|
|
1746
|
+
/**
|
|
1747
|
+
* Columbus View mode. A 2.5D perspective view where the map is laid out
|
|
1748
|
+
* flat and objects with non-zero height are drawn above it.
|
|
1749
|
+
*
|
|
1750
|
+
* @type {number}
|
|
1751
|
+
* @constant
|
|
1752
|
+
*/
|
|
1753
|
+
COLUMBUS_VIEW: 1,
|
|
1754
|
+
/**
|
|
1755
|
+
* 2D mode. The map is viewed top-down with an orthographic projection.
|
|
1756
|
+
*
|
|
1757
|
+
* @type {number}
|
|
1758
|
+
* @constant
|
|
1759
|
+
*/
|
|
1760
|
+
SCENE2D: 2,
|
|
1761
|
+
/**
|
|
1762
|
+
* 3D mode. A traditional 3D perspective view of the globe.
|
|
1763
|
+
*
|
|
1764
|
+
* @type {number}
|
|
1765
|
+
* @constant
|
|
1766
|
+
*/
|
|
1767
|
+
SCENE3D: 3
|
|
1768
|
+
};
|
|
1769
|
+
SceneMode.getMorphTime = function(value) {
|
|
1770
|
+
if (value === SceneMode.SCENE3D) {
|
|
1771
|
+
return 1;
|
|
1772
|
+
} else if (value === SceneMode.MORPHING) {
|
|
1773
|
+
return void 0;
|
|
1774
|
+
}
|
|
1775
|
+
return 0;
|
|
1776
|
+
};
|
|
1777
|
+
Object.freeze(SceneMode);
|
|
1778
|
+
var SceneMode_default = SceneMode;
|
|
1779
|
+
|
|
1780
|
+
// packages/engine/Source/Core/TaskProcessor.js
|
|
1781
|
+
var import_urijs = __toESM(require_URI(), 1);
|
|
1782
|
+
|
|
1783
|
+
// packages/engine/Source/Core/destroyObject.js
|
|
1784
|
+
function returnTrue() {
|
|
1785
|
+
return true;
|
|
1786
|
+
}
|
|
1787
|
+
function destroyObject(object, message) {
|
|
1788
|
+
message = message ?? "This object was destroyed, i.e., destroy() was called.";
|
|
1789
|
+
function throwOnDestroyed() {
|
|
1790
|
+
throw new DeveloperError_default(message);
|
|
1791
|
+
}
|
|
1792
|
+
for (const key in object) {
|
|
1793
|
+
if (typeof object[key] === "function") {
|
|
1794
|
+
object[key] = throwOnDestroyed;
|
|
1795
|
+
}
|
|
1796
|
+
}
|
|
1797
|
+
object.isDestroyed = returnTrue;
|
|
1798
|
+
return void 0;
|
|
1799
|
+
}
|
|
1800
|
+
var destroyObject_default = destroyObject;
|
|
1801
|
+
|
|
1802
|
+
// packages/engine/Source/Core/TaskProcessor.js
|
|
1803
|
+
function canTransferArrayBuffer() {
|
|
1804
|
+
if (!defined_default(TaskProcessor._canTransferArrayBuffer)) {
|
|
1805
|
+
const worker = createWorker("transferTypedArrayTest");
|
|
1806
|
+
worker.postMessage = worker.webkitPostMessage ?? worker.postMessage;
|
|
1807
|
+
const value = 99;
|
|
1808
|
+
const array = new Int8Array([value]);
|
|
1809
|
+
try {
|
|
1810
|
+
worker.postMessage(
|
|
1811
|
+
{
|
|
1812
|
+
array
|
|
1813
|
+
},
|
|
1814
|
+
[array.buffer]
|
|
1815
|
+
);
|
|
1816
|
+
} catch (e) {
|
|
1817
|
+
TaskProcessor._canTransferArrayBuffer = false;
|
|
1818
|
+
return TaskProcessor._canTransferArrayBuffer;
|
|
1819
|
+
}
|
|
1820
|
+
TaskProcessor._canTransferArrayBuffer = new Promise((resolve) => {
|
|
1821
|
+
worker.onmessage = function(event) {
|
|
1822
|
+
const array2 = event.data.array;
|
|
1823
|
+
const result = defined_default(array2) && array2[0] === value;
|
|
1824
|
+
resolve(result);
|
|
1825
|
+
worker.terminate();
|
|
1826
|
+
TaskProcessor._canTransferArrayBuffer = result;
|
|
1827
|
+
};
|
|
1828
|
+
});
|
|
1829
|
+
}
|
|
1830
|
+
return TaskProcessor._canTransferArrayBuffer;
|
|
1831
|
+
}
|
|
1832
|
+
var taskCompletedEvent = new Event_default();
|
|
1833
|
+
function urlFromScript(script) {
|
|
1834
|
+
let blob;
|
|
1835
|
+
try {
|
|
1836
|
+
blob = new Blob([script], {
|
|
1837
|
+
type: "application/javascript"
|
|
1838
|
+
});
|
|
1839
|
+
} catch (e) {
|
|
1840
|
+
const BlobBuilder = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder || window.MSBlobBuilder;
|
|
1841
|
+
const blobBuilder = new BlobBuilder();
|
|
1842
|
+
blobBuilder.append(script);
|
|
1843
|
+
blob = blobBuilder.getBlob("application/javascript");
|
|
1844
|
+
}
|
|
1845
|
+
const URL2 = window.URL || window.webkitURL;
|
|
1846
|
+
return URL2.createObjectURL(blob);
|
|
1847
|
+
}
|
|
1848
|
+
function createWorker(url) {
|
|
1849
|
+
const uri = new import_urijs.default(url);
|
|
1850
|
+
const isUri = uri.scheme().length !== 0 && uri.fragment().length === 0;
|
|
1851
|
+
const moduleID = url.replace(/\.js$/, "");
|
|
1852
|
+
const options = {};
|
|
1853
|
+
let workerPath;
|
|
1854
|
+
let crossOriginUrl;
|
|
1855
|
+
if (isCrossOriginUrl_default(url)) {
|
|
1856
|
+
crossOriginUrl = url;
|
|
1857
|
+
} else if (!isUri) {
|
|
1858
|
+
const moduleAbsoluteUrl = buildModuleUrl_default(
|
|
1859
|
+
`${TaskProcessor._workerModulePrefix}/${moduleID}.js`
|
|
1860
|
+
);
|
|
1861
|
+
if (isCrossOriginUrl_default(moduleAbsoluteUrl)) {
|
|
1862
|
+
crossOriginUrl = moduleAbsoluteUrl;
|
|
1863
|
+
}
|
|
1864
|
+
}
|
|
1865
|
+
if (crossOriginUrl) {
|
|
1866
|
+
const script = `import "${crossOriginUrl}";`;
|
|
1867
|
+
workerPath = urlFromScript(script);
|
|
1868
|
+
options.type = "module";
|
|
1869
|
+
return new Worker(workerPath, options);
|
|
1870
|
+
}
|
|
1871
|
+
if (!isUri && typeof CESIUM_WORKERS !== "undefined") {
|
|
1872
|
+
const script = `
|
|
1873
|
+
importScripts("${urlFromScript(CESIUM_WORKERS)}");
|
|
1874
|
+
CesiumWorkers["${moduleID}"]();
|
|
1875
|
+
`;
|
|
1876
|
+
workerPath = urlFromScript(script);
|
|
1877
|
+
return new Worker(workerPath, options);
|
|
1878
|
+
}
|
|
1879
|
+
workerPath = url;
|
|
1880
|
+
if (!isUri) {
|
|
1881
|
+
workerPath = buildModuleUrl_default(
|
|
1882
|
+
`${TaskProcessor._workerModulePrefix + moduleID}.js`
|
|
1883
|
+
);
|
|
1884
|
+
}
|
|
1885
|
+
if (!FeatureDetection_default.supportsEsmWebWorkers()) {
|
|
1886
|
+
throw new RuntimeError_default(
|
|
1887
|
+
"This browser is not supported. Please update your browser to continue."
|
|
1888
|
+
);
|
|
1889
|
+
}
|
|
1890
|
+
options.type = "module";
|
|
1891
|
+
return new Worker(workerPath, options);
|
|
1892
|
+
}
|
|
1893
|
+
async function getWebAssemblyLoaderConfig(processor, wasmOptions) {
|
|
1894
|
+
const config = {
|
|
1895
|
+
modulePath: void 0,
|
|
1896
|
+
wasmBinaryFile: void 0,
|
|
1897
|
+
wasmBinary: void 0
|
|
1898
|
+
};
|
|
1899
|
+
if (!FeatureDetection_default.supportsWebAssembly()) {
|
|
1900
|
+
if (!defined_default(wasmOptions.fallbackModulePath)) {
|
|
1901
|
+
throw new RuntimeError_default(
|
|
1902
|
+
`This browser does not support Web Assembly, and no backup module was provided for ${processor._workerPath}`
|
|
1903
|
+
);
|
|
1904
|
+
}
|
|
1905
|
+
config.modulePath = buildModuleUrl_default(wasmOptions.fallbackModulePath);
|
|
1906
|
+
return config;
|
|
1907
|
+
}
|
|
1908
|
+
config.wasmBinaryFile = buildModuleUrl_default(wasmOptions.wasmBinaryFile);
|
|
1909
|
+
const arrayBuffer = await Resource_default.fetchArrayBuffer({
|
|
1910
|
+
url: config.wasmBinaryFile
|
|
1911
|
+
});
|
|
1912
|
+
config.wasmBinary = arrayBuffer;
|
|
1913
|
+
return config;
|
|
1914
|
+
}
|
|
1915
|
+
function TaskProcessor(workerPath, maximumActiveTasks) {
|
|
1916
|
+
this._workerPath = workerPath;
|
|
1917
|
+
this._maximumActiveTasks = maximumActiveTasks ?? Number.POSITIVE_INFINITY;
|
|
1918
|
+
this._activeTasks = 0;
|
|
1919
|
+
this._nextID = 0;
|
|
1920
|
+
this._webAssemblyPromise = void 0;
|
|
1921
|
+
}
|
|
1922
|
+
var createOnmessageHandler = (worker, id, resolve, reject) => {
|
|
1923
|
+
const listener = ({ data }) => {
|
|
1924
|
+
if (data.id !== id) {
|
|
1925
|
+
return;
|
|
1926
|
+
}
|
|
1927
|
+
if (defined_default(data.error)) {
|
|
1928
|
+
let error = data.error;
|
|
1929
|
+
if (error.name === "RuntimeError") {
|
|
1930
|
+
error = new RuntimeError_default(data.error.message);
|
|
1931
|
+
error.stack = data.error.stack;
|
|
1932
|
+
} else if (error.name === "DeveloperError") {
|
|
1933
|
+
error = new DeveloperError_default(data.error.message);
|
|
1934
|
+
error.stack = data.error.stack;
|
|
1935
|
+
} else if (error.name === "Error") {
|
|
1936
|
+
error = new Error(data.error.message);
|
|
1937
|
+
error.stack = data.error.stack;
|
|
1938
|
+
}
|
|
1939
|
+
taskCompletedEvent.raiseEvent(error);
|
|
1940
|
+
reject(error);
|
|
1941
|
+
} else {
|
|
1942
|
+
taskCompletedEvent.raiseEvent();
|
|
1943
|
+
resolve(data.result);
|
|
1944
|
+
}
|
|
1945
|
+
worker.removeEventListener("message", listener);
|
|
1946
|
+
};
|
|
1947
|
+
return listener;
|
|
1948
|
+
};
|
|
1949
|
+
var emptyTransferableObjectArray = [];
|
|
1950
|
+
async function runTask(processor, parameters, transferableObjects) {
|
|
1951
|
+
const canTransfer = await Promise.resolve(canTransferArrayBuffer());
|
|
1952
|
+
if (!defined_default(transferableObjects)) {
|
|
1953
|
+
transferableObjects = emptyTransferableObjectArray;
|
|
1954
|
+
} else if (!canTransfer) {
|
|
1955
|
+
transferableObjects.length = 0;
|
|
1956
|
+
}
|
|
1957
|
+
const id = processor._nextID++;
|
|
1958
|
+
const promise = new Promise((resolve, reject) => {
|
|
1959
|
+
processor._worker.addEventListener(
|
|
1960
|
+
"message",
|
|
1961
|
+
createOnmessageHandler(processor._worker, id, resolve, reject)
|
|
1962
|
+
);
|
|
1963
|
+
});
|
|
1964
|
+
processor._worker.postMessage(
|
|
1965
|
+
{
|
|
1966
|
+
id,
|
|
1967
|
+
baseUrl: buildModuleUrl_default.getCesiumBaseUrl().url,
|
|
1968
|
+
parameters,
|
|
1969
|
+
canTransferArrayBuffer: canTransfer
|
|
1970
|
+
},
|
|
1971
|
+
transferableObjects
|
|
1972
|
+
);
|
|
1973
|
+
return promise;
|
|
1974
|
+
}
|
|
1975
|
+
async function scheduleTask(processor, parameters, transferableObjects) {
|
|
1976
|
+
++processor._activeTasks;
|
|
1977
|
+
try {
|
|
1978
|
+
const result = await runTask(processor, parameters, transferableObjects);
|
|
1979
|
+
--processor._activeTasks;
|
|
1980
|
+
return result;
|
|
1981
|
+
} catch (error) {
|
|
1982
|
+
--processor._activeTasks;
|
|
1983
|
+
throw error;
|
|
1984
|
+
}
|
|
1985
|
+
}
|
|
1986
|
+
TaskProcessor.prototype.scheduleTask = function(parameters, transferableObjects) {
|
|
1987
|
+
if (!defined_default(this._worker)) {
|
|
1988
|
+
this._worker = createWorker(this._workerPath);
|
|
1989
|
+
}
|
|
1990
|
+
if (this._activeTasks >= this._maximumActiveTasks) {
|
|
1991
|
+
return void 0;
|
|
1992
|
+
}
|
|
1993
|
+
return scheduleTask(this, parameters, transferableObjects);
|
|
1994
|
+
};
|
|
1995
|
+
TaskProcessor.prototype.initWebAssemblyModule = async function(webAssemblyOptions) {
|
|
1996
|
+
if (defined_default(this._webAssemblyPromise)) {
|
|
1997
|
+
return this._webAssemblyPromise;
|
|
1998
|
+
}
|
|
1999
|
+
const init = async () => {
|
|
2000
|
+
const worker = this._worker = createWorker(this._workerPath);
|
|
2001
|
+
const wasmConfig = await getWebAssemblyLoaderConfig(
|
|
2002
|
+
this,
|
|
2003
|
+
webAssemblyOptions
|
|
2004
|
+
);
|
|
2005
|
+
const canTransfer = await Promise.resolve(canTransferArrayBuffer());
|
|
2006
|
+
let transferableObjects;
|
|
2007
|
+
const binary = wasmConfig.wasmBinary;
|
|
2008
|
+
if (defined_default(binary) && canTransfer) {
|
|
2009
|
+
transferableObjects = [binary];
|
|
2010
|
+
}
|
|
2011
|
+
const promise = new Promise((resolve, reject) => {
|
|
2012
|
+
worker.onmessage = function({ data }) {
|
|
2013
|
+
if (defined_default(data)) {
|
|
2014
|
+
resolve(data.result);
|
|
2015
|
+
} else {
|
|
2016
|
+
reject(new RuntimeError_default("Could not configure wasm module"));
|
|
2017
|
+
}
|
|
2018
|
+
};
|
|
2019
|
+
});
|
|
2020
|
+
worker.postMessage(
|
|
2021
|
+
{
|
|
2022
|
+
canTransferArrayBuffer: canTransfer,
|
|
2023
|
+
parameters: { webAssemblyConfig: wasmConfig }
|
|
2024
|
+
},
|
|
2025
|
+
transferableObjects
|
|
2026
|
+
);
|
|
2027
|
+
return promise;
|
|
2028
|
+
};
|
|
2029
|
+
this._webAssemblyPromise = init();
|
|
2030
|
+
return this._webAssemblyPromise;
|
|
2031
|
+
};
|
|
2032
|
+
TaskProcessor.prototype.isDestroyed = function() {
|
|
2033
|
+
return false;
|
|
2034
|
+
};
|
|
2035
|
+
TaskProcessor.prototype.destroy = function() {
|
|
2036
|
+
if (defined_default(this._worker)) {
|
|
2037
|
+
this._worker.terminate();
|
|
2038
|
+
}
|
|
2039
|
+
return destroyObject_default(this);
|
|
2040
|
+
};
|
|
2041
|
+
TaskProcessor.taskCompletedEvent = taskCompletedEvent;
|
|
2042
|
+
TaskProcessor._defaultWorkerModulePrefix = "Workers/";
|
|
2043
|
+
TaskProcessor._workerModulePrefix = TaskProcessor._defaultWorkerModulePrefix;
|
|
2044
|
+
TaskProcessor._canTransferArrayBuffer = void 0;
|
|
2045
|
+
var TaskProcessor_default = TaskProcessor;
|
|
2046
|
+
|
|
2047
|
+
// packages/engine/Source/Core/TerrainPicker.js
|
|
2048
|
+
var MAXIMUM_TERRAIN_PICKER_LEVEL = 3;
|
|
2049
|
+
function TerrainPicker(vertices, indices, encoding) {
|
|
2050
|
+
Check_default.defined("vertices", vertices);
|
|
2051
|
+
Check_default.defined("indices", indices);
|
|
2052
|
+
Check_default.defined("encoding", encoding);
|
|
2053
|
+
this._vertices = vertices;
|
|
2054
|
+
this._indices = indices;
|
|
2055
|
+
this._encoding = encoding;
|
|
2056
|
+
this._inverseTransform = new Matrix4_default();
|
|
2057
|
+
this._needsRebuild = true;
|
|
2058
|
+
this._rootNode = new TerrainPickerNode();
|
|
2059
|
+
}
|
|
2060
|
+
var incrementallyBuildTerrainPickerTaskProcessor = new TaskProcessor_default(
|
|
2061
|
+
"incrementallyBuildTerrainPicker"
|
|
2062
|
+
);
|
|
2063
|
+
Object.defineProperties(TerrainPicker.prototype, {
|
|
2064
|
+
/**
|
|
2065
|
+
* Indicates whether the terrain picker needs to be rebuilt due to changes in the underlying terrain mesh's vertices or indices.
|
|
2066
|
+
* @memberof TerrainPicker.prototype
|
|
2067
|
+
* @type {boolean}
|
|
2068
|
+
*/
|
|
2069
|
+
needsRebuild: {
|
|
2070
|
+
get: function() {
|
|
2071
|
+
return this._needsRebuild;
|
|
2072
|
+
},
|
|
2073
|
+
set: function(value) {
|
|
2074
|
+
this._needsRebuild = value;
|
|
2075
|
+
}
|
|
2076
|
+
}
|
|
2077
|
+
});
|
|
2078
|
+
function TerrainPickerNode() {
|
|
2079
|
+
this.x = 0;
|
|
2080
|
+
this.y = 0;
|
|
2081
|
+
this.level = 0;
|
|
2082
|
+
this.aabb = createAABBForNode(this.x, this.y, this.level);
|
|
2083
|
+
this.intersectingTriangles = new Uint32Array(0);
|
|
2084
|
+
this.children = [];
|
|
2085
|
+
this.buildingChildren = false;
|
|
2086
|
+
}
|
|
2087
|
+
TerrainPickerNode.prototype.addChild = function(childIdx) {
|
|
2088
|
+
if (childIdx < 0 || childIdx > 3) {
|
|
2089
|
+
throw new DeveloperError_default(
|
|
2090
|
+
"TerrainPickerNode child index must be between 0 and 3, inclusive."
|
|
2091
|
+
);
|
|
2092
|
+
}
|
|
2093
|
+
const childNode = new TerrainPickerNode();
|
|
2094
|
+
childNode.x = this.x * 2 + (childIdx & 1);
|
|
2095
|
+
childNode.y = this.y * 2 + (childIdx >> 1 & 1);
|
|
2096
|
+
childNode.level = this.level + 1;
|
|
2097
|
+
childNode.aabb = createAABBForNode(childNode.x, childNode.y, childNode.level);
|
|
2098
|
+
this.children[childIdx] = childNode;
|
|
2099
|
+
};
|
|
2100
|
+
var scratchTransformedRay = new Ray_default();
|
|
2101
|
+
var scratchTrianglePoints = [
|
|
2102
|
+
new Cartesian3_default(),
|
|
2103
|
+
new Cartesian3_default(),
|
|
2104
|
+
new Cartesian3_default()
|
|
2105
|
+
];
|
|
2106
|
+
TerrainPicker.prototype.rayIntersect = function(ray, tileTransform, cullBackFaces, mode, projection) {
|
|
2107
|
+
if (this._needsRebuild) {
|
|
2108
|
+
reset(this, tileTransform);
|
|
2109
|
+
}
|
|
2110
|
+
const invTransform = this._inverseTransform;
|
|
2111
|
+
const transformedRay = scratchTransformedRay;
|
|
2112
|
+
transformedRay.origin = Matrix4_default.multiplyByPoint(
|
|
2113
|
+
invTransform,
|
|
2114
|
+
ray.origin,
|
|
2115
|
+
transformedRay.origin
|
|
2116
|
+
);
|
|
2117
|
+
transformedRay.direction = Matrix4_default.multiplyByPointAsVector(
|
|
2118
|
+
invTransform,
|
|
2119
|
+
ray.direction,
|
|
2120
|
+
transformedRay.direction
|
|
2121
|
+
);
|
|
2122
|
+
const intersections = [];
|
|
2123
|
+
getNodesIntersectingRay(this._rootNode, transformedRay, intersections);
|
|
2124
|
+
return findClosestPointInClosestNode(
|
|
2125
|
+
this,
|
|
2126
|
+
intersections,
|
|
2127
|
+
ray,
|
|
2128
|
+
cullBackFaces,
|
|
2129
|
+
mode,
|
|
2130
|
+
projection
|
|
2131
|
+
);
|
|
2132
|
+
};
|
|
2133
|
+
function reset(terrainPicker, tileTransform) {
|
|
2134
|
+
Matrix4_default.inverse(tileTransform, terrainPicker._inverseTransform);
|
|
2135
|
+
terrainPicker._needsRebuild = false;
|
|
2136
|
+
const triangleCount = terrainPicker._indices.length / 3;
|
|
2137
|
+
const intersectingTriangles = new Uint32Array(triangleCount);
|
|
2138
|
+
for (let i = 0; i < triangleCount; ++i) {
|
|
2139
|
+
intersectingTriangles[i] = i;
|
|
2140
|
+
}
|
|
2141
|
+
terrainPicker._rootNode.intersectingTriangles = intersectingTriangles;
|
|
2142
|
+
terrainPicker._rootNode.children.length = 0;
|
|
2143
|
+
}
|
|
2144
|
+
var scratchAABBMin = new Cartesian3_default();
|
|
2145
|
+
var scratchAABBMax = new Cartesian3_default();
|
|
2146
|
+
function createAABBForNode(x, y, level) {
|
|
2147
|
+
const sizeAtLevel = 1 / Math.pow(2, level);
|
|
2148
|
+
const aabbMin = Cartesian3_default.fromElements(
|
|
2149
|
+
x * sizeAtLevel - 0.5,
|
|
2150
|
+
y * sizeAtLevel - 0.5,
|
|
2151
|
+
-0.5,
|
|
2152
|
+
scratchAABBMin
|
|
2153
|
+
);
|
|
2154
|
+
const aabbMax = Cartesian3_default.fromElements(
|
|
2155
|
+
(x + 1) * sizeAtLevel - 0.5,
|
|
2156
|
+
(y + 1) * sizeAtLevel - 0.5,
|
|
2157
|
+
0.5,
|
|
2158
|
+
scratchAABBMax
|
|
2159
|
+
);
|
|
2160
|
+
return AxisAlignedBoundingBox_default.fromCorners(aabbMin, aabbMax);
|
|
2161
|
+
}
|
|
2162
|
+
function packTriangleBuffers(trianglePositionsBuffer, triangleIndicesBuffer, trianglePositions, triangleIndex, bufferIndex) {
|
|
2163
|
+
Cartesian3_default.pack(
|
|
2164
|
+
trianglePositions[0],
|
|
2165
|
+
trianglePositionsBuffer,
|
|
2166
|
+
9 * bufferIndex
|
|
2167
|
+
);
|
|
2168
|
+
Cartesian3_default.pack(
|
|
2169
|
+
trianglePositions[1],
|
|
2170
|
+
trianglePositionsBuffer,
|
|
2171
|
+
9 * bufferIndex + 3
|
|
2172
|
+
);
|
|
2173
|
+
Cartesian3_default.pack(
|
|
2174
|
+
trianglePositions[2],
|
|
2175
|
+
trianglePositionsBuffer,
|
|
2176
|
+
9 * bufferIndex + 6
|
|
2177
|
+
);
|
|
2178
|
+
triangleIndicesBuffer[bufferIndex] = triangleIndex;
|
|
2179
|
+
}
|
|
2180
|
+
var scratchInterval = new Interval_default();
|
|
2181
|
+
function getNodesIntersectingRay(currentNode, ray, intersectingNodes) {
|
|
2182
|
+
const interval = IntersectionTests_default.rayAxisAlignedBoundingBox(
|
|
2183
|
+
ray,
|
|
2184
|
+
currentNode.aabb,
|
|
2185
|
+
scratchInterval
|
|
2186
|
+
);
|
|
2187
|
+
if (!defined_default(interval)) {
|
|
2188
|
+
return;
|
|
2189
|
+
}
|
|
2190
|
+
const isLeaf = !currentNode.children.length || currentNode.buildingChildren;
|
|
2191
|
+
if (isLeaf) {
|
|
2192
|
+
intersectingNodes.push({
|
|
2193
|
+
node: currentNode,
|
|
2194
|
+
interval: new Interval_default(interval.start, interval.stop)
|
|
2195
|
+
});
|
|
2196
|
+
return;
|
|
2197
|
+
}
|
|
2198
|
+
for (let i = 0; i < currentNode.children.length; i++) {
|
|
2199
|
+
getNodesIntersectingRay(currentNode.children[i], ray, intersectingNodes);
|
|
2200
|
+
}
|
|
2201
|
+
}
|
|
2202
|
+
function findClosestPointInClosestNode(terrainPicker, intersections, ray, cullBackFaces, mode, projection) {
|
|
2203
|
+
const sortedIntersections = intersections.sort(function(a, b) {
|
|
2204
|
+
return a.interval.start - b.interval.start;
|
|
2205
|
+
});
|
|
2206
|
+
let minT = Number.MAX_VALUE;
|
|
2207
|
+
for (let i = 0; i < sortedIntersections.length; i++) {
|
|
2208
|
+
const intersection = sortedIntersections[i];
|
|
2209
|
+
const intersectionResult = getClosestTriangleInNode(
|
|
2210
|
+
terrainPicker,
|
|
2211
|
+
ray,
|
|
2212
|
+
intersection.node,
|
|
2213
|
+
cullBackFaces,
|
|
2214
|
+
mode,
|
|
2215
|
+
projection
|
|
2216
|
+
);
|
|
2217
|
+
minT = Math.min(intersectionResult, minT);
|
|
2218
|
+
if (minT !== Number.MAX_VALUE) {
|
|
2219
|
+
break;
|
|
2220
|
+
}
|
|
2221
|
+
}
|
|
2222
|
+
if (minT !== Number.MAX_VALUE) {
|
|
2223
|
+
return Ray_default.getPoint(ray, minT);
|
|
2224
|
+
}
|
|
2225
|
+
return void 0;
|
|
2226
|
+
}
|
|
2227
|
+
function getClosestTriangleInNode(terrainPicker, ray, node, cullBackFaces, mode, projection) {
|
|
2228
|
+
let result = Number.MAX_VALUE;
|
|
2229
|
+
const encoding = terrainPicker._encoding;
|
|
2230
|
+
const indices = terrainPicker._indices;
|
|
2231
|
+
const vertices = terrainPicker._vertices;
|
|
2232
|
+
const triangleCount = node.intersectingTriangles.length;
|
|
2233
|
+
const isMaxLevel = node.level >= MAXIMUM_TERRAIN_PICKER_LEVEL;
|
|
2234
|
+
const shouldBuildChildren = !isMaxLevel && !node.buildingChildren;
|
|
2235
|
+
let trianglePositions;
|
|
2236
|
+
let triangleIndices;
|
|
2237
|
+
if (shouldBuildChildren) {
|
|
2238
|
+
trianglePositions = new Float64Array(triangleCount * 9);
|
|
2239
|
+
triangleIndices = new Uint32Array(triangleCount);
|
|
2240
|
+
}
|
|
2241
|
+
for (let i = 0; i < triangleCount; i++) {
|
|
2242
|
+
const triIndex = node.intersectingTriangles[i];
|
|
2243
|
+
const v0 = getVertexPosition(
|
|
2244
|
+
encoding,
|
|
2245
|
+
mode,
|
|
2246
|
+
projection,
|
|
2247
|
+
ray,
|
|
2248
|
+
vertices,
|
|
2249
|
+
indices[3 * triIndex],
|
|
2250
|
+
scratchTrianglePoints[0]
|
|
2251
|
+
);
|
|
2252
|
+
const v1 = getVertexPosition(
|
|
2253
|
+
encoding,
|
|
2254
|
+
mode,
|
|
2255
|
+
projection,
|
|
2256
|
+
ray,
|
|
2257
|
+
vertices,
|
|
2258
|
+
indices[3 * triIndex + 1],
|
|
2259
|
+
scratchTrianglePoints[1]
|
|
2260
|
+
);
|
|
2261
|
+
const v2 = getVertexPosition(
|
|
2262
|
+
encoding,
|
|
2263
|
+
mode,
|
|
2264
|
+
projection,
|
|
2265
|
+
ray,
|
|
2266
|
+
vertices,
|
|
2267
|
+
indices[3 * triIndex + 2],
|
|
2268
|
+
scratchTrianglePoints[2]
|
|
2269
|
+
);
|
|
2270
|
+
const triT = IntersectionTests_default.rayTriangleParametric(
|
|
2271
|
+
ray,
|
|
2272
|
+
v0,
|
|
2273
|
+
v1,
|
|
2274
|
+
v2,
|
|
2275
|
+
cullBackFaces
|
|
2276
|
+
);
|
|
2277
|
+
if (defined_default(triT) && triT < result && triT >= 0) {
|
|
2278
|
+
result = triT;
|
|
2279
|
+
}
|
|
2280
|
+
if (shouldBuildChildren) {
|
|
2281
|
+
packTriangleBuffers(
|
|
2282
|
+
trianglePositions,
|
|
2283
|
+
triangleIndices,
|
|
2284
|
+
scratchTrianglePoints,
|
|
2285
|
+
triIndex,
|
|
2286
|
+
i
|
|
2287
|
+
);
|
|
2288
|
+
}
|
|
2289
|
+
}
|
|
2290
|
+
if (shouldBuildChildren) {
|
|
2291
|
+
for (let childIdx = 0; childIdx < 4; childIdx++) {
|
|
2292
|
+
node.addChild(childIdx);
|
|
2293
|
+
}
|
|
2294
|
+
addTrianglesToChildrenNodes(
|
|
2295
|
+
terrainPicker._inverseTransform,
|
|
2296
|
+
node,
|
|
2297
|
+
triangleIndices,
|
|
2298
|
+
trianglePositions
|
|
2299
|
+
);
|
|
2300
|
+
}
|
|
2301
|
+
return result;
|
|
2302
|
+
}
|
|
2303
|
+
var scratchCartographic = new Cartographic_default();
|
|
2304
|
+
function getVertexPosition(encoding, mode, projection, ray, vertices, index, result) {
|
|
2305
|
+
let position = encoding.getExaggeratedPosition(vertices, index, result);
|
|
2306
|
+
if (mode === SceneMode_default.SCENE3D) {
|
|
2307
|
+
return position;
|
|
2308
|
+
}
|
|
2309
|
+
const ellipsoid = projection.ellipsoid;
|
|
2310
|
+
const positionCartographic = ellipsoid.cartesianToCartographic(
|
|
2311
|
+
position,
|
|
2312
|
+
scratchCartographic
|
|
2313
|
+
);
|
|
2314
|
+
position = projection.project(positionCartographic, result);
|
|
2315
|
+
position = Cartesian3_default.fromElements(
|
|
2316
|
+
position.z,
|
|
2317
|
+
position.x,
|
|
2318
|
+
position.y,
|
|
2319
|
+
result
|
|
2320
|
+
);
|
|
2321
|
+
const worldWidth = Math_default.TWO_PI * projection.ellipsoid.maximumRadius;
|
|
2322
|
+
const k = Math.round((ray.origin.y - position.y) / worldWidth);
|
|
2323
|
+
position.y += k * worldWidth;
|
|
2324
|
+
return position;
|
|
2325
|
+
}
|
|
2326
|
+
async function addTrianglesToChildrenNodes(inverseTransform, node, triangleIndices, trianglePositions) {
|
|
2327
|
+
node.buildingChildren = true;
|
|
2328
|
+
const inverseTransformPacked = new Float64Array(16);
|
|
2329
|
+
Matrix4_default.pack(inverseTransform, inverseTransformPacked, 0);
|
|
2330
|
+
const aabbArray = new Float64Array(6 * 4);
|
|
2331
|
+
for (let i = 0; i < 4; i++) {
|
|
2332
|
+
Cartesian3_default.pack(node.children[i].aabb.minimum, aabbArray, i * 6);
|
|
2333
|
+
Cartesian3_default.pack(node.children[i].aabb.maximum, aabbArray, i * 6 + 3);
|
|
2334
|
+
}
|
|
2335
|
+
const parameters = {
|
|
2336
|
+
aabbs: aabbArray,
|
|
2337
|
+
inverseTransform: inverseTransformPacked,
|
|
2338
|
+
triangleIndices,
|
|
2339
|
+
trianglePositions
|
|
2340
|
+
};
|
|
2341
|
+
const transferableObjects = [
|
|
2342
|
+
aabbArray.buffer,
|
|
2343
|
+
inverseTransformPacked.buffer,
|
|
2344
|
+
triangleIndices.buffer,
|
|
2345
|
+
trianglePositions.buffer
|
|
2346
|
+
];
|
|
2347
|
+
const incrementallyBuildTerrainPickerPromise = incrementallyBuildTerrainPickerTaskProcessor.scheduleTask(
|
|
2348
|
+
parameters,
|
|
2349
|
+
transferableObjects
|
|
2350
|
+
);
|
|
2351
|
+
if (!defined_default(incrementallyBuildTerrainPickerPromise)) {
|
|
2352
|
+
node.buildingChildren = false;
|
|
2353
|
+
return;
|
|
2354
|
+
}
|
|
2355
|
+
const result = await incrementallyBuildTerrainPickerPromise;
|
|
2356
|
+
result.intersectingTrianglesArrays.forEach((buffer, index) => {
|
|
2357
|
+
if (defined_default(node.children[index])) {
|
|
2358
|
+
node.children[index].intersectingTriangles = new Uint32Array(buffer);
|
|
2359
|
+
}
|
|
2360
|
+
});
|
|
2361
|
+
node.intersectingTriangles = new Uint32Array(0);
|
|
2362
|
+
node.buildingChildren = false;
|
|
2363
|
+
}
|
|
2364
|
+
var TerrainPicker_default = TerrainPicker;
|
|
2365
|
+
|
|
2366
|
+
// packages/engine/Source/Core/TerrainMesh.js
|
|
2367
|
+
function TerrainMesh(center, vertices, indices, indexCountWithoutSkirts, vertexCountWithoutSkirts, minimumHeight, maximumHeight, rectangle, boundingSphere3D, occludeePointInScaledSpace, vertexStride, orientedBoundingBox, encoding, westIndicesSouthToNorth, southIndicesEastToWest, eastIndicesNorthToSouth, northIndicesWestToEast) {
|
|
2368
|
+
this.center = center;
|
|
2369
|
+
this.vertices = vertices;
|
|
2370
|
+
this.stride = vertexStride ?? 6;
|
|
2371
|
+
this.indices = indices;
|
|
2372
|
+
this.indexCountWithoutSkirts = indexCountWithoutSkirts;
|
|
2373
|
+
this.vertexCountWithoutSkirts = vertexCountWithoutSkirts;
|
|
2374
|
+
this.minimumHeight = minimumHeight;
|
|
2375
|
+
this.maximumHeight = maximumHeight;
|
|
2376
|
+
this.rectangle = rectangle;
|
|
2377
|
+
this.boundingSphere3D = boundingSphere3D;
|
|
2378
|
+
this.occludeePointInScaledSpace = occludeePointInScaledSpace;
|
|
2379
|
+
this.orientedBoundingBox = orientedBoundingBox;
|
|
2380
|
+
this.encoding = encoding;
|
|
2381
|
+
this.westIndicesSouthToNorth = westIndicesSouthToNorth;
|
|
2382
|
+
this.southIndicesEastToWest = southIndicesEastToWest;
|
|
2383
|
+
this.eastIndicesNorthToSouth = eastIndicesNorthToSouth;
|
|
2384
|
+
this.northIndicesWestToEast = northIndicesWestToEast;
|
|
2385
|
+
this._transform = new Matrix4_default();
|
|
2386
|
+
this._lastPickSceneMode = void 0;
|
|
2387
|
+
this._terrainPicker = new TerrainPicker_default(vertices, indices, encoding);
|
|
2388
|
+
}
|
|
2389
|
+
TerrainMesh.prototype.getTransform = function(mode, projection) {
|
|
2390
|
+
if (this._lastPickSceneMode === mode) {
|
|
2391
|
+
return this._transform;
|
|
2392
|
+
}
|
|
2393
|
+
this._terrainPicker.needsRebuild = true;
|
|
2394
|
+
if (!defined_default(mode) || mode === SceneMode_default.SCENE3D) {
|
|
2395
|
+
return computeTransform(this, this._transform);
|
|
2396
|
+
}
|
|
2397
|
+
return computeTransform2D(this, projection, this._transform);
|
|
2398
|
+
};
|
|
2399
|
+
function computeTransform(mesh, result) {
|
|
2400
|
+
const exaggeration = mesh.encoding.exaggeration;
|
|
2401
|
+
const exaggerationRelativeHeight = mesh.encoding.exaggerationRelativeHeight;
|
|
2402
|
+
const exaggeratedMinHeight = VerticalExaggeration_default.getHeight(
|
|
2403
|
+
mesh.minimumHeight,
|
|
2404
|
+
exaggeration,
|
|
2405
|
+
exaggerationRelativeHeight
|
|
2406
|
+
);
|
|
2407
|
+
const exaggeratedMaxHeight = VerticalExaggeration_default.getHeight(
|
|
2408
|
+
mesh.maximumHeight,
|
|
2409
|
+
exaggeration,
|
|
2410
|
+
exaggerationRelativeHeight
|
|
2411
|
+
);
|
|
2412
|
+
const obb = OrientedBoundingBox_default.fromRectangle(
|
|
2413
|
+
mesh.rectangle,
|
|
2414
|
+
exaggeratedMinHeight,
|
|
2415
|
+
exaggeratedMaxHeight,
|
|
2416
|
+
Ellipsoid_default.default,
|
|
2417
|
+
mesh.orientedBoundingBox
|
|
2418
|
+
);
|
|
2419
|
+
OrientedBoundingBox_default.computeTransformation(obb, result);
|
|
2420
|
+
const zScale = Matrix4_default.getScale(result, scratchScale).z;
|
|
2421
|
+
if (zScale <= Math_default.EPSILON16) {
|
|
2422
|
+
scratchScale.z = 1;
|
|
2423
|
+
Matrix4_default.setScale(result, scratchScale, result);
|
|
2424
|
+
}
|
|
2425
|
+
return result;
|
|
2426
|
+
}
|
|
2427
|
+
var scratchSWCartesian = new Cartesian3_default();
|
|
2428
|
+
var scratchNECartesian = new Cartesian3_default();
|
|
2429
|
+
var scratchSWCartographic = new Cartographic_default();
|
|
2430
|
+
var scratchNECartographic = new Cartographic_default();
|
|
2431
|
+
var scratchScale2D = new Cartesian3_default();
|
|
2432
|
+
var scratchCenter2D = new Cartesian3_default();
|
|
2433
|
+
var scratchScale = new Cartesian3_default();
|
|
2434
|
+
function computeTransform2D(mesh, projection, result) {
|
|
2435
|
+
const exaggeration = mesh.encoding.exaggeration;
|
|
2436
|
+
const exaggerationRelativeHeight = mesh.encoding.exaggerationRelativeHeight;
|
|
2437
|
+
const exaggeratedMinHeight = VerticalExaggeration_default.getHeight(
|
|
2438
|
+
mesh.minimumHeight,
|
|
2439
|
+
exaggeration,
|
|
2440
|
+
exaggerationRelativeHeight
|
|
2441
|
+
);
|
|
2442
|
+
const exaggeratedMaxHeight = VerticalExaggeration_default.getHeight(
|
|
2443
|
+
mesh.maximumHeight,
|
|
2444
|
+
exaggeration,
|
|
2445
|
+
exaggerationRelativeHeight
|
|
2446
|
+
);
|
|
2447
|
+
const southwest = projection.project(
|
|
2448
|
+
Cartographic_default.fromRadians(
|
|
2449
|
+
mesh.rectangle.west,
|
|
2450
|
+
mesh.rectangle.south,
|
|
2451
|
+
0,
|
|
2452
|
+
scratchSWCartographic
|
|
2453
|
+
),
|
|
2454
|
+
scratchSWCartesian
|
|
2455
|
+
);
|
|
2456
|
+
const northeast = projection.project(
|
|
2457
|
+
Cartographic_default.fromRadians(
|
|
2458
|
+
mesh.rectangle.east,
|
|
2459
|
+
mesh.rectangle.north,
|
|
2460
|
+
0,
|
|
2461
|
+
scratchNECartographic
|
|
2462
|
+
),
|
|
2463
|
+
scratchNECartesian
|
|
2464
|
+
);
|
|
2465
|
+
const heightRange = exaggeratedMaxHeight - exaggeratedMinHeight;
|
|
2466
|
+
const scale = Cartesian3_default.fromElements(
|
|
2467
|
+
northeast.x - southwest.x,
|
|
2468
|
+
northeast.y - southwest.y,
|
|
2469
|
+
heightRange > 0 ? heightRange : 1,
|
|
2470
|
+
// Avoid zero scale
|
|
2471
|
+
scratchScale2D
|
|
2472
|
+
);
|
|
2473
|
+
const center = Cartesian3_default.fromElements(
|
|
2474
|
+
southwest.x + scale.x * 0.5,
|
|
2475
|
+
southwest.y + scale.y * 0.5,
|
|
2476
|
+
exaggeratedMinHeight + scale.z * 0.5,
|
|
2477
|
+
scratchCenter2D
|
|
2478
|
+
);
|
|
2479
|
+
Matrix4_default.fromTranslation(center, result);
|
|
2480
|
+
Matrix4_default.setScale(result, scale, result);
|
|
2481
|
+
Matrix4_default.multiply(Transforms_default.SWIZZLE_3D_TO_2D_MATRIX, result, result);
|
|
2482
|
+
return result;
|
|
2483
|
+
}
|
|
2484
|
+
TerrainMesh.prototype.pick = function(ray, cullBackFaces, mode, projection) {
|
|
2485
|
+
const intersection = this._terrainPicker.rayIntersect(
|
|
2486
|
+
ray,
|
|
2487
|
+
this.getTransform(mode, projection),
|
|
2488
|
+
cullBackFaces,
|
|
2489
|
+
mode,
|
|
2490
|
+
projection
|
|
2491
|
+
);
|
|
2492
|
+
this._lastPickSceneMode = mode;
|
|
2493
|
+
return intersection;
|
|
2494
|
+
};
|
|
2495
|
+
TerrainMesh.prototype.updateExaggeration = function(exaggeration, exaggerationRelativeHeight) {
|
|
2496
|
+
this._terrainPicker._vertices = this.vertices;
|
|
2497
|
+
this._terrainPicker.needsRebuild = true;
|
|
2498
|
+
this._lastPickSceneMode = void 0;
|
|
2499
|
+
};
|
|
2500
|
+
TerrainMesh.prototype.updateSceneMode = function(mode) {
|
|
2501
|
+
this._terrainPicker.needsRebuild = true;
|
|
2502
|
+
this._lastPickSceneMode = void 0;
|
|
2503
|
+
};
|
|
2504
|
+
var TerrainMesh_default = TerrainMesh;
|
|
2505
|
+
|
|
2506
|
+
// packages/engine/Source/Core/Cesium3DTilesTerrainGeometryProcessor.js
|
|
2507
|
+
var Cesium3DTilesTerrainGeometryProcessor = {};
|
|
2508
|
+
var scratchGltfInfo = {
|
|
2509
|
+
positions: void 0,
|
|
2510
|
+
normals: void 0,
|
|
2511
|
+
indices: void 0,
|
|
2512
|
+
edgeIndicesWest: void 0,
|
|
2513
|
+
edgeIndicesSouth: void 0,
|
|
2514
|
+
edgeIndicesEast: void 0,
|
|
2515
|
+
edgeIndicesNorth: void 0
|
|
2516
|
+
};
|
|
2517
|
+
var scratchCenterCartographic = new Cartographic_default();
|
|
2518
|
+
var scratchCenterCartesian = new Cartesian3_default();
|
|
2519
|
+
var scratchEnuToEcef = new Matrix4_default();
|
|
2520
|
+
var scratchEcefToEnu = new Matrix4_default();
|
|
2521
|
+
var scratchTilesetTransform = new Matrix4_default();
|
|
2522
|
+
var scratchMinimumPositionENU = new Cartesian3_default();
|
|
2523
|
+
var scratchMaximumPositionENU = new Cartesian3_default();
|
|
2524
|
+
var scratchPosLocal = new Cartesian3_default();
|
|
2525
|
+
var scratchPosEcef = new Cartesian3_default();
|
|
2526
|
+
var scratchCartographic2 = new Cartographic_default();
|
|
2527
|
+
var scratchUV = new Cartesian2_default();
|
|
2528
|
+
var scratchNormal = new Cartesian3_default();
|
|
2529
|
+
var scratchNormalOct = new Cartesian2_default();
|
|
2530
|
+
var scratchGeodeticSurfaceNormal = new Cartesian3_default();
|
|
2531
|
+
var scratchPosEnu = new Cartesian3_default();
|
|
2532
|
+
var sortedEdgeCompare = function(a, b) {
|
|
2533
|
+
return a - b;
|
|
2534
|
+
};
|
|
2535
|
+
Cesium3DTilesTerrainGeometryProcessor.createMesh = async function(options) {
|
|
2536
|
+
options = options ?? Frozen_default.EMPTY_OBJECT;
|
|
2537
|
+
const {
|
|
2538
|
+
exaggeration = 1,
|
|
2539
|
+
exaggerationRelativeHeight = 0,
|
|
2540
|
+
hasVertexNormals,
|
|
2541
|
+
hasWebMercatorT,
|
|
2542
|
+
gltf,
|
|
2543
|
+
minimumHeight,
|
|
2544
|
+
maximumHeight,
|
|
2545
|
+
skirtHeight
|
|
2546
|
+
} = options;
|
|
2547
|
+
Check_default.typeOf.object("options.ellipsoid", options.ellipsoid);
|
|
2548
|
+
Check_default.typeOf.object("options.rectangle", options.rectangle);
|
|
2549
|
+
Check_default.typeOf.bool("options.hasVertexNormals", hasVertexNormals);
|
|
2550
|
+
Check_default.typeOf.bool("options.hasWebMercatorT", hasWebMercatorT);
|
|
2551
|
+
Check_default.typeOf.object("options.gltf", gltf);
|
|
2552
|
+
Check_default.typeOf.number("options.minimumHeight", minimumHeight);
|
|
2553
|
+
Check_default.typeOf.number("options.maximumHeight", maximumHeight);
|
|
2554
|
+
Check_default.typeOf.object("options.boundingSphere", options.boundingSphere);
|
|
2555
|
+
Check_default.typeOf.object(
|
|
2556
|
+
"options.orientedBoundingBox",
|
|
2557
|
+
options.orientedBoundingBox
|
|
2558
|
+
);
|
|
2559
|
+
Check_default.typeOf.object(
|
|
2560
|
+
"options.horizonOcclusionPoint",
|
|
2561
|
+
options.horizonOcclusionPoint
|
|
2562
|
+
);
|
|
2563
|
+
Check_default.typeOf.number("options.skirtHeight", skirtHeight);
|
|
2564
|
+
const hasExaggeration = exaggeration !== 1;
|
|
2565
|
+
const hasGeodeticSurfaceNormals = hasExaggeration;
|
|
2566
|
+
const boundingSphere = BoundingSphere_default.clone(
|
|
2567
|
+
options.boundingSphere,
|
|
2568
|
+
new BoundingSphere_default()
|
|
2569
|
+
);
|
|
2570
|
+
const orientedBoundingBox = OrientedBoundingBox_default.clone(
|
|
2571
|
+
options.orientedBoundingBox,
|
|
2572
|
+
new OrientedBoundingBox_default()
|
|
2573
|
+
);
|
|
2574
|
+
const horizonOcclusionPoint = Cartesian3_default.clone(
|
|
2575
|
+
options.horizonOcclusionPoint,
|
|
2576
|
+
new Cartesian3_default()
|
|
2577
|
+
);
|
|
2578
|
+
const ellipsoid = Ellipsoid_default.clone(options.ellipsoid, new Ellipsoid_default());
|
|
2579
|
+
const rectangle = Rectangle_default.clone(options.rectangle, new Rectangle_default());
|
|
2580
|
+
const hasMeshOptCompression = gltf.extensionsRequired !== void 0 && gltf.extensionsRequired.indexOf("EXT_meshopt_compression") !== -1;
|
|
2581
|
+
const decoderPromise = hasMeshOptCompression ? MeshoptDecoder.ready : Promise.resolve(void 0);
|
|
2582
|
+
await decoderPromise;
|
|
2583
|
+
const tileMinLongitude = rectangle.west;
|
|
2584
|
+
const tileMinLatitude = rectangle.south;
|
|
2585
|
+
const tileMaxLatitude = rectangle.north;
|
|
2586
|
+
const tileLengthLongitude = rectangle.width;
|
|
2587
|
+
const tileLengthLatitude = rectangle.height;
|
|
2588
|
+
const approximateCenterCartographic = Rectangle_default.center(
|
|
2589
|
+
rectangle,
|
|
2590
|
+
scratchCenterCartographic
|
|
2591
|
+
);
|
|
2592
|
+
approximateCenterCartographic.height = 0.5 * (minimumHeight + maximumHeight);
|
|
2593
|
+
const approximateCenterPosition = Cartographic_default.toCartesian(
|
|
2594
|
+
approximateCenterCartographic,
|
|
2595
|
+
ellipsoid,
|
|
2596
|
+
scratchCenterCartesian
|
|
2597
|
+
);
|
|
2598
|
+
const enuToEcef = Transforms_default.eastNorthUpToFixedFrame(
|
|
2599
|
+
approximateCenterPosition,
|
|
2600
|
+
ellipsoid,
|
|
2601
|
+
scratchEnuToEcef
|
|
2602
|
+
);
|
|
2603
|
+
const ecefToEnu = Matrix4_default.inverseTransformation(enuToEcef, scratchEcefToEnu);
|
|
2604
|
+
let tilesetTransform = Matrix4_default.unpack(
|
|
2605
|
+
gltf.nodes[0].matrix,
|
|
2606
|
+
0,
|
|
2607
|
+
scratchTilesetTransform
|
|
2608
|
+
);
|
|
2609
|
+
tilesetTransform = Matrix4_default.multiply(
|
|
2610
|
+
Axis_default.Y_UP_TO_Z_UP,
|
|
2611
|
+
tilesetTransform,
|
|
2612
|
+
tilesetTransform
|
|
2613
|
+
);
|
|
2614
|
+
const gltfInfo = decodeGltf(gltf, hasVertexNormals, scratchGltfInfo);
|
|
2615
|
+
const skirtVertexCount = TerrainProvider_default.getSkirtVertexCount(
|
|
2616
|
+
gltfInfo.edgeIndicesWest,
|
|
2617
|
+
gltfInfo.edgeIndicesSouth,
|
|
2618
|
+
gltfInfo.edgeIndicesEast,
|
|
2619
|
+
gltfInfo.edgeIndicesNorth
|
|
2620
|
+
);
|
|
2621
|
+
const positionsLocalWithoutSkirts = gltfInfo.positions;
|
|
2622
|
+
const normalsWithoutSkirts = gltfInfo.normals;
|
|
2623
|
+
const indicesWithoutSkirts = gltfInfo.indices;
|
|
2624
|
+
const vertexCountWithoutSkirts = positionsLocalWithoutSkirts.length / 3;
|
|
2625
|
+
const vertexCountWithSkirts = vertexCountWithoutSkirts + skirtVertexCount;
|
|
2626
|
+
const indexCountWithoutSkirts = indicesWithoutSkirts.length;
|
|
2627
|
+
const skirtIndexCount = TerrainProvider_default.getSkirtIndexCountWithFilledCorners(skirtVertexCount);
|
|
2628
|
+
const SizedIndexTypeWithSkirts = vertexCountWithSkirts <= 65535 ? Uint16Array : Uint32Array;
|
|
2629
|
+
const indexBufferWithSkirts = new SizedIndexTypeWithSkirts(
|
|
2630
|
+
indexCountWithoutSkirts + skirtIndexCount
|
|
2631
|
+
);
|
|
2632
|
+
indexBufferWithSkirts.set(indicesWithoutSkirts);
|
|
2633
|
+
const westIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesWest);
|
|
2634
|
+
const southIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesSouth);
|
|
2635
|
+
const eastIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesEast);
|
|
2636
|
+
const northIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesNorth);
|
|
2637
|
+
const sortedWestIndices = new SizedIndexTypeWithSkirts(westIndices).sort();
|
|
2638
|
+
const sortedSouthIndices = new SizedIndexTypeWithSkirts(southIndices).sort();
|
|
2639
|
+
const sortedEastIndices = new SizedIndexTypeWithSkirts(eastIndices).sort();
|
|
2640
|
+
const sortedNorthIndices = new SizedIndexTypeWithSkirts(northIndices).sort();
|
|
2641
|
+
const southMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(tileMinLatitude);
|
|
2642
|
+
const northMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(tileMaxLatitude);
|
|
2643
|
+
const oneOverMercatorHeight = 1 / (northMercatorAngle - southMercatorAngle);
|
|
2644
|
+
let minPosEnu = Cartesian3_default.fromElements(
|
|
2645
|
+
Number.POSITIVE_INFINITY,
|
|
2646
|
+
Number.POSITIVE_INFINITY,
|
|
2647
|
+
Number.POSITIVE_INFINITY,
|
|
2648
|
+
scratchMinimumPositionENU
|
|
2649
|
+
);
|
|
2650
|
+
let maxPosEnu = Cartesian3_default.fromElements(
|
|
2651
|
+
Number.NEGATIVE_INFINITY,
|
|
2652
|
+
Number.NEGATIVE_INFINITY,
|
|
2653
|
+
Number.NEGATIVE_INFINITY,
|
|
2654
|
+
scratchMaximumPositionENU
|
|
2655
|
+
);
|
|
2656
|
+
const tempTerrainEncoding = new TerrainEncoding_default(
|
|
2657
|
+
boundingSphere.center,
|
|
2658
|
+
void 0,
|
|
2659
|
+
void 0,
|
|
2660
|
+
void 0,
|
|
2661
|
+
void 0,
|
|
2662
|
+
hasVertexNormals,
|
|
2663
|
+
hasWebMercatorT,
|
|
2664
|
+
hasGeodeticSurfaceNormals,
|
|
2665
|
+
exaggeration,
|
|
2666
|
+
exaggerationRelativeHeight
|
|
2667
|
+
);
|
|
2668
|
+
const tempBufferStride = tempTerrainEncoding.stride;
|
|
2669
|
+
const tempBuffer = new Float32Array(vertexCountWithSkirts * tempBufferStride);
|
|
2670
|
+
let tempBufferOffset = 0;
|
|
2671
|
+
for (let i = 0; i < vertexCountWithoutSkirts; i++) {
|
|
2672
|
+
const posLocal = Cartesian3_default.unpack(
|
|
2673
|
+
positionsLocalWithoutSkirts,
|
|
2674
|
+
i * 3,
|
|
2675
|
+
scratchPosLocal
|
|
2676
|
+
);
|
|
2677
|
+
const posECEF = Matrix4_default.multiplyByPoint(
|
|
2678
|
+
tilesetTransform,
|
|
2679
|
+
posLocal,
|
|
2680
|
+
scratchPosEcef
|
|
2681
|
+
);
|
|
2682
|
+
const cartographic = Cartographic_default.fromCartesian(
|
|
2683
|
+
posECEF,
|
|
2684
|
+
ellipsoid,
|
|
2685
|
+
scratchCartographic2
|
|
2686
|
+
);
|
|
2687
|
+
const { longitude, latitude, height } = cartographic;
|
|
2688
|
+
let u = (longitude - tileMinLongitude) / tileLengthLongitude;
|
|
2689
|
+
let v = (latitude - tileMinLatitude) / tileLengthLatitude;
|
|
2690
|
+
u = Math_default.clamp(u, 0, 1);
|
|
2691
|
+
v = Math_default.clamp(v, 0, 1);
|
|
2692
|
+
if (binarySearch_default(sortedWestIndices, i, sortedEdgeCompare) >= 0) {
|
|
2693
|
+
u = 0;
|
|
2694
|
+
} else if (binarySearch_default(sortedEastIndices, i, sortedEdgeCompare) >= 0) {
|
|
2695
|
+
u = 1;
|
|
2696
|
+
}
|
|
2697
|
+
if (binarySearch_default(sortedSouthIndices, i, sortedEdgeCompare) >= 0) {
|
|
2698
|
+
v = 0;
|
|
2699
|
+
} else if (binarySearch_default(sortedNorthIndices, i, sortedEdgeCompare) >= 0) {
|
|
2700
|
+
v = 1;
|
|
2701
|
+
}
|
|
2702
|
+
const uv = Cartesian2_default.fromElements(u, v, scratchUV);
|
|
2703
|
+
let normalOct;
|
|
2704
|
+
if (hasVertexNormals) {
|
|
2705
|
+
let normal = Cartesian3_default.unpack(
|
|
2706
|
+
normalsWithoutSkirts,
|
|
2707
|
+
i * 3,
|
|
2708
|
+
scratchNormal
|
|
2709
|
+
);
|
|
2710
|
+
normal = Matrix4_default.multiplyByPointAsVector(
|
|
2711
|
+
tilesetTransform,
|
|
2712
|
+
normal,
|
|
2713
|
+
scratchNormal
|
|
2714
|
+
);
|
|
2715
|
+
normal = Cartesian3_default.normalize(normal, scratchNormal);
|
|
2716
|
+
normalOct = AttributeCompression_default.octEncode(normal, scratchNormalOct);
|
|
2717
|
+
}
|
|
2718
|
+
let webMercatorT;
|
|
2719
|
+
if (hasWebMercatorT) {
|
|
2720
|
+
const mercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(latitude);
|
|
2721
|
+
webMercatorT = (mercatorAngle - southMercatorAngle) * oneOverMercatorHeight;
|
|
2722
|
+
}
|
|
2723
|
+
let geodeticSurfaceNormal;
|
|
2724
|
+
if (hasGeodeticSurfaceNormals) {
|
|
2725
|
+
geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
|
|
2726
|
+
posECEF,
|
|
2727
|
+
scratchGeodeticSurfaceNormal
|
|
2728
|
+
);
|
|
2729
|
+
}
|
|
2730
|
+
tempBufferOffset = tempTerrainEncoding.encode(
|
|
2731
|
+
tempBuffer,
|
|
2732
|
+
tempBufferOffset,
|
|
2733
|
+
posECEF,
|
|
2734
|
+
uv,
|
|
2735
|
+
height,
|
|
2736
|
+
normalOct,
|
|
2737
|
+
webMercatorT,
|
|
2738
|
+
geodeticSurfaceNormal
|
|
2739
|
+
);
|
|
2740
|
+
const posEnu = Matrix4_default.multiplyByPoint(ecefToEnu, posECEF, scratchPosEnu);
|
|
2741
|
+
minPosEnu = Cartesian3_default.minimumByComponent(posEnu, minPosEnu, minPosEnu);
|
|
2742
|
+
maxPosEnu = Cartesian3_default.maximumByComponent(posEnu, maxPosEnu, maxPosEnu);
|
|
2743
|
+
}
|
|
2744
|
+
const mesh = new TerrainMesh_default(
|
|
2745
|
+
Cartesian3_default.clone(tempTerrainEncoding.center, new Cartesian3_default()),
|
|
2746
|
+
tempBuffer,
|
|
2747
|
+
indexBufferWithSkirts,
|
|
2748
|
+
indexCountWithoutSkirts,
|
|
2749
|
+
vertexCountWithoutSkirts,
|
|
2750
|
+
minimumHeight,
|
|
2751
|
+
maximumHeight,
|
|
2752
|
+
rectangle,
|
|
2753
|
+
BoundingSphere_default.clone(boundingSphere, new BoundingSphere_default()),
|
|
2754
|
+
Cartesian3_default.clone(horizonOcclusionPoint, new Cartesian3_default()),
|
|
2755
|
+
tempBufferStride,
|
|
2756
|
+
OrientedBoundingBox_default.clone(orientedBoundingBox, new OrientedBoundingBox_default()),
|
|
2757
|
+
tempTerrainEncoding,
|
|
2758
|
+
westIndices,
|
|
2759
|
+
southIndices,
|
|
2760
|
+
eastIndices,
|
|
2761
|
+
northIndices
|
|
2762
|
+
);
|
|
2763
|
+
addSkirtsToMesh(
|
|
2764
|
+
mesh,
|
|
2765
|
+
rectangle,
|
|
2766
|
+
ellipsoid,
|
|
2767
|
+
minPosEnu,
|
|
2768
|
+
maxPosEnu,
|
|
2769
|
+
enuToEcef,
|
|
2770
|
+
ecefToEnu,
|
|
2771
|
+
skirtHeight
|
|
2772
|
+
);
|
|
2773
|
+
return Promise.resolve(mesh);
|
|
2774
|
+
};
|
|
2775
|
+
var scratchMinUV = new Cartesian2_default();
|
|
2776
|
+
var scratchMaxUV = new Cartesian2_default();
|
|
2777
|
+
var scratchPolygonIndices = new Array(6);
|
|
2778
|
+
var scratchUvA = new Cartesian2_default();
|
|
2779
|
+
var scratchUvB = new Cartesian2_default();
|
|
2780
|
+
var scratchUvC = new Cartesian2_default();
|
|
2781
|
+
var scratchNormalA = new Cartesian3_default();
|
|
2782
|
+
var scratchNormalB = new Cartesian3_default();
|
|
2783
|
+
var scratchNormalC = new Cartesian3_default();
|
|
2784
|
+
var scratchCenterCartographicUpsample = new Cartographic_default();
|
|
2785
|
+
var scratchCenterCartesianUpsample = new Cartesian3_default();
|
|
2786
|
+
var scratchCartographicSkirt = new Cartographic_default();
|
|
2787
|
+
var scratchCartographicUpsample = new Cartographic_default();
|
|
2788
|
+
var scratchPosEcefSkirt = new Cartesian3_default();
|
|
2789
|
+
var scratchPosEcefUpsample = new Cartesian3_default();
|
|
2790
|
+
var scratchPosEnuSkirt = new Cartesian3_default();
|
|
2791
|
+
var scratchPosEnuUpsample = new Cartesian3_default();
|
|
2792
|
+
var scratchMinimumPositionENUSkirt = new Cartesian3_default();
|
|
2793
|
+
var scratchMaximumPositionENUSkirt = new Cartesian3_default();
|
|
2794
|
+
var scratchMinimumPositionENUUpsample = new Cartesian3_default();
|
|
2795
|
+
var scratchMaximumPositionENUUpsample = new Cartesian3_default();
|
|
2796
|
+
var scratchEnuToEcefUpsample = new Matrix4_default();
|
|
2797
|
+
var scratchEcefToEnuUpsample = new Matrix4_default();
|
|
2798
|
+
var scratchUVSkirt = new Cartesian2_default();
|
|
2799
|
+
var scratchUVUpsample = new Cartesian2_default();
|
|
2800
|
+
var scratchHorizonOcclusionPoint = new Cartesian3_default();
|
|
2801
|
+
var scratchBoundingSphere = new BoundingSphere_default();
|
|
2802
|
+
var scratchOrientedBoundingBox = new OrientedBoundingBox_default();
|
|
2803
|
+
var scratchAABBEnuSkirt = new AxisAlignedBoundingBox_default();
|
|
2804
|
+
var scratchNormalUpsample = new Cartesian3_default();
|
|
2805
|
+
var scratchNormalOctSkirt = new Cartesian2_default();
|
|
2806
|
+
var scratchNormalOctUpsample = new Cartesian2_default();
|
|
2807
|
+
var scratchGeodeticSurfaceNormalSkirt = new Cartesian3_default();
|
|
2808
|
+
var scratchGeodeticSurfaceNormalUpsample = new Cartesian3_default();
|
|
2809
|
+
function decodePositions(gltf) {
|
|
2810
|
+
const primitive = gltf.meshes[0].primitives[0];
|
|
2811
|
+
const accessor = gltf.accessors[primitive.attributes["POSITION"]];
|
|
2812
|
+
const bufferView = gltf.bufferViews[accessor.bufferView];
|
|
2813
|
+
const positionCount = accessor.count;
|
|
2814
|
+
const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
|
|
2815
|
+
if (bufferViewMeshOpt === void 0) {
|
|
2816
|
+
const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
|
|
2817
|
+
return new Float32Array(
|
|
2818
|
+
buffer2.buffer,
|
|
2819
|
+
buffer2.byteOffset + // offset from the start of the glb
|
|
2820
|
+
(bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2821
|
+
positionCount * 3
|
|
2822
|
+
);
|
|
2823
|
+
}
|
|
2824
|
+
const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
|
|
2825
|
+
const compressedBuffer = new Uint8Array(
|
|
2826
|
+
buffer.buffer,
|
|
2827
|
+
buffer.byteOffset + // offset from the start of the glb
|
|
2828
|
+
(bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2829
|
+
bufferViewMeshOpt.byteLength
|
|
2830
|
+
);
|
|
2831
|
+
const positionByteLength = bufferViewMeshOpt.byteStride;
|
|
2832
|
+
const PositionType = positionByteLength === 4 ? Uint8Array : Uint16Array;
|
|
2833
|
+
const positionsResult = new PositionType(positionCount * 4);
|
|
2834
|
+
MeshoptDecoder.decodeVertexBuffer(
|
|
2835
|
+
new Uint8Array(positionsResult.buffer),
|
|
2836
|
+
positionCount,
|
|
2837
|
+
positionByteLength,
|
|
2838
|
+
compressedBuffer
|
|
2839
|
+
);
|
|
2840
|
+
const positionStorageValueMax = (1 << positionsResult.BYTES_PER_ELEMENT * 8) - 1;
|
|
2841
|
+
const positions = new Float32Array(positionCount * 3);
|
|
2842
|
+
for (let p = 0; p < positionCount; p++) {
|
|
2843
|
+
positions[p * 3 + 0] = positionsResult[p * 4 + 0] / positionStorageValueMax;
|
|
2844
|
+
positions[p * 3 + 1] = positionsResult[p * 4 + 1] / positionStorageValueMax;
|
|
2845
|
+
positions[p * 3 + 2] = positionsResult[p * 4 + 2] / positionStorageValueMax;
|
|
2846
|
+
}
|
|
2847
|
+
return positions;
|
|
2848
|
+
}
|
|
2849
|
+
function decodeNormals(gltf) {
|
|
2850
|
+
const primitive = gltf.meshes[0].primitives[0];
|
|
2851
|
+
const accessor = gltf.accessors[primitive.attributes["NORMAL"]];
|
|
2852
|
+
const bufferView = gltf.bufferViews[accessor.bufferView];
|
|
2853
|
+
const normalCount = accessor.count;
|
|
2854
|
+
const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
|
|
2855
|
+
if (bufferViewMeshOpt === void 0) {
|
|
2856
|
+
const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
|
|
2857
|
+
return new Float32Array(
|
|
2858
|
+
buffer2.buffer,
|
|
2859
|
+
buffer2.byteOffset + // offset from the start of the glb
|
|
2860
|
+
(bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2861
|
+
normalCount * 3
|
|
2862
|
+
);
|
|
2863
|
+
}
|
|
2864
|
+
const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
|
|
2865
|
+
const compressedBuffer = new Uint8Array(
|
|
2866
|
+
buffer.buffer,
|
|
2867
|
+
buffer.byteOffset + // offset from the start of the glb
|
|
2868
|
+
(bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2869
|
+
bufferViewMeshOpt.byteLength
|
|
2870
|
+
);
|
|
2871
|
+
const normalByteLength = bufferViewMeshOpt.byteStride;
|
|
2872
|
+
const normalsResult = new Int8Array(normalCount * normalByteLength);
|
|
2873
|
+
MeshoptDecoder.decodeVertexBuffer(
|
|
2874
|
+
new Uint8Array(normalsResult.buffer),
|
|
2875
|
+
normalCount,
|
|
2876
|
+
normalByteLength,
|
|
2877
|
+
compressedBuffer
|
|
2878
|
+
);
|
|
2879
|
+
const normals = new Float32Array(normalCount * 3);
|
|
2880
|
+
for (let i = 0; i < normalCount; i++) {
|
|
2881
|
+
let octX = Math.max(normalsResult[i * 4 + 0] / 127, -1);
|
|
2882
|
+
let octY = Math.max(normalsResult[i * 4 + 1] / 127, -1);
|
|
2883
|
+
const octZ = 1 - (Math.abs(octX) + Math.abs(octY));
|
|
2884
|
+
if (octZ < 0) {
|
|
2885
|
+
const oldX = octX;
|
|
2886
|
+
const oldY = octY;
|
|
2887
|
+
octX = (1 - Math.abs(oldY)) * Math_default.signNotZero(oldX);
|
|
2888
|
+
octY = (1 - Math.abs(oldX)) * Math_default.signNotZero(oldY);
|
|
2889
|
+
}
|
|
2890
|
+
let normal = scratchNormal;
|
|
2891
|
+
normal.x = octX;
|
|
2892
|
+
normal.y = octY;
|
|
2893
|
+
normal.z = octZ;
|
|
2894
|
+
normal = Cartesian3_default.normalize(normal, scratchNormal);
|
|
2895
|
+
normals[i * 3 + 0] = normal.x;
|
|
2896
|
+
normals[i * 3 + 1] = normal.y;
|
|
2897
|
+
normals[i * 3 + 2] = normal.z;
|
|
2898
|
+
}
|
|
2899
|
+
return normals;
|
|
2900
|
+
}
|
|
2901
|
+
function decodeIndices(gltf) {
|
|
2902
|
+
const primitive = gltf.meshes[0].primitives[0];
|
|
2903
|
+
const accessor = gltf.accessors[primitive.indices];
|
|
2904
|
+
const bufferView = gltf.bufferViews[accessor.bufferView];
|
|
2905
|
+
const indexCount = accessor.count;
|
|
2906
|
+
const SizedIndexType = accessor.componentType === ComponentDatatype_default.UNSIGNED_SHORT ? Uint16Array : Uint32Array;
|
|
2907
|
+
const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
|
|
2908
|
+
if (bufferViewMeshOpt === void 0) {
|
|
2909
|
+
const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
|
|
2910
|
+
return new SizedIndexType(
|
|
2911
|
+
buffer2.buffer,
|
|
2912
|
+
buffer2.byteOffset + // offset from the glb
|
|
2913
|
+
(bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2914
|
+
indexCount
|
|
2915
|
+
);
|
|
2916
|
+
}
|
|
2917
|
+
const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
|
|
2918
|
+
const compressedBuffer = new Uint8Array(
|
|
2919
|
+
buffer.buffer,
|
|
2920
|
+
buffer.byteOffset + // offset from the start of the glb
|
|
2921
|
+
(bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2922
|
+
bufferViewMeshOpt.byteLength
|
|
2923
|
+
);
|
|
2924
|
+
const indices = new SizedIndexType(indexCount);
|
|
2925
|
+
MeshoptDecoder.decodeIndexBuffer(
|
|
2926
|
+
new Uint8Array(indices.buffer),
|
|
2927
|
+
indexCount,
|
|
2928
|
+
bufferViewMeshOpt.byteStride,
|
|
2929
|
+
compressedBuffer
|
|
2930
|
+
);
|
|
2931
|
+
return indices;
|
|
2932
|
+
}
|
|
2933
|
+
function decodeEdgeIndices(gltf, name) {
|
|
2934
|
+
const primitive = gltf.meshes[0].primitives[0];
|
|
2935
|
+
const accessor = gltf.accessors[primitive.extensions.CESIUM_tile_edges[name]];
|
|
2936
|
+
const bufferView = gltf.bufferViews[accessor.bufferView];
|
|
2937
|
+
const indexCount = accessor.count;
|
|
2938
|
+
const SizedIndexType = accessor.componentType === ComponentDatatype_default.UNSIGNED_SHORT ? Uint16Array : Uint32Array;
|
|
2939
|
+
const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
|
|
2940
|
+
if (bufferViewMeshOpt === void 0) {
|
|
2941
|
+
const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
|
|
2942
|
+
return new SizedIndexType(
|
|
2943
|
+
buffer2.buffer,
|
|
2944
|
+
buffer2.byteOffset + // offset from the glb
|
|
2945
|
+
(bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2946
|
+
indexCount
|
|
2947
|
+
);
|
|
2948
|
+
}
|
|
2949
|
+
const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
|
|
2950
|
+
const compressedBuffer = new Uint8Array(
|
|
2951
|
+
buffer.buffer,
|
|
2952
|
+
buffer.byteOffset + // offset from the start of the glb
|
|
2953
|
+
(bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
|
|
2954
|
+
bufferViewMeshOpt.byteLength
|
|
2955
|
+
);
|
|
2956
|
+
const indices = new SizedIndexType(indexCount);
|
|
2957
|
+
const indexByteLength = bufferViewMeshOpt.byteStride;
|
|
2958
|
+
MeshoptDecoder.decodeIndexSequence(
|
|
2959
|
+
new Uint8Array(indices.buffer),
|
|
2960
|
+
indexCount,
|
|
2961
|
+
indexByteLength,
|
|
2962
|
+
compressedBuffer
|
|
2963
|
+
);
|
|
2964
|
+
return indices;
|
|
2965
|
+
}
|
|
2966
|
+
function decodeGltf(gltf, hasNormals, result) {
|
|
2967
|
+
result.positions = decodePositions(gltf);
|
|
2968
|
+
result.normals = hasNormals ? decodeNormals(gltf) : void 0;
|
|
2969
|
+
result.indices = decodeIndices(gltf);
|
|
2970
|
+
result.edgeIndicesWest = decodeEdgeIndices(gltf, "left");
|
|
2971
|
+
result.edgeIndicesSouth = decodeEdgeIndices(gltf, "bottom");
|
|
2972
|
+
result.edgeIndicesEast = decodeEdgeIndices(gltf, "right");
|
|
2973
|
+
result.edgeIndicesNorth = decodeEdgeIndices(gltf, "top");
|
|
2974
|
+
return result;
|
|
2975
|
+
}
|
|
2976
|
+
Cesium3DTilesTerrainGeometryProcessor.upsampleMesh = function(options) {
|
|
2977
|
+
options = options ?? Frozen_default.EMPTY_OBJECT;
|
|
2978
|
+
const {
|
|
2979
|
+
isEastChild,
|
|
2980
|
+
isNorthChild,
|
|
2981
|
+
parentMinimumHeight,
|
|
2982
|
+
parentMaximumHeight,
|
|
2983
|
+
skirtHeight
|
|
2984
|
+
} = options;
|
|
2985
|
+
Check_default.typeOf.bool("options.isEastChild", isEastChild);
|
|
2986
|
+
Check_default.typeOf.bool("options.isNorthChild", isNorthChild);
|
|
2987
|
+
Check_default.typeOf.object("options.parentVertices", options.parentVertices);
|
|
2988
|
+
Check_default.typeOf.object("options.parentIndices", options.parentIndices);
|
|
2989
|
+
Check_default.typeOf.number(
|
|
2990
|
+
"options.parentVertexCountWithoutSkirts",
|
|
2991
|
+
options.parentVertexCountWithoutSkirts
|
|
2992
|
+
);
|
|
2993
|
+
Check_default.typeOf.number(
|
|
2994
|
+
"options.parentIndexCountWithoutSkirts",
|
|
2995
|
+
options.parentIndexCountWithoutSkirts
|
|
2996
|
+
);
|
|
2997
|
+
Check_default.typeOf.number("options.parentMinimumHeight", parentMinimumHeight);
|
|
2998
|
+
Check_default.typeOf.number("options.parentMaximumHeight", parentMaximumHeight);
|
|
2999
|
+
Check_default.typeOf.object("options.parentEncoding", options.parentEncoding);
|
|
3000
|
+
Check_default.typeOf.object("options.rectangle", options.rectangle);
|
|
3001
|
+
Check_default.typeOf.number("options.skirtHeight", skirtHeight);
|
|
3002
|
+
Check_default.typeOf.object("options.ellipsoid", options.ellipsoid);
|
|
3003
|
+
const indexCount = options.parentIndexCountWithoutSkirts;
|
|
3004
|
+
const indices = options.parentIndices;
|
|
3005
|
+
const vertexCount = options.parentVertexCountWithoutSkirts;
|
|
3006
|
+
const vertexBuffer = options.parentVertices;
|
|
3007
|
+
const encoding = TerrainEncoding_default.clone(
|
|
3008
|
+
options.parentEncoding,
|
|
3009
|
+
new TerrainEncoding_default()
|
|
3010
|
+
);
|
|
3011
|
+
const hasVertexNormals = encoding.hasVertexNormals;
|
|
3012
|
+
const hasWebMercatorT = encoding.hasWebMercatorT;
|
|
3013
|
+
const exaggeration = encoding.exaggeration;
|
|
3014
|
+
const exaggerationRelativeHeight = encoding.exaggerationRelativeHeight;
|
|
3015
|
+
const hasExaggeration = exaggeration !== 1;
|
|
3016
|
+
const hasGeodeticSurfaceNormals = hasExaggeration;
|
|
3017
|
+
const upsampleRectangle = Rectangle_default.clone(options.rectangle, new Rectangle_default());
|
|
3018
|
+
const ellipsoid = Ellipsoid_default.clone(options.ellipsoid);
|
|
3019
|
+
const upsampledTriIDs = [];
|
|
3020
|
+
const upsampledUVs = [];
|
|
3021
|
+
const upsampledBarys = [];
|
|
3022
|
+
const upsampledIndices = [];
|
|
3023
|
+
const upsampledWestIndices = [];
|
|
3024
|
+
const upsampledSouthIndices = [];
|
|
3025
|
+
const upsampledEastIndices = [];
|
|
3026
|
+
const upsampledNorthIndices = [];
|
|
3027
|
+
clipTileFromQuadrant(
|
|
3028
|
+
isEastChild,
|
|
3029
|
+
isNorthChild,
|
|
3030
|
+
indexCount,
|
|
3031
|
+
indices,
|
|
3032
|
+
vertexCount,
|
|
3033
|
+
vertexBuffer,
|
|
3034
|
+
encoding,
|
|
3035
|
+
upsampledIndices,
|
|
3036
|
+
upsampledWestIndices,
|
|
3037
|
+
upsampledSouthIndices,
|
|
3038
|
+
upsampledEastIndices,
|
|
3039
|
+
upsampledNorthIndices,
|
|
3040
|
+
upsampledTriIDs,
|
|
3041
|
+
upsampledBarys,
|
|
3042
|
+
upsampledUVs
|
|
3043
|
+
);
|
|
3044
|
+
const approximateCenterCartographic = Rectangle_default.center(
|
|
3045
|
+
upsampleRectangle,
|
|
3046
|
+
scratchCenterCartographicUpsample
|
|
3047
|
+
);
|
|
3048
|
+
approximateCenterCartographic.height = 0.5 * (parentMinimumHeight + parentMaximumHeight);
|
|
3049
|
+
const approximateCenterPosition = Cartographic_default.toCartesian(
|
|
3050
|
+
approximateCenterCartographic,
|
|
3051
|
+
ellipsoid,
|
|
3052
|
+
scratchCenterCartesianUpsample
|
|
3053
|
+
);
|
|
3054
|
+
const upsampledVertexCountWithoutSkirts = upsampledTriIDs.length;
|
|
3055
|
+
const upsampledTerrainEncoding = new TerrainEncoding_default(
|
|
3056
|
+
approximateCenterPosition,
|
|
3057
|
+
void 0,
|
|
3058
|
+
void 0,
|
|
3059
|
+
void 0,
|
|
3060
|
+
void 0,
|
|
3061
|
+
hasVertexNormals,
|
|
3062
|
+
hasWebMercatorT,
|
|
3063
|
+
hasGeodeticSurfaceNormals,
|
|
3064
|
+
exaggeration,
|
|
3065
|
+
exaggerationRelativeHeight
|
|
3066
|
+
);
|
|
3067
|
+
const upsampledVertexBufferStride = upsampledTerrainEncoding.stride;
|
|
3068
|
+
const upsampledSkirtVertexCount = TerrainProvider_default.getSkirtVertexCount(
|
|
3069
|
+
upsampledWestIndices,
|
|
3070
|
+
upsampledSouthIndices,
|
|
3071
|
+
upsampledEastIndices,
|
|
3072
|
+
upsampledNorthIndices
|
|
3073
|
+
);
|
|
3074
|
+
const upsampledVertexCountWithSkirts = upsampledVertexCountWithoutSkirts + upsampledSkirtVertexCount;
|
|
3075
|
+
const upsampledIndexCountWithoutSkirts = upsampledIndices.length;
|
|
3076
|
+
const upsampledSkirtIndexCount = TerrainProvider_default.getSkirtIndexCountWithFilledCorners(
|
|
3077
|
+
upsampledSkirtVertexCount
|
|
3078
|
+
);
|
|
3079
|
+
const upsampledIndexCountWithSkirts = upsampledIndexCountWithoutSkirts + upsampledSkirtIndexCount;
|
|
3080
|
+
const SizedIndexTypeWithSkirts = upsampledVertexCountWithSkirts <= 65535 ? Uint16Array : Uint32Array;
|
|
3081
|
+
const upsampledIndexBuffer = new SizedIndexTypeWithSkirts(
|
|
3082
|
+
upsampledIndexCountWithSkirts
|
|
3083
|
+
);
|
|
3084
|
+
upsampledIndexBuffer.set(upsampledIndices);
|
|
3085
|
+
const upsampledWestIndicesBuffer = new SizedIndexTypeWithSkirts(
|
|
3086
|
+
upsampledWestIndices
|
|
3087
|
+
);
|
|
3088
|
+
const upsampledSouthIndicesBuffer = new SizedIndexTypeWithSkirts(
|
|
3089
|
+
upsampledSouthIndices
|
|
3090
|
+
);
|
|
3091
|
+
const upsampledEastIndicesBuffer = new SizedIndexTypeWithSkirts(
|
|
3092
|
+
upsampledEastIndices
|
|
3093
|
+
);
|
|
3094
|
+
const upsampledNorthIndicesBuffer = new SizedIndexTypeWithSkirts(
|
|
3095
|
+
upsampledNorthIndices
|
|
3096
|
+
);
|
|
3097
|
+
const upsampledVertexBuffer = new Float32Array(
|
|
3098
|
+
upsampledVertexCountWithSkirts * upsampledVertexBufferStride
|
|
3099
|
+
);
|
|
3100
|
+
let upsampledVertexBufferOffset = 0;
|
|
3101
|
+
const enuToEcef = Transforms_default.eastNorthUpToFixedFrame(
|
|
3102
|
+
approximateCenterPosition,
|
|
3103
|
+
ellipsoid,
|
|
3104
|
+
scratchEnuToEcefUpsample
|
|
3105
|
+
);
|
|
3106
|
+
const ecefToEnu = Matrix4_default.inverseTransformation(
|
|
3107
|
+
enuToEcef,
|
|
3108
|
+
scratchEcefToEnuUpsample
|
|
3109
|
+
);
|
|
3110
|
+
const minimumLongitude = upsampleRectangle.west;
|
|
3111
|
+
const maximumLongitude = upsampleRectangle.east;
|
|
3112
|
+
const minimumLatitude = upsampleRectangle.south;
|
|
3113
|
+
const maximumLatitude = upsampleRectangle.north;
|
|
3114
|
+
const southMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(minimumLatitude);
|
|
3115
|
+
const northMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(maximumLatitude);
|
|
3116
|
+
const oneOverMercatorHeight = 1 / (northMercatorAngle - southMercatorAngle);
|
|
3117
|
+
let minimumHeight = Number.POSITIVE_INFINITY;
|
|
3118
|
+
let maximumHeight = Number.NEGATIVE_INFINITY;
|
|
3119
|
+
let minPosEnu = Cartesian3_default.fromElements(
|
|
3120
|
+
Number.POSITIVE_INFINITY,
|
|
3121
|
+
Number.POSITIVE_INFINITY,
|
|
3122
|
+
Number.POSITIVE_INFINITY,
|
|
3123
|
+
scratchMinimumPositionENUUpsample
|
|
3124
|
+
);
|
|
3125
|
+
let maxPosEnu = Cartesian3_default.fromElements(
|
|
3126
|
+
Number.NEGATIVE_INFINITY,
|
|
3127
|
+
Number.NEGATIVE_INFINITY,
|
|
3128
|
+
Number.NEGATIVE_INFINITY,
|
|
3129
|
+
scratchMaximumPositionENUUpsample
|
|
3130
|
+
);
|
|
3131
|
+
for (let i = 0; i < upsampledVertexCountWithoutSkirts; i++) {
|
|
3132
|
+
const triId = upsampledTriIDs[i];
|
|
3133
|
+
const indexA = indices[triId * 3 + 0];
|
|
3134
|
+
const indexB = indices[triId * 3 + 1];
|
|
3135
|
+
const indexC = indices[triId * 3 + 2];
|
|
3136
|
+
const uv = scratchUVUpsample;
|
|
3137
|
+
uv.x = upsampledUVs[i * 2 + 0];
|
|
3138
|
+
uv.y = upsampledUVs[i * 2 + 1];
|
|
3139
|
+
const u = uv.x;
|
|
3140
|
+
const v = uv.y;
|
|
3141
|
+
const baryA = upsampledBarys[i * 2 + 0];
|
|
3142
|
+
const baryB = upsampledBarys[i * 2 + 1];
|
|
3143
|
+
const baryC = 1 - baryA - baryB;
|
|
3144
|
+
const heightA = encoding.decodeHeight(vertexBuffer, indexA);
|
|
3145
|
+
const heightB = encoding.decodeHeight(vertexBuffer, indexB);
|
|
3146
|
+
const heightC = encoding.decodeHeight(vertexBuffer, indexC);
|
|
3147
|
+
const height = heightA * baryA + heightB * baryB + heightC * baryC;
|
|
3148
|
+
minimumHeight = Math.min(height, minimumHeight);
|
|
3149
|
+
maximumHeight = Math.max(height, maximumHeight);
|
|
3150
|
+
const lon = Math_default.lerp(minimumLongitude, maximumLongitude, u);
|
|
3151
|
+
const lat = Math_default.lerp(minimumLatitude, maximumLatitude, v);
|
|
3152
|
+
const carto = Cartographic_default.fromRadians(
|
|
3153
|
+
lon,
|
|
3154
|
+
lat,
|
|
3155
|
+
height,
|
|
3156
|
+
scratchCartographicUpsample
|
|
3157
|
+
);
|
|
3158
|
+
const position = Cartographic_default.toCartesian(
|
|
3159
|
+
carto,
|
|
3160
|
+
ellipsoid,
|
|
3161
|
+
scratchPosEcefUpsample
|
|
3162
|
+
);
|
|
3163
|
+
const posEnu = Matrix4_default.multiplyByPoint(
|
|
3164
|
+
ecefToEnu,
|
|
3165
|
+
position,
|
|
3166
|
+
scratchPosEnuUpsample
|
|
3167
|
+
);
|
|
3168
|
+
minPosEnu = Cartesian3_default.minimumByComponent(posEnu, minPosEnu, minPosEnu);
|
|
3169
|
+
maxPosEnu = Cartesian3_default.maximumByComponent(posEnu, maxPosEnu, maxPosEnu);
|
|
3170
|
+
let normalOct;
|
|
3171
|
+
if (hasVertexNormals) {
|
|
3172
|
+
const normalA = encoding.decodeNormal(
|
|
3173
|
+
vertexBuffer,
|
|
3174
|
+
indexA,
|
|
3175
|
+
scratchNormalA
|
|
3176
|
+
);
|
|
3177
|
+
const normalB = encoding.decodeNormal(
|
|
3178
|
+
vertexBuffer,
|
|
3179
|
+
indexB,
|
|
3180
|
+
scratchNormalB
|
|
3181
|
+
);
|
|
3182
|
+
const normalC = encoding.decodeNormal(
|
|
3183
|
+
vertexBuffer,
|
|
3184
|
+
indexC,
|
|
3185
|
+
scratchNormalC
|
|
3186
|
+
);
|
|
3187
|
+
let normal = Cartesian3_default.fromElements(
|
|
3188
|
+
normalA.x * baryA + normalB.x * baryB + normalC.x * baryC,
|
|
3189
|
+
normalA.y * baryA + normalB.y * baryB + normalC.y * baryC,
|
|
3190
|
+
normalA.z * baryA + normalB.z * baryB + normalC.z * baryC,
|
|
3191
|
+
scratchNormalUpsample
|
|
3192
|
+
);
|
|
3193
|
+
normal = Cartesian3_default.normalize(normal, scratchNormalUpsample);
|
|
3194
|
+
normalOct = AttributeCompression_default.octEncode(
|
|
3195
|
+
normal,
|
|
3196
|
+
scratchNormalOctUpsample
|
|
3197
|
+
);
|
|
3198
|
+
}
|
|
3199
|
+
let webMercatorT;
|
|
3200
|
+
if (hasWebMercatorT) {
|
|
3201
|
+
const mercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(lat);
|
|
3202
|
+
webMercatorT = (mercatorAngle - southMercatorAngle) * oneOverMercatorHeight;
|
|
3203
|
+
}
|
|
3204
|
+
let geodeticSurfaceNormal;
|
|
3205
|
+
if (hasGeodeticSurfaceNormals) {
|
|
3206
|
+
geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
|
|
3207
|
+
position,
|
|
3208
|
+
scratchGeodeticSurfaceNormalUpsample
|
|
3209
|
+
);
|
|
3210
|
+
}
|
|
3211
|
+
upsampledVertexBufferOffset = upsampledTerrainEncoding.encode(
|
|
3212
|
+
upsampledVertexBuffer,
|
|
3213
|
+
upsampledVertexBufferOffset,
|
|
3214
|
+
position,
|
|
3215
|
+
uv,
|
|
3216
|
+
height,
|
|
3217
|
+
normalOct,
|
|
3218
|
+
webMercatorT,
|
|
3219
|
+
geodeticSurfaceNormal
|
|
3220
|
+
);
|
|
3221
|
+
}
|
|
3222
|
+
const orientedBoundingBox = OrientedBoundingBox_default.fromRectangle(
|
|
3223
|
+
upsampleRectangle,
|
|
3224
|
+
minimumHeight,
|
|
3225
|
+
maximumHeight,
|
|
3226
|
+
ellipsoid,
|
|
3227
|
+
scratchOrientedBoundingBox
|
|
3228
|
+
);
|
|
3229
|
+
const boundingSphere = BoundingSphere_default.fromVertices(
|
|
3230
|
+
upsampledVertexBuffer,
|
|
3231
|
+
upsampledTerrainEncoding.center,
|
|
3232
|
+
upsampledVertexBufferStride,
|
|
3233
|
+
scratchBoundingSphere
|
|
3234
|
+
);
|
|
3235
|
+
const occluder = new EllipsoidalOccluder_default(ellipsoid);
|
|
3236
|
+
const horizonOcclusionPoint = occluder.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(
|
|
3237
|
+
upsampledTerrainEncoding.center,
|
|
3238
|
+
// vector from ellipsoid center to horizon occlusion point
|
|
3239
|
+
upsampledVertexBuffer,
|
|
3240
|
+
upsampledVertexBufferStride,
|
|
3241
|
+
upsampledTerrainEncoding.center,
|
|
3242
|
+
minimumHeight,
|
|
3243
|
+
scratchHorizonOcclusionPoint
|
|
3244
|
+
);
|
|
3245
|
+
const upsampledMesh = new TerrainMesh_default(
|
|
3246
|
+
Cartesian3_default.clone(upsampledTerrainEncoding.center, new Cartesian3_default()),
|
|
3247
|
+
upsampledVertexBuffer,
|
|
3248
|
+
upsampledIndexBuffer,
|
|
3249
|
+
upsampledIndexCountWithoutSkirts,
|
|
3250
|
+
upsampledVertexCountWithoutSkirts,
|
|
3251
|
+
minimumHeight,
|
|
3252
|
+
maximumHeight,
|
|
3253
|
+
upsampleRectangle,
|
|
3254
|
+
BoundingSphere_default.clone(boundingSphere),
|
|
3255
|
+
Cartesian3_default.clone(horizonOcclusionPoint),
|
|
3256
|
+
upsampledVertexBufferStride,
|
|
3257
|
+
OrientedBoundingBox_default.clone(orientedBoundingBox),
|
|
3258
|
+
upsampledTerrainEncoding,
|
|
3259
|
+
upsampledWestIndicesBuffer,
|
|
3260
|
+
upsampledSouthIndicesBuffer,
|
|
3261
|
+
upsampledEastIndicesBuffer,
|
|
3262
|
+
upsampledNorthIndicesBuffer
|
|
3263
|
+
);
|
|
3264
|
+
addSkirtsToMesh(
|
|
3265
|
+
upsampledMesh,
|
|
3266
|
+
upsampleRectangle,
|
|
3267
|
+
ellipsoid,
|
|
3268
|
+
minPosEnu,
|
|
3269
|
+
maxPosEnu,
|
|
3270
|
+
enuToEcef,
|
|
3271
|
+
ecefToEnu,
|
|
3272
|
+
skirtHeight
|
|
3273
|
+
);
|
|
3274
|
+
return upsampledMesh;
|
|
3275
|
+
};
|
|
3276
|
+
function addSkirtsToMesh(mesh, rectangle, ellipsoid, enuMinimum, enuMaximum, enuToEcef, ecefToEnu, skirtHeight) {
|
|
3277
|
+
const { encoding } = mesh;
|
|
3278
|
+
const vertexStride = encoding.stride;
|
|
3279
|
+
const vertexBuffer = mesh.vertices;
|
|
3280
|
+
const {
|
|
3281
|
+
hasVertexNormals,
|
|
3282
|
+
hasWebMercatorT,
|
|
3283
|
+
exaggeration,
|
|
3284
|
+
exaggerationRelativeHeight
|
|
3285
|
+
} = encoding;
|
|
3286
|
+
const hasExaggeration = exaggeration !== 1;
|
|
3287
|
+
const hasGeodeticSurfaceNormals = hasExaggeration;
|
|
3288
|
+
const vertexCountWithoutSkirts = mesh.vertexCountWithoutSkirts;
|
|
3289
|
+
let vertexBufferOffset = vertexCountWithoutSkirts * vertexStride;
|
|
3290
|
+
const vertexCountWithSkirts = vertexBuffer.length / vertexStride;
|
|
3291
|
+
const skirtVertexCount = vertexCountWithSkirts - vertexCountWithoutSkirts;
|
|
3292
|
+
const indices = mesh.indices;
|
|
3293
|
+
const indexCountWithoutSkirts = mesh.indexCountWithoutSkirts;
|
|
3294
|
+
const westIndices = mesh.westIndicesSouthToNorth;
|
|
3295
|
+
const southIndices = mesh.southIndicesEastToWest;
|
|
3296
|
+
const eastIndices = mesh.eastIndicesNorthToSouth;
|
|
3297
|
+
const northIndices = mesh.northIndicesWestToEast;
|
|
3298
|
+
TerrainProvider_default.addSkirtIndicesWithFilledCorners(
|
|
3299
|
+
westIndices,
|
|
3300
|
+
southIndices,
|
|
3301
|
+
eastIndices,
|
|
3302
|
+
northIndices,
|
|
3303
|
+
vertexCountWithoutSkirts,
|
|
3304
|
+
indices,
|
|
3305
|
+
indexCountWithoutSkirts
|
|
3306
|
+
);
|
|
3307
|
+
const westOffset = 0;
|
|
3308
|
+
const southOffset = westOffset + westIndices.length;
|
|
3309
|
+
const eastOffset = southOffset + southIndices.length;
|
|
3310
|
+
const northOffset = eastOffset + eastIndices.length;
|
|
3311
|
+
const edges = [westIndices, southIndices, eastIndices, northIndices];
|
|
3312
|
+
const edgeIndexOffset = [westOffset, southOffset, eastOffset, northOffset];
|
|
3313
|
+
const edgeLongitudeSign = [-1, 0, 1, 0];
|
|
3314
|
+
const edgeLatitudeSign = [0, -1, 0, 1];
|
|
3315
|
+
const minimumPositionENUWithSkirts = Cartesian3_default.clone(
|
|
3316
|
+
enuMinimum,
|
|
3317
|
+
scratchMinimumPositionENUSkirt
|
|
3318
|
+
);
|
|
3319
|
+
const maximumPositionENUWithSkirts = Cartesian3_default.clone(
|
|
3320
|
+
enuMaximum,
|
|
3321
|
+
scratchMaximumPositionENUSkirt
|
|
3322
|
+
);
|
|
3323
|
+
const maximumHeight = mesh.maximumHeight;
|
|
3324
|
+
const minimumHeightWithSkirts = mesh.minimumHeight - skirtHeight;
|
|
3325
|
+
for (let skirtId = 0; skirtId < skirtVertexCount; skirtId++) {
|
|
3326
|
+
let side = 0;
|
|
3327
|
+
for (side = 0; side < 3; side++) {
|
|
3328
|
+
if (skirtId < edgeIndexOffset[side + 1]) {
|
|
3329
|
+
break;
|
|
3330
|
+
}
|
|
3331
|
+
}
|
|
3332
|
+
const vertexIndex = edges[side][skirtId - edgeIndexOffset[side]];
|
|
3333
|
+
const uv = encoding.decodeTextureCoordinates(
|
|
3334
|
+
vertexBuffer,
|
|
3335
|
+
vertexIndex,
|
|
3336
|
+
scratchUVSkirt
|
|
3337
|
+
);
|
|
3338
|
+
const skirtLonLatOffsetPercent = 1e-4;
|
|
3339
|
+
const longitudeT = uv.x + edgeLongitudeSign[side] * skirtLonLatOffsetPercent;
|
|
3340
|
+
const latitudeT = uv.y + edgeLatitudeSign[side] * skirtLonLatOffsetPercent;
|
|
3341
|
+
const longitude = Math_default.lerp(
|
|
3342
|
+
rectangle.west,
|
|
3343
|
+
rectangle.east,
|
|
3344
|
+
longitudeT
|
|
3345
|
+
);
|
|
3346
|
+
const latitude = Math_default.clamp(
|
|
3347
|
+
Math_default.lerp(rectangle.south, rectangle.north, latitudeT),
|
|
3348
|
+
-Math_default.PI_OVER_TWO,
|
|
3349
|
+
+Math_default.PI_OVER_TWO
|
|
3350
|
+
);
|
|
3351
|
+
const vertHeight = encoding.decodeHeight(vertexBuffer, vertexIndex);
|
|
3352
|
+
const height = vertHeight - skirtHeight;
|
|
3353
|
+
const cartographic = Cartographic_default.fromRadians(
|
|
3354
|
+
longitude,
|
|
3355
|
+
latitude,
|
|
3356
|
+
height,
|
|
3357
|
+
scratchCartographicSkirt
|
|
3358
|
+
);
|
|
3359
|
+
const positionEcef = Cartographic_default.toCartesian(
|
|
3360
|
+
cartographic,
|
|
3361
|
+
ellipsoid,
|
|
3362
|
+
scratchPosEcefSkirt
|
|
3363
|
+
);
|
|
3364
|
+
let normalOct;
|
|
3365
|
+
if (hasVertexNormals) {
|
|
3366
|
+
normalOct = encoding.getOctEncodedNormal(
|
|
3367
|
+
vertexBuffer,
|
|
3368
|
+
vertexIndex,
|
|
3369
|
+
scratchNormalOctSkirt
|
|
3370
|
+
);
|
|
3371
|
+
}
|
|
3372
|
+
let webMercatorT;
|
|
3373
|
+
if (hasWebMercatorT) {
|
|
3374
|
+
webMercatorT = encoding.decodeWebMercatorT(vertexBuffer, vertexIndex);
|
|
3375
|
+
}
|
|
3376
|
+
let geodeticSurfaceNormal;
|
|
3377
|
+
if (hasGeodeticSurfaceNormals) {
|
|
3378
|
+
geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
|
|
3379
|
+
positionEcef,
|
|
3380
|
+
scratchGeodeticSurfaceNormalSkirt
|
|
3381
|
+
);
|
|
3382
|
+
}
|
|
3383
|
+
vertexBufferOffset = encoding.encode(
|
|
3384
|
+
vertexBuffer,
|
|
3385
|
+
vertexBufferOffset,
|
|
3386
|
+
positionEcef,
|
|
3387
|
+
uv,
|
|
3388
|
+
height,
|
|
3389
|
+
normalOct,
|
|
3390
|
+
webMercatorT,
|
|
3391
|
+
geodeticSurfaceNormal
|
|
3392
|
+
);
|
|
3393
|
+
const positionENU = Matrix4_default.multiplyByPoint(
|
|
3394
|
+
ecefToEnu,
|
|
3395
|
+
positionEcef,
|
|
3396
|
+
scratchPosEnuSkirt
|
|
3397
|
+
);
|
|
3398
|
+
Cartesian3_default.minimumByComponent(
|
|
3399
|
+
positionENU,
|
|
3400
|
+
minimumPositionENUWithSkirts,
|
|
3401
|
+
minimumPositionENUWithSkirts
|
|
3402
|
+
);
|
|
3403
|
+
Cartesian3_default.maximumByComponent(
|
|
3404
|
+
positionENU,
|
|
3405
|
+
maximumPositionENUWithSkirts,
|
|
3406
|
+
maximumPositionENUWithSkirts
|
|
3407
|
+
);
|
|
3408
|
+
}
|
|
3409
|
+
const aabbEnuWithSkirts = AxisAlignedBoundingBox_default.fromCorners(
|
|
3410
|
+
minimumPositionENUWithSkirts,
|
|
3411
|
+
maximumPositionENUWithSkirts,
|
|
3412
|
+
scratchAABBEnuSkirt
|
|
3413
|
+
);
|
|
3414
|
+
const encodingWithSkirts = new TerrainEncoding_default(
|
|
3415
|
+
encoding.center,
|
|
3416
|
+
aabbEnuWithSkirts,
|
|
3417
|
+
minimumHeightWithSkirts,
|
|
3418
|
+
maximumHeight,
|
|
3419
|
+
enuToEcef,
|
|
3420
|
+
encoding.hasVertexNormals,
|
|
3421
|
+
encoding.hasWebMercatorT,
|
|
3422
|
+
hasGeodeticSurfaceNormals,
|
|
3423
|
+
exaggeration,
|
|
3424
|
+
exaggerationRelativeHeight
|
|
3425
|
+
);
|
|
3426
|
+
if (encoding.quantization !== encodingWithSkirts.quantization) {
|
|
3427
|
+
const finalEncoding = encodingWithSkirts;
|
|
3428
|
+
const finalVertexStride = finalEncoding.stride;
|
|
3429
|
+
const finalVertexBuffer = new Float32Array(
|
|
3430
|
+
vertexCountWithSkirts * finalVertexStride
|
|
3431
|
+
);
|
|
3432
|
+
let finalVertexBufferOffset = 0;
|
|
3433
|
+
for (let i = 0; i < vertexCountWithSkirts; i++) {
|
|
3434
|
+
finalVertexBufferOffset = finalEncoding.encode(
|
|
3435
|
+
finalVertexBuffer,
|
|
3436
|
+
finalVertexBufferOffset,
|
|
3437
|
+
encoding.decodePosition(vertexBuffer, i, scratchPosEcefSkirt),
|
|
3438
|
+
encoding.decodeTextureCoordinates(vertexBuffer, i, scratchUVSkirt),
|
|
3439
|
+
encoding.decodeHeight(vertexBuffer, i),
|
|
3440
|
+
encoding.hasVertexNormals ? encoding.getOctEncodedNormal(vertexBuffer, i, scratchNormalOctSkirt) : void 0,
|
|
3441
|
+
encoding.hasWebMercatorT ? encoding.decodeWebMercatorT(vertexBuffer, i) : void 0,
|
|
3442
|
+
encoding.hasGeodeticSurfaceNormals ? encoding.decodeGeodeticSurfaceNormal(
|
|
3443
|
+
vertexBuffer,
|
|
3444
|
+
i,
|
|
3445
|
+
scratchGeodeticSurfaceNormalSkirt
|
|
3446
|
+
) : void 0
|
|
3447
|
+
);
|
|
3448
|
+
}
|
|
3449
|
+
mesh.vertices = finalVertexBuffer;
|
|
3450
|
+
mesh.stride = finalVertexStride;
|
|
3451
|
+
mesh.encoding = finalEncoding;
|
|
3452
|
+
}
|
|
3453
|
+
return mesh;
|
|
3454
|
+
}
|
|
3455
|
+
var EDGE_ID_LEFT = 0;
|
|
3456
|
+
var EDGE_ID_TOP = 1;
|
|
3457
|
+
var EDGE_ID_RIGHT = 2;
|
|
3458
|
+
var EDGE_ID_BOTTOM = 3;
|
|
3459
|
+
var EDGE_COUNT = 4;
|
|
3460
|
+
var scratchIntersection = new Cartesian3_default();
|
|
3461
|
+
var scratchInBarys = [
|
|
3462
|
+
new Cartesian3_default(),
|
|
3463
|
+
new Cartesian3_default(),
|
|
3464
|
+
new Cartesian3_default(),
|
|
3465
|
+
new Cartesian3_default(),
|
|
3466
|
+
new Cartesian3_default(),
|
|
3467
|
+
new Cartesian3_default()
|
|
3468
|
+
];
|
|
3469
|
+
var scratchInPoints = [
|
|
3470
|
+
new Cartesian2_default(),
|
|
3471
|
+
new Cartesian2_default(),
|
|
3472
|
+
new Cartesian2_default(),
|
|
3473
|
+
new Cartesian2_default(),
|
|
3474
|
+
new Cartesian2_default(),
|
|
3475
|
+
new Cartesian2_default()
|
|
3476
|
+
];
|
|
3477
|
+
var scratchOutBarys = [
|
|
3478
|
+
new Cartesian3_default(),
|
|
3479
|
+
new Cartesian3_default(),
|
|
3480
|
+
new Cartesian3_default(),
|
|
3481
|
+
new Cartesian3_default(),
|
|
3482
|
+
new Cartesian3_default(),
|
|
3483
|
+
new Cartesian3_default()
|
|
3484
|
+
];
|
|
3485
|
+
var scratchOutPoints = [
|
|
3486
|
+
new Cartesian2_default(),
|
|
3487
|
+
new Cartesian2_default(),
|
|
3488
|
+
new Cartesian2_default(),
|
|
3489
|
+
new Cartesian2_default(),
|
|
3490
|
+
new Cartesian2_default(),
|
|
3491
|
+
new Cartesian2_default()
|
|
3492
|
+
];
|
|
3493
|
+
function inside(boxMinimum, boxMaximum, edgeId, p) {
|
|
3494
|
+
switch (edgeId) {
|
|
3495
|
+
case EDGE_ID_LEFT:
|
|
3496
|
+
return Math_default.sign(p.x - boxMinimum.x);
|
|
3497
|
+
case EDGE_ID_RIGHT:
|
|
3498
|
+
return Math_default.sign(boxMaximum.x - p.x);
|
|
3499
|
+
case EDGE_ID_BOTTOM:
|
|
3500
|
+
return Math_default.sign(p.y - boxMinimum.y);
|
|
3501
|
+
default:
|
|
3502
|
+
return Math_default.sign(boxMaximum.y - p.y);
|
|
3503
|
+
}
|
|
3504
|
+
}
|
|
3505
|
+
function intersect(boxMinimum, boxMaximum, edgeId, a, b, result) {
|
|
3506
|
+
let t, intersectX, intersectY;
|
|
3507
|
+
switch (edgeId) {
|
|
3508
|
+
case EDGE_ID_LEFT:
|
|
3509
|
+
t = (boxMinimum.x - a.x) / (b.x - a.x);
|
|
3510
|
+
intersectX = boxMinimum.x;
|
|
3511
|
+
intersectY = a.y + (b.y - a.y) * t;
|
|
3512
|
+
break;
|
|
3513
|
+
case EDGE_ID_RIGHT:
|
|
3514
|
+
t = (boxMaximum.x - a.x) / (b.x - a.x);
|
|
3515
|
+
intersectX = boxMaximum.x;
|
|
3516
|
+
intersectY = a.y + (b.y - a.y) * t;
|
|
3517
|
+
break;
|
|
3518
|
+
case EDGE_ID_BOTTOM:
|
|
3519
|
+
t = (boxMinimum.y - a.y) / (b.y - a.y);
|
|
3520
|
+
intersectX = a.x + (b.x - a.x) * t;
|
|
3521
|
+
intersectY = boxMinimum.y;
|
|
3522
|
+
break;
|
|
3523
|
+
default:
|
|
3524
|
+
t = (boxMaximum.y - a.y) / (b.y - a.y);
|
|
3525
|
+
intersectX = a.x + (b.x - a.x) * t;
|
|
3526
|
+
intersectY = boxMaximum.y;
|
|
3527
|
+
break;
|
|
3528
|
+
}
|
|
3529
|
+
return Cartesian3_default.fromElements(intersectX, intersectY, t, result);
|
|
3530
|
+
}
|
|
3531
|
+
var scratchPolygon = {
|
|
3532
|
+
length: 0,
|
|
3533
|
+
coordinates: [
|
|
3534
|
+
new Cartesian2_default(),
|
|
3535
|
+
new Cartesian2_default(),
|
|
3536
|
+
new Cartesian2_default(),
|
|
3537
|
+
new Cartesian2_default(),
|
|
3538
|
+
new Cartesian2_default(),
|
|
3539
|
+
new Cartesian2_default()
|
|
3540
|
+
],
|
|
3541
|
+
barycentricCoordinates: [
|
|
3542
|
+
new Cartesian3_default(),
|
|
3543
|
+
new Cartesian3_default(),
|
|
3544
|
+
new Cartesian3_default(),
|
|
3545
|
+
new Cartesian3_default(),
|
|
3546
|
+
new Cartesian3_default(),
|
|
3547
|
+
new Cartesian3_default()
|
|
3548
|
+
]
|
|
3549
|
+
};
|
|
3550
|
+
function clipTriangleAgainstBoxEdgeRange(edgeStart, edgeCount, boxMinimum, boxMaximum, p0, p1, p2, result) {
|
|
3551
|
+
let inputLength = 0;
|
|
3552
|
+
let inputPoints = scratchInPoints;
|
|
3553
|
+
let inputBarys = scratchInBarys;
|
|
3554
|
+
let outputLength = 3;
|
|
3555
|
+
let outputPoints = scratchOutPoints;
|
|
3556
|
+
Cartesian2_default.clone(p0, outputPoints[0]);
|
|
3557
|
+
Cartesian2_default.clone(p1, outputPoints[1]);
|
|
3558
|
+
Cartesian2_default.clone(p2, outputPoints[2]);
|
|
3559
|
+
let outputBarys = scratchOutBarys;
|
|
3560
|
+
Cartesian3_default.fromElements(1, 0, 0, outputBarys[0]);
|
|
3561
|
+
Cartesian3_default.fromElements(0, 1, 0, outputBarys[1]);
|
|
3562
|
+
Cartesian3_default.fromElements(0, 0, 1, outputBarys[2]);
|
|
3563
|
+
for (let e = 0; e < edgeCount; e++) {
|
|
3564
|
+
const edgeId = (edgeStart + e) % EDGE_COUNT;
|
|
3565
|
+
const tempPoints = inputPoints;
|
|
3566
|
+
const tempBarys = inputBarys;
|
|
3567
|
+
inputPoints = outputPoints;
|
|
3568
|
+
inputBarys = outputBarys;
|
|
3569
|
+
inputLength = outputLength;
|
|
3570
|
+
outputPoints = tempPoints;
|
|
3571
|
+
outputBarys = tempBarys;
|
|
3572
|
+
outputLength = 0;
|
|
3573
|
+
let prevIdx = inputLength - 1;
|
|
3574
|
+
let prevPoint = inputPoints[prevIdx];
|
|
3575
|
+
let prevBary = inputBarys[prevIdx];
|
|
3576
|
+
let prevInside = inside(boxMinimum, boxMaximum, edgeId, prevPoint);
|
|
3577
|
+
for (let currIdx = 0; currIdx < inputLength; currIdx++) {
|
|
3578
|
+
const currPoint = inputPoints[currIdx];
|
|
3579
|
+
const currBary = inputBarys[currIdx];
|
|
3580
|
+
const currInside = inside(boxMinimum, boxMaximum, edgeId, currPoint);
|
|
3581
|
+
if (prevInside * currInside === -1) {
|
|
3582
|
+
const intersection = intersect(
|
|
3583
|
+
boxMinimum,
|
|
3584
|
+
boxMaximum,
|
|
3585
|
+
edgeId,
|
|
3586
|
+
prevPoint,
|
|
3587
|
+
currPoint,
|
|
3588
|
+
scratchIntersection
|
|
3589
|
+
);
|
|
3590
|
+
const { x, y, z: t } = intersection;
|
|
3591
|
+
const tInv = 1 - t;
|
|
3592
|
+
const baryA = prevBary.x * tInv + currBary.x * t;
|
|
3593
|
+
const baryB = prevBary.y * tInv + currBary.y * t;
|
|
3594
|
+
const baryC = prevBary.z * tInv + currBary.z * t;
|
|
3595
|
+
Cartesian2_default.fromElements(x, y, outputPoints[outputLength]);
|
|
3596
|
+
Cartesian3_default.fromElements(baryA, baryB, baryC, outputBarys[outputLength]);
|
|
3597
|
+
outputLength++;
|
|
3598
|
+
}
|
|
3599
|
+
if (currInside >= 0) {
|
|
3600
|
+
Cartesian2_default.clone(currPoint, outputPoints[outputLength]);
|
|
3601
|
+
Cartesian3_default.clone(currBary, outputBarys[outputLength]);
|
|
3602
|
+
outputLength++;
|
|
3603
|
+
}
|
|
3604
|
+
prevIdx = currIdx;
|
|
3605
|
+
prevPoint = currPoint;
|
|
3606
|
+
prevBary = currBary;
|
|
3607
|
+
prevInside = currInside;
|
|
3608
|
+
}
|
|
3609
|
+
if (outputLength === 0) {
|
|
3610
|
+
break;
|
|
3611
|
+
}
|
|
3612
|
+
}
|
|
3613
|
+
result.length = outputLength;
|
|
3614
|
+
for (let i = 0; i < outputLength; i++) {
|
|
3615
|
+
Cartesian2_default.clone(outputPoints[i], result.coordinates[i]);
|
|
3616
|
+
Cartesian3_default.clone(outputBarys[i], result.barycentricCoordinates[i]);
|
|
3617
|
+
}
|
|
3618
|
+
return result;
|
|
3619
|
+
}
|
|
3620
|
+
function clipTriangleFromQuadrant(isEastChild, isNorthChild, boxMinimum, boxMaximum, p0, p1, p2, result) {
|
|
3621
|
+
const edgeStart = isEastChild ? isNorthChild ? EDGE_ID_BOTTOM : EDGE_ID_LEFT : isNorthChild ? EDGE_ID_RIGHT : EDGE_ID_TOP;
|
|
3622
|
+
return clipTriangleAgainstBoxEdgeRange(
|
|
3623
|
+
edgeStart,
|
|
3624
|
+
2,
|
|
3625
|
+
boxMinimum,
|
|
3626
|
+
boxMaximum,
|
|
3627
|
+
p0,
|
|
3628
|
+
p1,
|
|
3629
|
+
p2,
|
|
3630
|
+
result
|
|
3631
|
+
);
|
|
3632
|
+
}
|
|
3633
|
+
var lookUpTableBaryToPrim = [
|
|
3634
|
+
[],
|
|
3635
|
+
// 000
|
|
3636
|
+
[0],
|
|
3637
|
+
// 001
|
|
3638
|
+
[1],
|
|
3639
|
+
// 010
|
|
3640
|
+
[0, 1],
|
|
3641
|
+
// 011
|
|
3642
|
+
[2],
|
|
3643
|
+
// 100
|
|
3644
|
+
[0, 2],
|
|
3645
|
+
// 101
|
|
3646
|
+
[1, 2],
|
|
3647
|
+
// 110
|
|
3648
|
+
[0, 1, 2]
|
|
3649
|
+
// 111
|
|
3650
|
+
];
|
|
3651
|
+
function clipTileFromQuadrant(isEastChild, isNorthChild, indexCount, indices, vertexCount, vertices, vertexEncoding, resultIndices, resultWestIndices, resultSouthIndices, resultEastIndices, resultNorthIndices, resultTriIds, resultBary, resultUVs) {
|
|
3652
|
+
const upsampledVertexMap = {};
|
|
3653
|
+
const minU = isEastChild ? 0.5 : 0;
|
|
3654
|
+
const maxU = isEastChild ? 1 : 0.5;
|
|
3655
|
+
const minV = isNorthChild ? 0.5 : 0;
|
|
3656
|
+
const maxV = isNorthChild ? 1 : 0.5;
|
|
3657
|
+
const minUV = scratchMinUV;
|
|
3658
|
+
minUV.x = minU;
|
|
3659
|
+
minUV.y = minV;
|
|
3660
|
+
const maxUV = scratchMaxUV;
|
|
3661
|
+
maxUV.x = maxU;
|
|
3662
|
+
maxUV.y = maxV;
|
|
3663
|
+
let upsampledVertexCount = 0;
|
|
3664
|
+
for (let i = 0; i < indexCount; i += 3) {
|
|
3665
|
+
const indexA = indices[i + 0];
|
|
3666
|
+
const indexB = indices[i + 1];
|
|
3667
|
+
const indexC = indices[i + 2];
|
|
3668
|
+
const uvA = vertexEncoding.decodeTextureCoordinates(
|
|
3669
|
+
vertices,
|
|
3670
|
+
indexA,
|
|
3671
|
+
scratchUvA
|
|
3672
|
+
);
|
|
3673
|
+
const uvB = vertexEncoding.decodeTextureCoordinates(
|
|
3674
|
+
vertices,
|
|
3675
|
+
indexB,
|
|
3676
|
+
scratchUvB
|
|
3677
|
+
);
|
|
3678
|
+
const uvC = vertexEncoding.decodeTextureCoordinates(
|
|
3679
|
+
vertices,
|
|
3680
|
+
indexC,
|
|
3681
|
+
scratchUvC
|
|
3682
|
+
);
|
|
3683
|
+
const clippedPolygon = clipTriangleFromQuadrant(
|
|
3684
|
+
isEastChild,
|
|
3685
|
+
isNorthChild,
|
|
3686
|
+
minUV,
|
|
3687
|
+
maxUV,
|
|
3688
|
+
uvA,
|
|
3689
|
+
uvB,
|
|
3690
|
+
uvC,
|
|
3691
|
+
scratchPolygon
|
|
3692
|
+
);
|
|
3693
|
+
const clippedPolygonLength = clippedPolygon.length;
|
|
3694
|
+
if (clippedPolygonLength < 3) {
|
|
3695
|
+
continue;
|
|
3696
|
+
}
|
|
3697
|
+
const polygonUpsampledIndices = scratchPolygonIndices;
|
|
3698
|
+
for (let p = 0; p < clippedPolygonLength; p++) {
|
|
3699
|
+
const polygonBary = clippedPolygon.barycentricCoordinates[p];
|
|
3700
|
+
const bA = polygonBary.x;
|
|
3701
|
+
const bB = polygonBary.y;
|
|
3702
|
+
const bC = polygonBary.z;
|
|
3703
|
+
const baryId = Math.ceil(bA) | Math.ceil(bB) << 1 | Math.ceil(bC) << 2;
|
|
3704
|
+
const primitiveIds = lookUpTableBaryToPrim[baryId];
|
|
3705
|
+
let upsampledIndex;
|
|
3706
|
+
let isNewVertex = false;
|
|
3707
|
+
if (primitiveIds.length === 1) {
|
|
3708
|
+
const pointPrimitiveId = primitiveIds[0];
|
|
3709
|
+
const pointIndex = indices[i + pointPrimitiveId];
|
|
3710
|
+
const pointKey = pointIndex;
|
|
3711
|
+
upsampledIndex = upsampledVertexMap[pointKey];
|
|
3712
|
+
if (upsampledIndex === void 0) {
|
|
3713
|
+
isNewVertex = true;
|
|
3714
|
+
upsampledIndex = upsampledVertexCount++;
|
|
3715
|
+
upsampledVertexMap[pointKey] = upsampledIndex;
|
|
3716
|
+
}
|
|
3717
|
+
} else if (primitiveIds.length === 2) {
|
|
3718
|
+
const edgePrimitiveIdA = primitiveIds[0];
|
|
3719
|
+
const edgePrimitiveIdB = primitiveIds[1];
|
|
3720
|
+
const edgeIndexA = indices[i + edgePrimitiveIdA];
|
|
3721
|
+
const edgeIndexB = indices[i + edgePrimitiveIdB];
|
|
3722
|
+
const prevBary = clippedPolygon.barycentricCoordinates[(p + clippedPolygonLength - 1) % clippedPolygonLength];
|
|
3723
|
+
const prevBaryId = Math.ceil(prevBary.x) | Math.ceil(prevBary.y) << 1 | Math.ceil(prevBary.z) << 2;
|
|
3724
|
+
const sameEdge = baryId === prevBaryId;
|
|
3725
|
+
const minIndex = Math.min(edgeIndexA, edgeIndexB);
|
|
3726
|
+
const maxIndex = Math.max(edgeIndexA, edgeIndexB);
|
|
3727
|
+
const baseKey = vertexCount + 2 * (minIndex * vertexCount + maxIndex);
|
|
3728
|
+
const firstKey = baseKey + 0;
|
|
3729
|
+
const secondKey = baseKey + 1;
|
|
3730
|
+
const firstEntry = upsampledVertexMap[firstKey];
|
|
3731
|
+
const secondEntry = upsampledVertexMap[secondKey];
|
|
3732
|
+
const useFirst = !sameEdge === (firstEntry === void 0 || secondEntry === void 0);
|
|
3733
|
+
upsampledIndex = useFirst ? firstEntry : secondEntry;
|
|
3734
|
+
if (upsampledIndex === void 0) {
|
|
3735
|
+
isNewVertex = true;
|
|
3736
|
+
upsampledIndex = upsampledVertexCount++;
|
|
3737
|
+
const edgeKey = useFirst ? firstKey : secondKey;
|
|
3738
|
+
upsampledVertexMap[edgeKey] = upsampledIndex;
|
|
3739
|
+
}
|
|
3740
|
+
} else {
|
|
3741
|
+
isNewVertex = true;
|
|
3742
|
+
upsampledIndex = upsampledVertexCount++;
|
|
3743
|
+
}
|
|
3744
|
+
polygonUpsampledIndices[p] = upsampledIndex;
|
|
3745
|
+
if (isNewVertex) {
|
|
3746
|
+
const triId = i / 3;
|
|
3747
|
+
resultTriIds.push(triId);
|
|
3748
|
+
const polygonUV = clippedPolygon.coordinates[p];
|
|
3749
|
+
const u = (polygonUV.x - minU) / (maxU - minU);
|
|
3750
|
+
const v = (polygonUV.y - minV) / (maxV - minV);
|
|
3751
|
+
resultUVs.push(u, v);
|
|
3752
|
+
resultBary.push(bA, bB);
|
|
3753
|
+
if (u === 0) {
|
|
3754
|
+
resultWestIndices.push(upsampledIndex);
|
|
3755
|
+
} else if (u === 1) {
|
|
3756
|
+
resultEastIndices.push(upsampledIndex);
|
|
3757
|
+
}
|
|
3758
|
+
if (v === 0) {
|
|
3759
|
+
resultSouthIndices.push(upsampledIndex);
|
|
3760
|
+
} else if (v === 1) {
|
|
3761
|
+
resultNorthIndices.push(upsampledIndex);
|
|
3762
|
+
}
|
|
3763
|
+
}
|
|
3764
|
+
}
|
|
3765
|
+
const ui0 = polygonUpsampledIndices[0];
|
|
3766
|
+
let ui1 = polygonUpsampledIndices[1];
|
|
3767
|
+
let ui2 = polygonUpsampledIndices[2];
|
|
3768
|
+
resultIndices.push(ui0, ui1, ui2);
|
|
3769
|
+
for (let j = 3; j < clippedPolygonLength; j++) {
|
|
3770
|
+
ui1 = ui2;
|
|
3771
|
+
ui2 = polygonUpsampledIndices[j];
|
|
3772
|
+
resultIndices.push(ui0, ui1, ui2);
|
|
3773
|
+
}
|
|
3774
|
+
}
|
|
3775
|
+
resultWestIndices.sort(function(a, b) {
|
|
3776
|
+
return resultUVs[a * 2 + 1] - resultUVs[b * 2 + 1];
|
|
3777
|
+
});
|
|
3778
|
+
resultSouthIndices.sort(function(a, b) {
|
|
3779
|
+
return resultUVs[b * 2 + 0] - resultUVs[a * 2 + 0];
|
|
3780
|
+
});
|
|
3781
|
+
resultEastIndices.sort(function(a, b) {
|
|
3782
|
+
return resultUVs[b * 2 + 1] - resultUVs[a * 2 + 1];
|
|
3783
|
+
});
|
|
3784
|
+
resultNorthIndices.sort(function(a, b) {
|
|
3785
|
+
return resultUVs[a * 2 + 0] - resultUVs[b * 2 + 0];
|
|
3786
|
+
});
|
|
3787
|
+
}
|
|
3788
|
+
var Cesium3DTilesTerrainGeometryProcessor_default = Cesium3DTilesTerrainGeometryProcessor;
|
|
3789
|
+
|
|
3790
|
+
export {
|
|
3791
|
+
Cesium3DTilesTerrainGeometryProcessor_default
|
|
3792
|
+
};
|