@vcmap/ui 5.0.0-rc.30 → 5.0.0-rc.31
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/buildHelpers.js +4 -3
- package/config/base.config.json +5 -4
- package/config/dev.config.json +4 -0
- package/config/graphFeatureInfo.config.json +1 -1
- package/config/projects.config.json +2 -2
- package/dist/assets/cesium/ThirdParty/Workers/basis_transcoder.js +1 -1
- package/dist/assets/cesium/Workers/chunk-227AJNOA.js +59 -0
- package/dist/assets/cesium/Workers/chunk-2R5O53JW.js +157 -0
- package/dist/assets/cesium/Workers/chunk-34YUDLRP.js +781 -0
- package/dist/assets/cesium/Workers/chunk-3W63OHNJ.js +100 -0
- package/dist/assets/cesium/Workers/chunk-4MFFIWUA.js +163 -0
- package/dist/assets/cesium/Workers/chunk-66QLLS45.js +218 -0
- package/dist/assets/cesium/Workers/chunk-6BTKZDRG.js +77 -0
- package/dist/assets/cesium/Workers/chunk-A4JVFBQ3.js +101 -0
- package/dist/assets/cesium/Workers/chunk-ABADGKYE.js +58 -0
- package/dist/assets/cesium/Workers/chunk-AFFLIKOH.js +353 -0
- package/dist/assets/cesium/Workers/chunk-AHKEZ2OE.js +629 -0
- package/dist/assets/cesium/Workers/chunk-C3SXRKRW.js +476 -0
- package/dist/assets/cesium/Workers/chunk-CCFQRR6D.js +55 -0
- package/dist/assets/cesium/Workers/chunk-CHHNOC2C.js +1860 -0
- package/dist/assets/cesium/Workers/chunk-CTELOFLA.js +196 -0
- package/dist/assets/cesium/Workers/chunk-DUHWWBQQ.js +3273 -0
- package/dist/assets/cesium/Workers/chunk-EW2GWJYB.js +44 -0
- package/dist/assets/cesium/Workers/chunk-GLZBE3ML.js +421 -0
- package/dist/assets/cesium/Workers/chunk-HARLBUOL.js +236 -0
- package/dist/assets/cesium/Workers/chunk-HQF437NJ.js +117 -0
- package/dist/assets/cesium/Workers/chunk-IPA4EACJ.js +368 -0
- package/dist/assets/cesium/Workers/chunk-J3JY6I2C.js +1009 -0
- package/dist/assets/cesium/Workers/chunk-JB2LWGH4.js +390 -0
- package/dist/assets/cesium/Workers/chunk-JS3AW5BK.js +634 -0
- package/dist/assets/cesium/Workers/chunk-K36FEYS7.js +452 -0
- package/dist/assets/cesium/Workers/chunk-KD4Y7CZL.js +400 -0
- package/dist/assets/cesium/Workers/chunk-KTJSNCK4.js +842 -0
- package/dist/assets/cesium/Workers/chunk-LLUNNUJV.js +258 -0
- package/dist/assets/cesium/Workers/{package.js → chunk-MPAZH4BF.js} +13 -2
- package/dist/assets/cesium/Workers/chunk-MYZB7C4T.js +1258 -0
- package/dist/assets/cesium/Workers/chunk-N3JIFFX2.js +501 -0
- package/dist/assets/cesium/Workers/chunk-O5AMBQ36.js +430 -0
- package/dist/assets/cesium/Workers/chunk-OAVNIRB4.js +124 -0
- package/dist/assets/cesium/Workers/chunk-OYFCF4PL.js +171 -0
- package/dist/assets/cesium/Workers/chunk-OZJDGN5F.js +1477 -0
- package/dist/assets/cesium/Workers/chunk-PCJWUS4M.js +2041 -0
- package/dist/assets/cesium/Workers/chunk-PFQBCKBM.js +8644 -0
- package/dist/assets/cesium/Workers/chunk-QIKODV5G.js +305 -0
- package/dist/assets/cesium/Workers/chunk-QJ3DFBH3.js +73 -0
- package/dist/assets/cesium/Workers/chunk-QMEMZIJI.js +138 -0
- package/dist/assets/cesium/Workers/chunk-QT3MPEMI.js +102 -0
- package/dist/assets/cesium/Workers/chunk-RP2A7BR5.js +289 -0
- package/dist/assets/cesium/Workers/chunk-RW6LU2CJ.js +138 -0
- package/dist/assets/cesium/Workers/chunk-TFC6TZ3S.js +757 -0
- package/dist/assets/cesium/Workers/chunk-V3NGATMV.js +693 -0
- package/dist/assets/cesium/Workers/chunk-VLGOATD6.js +1075 -0
- package/dist/assets/cesium/Workers/chunk-WXTV4ATB.js +39 -0
- package/dist/assets/cesium/Workers/chunk-X4SU25DT.js +302 -0
- package/dist/assets/cesium/Workers/chunk-XTY7B2N6.js +2716 -0
- package/dist/assets/cesium/Workers/chunk-XY7MGBKC.js +513 -0
- package/dist/assets/cesium/Workers/chunk-Z24VKNDO.js +834 -0
- package/dist/assets/cesium/Workers/chunk-ZA25DG4Y.js +684 -0
- package/dist/assets/cesium/Workers/chunk-ZFOBYDGF.js +73 -0
- package/dist/assets/cesium/Workers/combineGeometry.js +65 -15
- package/dist/assets/cesium/Workers/createBoxGeometry.js +55 -10
- package/dist/assets/cesium/Workers/createBoxOutlineGeometry.js +231 -310
- package/dist/assets/cesium/Workers/createCircleGeometry.js +185 -202
- package/dist/assets/cesium/Workers/createCircleOutlineGeometry.js +141 -155
- package/dist/assets/cesium/Workers/createCoplanarPolygonGeometry.js +477 -557
- package/dist/assets/cesium/Workers/createCoplanarPolygonOutlineGeometry.js +218 -230
- package/dist/assets/cesium/Workers/createCorridorGeometry.js +1162 -1307
- package/dist/assets/cesium/Workers/createCorridorOutlineGeometry.js +533 -569
- package/dist/assets/cesium/Workers/createCylinderGeometry.js +57 -10
- package/dist/assets/cesium/Workers/createCylinderOutlineGeometry.js +224 -258
- package/dist/assets/cesium/Workers/createEllipseGeometry.js +68 -12
- package/dist/assets/cesium/Workers/createEllipseOutlineGeometry.js +61 -12
- package/dist/assets/cesium/Workers/createEllipsoidGeometry.js +56 -10
- package/dist/assets/cesium/Workers/createEllipsoidOutlineGeometry.js +58 -13
- package/dist/assets/cesium/Workers/createFrustumGeometry.js +55 -10
- package/dist/assets/cesium/Workers/createFrustumOutlineGeometry.js +226 -243
- package/dist/assets/cesium/Workers/createGeometry.js +143 -48
- package/dist/assets/cesium/Workers/createGroundPolylineGeometry.js +1484 -2011
- package/dist/assets/cesium/Workers/createPlaneGeometry.js +216 -243
- package/dist/assets/cesium/Workers/createPlaneOutlineGeometry.js +121 -113
- package/dist/assets/cesium/Workers/createPolygonGeometry.js +1041 -1327
- package/dist/assets/cesium/Workers/createPolygonOutlineGeometry.js +516 -657
- package/dist/assets/cesium/Workers/createPolylineGeometry.js +471 -547
- package/dist/assets/cesium/Workers/createPolylineVolumeGeometry.js +352 -384
- package/dist/assets/cesium/Workers/createPolylineVolumeOutlineGeometry.js +271 -295
- package/dist/assets/cesium/Workers/createRectangleGeometry.js +1128 -1331
- package/dist/assets/cesium/Workers/createRectangleOutlineGeometry.js +445 -500
- package/dist/assets/cesium/Workers/createSimplePolylineGeometry.js +381 -440
- package/dist/assets/cesium/Workers/createSphereGeometry.js +112 -118
- package/dist/assets/cesium/Workers/createSphereOutlineGeometry.js +112 -121
- package/dist/assets/cesium/Workers/createTaskProcessorWorker.js +32 -127
- package/dist/assets/cesium/Workers/createVectorTileClampedPolylines.js +462 -505
- package/dist/assets/cesium/Workers/createVectorTileGeometries.js +377 -436
- package/dist/assets/cesium/Workers/createVectorTilePoints.js +110 -77
- package/dist/assets/cesium/Workers/createVectorTilePolygons.js +369 -391
- package/dist/assets/cesium/Workers/createVectorTilePolylines.js +252 -244
- package/dist/assets/cesium/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +543 -615
- package/dist/assets/cesium/Workers/createVerticesFromHeightmap.js +2244 -2677
- package/dist/assets/cesium/Workers/createVerticesFromQuantizedTerrainMesh.js +682 -926
- package/dist/assets/cesium/Workers/createWallGeometry.js +459 -593
- package/dist/assets/cesium/Workers/createWallOutlineGeometry.js +324 -419
- package/dist/assets/cesium/Workers/decodeDraco.js +327 -347
- package/dist/assets/cesium/Workers/decodeGoogleEarthEnterprisePacket.js +2530 -3567
- package/dist/assets/cesium/Workers/decodeI3S.js +765 -970
- package/dist/assets/cesium/Workers/transcodeKTX2.js +3353 -1464
- package/dist/assets/cesium/Workers/transferTypedArrayTest.js +3 -4
- package/dist/assets/cesium/Workers/upsampleQuantizedTerrainMesh.js +748 -953
- package/dist/assets/{cesium.eaf7cc.js → cesium.77d0f7.js} +8915 -13165
- package/dist/assets/cesium.js +1 -1
- package/dist/assets/{core.b16511.js → core.720589.js} +3421 -3365
- package/dist/assets/core.js +1 -1
- package/dist/assets/index-dd539204.js +1 -0
- package/dist/assets/{ol.4bbf0f.js → ol.e48649.js} +4 -4
- package/dist/assets/ol.js +1 -1
- package/dist/assets/{ui.ab815e.css → ui.50452a.css} +1 -1
- package/dist/assets/{ui.ab815e.js → ui.50452a.js} +4270 -4355
- package/dist/assets/ui.js +1 -1
- package/dist/assets/vue.js +2 -2
- package/dist/assets/{vuetify.ea3fa8.js → vuetify.f0a769.js} +1 -1
- package/dist/assets/vuetify.js +2 -2
- package/dist/index.html +27 -23
- package/index.html +23 -22
- package/package.json +5 -5
- package/plugins/@vcmap-show-case/plugin-editors/PluginEditors.vue +119 -0
- package/plugins/@vcmap-show-case/plugin-editors/index.js +41 -0
- package/plugins/@vcmap-show-case/plugin-editors/package.json +5 -0
- package/plugins/{@vcmap → @vcmap-show-case}/project-selector/ProjectSelectorComponent.vue +1 -1
- package/plugins/{@vcmap → @vcmap-show-case}/project-selector/config.json +2 -2
- package/plugins/{@vcmap → @vcmap-show-case}/project-selector/package.json +1 -1
- package/plugins/{@vcmap → @vcmap-show-case}/simple-graph/package.json +1 -1
- package/plugins/@vcmap-show-case/table-example/DataTableExample.vue +1 -1
- package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/ThemeChangerComponent.vue +1 -1
- package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/config.json +2 -2
- package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/package.json +1 -1
- package/plugins/@vcmap-show-case/vector-properties-example/vectorPropertiesExample.vue +20 -1
- package/plugins/package.json +6 -2
- package/src/application/VcsAttributions.vue +27 -20
- package/src/components/form-inputs-controls/VcsChipArrayInput.vue +22 -14
- package/src/components/form-inputs-controls/VcsSlider.vue +1 -0
- package/src/components/icons/2DAreaIcon.vue +2 -17
- package/src/components/icons/2DDistanceIcon.vue +0 -3
- package/src/components/icons/3DAreaIcon.vue +2 -17
- package/src/components/icons/3DDistanceIcon.vue +0 -3
- package/src/components/icons/3DHeightIcon.vue +0 -3
- package/src/components/icons/AngleIcon.vue +0 -1
- package/src/components/icons/AssociationsIcon.vue +1 -3
- package/src/components/icons/AxisIcon.vue +0 -4
- package/src/components/icons/BoundingBoxIcon.vue +1 -4
- package/src/components/icons/CheckboxIcon.vue +0 -2
- package/src/components/icons/CheckboxIndeterminateIcon.vue +1 -5
- package/src/components/icons/CircleIcon.vue +1 -6
- package/src/components/icons/ClippingHorizontalIcon.vue +0 -1
- package/src/components/icons/ClippingIcon.vue +0 -1
- package/src/components/icons/ClippingVerticalIcon.vue +0 -1
- package/src/components/icons/ColorPickerIcon.vue +0 -1
- package/src/components/icons/ColorSwatchIcon.vue +0 -2
- package/src/components/icons/CommentIcon.vue +0 -1
- package/src/components/icons/CompassIcon.vue +0 -2
- package/src/components/icons/ComponentsIcon.vue +0 -1
- package/src/components/icons/ConeIcon.vue +1 -4
- package/src/components/icons/DimensionsHouseIcon.vue +0 -2
- package/src/components/icons/EditIcon.vue +0 -1
- package/src/components/icons/EditVerticesIcon.vue +0 -4
- package/src/components/icons/ElevationProfileIcon.vue +1 -13
- package/src/components/icons/ExportAreaIcon.vue +0 -1
- package/src/components/icons/ExportFlightIcon.vue +0 -1
- package/src/components/icons/ExportIcon.vue +12 -8
- package/src/components/icons/ExternalLinkIcon.vue +0 -2
- package/src/components/icons/FastForwardIcon.vue +0 -1
- package/src/components/icons/FilterIcon.vue +0 -1
- package/src/components/icons/GlobeNatureIcon.vue +0 -3
- package/src/components/icons/GroundIcon.vue +0 -1
- package/src/components/icons/HealthCareIndustriesIcon.vue +1 -11
- package/src/components/icons/HideIcon.vue +0 -1
- package/src/components/icons/HomePointIcon.vue +0 -1
- package/src/components/icons/HospitalsIcon.vue +1 -20
- package/src/components/icons/HouseIcon.vue +3 -13
- package/src/components/icons/ImportIcon.vue +6 -14
- package/src/components/icons/InfoIcon.vue +0 -2
- package/src/components/icons/KebabIcon.vue +1 -9
- package/src/components/icons/LabelIcon.vue +0 -2
- package/src/components/icons/LayersIcon.vue +1 -9
- package/src/components/icons/LegendIcon.vue +0 -1
- package/src/components/icons/LineIcon.vue +0 -2
- package/src/components/icons/LinkIcon.vue +0 -1
- package/src/components/icons/LogoutIcon.vue +0 -1
- package/src/components/icons/MapIcon.vue +0 -2
- package/src/components/icons/MenuIcon.vue +1 -5
- package/src/components/icons/MinusIcon.vue +0 -2
- package/src/components/icons/ObjectSelectIcon.vue +0 -2
- package/src/components/icons/ObliqueViewIcon.vue +0 -1
- package/src/components/icons/PdfIcon.vue +0 -1
- package/src/components/icons/PedestrianIcon.vue +0 -1
- package/src/components/icons/PenIcon.vue +0 -1
- package/src/components/icons/PlayCircleIcon.vue +1 -8
- package/src/components/icons/PlusIcon.vue +0 -2
- package/src/components/icons/PoiIcon.vue +0 -1
- package/src/components/icons/PointIcon.vue +2 -6
- package/src/components/icons/PointSelectIcon.vue +0 -1
- package/src/components/icons/PresentationModeIcon.vue +0 -1
- package/src/components/icons/ProgressIcon.vue +1 -1
- package/src/components/icons/QueryIcon.vue +0 -1
- package/src/components/icons/RectangleIcon.vue +1 -6
- package/src/components/icons/ReturnIcon.vue +0 -1
- package/src/components/icons/RewindIcon.vue +0 -1
- package/src/components/icons/RotateLeftIcon.vue +0 -1
- package/src/components/icons/RotateRightIcon.vue +0 -1
- package/src/components/icons/ScreenshotIcon.vue +1 -6
- package/src/components/icons/SearchIcon.vue +0 -1
- package/src/components/icons/ShadowIcon.vue +0 -2
- package/src/components/icons/ShapesIcon.vue +1 -4
- package/src/components/icons/ShareIcon.vue +0 -1
- package/src/components/icons/SimpleCircleFilledIcon.vue +0 -1
- package/src/components/icons/SimpleCircleHalfFilledIcon.vue +0 -1
- package/src/components/icons/SimpleCircleOutlinedIcon.vue +1 -7
- package/src/components/icons/SkipPreviousIcon.vue +1 -6
- package/src/components/icons/SplitViewIcon.vue +0 -1
- package/src/components/icons/TextStyleIcon.vue +0 -3
- package/src/components/icons/ThreeDimensionsIcon.vue +0 -1
- package/src/components/icons/ToolsIcon.vue +0 -1
- package/src/components/icons/TouchIcon.vue +0 -1
- package/src/components/icons/TriangleIcon.vue +0 -3
- package/src/components/icons/TwoDimensionsIcon.vue +0 -2
- package/src/components/icons/UploadIcon.vue +0 -1
- package/src/components/icons/UserProfileIcon.vue +0 -1
- package/src/components/icons/UserShareIcon.vue +0 -1
- package/src/components/icons/ViewpointFlightIcon.vue +0 -1
- package/src/components/icons/ViewpointIcon.vue +0 -1
- package/src/components/icons/Viewshed360Icon.vue +0 -1
- package/src/components/icons/ViewshedConeIcon.vue +0 -1
- package/src/components/icons/ViewshedIcon.vue +0 -1
- package/src/components/icons/WalkingIcon.vue +0 -1
- package/src/components/icons/WallIcon.vue +1 -4
- package/src/components/icons/WandIcon.vue +22 -70
- package/src/components/lists/VcsList.vue +18 -12
- package/src/components/plugins/AbstractConfigEditor.vue +2 -2
- package/src/components/tables/VcsDataTable.vue +1 -1
- package/src/components/vector-properties/VcsVectorPropertiesComponent.vue +57 -14
- package/src/contentTree/contentTreeCollection.js +30 -9
- package/src/i18n/de.js +8 -5
- package/src/i18n/en.js +8 -5
- package/src/i18n/i18nCollection.js +19 -65
- package/src/manager/buttonManager.js +4 -0
- package/src/manager/contextMenu/contextMenuManager.js +2 -0
- package/src/pluginHelper.js +2 -2
- package/src/vcsUiApp.js +9 -4
- package/src/vuePlugins/i18n.js +0 -8
- package/dist/assets/cesium/ThirdParty/Workers/draco_decoder_nodejs.js +0 -117
- package/dist/assets/cesium/Workers/ArcType-2d9abbbc.js +0 -37
- package/dist/assets/cesium/Workers/AttributeCompression-f9f6c717.js +0 -716
- package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-4140c51f.js +0 -258
- package/dist/assets/cesium/Workers/BoundingRectangle-c714b156.js +0 -369
- package/dist/assets/cesium/Workers/BoxGeometry-6f3da43d.js +0 -884
- package/dist/assets/cesium/Workers/Check-6ede7e26.js +0 -290
- package/dist/assets/cesium/Workers/Color-8a565ff2.js +0 -2262
- package/dist/assets/cesium/Workers/ComponentDatatype-cf1fa08e.js +0 -341
- package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-4b4d4096.js +0 -132
- package/dist/assets/cesium/Workers/CorridorGeometryLibrary-7b94502b.js +0 -498
- package/dist/assets/cesium/Workers/CylinderGeometry-ca070b87.js +0 -467
- package/dist/assets/cesium/Workers/CylinderGeometryLibrary-7bf291b4.js +0 -63
- package/dist/assets/cesium/Workers/EllipseGeometry-122e51fa.js +0 -1304
- package/dist/assets/cesium/Workers/EllipseGeometryLibrary-4d326efc.js +0 -366
- package/dist/assets/cesium/Workers/EllipseOutlineGeometry-16cc2bd7.js +0 -443
- package/dist/assets/cesium/Workers/EllipsoidGeodesic-5b3623dc.js +0 -520
- package/dist/assets/cesium/Workers/EllipsoidGeometry-cb148ca2.js +0 -637
- package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-0fa10c79.js +0 -454
- package/dist/assets/cesium/Workers/EllipsoidRhumbLine-ef872433.js +0 -741
- package/dist/assets/cesium/Workers/EllipsoidTangentPlane-6dd1b7af.js +0 -373
- package/dist/assets/cesium/Workers/EncodedCartesian3-57415c8a.js +0 -171
- package/dist/assets/cesium/Workers/FrustumGeometry-ee73037c.js +0 -2540
- package/dist/assets/cesium/Workers/GeometryAttribute-ff5b4fb1.js +0 -619
- package/dist/assets/cesium/Workers/GeometryAttributes-ad136444.js +0 -91
- package/dist/assets/cesium/Workers/GeometryInstance-34d9e21e.js +0 -121
- package/dist/assets/cesium/Workers/GeometryOffsetAttribute-9ad0019c.js +0 -16
- package/dist/assets/cesium/Workers/GeometryPipeline-1f8fbf05.js +0 -3690
- package/dist/assets/cesium/Workers/IndexDatatype-2643aa47.js +0 -200
- package/dist/assets/cesium/Workers/IntersectionTests-70d39ba9.js +0 -1836
- package/dist/assets/cesium/Workers/Math-0a2ac845.js +0 -1340
- package/dist/assets/cesium/Workers/Matrix2-e1298525.js +0 -7086
- package/dist/assets/cesium/Workers/Matrix3-41c58dde.js +0 -4283
- package/dist/assets/cesium/Workers/OrientedBoundingBox-159cf1d6.js +0 -1259
- package/dist/assets/cesium/Workers/Plane-4c3d403b.js +0 -309
- package/dist/assets/cesium/Workers/PolygonGeometryLibrary-076a5d25.js +0 -1074
- package/dist/assets/cesium/Workers/PolygonPipeline-b9f2810a.js +0 -1344
- package/dist/assets/cesium/Workers/PolylinePipeline-639192e0.js +0 -573
- package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-b73549fb.js +0 -781
- package/dist/assets/cesium/Workers/PrimitivePipeline-10ede1b6.js +0 -966
- package/dist/assets/cesium/Workers/RectangleGeometryLibrary-c35a7356.js +0 -280
- package/dist/assets/cesium/Workers/RuntimeError-ef395448.js +0 -68
- package/dist/assets/cesium/Workers/TerrainEncoding-668d242f.js +0 -1227
- package/dist/assets/cesium/Workers/Transforms-a2a85221.js +0 -14712
- package/dist/assets/cesium/Workers/VertexFormat-030f11ff.js +0 -312
- package/dist/assets/cesium/Workers/WallGeometryLibrary-1938bf0d.js +0 -211
- package/dist/assets/cesium/Workers/WebGLConstants-0b1ce7ba.js +0 -620
- package/dist/assets/cesium/Workers/WebMercatorProjection-13ed1a6e.js +0 -151
- package/dist/assets/cesium/Workers/arrayRemoveDuplicates-d2061e85.js +0 -129
- package/dist/assets/cesium/Workers/cesiumWorkerBootstrapper.js +0 -1363
- package/dist/assets/cesium/Workers/combine-d9581036.js +0 -82
- package/dist/assets/cesium/Workers/defaultValue-fe22d8c0.js +0 -51
- package/dist/assets/index-c115e3a1.js +0 -1
- package/plugins/@vcmap/create-link/fallbackCreateLink.vue +0 -76
- package/plugins/@vcmap/create-link/index.js +0 -95
- package/plugins/@vcmap/create-link/package.json +0 -6
- package/plugins/@vcmap/search-nominatim/LICENSE.md +0 -13
- package/plugins/@vcmap/search-nominatim/README.md +0 -3
- package/plugins/@vcmap/search-nominatim/SearchNominatimEditor.vue +0 -90
- package/plugins/@vcmap/search-nominatim/config.json +0 -3
- package/plugins/@vcmap/search-nominatim/index.js +0 -66
- package/plugins/@vcmap/search-nominatim/nominatim.js +0 -175
- package/plugins/@vcmap/search-nominatim/package.json +0 -9
- /package/dist/assets/{vue.67e80f.js → vue.5d696e.js} +0 -0
- /package/dist/assets/{vuetify.ea3fa8.css → vuetify.f0a769.css} +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/project-selector/ModulesListComponent.vue +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/project-selector/README.md +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/project-selector/de.json +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/project-selector/en.json +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/project-selector/index.js +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/simple-graph/README.md +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/simple-graph/SimpleGraphComponent.vue +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/simple-graph/index.js +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/simple-graph/simpleGraphView.js +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/README.md +0 -0
- /package/plugins/{@vcmap → @vcmap-show-case}/theme-changer/index.js +0 -0
@@ -1,579 +1,487 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
1
|
+
/**
|
2
|
+
* @license
|
3
|
+
* Cesium - https://github.com/CesiumGS/cesium
|
4
|
+
* Version 1.109.3
|
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
|
+
EllipsoidalOccluder_default,
|
28
|
+
TerrainEncoding_default
|
29
|
+
} from "./chunk-TFC6TZ3S.js";
|
30
|
+
import {
|
31
|
+
createTaskProcessorWorker_default
|
32
|
+
} from "./chunk-A4JVFBQ3.js";
|
33
|
+
import {
|
34
|
+
OrientedBoundingBox_default
|
35
|
+
} from "./chunk-Z24VKNDO.js";
|
36
|
+
import {
|
37
|
+
AttributeCompression_default
|
38
|
+
} from "./chunk-O5AMBQ36.js";
|
39
|
+
import "./chunk-RP2A7BR5.js";
|
40
|
+
import "./chunk-2R5O53JW.js";
|
41
|
+
import "./chunk-MYZB7C4T.js";
|
42
|
+
import "./chunk-OYFCF4PL.js";
|
43
|
+
import {
|
44
|
+
IndexDatatype_default
|
45
|
+
} from "./chunk-RW6LU2CJ.js";
|
46
|
+
import {
|
47
|
+
BoundingSphere_default
|
48
|
+
} from "./chunk-PFQBCKBM.js";
|
49
|
+
import "./chunk-QJ3DFBH3.js";
|
50
|
+
import {
|
51
|
+
Cartesian2_default,
|
52
|
+
Rectangle_default
|
53
|
+
} from "./chunk-DUHWWBQQ.js";
|
54
|
+
import "./chunk-LLUNNUJV.js";
|
55
|
+
import {
|
56
|
+
Cartesian3_default,
|
57
|
+
Cartographic_default,
|
58
|
+
Ellipsoid_default
|
59
|
+
} from "./chunk-PCJWUS4M.js";
|
60
|
+
import {
|
61
|
+
Math_default
|
62
|
+
} from "./chunk-N3JIFFX2.js";
|
63
|
+
import "./chunk-AHKEZ2OE.js";
|
64
|
+
import "./chunk-ABADGKYE.js";
|
65
|
+
import "./chunk-WXTV4ATB.js";
|
66
|
+
import {
|
67
|
+
Check_default,
|
68
|
+
DeveloperError_default
|
69
|
+
} from "./chunk-4MFFIWUA.js";
|
70
|
+
import {
|
71
|
+
defined_default
|
72
|
+
} from "./chunk-6BTKZDRG.js";
|
73
|
+
|
74
|
+
// packages/engine/Source/Core/Intersections2D.js
|
75
|
+
var Intersections2D = {};
|
76
|
+
Intersections2D.clipTriangleAtAxisAlignedThreshold = function(threshold, keepAbove, u0, u1, u2, result) {
|
77
|
+
if (!defined_default(threshold)) {
|
78
|
+
throw new DeveloperError_default("threshold is required.");
|
79
|
+
}
|
80
|
+
if (!defined_default(keepAbove)) {
|
81
|
+
throw new DeveloperError_default("keepAbove is required.");
|
82
|
+
}
|
83
|
+
if (!defined_default(u0)) {
|
84
|
+
throw new DeveloperError_default("u0 is required.");
|
85
|
+
}
|
86
|
+
if (!defined_default(u1)) {
|
87
|
+
throw new DeveloperError_default("u1 is required.");
|
88
|
+
}
|
89
|
+
if (!defined_default(u2)) {
|
90
|
+
throw new DeveloperError_default("u2 is required.");
|
91
|
+
}
|
92
|
+
if (!defined_default(result)) {
|
93
|
+
result = [];
|
94
|
+
} else {
|
95
|
+
result.length = 0;
|
96
|
+
}
|
97
|
+
let u0Behind;
|
98
|
+
let u1Behind;
|
99
|
+
let u2Behind;
|
100
|
+
if (keepAbove) {
|
101
|
+
u0Behind = u0 < threshold;
|
102
|
+
u1Behind = u1 < threshold;
|
103
|
+
u2Behind = u2 < threshold;
|
104
|
+
} else {
|
105
|
+
u0Behind = u0 > threshold;
|
106
|
+
u1Behind = u1 > threshold;
|
107
|
+
u2Behind = u2 > threshold;
|
108
|
+
}
|
109
|
+
const numBehind = u0Behind + u1Behind + u2Behind;
|
110
|
+
let u01Ratio;
|
111
|
+
let u02Ratio;
|
112
|
+
let u12Ratio;
|
113
|
+
let u10Ratio;
|
114
|
+
let u20Ratio;
|
115
|
+
let u21Ratio;
|
116
|
+
if (numBehind === 1) {
|
117
|
+
if (u0Behind) {
|
118
|
+
u01Ratio = (threshold - u0) / (u1 - u0);
|
119
|
+
u02Ratio = (threshold - u0) / (u2 - u0);
|
120
|
+
result.push(1);
|
121
|
+
result.push(2);
|
122
|
+
if (u02Ratio !== 1) {
|
123
|
+
result.push(-1);
|
118
124
|
result.push(0);
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
result.push(u10Ratio);
|
125
|
-
}
|
126
|
-
|
127
|
-
if (u12Ratio !== 1.0) {
|
128
|
-
result.push(-1);
|
129
|
-
result.push(1);
|
130
|
-
result.push(2);
|
131
|
-
result.push(u12Ratio);
|
132
|
-
}
|
133
|
-
} else if (u2Behind) {
|
134
|
-
u20Ratio = (threshold - u2) / (u0 - u2);
|
135
|
-
u21Ratio = (threshold - u2) / (u1 - u2);
|
136
|
-
|
125
|
+
result.push(2);
|
126
|
+
result.push(u02Ratio);
|
127
|
+
}
|
128
|
+
if (u01Ratio !== 1) {
|
129
|
+
result.push(-1);
|
137
130
|
result.push(0);
|
138
|
-
|
139
131
|
result.push(1);
|
140
|
-
|
141
|
-
if (u21Ratio !== 1.0) {
|
142
|
-
result.push(-1);
|
143
|
-
result.push(2);
|
144
|
-
result.push(1);
|
145
|
-
result.push(u21Ratio);
|
146
|
-
}
|
147
|
-
|
148
|
-
if (u20Ratio !== 1.0) {
|
149
|
-
result.push(-1);
|
150
|
-
result.push(2);
|
151
|
-
result.push(0);
|
152
|
-
result.push(u20Ratio);
|
153
|
-
}
|
132
|
+
result.push(u01Ratio);
|
154
133
|
}
|
155
|
-
} else if (
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
134
|
+
} else if (u1Behind) {
|
135
|
+
u12Ratio = (threshold - u1) / (u2 - u1);
|
136
|
+
u10Ratio = (threshold - u1) / (u0 - u1);
|
137
|
+
result.push(2);
|
138
|
+
result.push(0);
|
139
|
+
if (u10Ratio !== 1) {
|
162
140
|
result.push(-1);
|
163
141
|
result.push(1);
|
164
142
|
result.push(0);
|
165
143
|
result.push(u10Ratio);
|
166
|
-
|
144
|
+
}
|
145
|
+
if (u12Ratio !== 1) {
|
167
146
|
result.push(-1);
|
168
|
-
result.push(2);
|
169
|
-
result.push(0);
|
170
|
-
result.push(u20Ratio);
|
171
|
-
} else if (!u1Behind && u1 !== threshold) {
|
172
|
-
u21Ratio = (threshold - u2) / (u1 - u2);
|
173
|
-
u01Ratio = (threshold - u0) / (u1 - u0);
|
174
|
-
|
175
147
|
result.push(1);
|
176
|
-
|
148
|
+
result.push(2);
|
149
|
+
result.push(u12Ratio);
|
150
|
+
}
|
151
|
+
} else if (u2Behind) {
|
152
|
+
u20Ratio = (threshold - u2) / (u0 - u2);
|
153
|
+
u21Ratio = (threshold - u2) / (u1 - u2);
|
154
|
+
result.push(0);
|
155
|
+
result.push(1);
|
156
|
+
if (u21Ratio !== 1) {
|
177
157
|
result.push(-1);
|
178
158
|
result.push(2);
|
179
159
|
result.push(1);
|
180
160
|
result.push(u21Ratio);
|
181
|
-
|
161
|
+
}
|
162
|
+
if (u20Ratio !== 1) {
|
182
163
|
result.push(-1);
|
183
|
-
result.push(0);
|
184
|
-
result.push(1);
|
185
|
-
result.push(u01Ratio);
|
186
|
-
} else if (!u2Behind && u2 !== threshold) {
|
187
|
-
u02Ratio = (threshold - u0) / (u2 - u0);
|
188
|
-
u12Ratio = (threshold - u1) / (u2 - u1);
|
189
|
-
|
190
164
|
result.push(2);
|
191
|
-
|
192
|
-
result.push(-1);
|
193
165
|
result.push(0);
|
194
|
-
result.push(
|
195
|
-
result.push(u02Ratio);
|
196
|
-
|
197
|
-
result.push(-1);
|
198
|
-
result.push(1);
|
199
|
-
result.push(2);
|
200
|
-
result.push(u12Ratio);
|
166
|
+
result.push(u20Ratio);
|
201
167
|
}
|
202
|
-
}
|
203
|
-
|
168
|
+
}
|
169
|
+
} else if (numBehind === 2) {
|
170
|
+
if (!u0Behind && u0 !== threshold) {
|
171
|
+
u10Ratio = (threshold - u1) / (u0 - u1);
|
172
|
+
u20Ratio = (threshold - u2) / (u0 - u2);
|
173
|
+
result.push(0);
|
174
|
+
result.push(-1);
|
175
|
+
result.push(1);
|
204
176
|
result.push(0);
|
177
|
+
result.push(u10Ratio);
|
178
|
+
result.push(-1);
|
179
|
+
result.push(2);
|
180
|
+
result.push(0);
|
181
|
+
result.push(u20Ratio);
|
182
|
+
} else if (!u1Behind && u1 !== threshold) {
|
183
|
+
u21Ratio = (threshold - u2) / (u1 - u2);
|
184
|
+
u01Ratio = (threshold - u0) / (u1 - u0);
|
205
185
|
result.push(1);
|
186
|
+
result.push(-1);
|
187
|
+
result.push(2);
|
188
|
+
result.push(1);
|
189
|
+
result.push(u21Ratio);
|
190
|
+
result.push(-1);
|
191
|
+
result.push(0);
|
192
|
+
result.push(1);
|
193
|
+
result.push(u01Ratio);
|
194
|
+
} else if (!u2Behind && u2 !== threshold) {
|
195
|
+
u02Ratio = (threshold - u0) / (u2 - u0);
|
196
|
+
u12Ratio = (threshold - u1) / (u2 - u1);
|
197
|
+
result.push(2);
|
198
|
+
result.push(-1);
|
199
|
+
result.push(0);
|
206
200
|
result.push(2);
|
201
|
+
result.push(u02Ratio);
|
202
|
+
result.push(-1);
|
203
|
+
result.push(1);
|
204
|
+
result.push(2);
|
205
|
+
result.push(u12Ratio);
|
207
206
|
}
|
208
|
-
|
209
|
-
|
207
|
+
} else if (numBehind !== 3) {
|
208
|
+
result.push(0);
|
209
|
+
result.push(1);
|
210
|
+
result.push(2);
|
211
|
+
}
|
212
|
+
return result;
|
213
|
+
};
|
214
|
+
Intersections2D.computeBarycentricCoordinates = function(x, y, x1, y1, x2, y2, x3, y3, result) {
|
215
|
+
if (!defined_default(x)) {
|
216
|
+
throw new DeveloperError_default("x is required.");
|
217
|
+
}
|
218
|
+
if (!defined_default(y)) {
|
219
|
+
throw new DeveloperError_default("y is required.");
|
220
|
+
}
|
221
|
+
if (!defined_default(x1)) {
|
222
|
+
throw new DeveloperError_default("x1 is required.");
|
223
|
+
}
|
224
|
+
if (!defined_default(y1)) {
|
225
|
+
throw new DeveloperError_default("y1 is required.");
|
226
|
+
}
|
227
|
+
if (!defined_default(x2)) {
|
228
|
+
throw new DeveloperError_default("x2 is required.");
|
229
|
+
}
|
230
|
+
if (!defined_default(y2)) {
|
231
|
+
throw new DeveloperError_default("y2 is required.");
|
232
|
+
}
|
233
|
+
if (!defined_default(x3)) {
|
234
|
+
throw new DeveloperError_default("x3 is required.");
|
235
|
+
}
|
236
|
+
if (!defined_default(y3)) {
|
237
|
+
throw new DeveloperError_default("y3 is required.");
|
238
|
+
}
|
239
|
+
const x1mx3 = x1 - x3;
|
240
|
+
const x3mx2 = x3 - x2;
|
241
|
+
const y2my3 = y2 - y3;
|
242
|
+
const y1my3 = y1 - y3;
|
243
|
+
const inverseDeterminant = 1 / (y2my3 * x1mx3 + x3mx2 * y1my3);
|
244
|
+
const ymy3 = y - y3;
|
245
|
+
const xmx3 = x - x3;
|
246
|
+
const l1 = (y2my3 * xmx3 + x3mx2 * ymy3) * inverseDeterminant;
|
247
|
+
const l2 = (-y1my3 * xmx3 + x1mx3 * ymy3) * inverseDeterminant;
|
248
|
+
const l3 = 1 - l1 - l2;
|
249
|
+
if (defined_default(result)) {
|
250
|
+
result.x = l1;
|
251
|
+
result.y = l2;
|
252
|
+
result.z = l3;
|
210
253
|
return result;
|
211
|
-
}
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
254
|
+
}
|
255
|
+
return new Cartesian3_default(l1, l2, l3);
|
256
|
+
};
|
257
|
+
Intersections2D.computeLineSegmentLineSegmentIntersection = function(x00, y00, x01, y01, x10, y10, x11, y11, result) {
|
258
|
+
Check_default.typeOf.number("x00", x00);
|
259
|
+
Check_default.typeOf.number("y00", y00);
|
260
|
+
Check_default.typeOf.number("x01", x01);
|
261
|
+
Check_default.typeOf.number("y01", y01);
|
262
|
+
Check_default.typeOf.number("x10", x10);
|
263
|
+
Check_default.typeOf.number("y10", y10);
|
264
|
+
Check_default.typeOf.number("x11", x11);
|
265
|
+
Check_default.typeOf.number("y11", y11);
|
266
|
+
const numerator1A = (x11 - x10) * (y00 - y10) - (y11 - y10) * (x00 - x10);
|
267
|
+
const numerator1B = (x01 - x00) * (y00 - y10) - (y01 - y00) * (x00 - x10);
|
268
|
+
const denominator1 = (y11 - y10) * (x01 - x00) - (x11 - x10) * (y01 - y00);
|
269
|
+
if (denominator1 === 0) {
|
270
|
+
return;
|
271
|
+
}
|
272
|
+
const ua1 = numerator1A / denominator1;
|
273
|
+
const ub1 = numerator1B / denominator1;
|
274
|
+
if (ua1 >= 0 && ua1 <= 1 && ub1 >= 0 && ub1 <= 1) {
|
275
|
+
if (!defined_default(result)) {
|
276
|
+
result = new Cartesian2_default();
|
277
|
+
}
|
278
|
+
result.x = x00 + ua1 * (x01 - x00);
|
279
|
+
result.y = y00 + ua1 * (y01 - y00);
|
280
|
+
return result;
|
281
|
+
}
|
282
|
+
};
|
283
|
+
var Intersections2D_default = Intersections2D;
|
284
|
+
|
285
|
+
// packages/engine/Source/Workers/upsampleQuantizedTerrainMesh.js
|
286
|
+
var maxShort = 32767;
|
287
|
+
var halfMaxShort = maxShort / 2 | 0;
|
288
|
+
var clipScratch = [];
|
289
|
+
var clipScratch2 = [];
|
290
|
+
var verticesScratch = [];
|
291
|
+
var cartographicScratch = new Cartographic_default();
|
292
|
+
var cartesian3Scratch = new Cartesian3_default();
|
293
|
+
var uScratch = [];
|
294
|
+
var vScratch = [];
|
295
|
+
var heightScratch = [];
|
296
|
+
var indicesScratch = [];
|
297
|
+
var normalsScratch = [];
|
298
|
+
var horizonOcclusionPointScratch = new Cartesian3_default();
|
299
|
+
var boundingSphereScratch = new BoundingSphere_default();
|
300
|
+
var orientedBoundingBoxScratch = new OrientedBoundingBox_default();
|
301
|
+
var decodeTexCoordsScratch = new Cartesian2_default();
|
302
|
+
var octEncodedNormalScratch = new Cartesian3_default();
|
303
|
+
function upsampleQuantizedTerrainMesh(parameters, transferableObjects) {
|
304
|
+
const isEastChild = parameters.isEastChild;
|
305
|
+
const isNorthChild = parameters.isNorthChild;
|
306
|
+
const minU = isEastChild ? halfMaxShort : 0;
|
307
|
+
const maxU = isEastChild ? maxShort : halfMaxShort;
|
308
|
+
const minV = isNorthChild ? halfMaxShort : 0;
|
309
|
+
const maxV = isNorthChild ? maxShort : halfMaxShort;
|
310
|
+
const uBuffer = uScratch;
|
311
|
+
const vBuffer = vScratch;
|
312
|
+
const heightBuffer = heightScratch;
|
313
|
+
const normalBuffer = normalsScratch;
|
314
|
+
uBuffer.length = 0;
|
315
|
+
vBuffer.length = 0;
|
316
|
+
heightBuffer.length = 0;
|
317
|
+
normalBuffer.length = 0;
|
318
|
+
const indices = indicesScratch;
|
319
|
+
indices.length = 0;
|
320
|
+
const vertexMap = {};
|
321
|
+
const parentVertices = parameters.vertices;
|
322
|
+
let parentIndices = parameters.indices;
|
323
|
+
parentIndices = parentIndices.subarray(0, parameters.indexCountWithoutSkirts);
|
324
|
+
const encoding = TerrainEncoding_default.clone(parameters.encoding);
|
325
|
+
const hasVertexNormals = encoding.hasVertexNormals;
|
326
|
+
let vertexCount = 0;
|
327
|
+
const quantizedVertexCount = parameters.vertexCountWithoutSkirts;
|
328
|
+
const parentMinimumHeight = parameters.minimumHeight;
|
329
|
+
const parentMaximumHeight = parameters.maximumHeight;
|
330
|
+
const parentUBuffer = new Array(quantizedVertexCount);
|
331
|
+
const parentVBuffer = new Array(quantizedVertexCount);
|
332
|
+
const parentHeightBuffer = new Array(quantizedVertexCount);
|
333
|
+
const parentNormalBuffer = hasVertexNormals ? new Array(quantizedVertexCount * 2) : void 0;
|
334
|
+
const threshold = 20;
|
335
|
+
let height;
|
336
|
+
let i, n;
|
337
|
+
let u, v;
|
338
|
+
for (i = 0, n = 0; i < quantizedVertexCount; ++i, n += 2) {
|
339
|
+
const texCoords = encoding.decodeTextureCoordinates(
|
340
|
+
parentVertices,
|
341
|
+
i,
|
342
|
+
decodeTexCoordsScratch
|
343
|
+
);
|
344
|
+
height = encoding.decodeHeight(parentVertices, i);
|
345
|
+
u = Math_default.clamp(texCoords.x * maxShort | 0, 0, maxShort);
|
346
|
+
v = Math_default.clamp(texCoords.y * maxShort | 0, 0, maxShort);
|
347
|
+
parentHeightBuffer[i] = Math_default.clamp(
|
348
|
+
(height - parentMinimumHeight) / (parentMaximumHeight - parentMinimumHeight) * maxShort | 0,
|
349
|
+
0,
|
350
|
+
maxShort
|
351
|
+
);
|
352
|
+
if (u < threshold) {
|
353
|
+
u = 0;
|
267
354
|
}
|
268
|
-
|
269
|
-
|
270
|
-
const x1mx3 = x1 - x3;
|
271
|
-
const x3mx2 = x3 - x2;
|
272
|
-
const y2my3 = y2 - y3;
|
273
|
-
const y1my3 = y1 - y3;
|
274
|
-
const inverseDeterminant = 1.0 / (y2my3 * x1mx3 + x3mx2 * y1my3);
|
275
|
-
const ymy3 = y - y3;
|
276
|
-
const xmx3 = x - x3;
|
277
|
-
const l1 = (y2my3 * xmx3 + x3mx2 * ymy3) * inverseDeterminant;
|
278
|
-
const l2 = (-y1my3 * xmx3 + x1mx3 * ymy3) * inverseDeterminant;
|
279
|
-
const l3 = 1.0 - l1 - l2;
|
280
|
-
|
281
|
-
if (defaultValue.defined(result)) {
|
282
|
-
result.x = l1;
|
283
|
-
result.y = l2;
|
284
|
-
result.z = l3;
|
285
|
-
return result;
|
355
|
+
if (v < threshold) {
|
356
|
+
v = 0;
|
286
357
|
}
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
/**
|
291
|
-
* Compute the intersection between 2 line segments
|
292
|
-
*
|
293
|
-
* @param {number} x00 The x coordinate of the first line's first vertex.
|
294
|
-
* @param {number} y00 The y coordinate of the first line's first vertex.
|
295
|
-
* @param {number} x01 The x coordinate of the first line's second vertex.
|
296
|
-
* @param {number} y01 The y coordinate of the first line's second vertex.
|
297
|
-
* @param {number} x10 The x coordinate of the second line's first vertex.
|
298
|
-
* @param {number} y10 The y coordinate of the second line's first vertex.
|
299
|
-
* @param {number} x11 The x coordinate of the second line's second vertex.
|
300
|
-
* @param {number} y11 The y coordinate of the second line's second vertex.
|
301
|
-
* @param {Cartesian2} [result] The instance into to which to copy the result. If this parameter
|
302
|
-
* is undefined, a new instance is created and returned.
|
303
|
-
* @returns {Cartesian2} The intersection point, undefined if there is no intersection point or lines are coincident.
|
304
|
-
*
|
305
|
-
* @example
|
306
|
-
* const result = Cesium.Intersections2D.computeLineSegmentLineSegmentIntersection(0.0, 0.0, 0.0, 2.0, -1, 1, 1, 1);
|
307
|
-
* // result === new Cesium.Cartesian2(0.0, 1.0);
|
308
|
-
*/
|
309
|
-
Intersections2D.computeLineSegmentLineSegmentIntersection = function (
|
310
|
-
x00,
|
311
|
-
y00,
|
312
|
-
x01,
|
313
|
-
y01,
|
314
|
-
x10,
|
315
|
-
y10,
|
316
|
-
x11,
|
317
|
-
y11,
|
318
|
-
result
|
319
|
-
) {
|
320
|
-
//>>includeStart('debug', pragmas.debug);
|
321
|
-
Check.Check.typeOf.number("x00", x00);
|
322
|
-
Check.Check.typeOf.number("y00", y00);
|
323
|
-
Check.Check.typeOf.number("x01", x01);
|
324
|
-
Check.Check.typeOf.number("y01", y01);
|
325
|
-
Check.Check.typeOf.number("x10", x10);
|
326
|
-
Check.Check.typeOf.number("y10", y10);
|
327
|
-
Check.Check.typeOf.number("x11", x11);
|
328
|
-
Check.Check.typeOf.number("y11", y11);
|
329
|
-
//>>includeEnd('debug');
|
330
|
-
|
331
|
-
const numerator1A = (x11 - x10) * (y00 - y10) - (y11 - y10) * (x00 - x10);
|
332
|
-
const numerator1B = (x01 - x00) * (y00 - y10) - (y01 - y00) * (x00 - x10);
|
333
|
-
const denominator1 = (y11 - y10) * (x01 - x00) - (x11 - x10) * (y01 - y00);
|
334
|
-
|
335
|
-
// If denominator = 0, then lines are parallel. If denominator = 0 and both numerators are 0, then coincident
|
336
|
-
if (denominator1 === 0) {
|
337
|
-
return;
|
358
|
+
if (maxShort - u < threshold) {
|
359
|
+
u = maxShort;
|
338
360
|
}
|
339
|
-
|
340
|
-
|
341
|
-
const ub1 = numerator1B / denominator1;
|
342
|
-
|
343
|
-
if (ua1 >= 0 && ua1 <= 1 && ub1 >= 0 && ub1 <= 1) {
|
344
|
-
if (!defaultValue.defined(result)) {
|
345
|
-
result = new Matrix2.Cartesian2();
|
346
|
-
}
|
347
|
-
|
348
|
-
result.x = x00 + ua1 * (x01 - x00);
|
349
|
-
result.y = y00 + ua1 * (y01 - y00);
|
350
|
-
|
351
|
-
return result;
|
361
|
+
if (maxShort - v < threshold) {
|
362
|
+
v = maxShort;
|
352
363
|
}
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
const halfMaxShort = (maxShort / 2) | 0;
|
358
|
-
|
359
|
-
const clipScratch = [];
|
360
|
-
const clipScratch2 = [];
|
361
|
-
const verticesScratch = [];
|
362
|
-
const cartographicScratch = new Matrix3.Cartographic();
|
363
|
-
let cartesian3Scratch = new Matrix3.Cartesian3();
|
364
|
-
const uScratch = [];
|
365
|
-
const vScratch = [];
|
366
|
-
const heightScratch = [];
|
367
|
-
const indicesScratch = [];
|
368
|
-
const normalsScratch = [];
|
369
|
-
const horizonOcclusionPointScratch = new Matrix3.Cartesian3();
|
370
|
-
const boundingSphereScratch = new Transforms.BoundingSphere();
|
371
|
-
const orientedBoundingBoxScratch = new OrientedBoundingBox.OrientedBoundingBox();
|
372
|
-
const decodeTexCoordsScratch = new Matrix2.Cartesian2();
|
373
|
-
const octEncodedNormalScratch = new Matrix3.Cartesian3();
|
374
|
-
|
375
|
-
function upsampleQuantizedTerrainMesh(parameters, transferableObjects) {
|
376
|
-
const isEastChild = parameters.isEastChild;
|
377
|
-
const isNorthChild = parameters.isNorthChild;
|
378
|
-
|
379
|
-
const minU = isEastChild ? halfMaxShort : 0;
|
380
|
-
const maxU = isEastChild ? maxShort : halfMaxShort;
|
381
|
-
const minV = isNorthChild ? halfMaxShort : 0;
|
382
|
-
const maxV = isNorthChild ? maxShort : halfMaxShort;
|
383
|
-
|
384
|
-
const uBuffer = uScratch;
|
385
|
-
const vBuffer = vScratch;
|
386
|
-
const heightBuffer = heightScratch;
|
387
|
-
const normalBuffer = normalsScratch;
|
388
|
-
|
389
|
-
uBuffer.length = 0;
|
390
|
-
vBuffer.length = 0;
|
391
|
-
heightBuffer.length = 0;
|
392
|
-
normalBuffer.length = 0;
|
393
|
-
|
394
|
-
const indices = indicesScratch;
|
395
|
-
indices.length = 0;
|
396
|
-
|
397
|
-
const vertexMap = {};
|
398
|
-
|
399
|
-
const parentVertices = parameters.vertices;
|
400
|
-
let parentIndices = parameters.indices;
|
401
|
-
parentIndices = parentIndices.subarray(0, parameters.indexCountWithoutSkirts);
|
402
|
-
|
403
|
-
const encoding = TerrainEncoding.TerrainEncoding.clone(parameters.encoding);
|
404
|
-
const hasVertexNormals = encoding.hasVertexNormals;
|
405
|
-
|
406
|
-
let vertexCount = 0;
|
407
|
-
const quantizedVertexCount = parameters.vertexCountWithoutSkirts;
|
408
|
-
|
409
|
-
const parentMinimumHeight = parameters.minimumHeight;
|
410
|
-
const parentMaximumHeight = parameters.maximumHeight;
|
411
|
-
|
412
|
-
const parentUBuffer = new Array(quantizedVertexCount);
|
413
|
-
const parentVBuffer = new Array(quantizedVertexCount);
|
414
|
-
const parentHeightBuffer = new Array(quantizedVertexCount);
|
415
|
-
const parentNormalBuffer = hasVertexNormals
|
416
|
-
? new Array(quantizedVertexCount * 2)
|
417
|
-
: undefined;
|
418
|
-
|
419
|
-
const threshold = 20;
|
420
|
-
let height;
|
421
|
-
|
422
|
-
let i, n;
|
423
|
-
let u, v;
|
424
|
-
for (i = 0, n = 0; i < quantizedVertexCount; ++i, n += 2) {
|
425
|
-
const texCoords = encoding.decodeTextureCoordinates(
|
364
|
+
parentUBuffer[i] = u;
|
365
|
+
parentVBuffer[i] = v;
|
366
|
+
if (hasVertexNormals) {
|
367
|
+
const encodedNormal = encoding.getOctEncodedNormal(
|
426
368
|
parentVertices,
|
427
369
|
i,
|
428
|
-
|
370
|
+
octEncodedNormalScratch
|
429
371
|
);
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
0,
|
439
|
-
0,
|
440
|
-
maxShort
|
441
|
-
);
|
442
|
-
|
443
|
-
if (u < threshold) {
|
444
|
-
u = 0;
|
445
|
-
}
|
446
|
-
|
447
|
-
if (v < threshold) {
|
448
|
-
v = 0;
|
449
|
-
}
|
450
|
-
|
451
|
-
if (maxShort - u < threshold) {
|
452
|
-
u = maxShort;
|
453
|
-
}
|
454
|
-
|
455
|
-
if (maxShort - v < threshold) {
|
456
|
-
v = maxShort;
|
457
|
-
}
|
458
|
-
|
459
|
-
parentUBuffer[i] = u;
|
460
|
-
parentVBuffer[i] = v;
|
461
|
-
|
372
|
+
parentNormalBuffer[n] = encodedNormal.x;
|
373
|
+
parentNormalBuffer[n + 1] = encodedNormal.y;
|
374
|
+
}
|
375
|
+
if ((isEastChild && u >= halfMaxShort || !isEastChild && u <= halfMaxShort) && (isNorthChild && v >= halfMaxShort || !isNorthChild && v <= halfMaxShort)) {
|
376
|
+
vertexMap[i] = vertexCount;
|
377
|
+
uBuffer.push(u);
|
378
|
+
vBuffer.push(v);
|
379
|
+
heightBuffer.push(parentHeightBuffer[i]);
|
462
380
|
if (hasVertexNormals) {
|
463
|
-
|
464
|
-
|
465
|
-
i,
|
466
|
-
octEncodedNormalScratch
|
467
|
-
);
|
468
|
-
parentNormalBuffer[n] = encodedNormal.x;
|
469
|
-
parentNormalBuffer[n + 1] = encodedNormal.y;
|
470
|
-
}
|
471
|
-
|
472
|
-
if (
|
473
|
-
((isEastChild && u >= halfMaxShort) ||
|
474
|
-
(!isEastChild && u <= halfMaxShort)) &&
|
475
|
-
((isNorthChild && v >= halfMaxShort) ||
|
476
|
-
(!isNorthChild && v <= halfMaxShort))
|
477
|
-
) {
|
478
|
-
vertexMap[i] = vertexCount;
|
479
|
-
uBuffer.push(u);
|
480
|
-
vBuffer.push(v);
|
481
|
-
heightBuffer.push(parentHeightBuffer[i]);
|
482
|
-
if (hasVertexNormals) {
|
483
|
-
normalBuffer.push(parentNormalBuffer[n]);
|
484
|
-
normalBuffer.push(parentNormalBuffer[n + 1]);
|
485
|
-
}
|
486
|
-
|
487
|
-
++vertexCount;
|
381
|
+
normalBuffer.push(parentNormalBuffer[n]);
|
382
|
+
normalBuffer.push(parentNormalBuffer[n + 1]);
|
488
383
|
}
|
384
|
+
++vertexCount;
|
489
385
|
}
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
|
495
|
-
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
523
|
-
|
524
|
-
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
|
532
|
-
|
533
|
-
|
534
|
-
|
535
|
-
|
536
|
-
|
537
|
-
|
538
|
-
|
539
|
-
|
540
|
-
|
541
|
-
|
542
|
-
|
543
|
-
|
544
|
-
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
|
551
|
-
clippedIndex
|
552
|
-
|
553
|
-
|
554
|
-
|
555
|
-
|
556
|
-
|
557
|
-
|
558
|
-
|
559
|
-
|
560
|
-
|
561
|
-
|
562
|
-
|
563
|
-
|
564
|
-
|
565
|
-
|
566
|
-
|
567
|
-
|
568
|
-
|
569
|
-
|
386
|
+
}
|
387
|
+
const triangleVertices = [];
|
388
|
+
triangleVertices.push(new Vertex());
|
389
|
+
triangleVertices.push(new Vertex());
|
390
|
+
triangleVertices.push(new Vertex());
|
391
|
+
const clippedTriangleVertices = [];
|
392
|
+
clippedTriangleVertices.push(new Vertex());
|
393
|
+
clippedTriangleVertices.push(new Vertex());
|
394
|
+
clippedTriangleVertices.push(new Vertex());
|
395
|
+
let clippedIndex;
|
396
|
+
let clipped2;
|
397
|
+
for (i = 0; i < parentIndices.length; i += 3) {
|
398
|
+
const i0 = parentIndices[i];
|
399
|
+
const i1 = parentIndices[i + 1];
|
400
|
+
const i2 = parentIndices[i + 2];
|
401
|
+
const u0 = parentUBuffer[i0];
|
402
|
+
const u1 = parentUBuffer[i1];
|
403
|
+
const u2 = parentUBuffer[i2];
|
404
|
+
triangleVertices[0].initializeIndexed(
|
405
|
+
parentUBuffer,
|
406
|
+
parentVBuffer,
|
407
|
+
parentHeightBuffer,
|
408
|
+
parentNormalBuffer,
|
409
|
+
i0
|
410
|
+
);
|
411
|
+
triangleVertices[1].initializeIndexed(
|
412
|
+
parentUBuffer,
|
413
|
+
parentVBuffer,
|
414
|
+
parentHeightBuffer,
|
415
|
+
parentNormalBuffer,
|
416
|
+
i1
|
417
|
+
);
|
418
|
+
triangleVertices[2].initializeIndexed(
|
419
|
+
parentUBuffer,
|
420
|
+
parentVBuffer,
|
421
|
+
parentHeightBuffer,
|
422
|
+
parentNormalBuffer,
|
423
|
+
i2
|
424
|
+
);
|
425
|
+
const clipped = Intersections2D_default.clipTriangleAtAxisAlignedThreshold(
|
426
|
+
halfMaxShort,
|
427
|
+
isEastChild,
|
428
|
+
u0,
|
429
|
+
u1,
|
430
|
+
u2,
|
431
|
+
clipScratch
|
432
|
+
);
|
433
|
+
clippedIndex = 0;
|
434
|
+
if (clippedIndex >= clipped.length) {
|
435
|
+
continue;
|
436
|
+
}
|
437
|
+
clippedIndex = clippedTriangleVertices[0].initializeFromClipResult(
|
438
|
+
clipped,
|
439
|
+
clippedIndex,
|
440
|
+
triangleVertices
|
441
|
+
);
|
442
|
+
if (clippedIndex >= clipped.length) {
|
443
|
+
continue;
|
444
|
+
}
|
445
|
+
clippedIndex = clippedTriangleVertices[1].initializeFromClipResult(
|
446
|
+
clipped,
|
447
|
+
clippedIndex,
|
448
|
+
triangleVertices
|
449
|
+
);
|
450
|
+
if (clippedIndex >= clipped.length) {
|
451
|
+
continue;
|
452
|
+
}
|
453
|
+
clippedIndex = clippedTriangleVertices[2].initializeFromClipResult(
|
454
|
+
clipped,
|
455
|
+
clippedIndex,
|
456
|
+
triangleVertices
|
457
|
+
);
|
458
|
+
clipped2 = Intersections2D_default.clipTriangleAtAxisAlignedThreshold(
|
459
|
+
halfMaxShort,
|
460
|
+
isNorthChild,
|
461
|
+
clippedTriangleVertices[0].getV(),
|
462
|
+
clippedTriangleVertices[1].getV(),
|
463
|
+
clippedTriangleVertices[2].getV(),
|
464
|
+
clipScratch2
|
465
|
+
);
|
466
|
+
addClippedPolygon(
|
467
|
+
uBuffer,
|
468
|
+
vBuffer,
|
469
|
+
heightBuffer,
|
470
|
+
normalBuffer,
|
471
|
+
indices,
|
472
|
+
vertexMap,
|
473
|
+
clipped2,
|
474
|
+
clippedTriangleVertices,
|
475
|
+
hasVertexNormals
|
476
|
+
);
|
477
|
+
if (clippedIndex < clipped.length) {
|
478
|
+
clippedTriangleVertices[2].clone(clippedTriangleVertices[1]);
|
479
|
+
clippedTriangleVertices[2].initializeFromClipResult(
|
570
480
|
clipped,
|
571
481
|
clippedIndex,
|
572
482
|
triangleVertices
|
573
483
|
);
|
574
|
-
|
575
|
-
// Clip the triangle against the North-south boundary.
|
576
|
-
clipped2 = Intersections2D$1.clipTriangleAtAxisAlignedThreshold(
|
484
|
+
clipped2 = Intersections2D_default.clipTriangleAtAxisAlignedThreshold(
|
577
485
|
halfMaxShort,
|
578
486
|
isNorthChild,
|
579
487
|
clippedTriangleVertices[0].getV(),
|
@@ -592,432 +500,319 @@ define(['./AttributeCompression-f9f6c717', './Transforms-a2a85221', './Matrix2-e
|
|
592
500
|
clippedTriangleVertices,
|
593
501
|
hasVertexNormals
|
594
502
|
);
|
595
|
-
|
596
|
-
// If there's another vertex in the original clipped result,
|
597
|
-
// it forms a second triangle. Clip it as well.
|
598
|
-
if (clippedIndex < clipped.length) {
|
599
|
-
clippedTriangleVertices[2].clone(clippedTriangleVertices[1]);
|
600
|
-
clippedTriangleVertices[2].initializeFromClipResult(
|
601
|
-
clipped,
|
602
|
-
clippedIndex,
|
603
|
-
triangleVertices
|
604
|
-
);
|
605
|
-
|
606
|
-
clipped2 = Intersections2D$1.clipTriangleAtAxisAlignedThreshold(
|
607
|
-
halfMaxShort,
|
608
|
-
isNorthChild,
|
609
|
-
clippedTriangleVertices[0].getV(),
|
610
|
-
clippedTriangleVertices[1].getV(),
|
611
|
-
clippedTriangleVertices[2].getV(),
|
612
|
-
clipScratch2
|
613
|
-
);
|
614
|
-
addClippedPolygon(
|
615
|
-
uBuffer,
|
616
|
-
vBuffer,
|
617
|
-
heightBuffer,
|
618
|
-
normalBuffer,
|
619
|
-
indices,
|
620
|
-
vertexMap,
|
621
|
-
clipped2,
|
622
|
-
clippedTriangleVertices,
|
623
|
-
hasVertexNormals
|
624
|
-
);
|
625
|
-
}
|
626
503
|
}
|
627
|
-
|
628
|
-
const uOffset = isEastChild ? -maxShort : 0;
|
629
|
-
const vOffset = isNorthChild ? -maxShort : 0;
|
630
|
-
|
631
|
-
const westIndices = [];
|
632
|
-
const southIndices = [];
|
633
|
-
const eastIndices = [];
|
634
|
-
const northIndices = [];
|
635
|
-
|
636
|
-
let minimumHeight = Number.MAX_VALUE;
|
637
|
-
let maximumHeight = -minimumHeight;
|
638
|
-
|
639
|
-
const cartesianVertices = verticesScratch;
|
640
|
-
cartesianVertices.length = 0;
|
641
|
-
|
642
|
-
const ellipsoid = Matrix3.Ellipsoid.clone(parameters.ellipsoid);
|
643
|
-
const rectangle = Matrix2.Rectangle.clone(parameters.childRectangle);
|
644
|
-
|
645
|
-
const north = rectangle.north;
|
646
|
-
const south = rectangle.south;
|
647
|
-
let east = rectangle.east;
|
648
|
-
const west = rectangle.west;
|
649
|
-
|
650
|
-
if (east < west) {
|
651
|
-
east += Math$1.CesiumMath.TWO_PI;
|
652
|
-
}
|
653
|
-
|
654
|
-
for (i = 0; i < uBuffer.length; ++i) {
|
655
|
-
u = Math.round(uBuffer[i]);
|
656
|
-
if (u <= minU) {
|
657
|
-
westIndices.push(i);
|
658
|
-
u = 0;
|
659
|
-
} else if (u >= maxU) {
|
660
|
-
eastIndices.push(i);
|
661
|
-
u = maxShort;
|
662
|
-
} else {
|
663
|
-
u = u * 2 + uOffset;
|
664
|
-
}
|
665
|
-
|
666
|
-
uBuffer[i] = u;
|
667
|
-
|
668
|
-
v = Math.round(vBuffer[i]);
|
669
|
-
if (v <= minV) {
|
670
|
-
southIndices.push(i);
|
671
|
-
v = 0;
|
672
|
-
} else if (v >= maxV) {
|
673
|
-
northIndices.push(i);
|
674
|
-
v = maxShort;
|
675
|
-
} else {
|
676
|
-
v = v * 2 + vOffset;
|
677
|
-
}
|
678
|
-
|
679
|
-
vBuffer[i] = v;
|
680
|
-
|
681
|
-
height = Math$1.CesiumMath.lerp(
|
682
|
-
parentMinimumHeight,
|
683
|
-
parentMaximumHeight,
|
684
|
-
heightBuffer[i] / maxShort
|
685
|
-
);
|
686
|
-
if (height < minimumHeight) {
|
687
|
-
minimumHeight = height;
|
688
|
-
}
|
689
|
-
if (height > maximumHeight) {
|
690
|
-
maximumHeight = height;
|
691
|
-
}
|
692
|
-
|
693
|
-
heightBuffer[i] = height;
|
694
|
-
|
695
|
-
cartographicScratch.longitude = Math$1.CesiumMath.lerp(west, east, u / maxShort);
|
696
|
-
cartographicScratch.latitude = Math$1.CesiumMath.lerp(south, north, v / maxShort);
|
697
|
-
cartographicScratch.height = height;
|
698
|
-
|
699
|
-
ellipsoid.cartographicToCartesian(cartographicScratch, cartesian3Scratch);
|
700
|
-
|
701
|
-
cartesianVertices.push(cartesian3Scratch.x);
|
702
|
-
cartesianVertices.push(cartesian3Scratch.y);
|
703
|
-
cartesianVertices.push(cartesian3Scratch.z);
|
704
|
-
}
|
705
|
-
|
706
|
-
const boundingSphere = Transforms.BoundingSphere.fromVertices(
|
707
|
-
cartesianVertices,
|
708
|
-
Matrix3.Cartesian3.ZERO,
|
709
|
-
3,
|
710
|
-
boundingSphereScratch
|
711
|
-
);
|
712
|
-
const orientedBoundingBox = OrientedBoundingBox.OrientedBoundingBox.fromRectangle(
|
713
|
-
rectangle,
|
714
|
-
minimumHeight,
|
715
|
-
maximumHeight,
|
716
|
-
ellipsoid,
|
717
|
-
orientedBoundingBoxScratch
|
718
|
-
);
|
719
|
-
|
720
|
-
const occluder = new TerrainEncoding.EllipsoidalOccluder(ellipsoid);
|
721
|
-
const horizonOcclusionPoint = occluder.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(
|
722
|
-
boundingSphere.center,
|
723
|
-
cartesianVertices,
|
724
|
-
3,
|
725
|
-
boundingSphere.center,
|
726
|
-
minimumHeight,
|
727
|
-
horizonOcclusionPointScratch
|
728
|
-
);
|
729
|
-
|
730
|
-
const heightRange = maximumHeight - minimumHeight;
|
731
|
-
|
732
|
-
const vertices = new Uint16Array(
|
733
|
-
uBuffer.length + vBuffer.length + heightBuffer.length
|
734
|
-
);
|
735
|
-
|
736
|
-
for (i = 0; i < uBuffer.length; ++i) {
|
737
|
-
vertices[i] = uBuffer[i];
|
738
|
-
}
|
739
|
-
|
740
|
-
let start = uBuffer.length;
|
741
|
-
|
742
|
-
for (i = 0; i < vBuffer.length; ++i) {
|
743
|
-
vertices[start + i] = vBuffer[i];
|
744
|
-
}
|
745
|
-
|
746
|
-
start += vBuffer.length;
|
747
|
-
|
748
|
-
for (i = 0; i < heightBuffer.length; ++i) {
|
749
|
-
vertices[start + i] =
|
750
|
-
(maxShort * (heightBuffer[i] - minimumHeight)) / heightRange;
|
751
|
-
}
|
752
|
-
|
753
|
-
const indicesTypedArray = IndexDatatype.IndexDatatype.createTypedArray(
|
754
|
-
uBuffer.length,
|
755
|
-
indices
|
756
|
-
);
|
757
|
-
|
758
|
-
let encodedNormals;
|
759
|
-
if (hasVertexNormals) {
|
760
|
-
const normalArray = new Uint8Array(normalBuffer);
|
761
|
-
transferableObjects.push(
|
762
|
-
vertices.buffer,
|
763
|
-
indicesTypedArray.buffer,
|
764
|
-
normalArray.buffer
|
765
|
-
);
|
766
|
-
encodedNormals = normalArray.buffer;
|
767
|
-
} else {
|
768
|
-
transferableObjects.push(vertices.buffer, indicesTypedArray.buffer);
|
769
|
-
}
|
770
|
-
|
771
|
-
return {
|
772
|
-
vertices: vertices.buffer,
|
773
|
-
encodedNormals: encodedNormals,
|
774
|
-
indices: indicesTypedArray.buffer,
|
775
|
-
minimumHeight: minimumHeight,
|
776
|
-
maximumHeight: maximumHeight,
|
777
|
-
westIndices: westIndices,
|
778
|
-
southIndices: southIndices,
|
779
|
-
eastIndices: eastIndices,
|
780
|
-
northIndices: northIndices,
|
781
|
-
boundingSphere: boundingSphere,
|
782
|
-
orientedBoundingBox: orientedBoundingBox,
|
783
|
-
horizonOcclusionPoint: horizonOcclusionPoint,
|
784
|
-
};
|
785
504
|
}
|
786
|
-
|
787
|
-
|
788
|
-
|
789
|
-
|
790
|
-
|
791
|
-
|
792
|
-
|
505
|
+
const uOffset = isEastChild ? -maxShort : 0;
|
506
|
+
const vOffset = isNorthChild ? -maxShort : 0;
|
507
|
+
const westIndices = [];
|
508
|
+
const southIndices = [];
|
509
|
+
const eastIndices = [];
|
510
|
+
const northIndices = [];
|
511
|
+
let minimumHeight = Number.MAX_VALUE;
|
512
|
+
let maximumHeight = -minimumHeight;
|
513
|
+
const cartesianVertices = verticesScratch;
|
514
|
+
cartesianVertices.length = 0;
|
515
|
+
const ellipsoid = Ellipsoid_default.clone(parameters.ellipsoid);
|
516
|
+
const rectangle = Rectangle_default.clone(parameters.childRectangle);
|
517
|
+
const north = rectangle.north;
|
518
|
+
const south = rectangle.south;
|
519
|
+
let east = rectangle.east;
|
520
|
+
const west = rectangle.west;
|
521
|
+
if (east < west) {
|
522
|
+
east += Math_default.TWO_PI;
|
793
523
|
}
|
794
|
-
|
795
|
-
|
796
|
-
if (
|
797
|
-
|
798
|
-
|
799
|
-
|
800
|
-
|
801
|
-
|
802
|
-
result.heightBuffer = this.heightBuffer;
|
803
|
-
result.normalBuffer = this.normalBuffer;
|
804
|
-
result.index = this.index;
|
805
|
-
result.first = this.first;
|
806
|
-
result.second = this.second;
|
807
|
-
result.ratio = this.ratio;
|
808
|
-
|
809
|
-
return result;
|
810
|
-
};
|
811
|
-
|
812
|
-
Vertex.prototype.initializeIndexed = function (
|
813
|
-
uBuffer,
|
814
|
-
vBuffer,
|
815
|
-
heightBuffer,
|
816
|
-
normalBuffer,
|
817
|
-
index
|
818
|
-
) {
|
819
|
-
this.uBuffer = uBuffer;
|
820
|
-
this.vBuffer = vBuffer;
|
821
|
-
this.heightBuffer = heightBuffer;
|
822
|
-
this.normalBuffer = normalBuffer;
|
823
|
-
this.index = index;
|
824
|
-
this.first = undefined;
|
825
|
-
this.second = undefined;
|
826
|
-
this.ratio = undefined;
|
827
|
-
};
|
828
|
-
|
829
|
-
Vertex.prototype.initializeFromClipResult = function (
|
830
|
-
clipResult,
|
831
|
-
index,
|
832
|
-
vertices
|
833
|
-
) {
|
834
|
-
let nextIndex = index + 1;
|
835
|
-
|
836
|
-
if (clipResult[index] !== -1) {
|
837
|
-
vertices[clipResult[index]].clone(this);
|
524
|
+
for (i = 0; i < uBuffer.length; ++i) {
|
525
|
+
u = Math.round(uBuffer[i]);
|
526
|
+
if (u <= minU) {
|
527
|
+
westIndices.push(i);
|
528
|
+
u = 0;
|
529
|
+
} else if (u >= maxU) {
|
530
|
+
eastIndices.push(i);
|
531
|
+
u = maxShort;
|
838
532
|
} else {
|
839
|
-
|
840
|
-
|
841
|
-
|
842
|
-
|
843
|
-
|
844
|
-
|
845
|
-
|
846
|
-
|
847
|
-
|
848
|
-
|
849
|
-
|
850
|
-
|
851
|
-
|
852
|
-
Vertex.prototype.getKey = function () {
|
853
|
-
if (this.isIndexed()) {
|
854
|
-
return this.index;
|
855
|
-
}
|
856
|
-
return JSON.stringify({
|
857
|
-
first: this.first.getKey(),
|
858
|
-
second: this.second.getKey(),
|
859
|
-
ratio: this.ratio,
|
860
|
-
});
|
861
|
-
};
|
862
|
-
|
863
|
-
Vertex.prototype.isIndexed = function () {
|
864
|
-
return defaultValue.defined(this.index);
|
865
|
-
};
|
866
|
-
|
867
|
-
Vertex.prototype.getH = function () {
|
868
|
-
if (defaultValue.defined(this.index)) {
|
869
|
-
return this.heightBuffer[this.index];
|
870
|
-
}
|
871
|
-
return Math$1.CesiumMath.lerp(this.first.getH(), this.second.getH(), this.ratio);
|
872
|
-
};
|
873
|
-
|
874
|
-
Vertex.prototype.getU = function () {
|
875
|
-
if (defaultValue.defined(this.index)) {
|
876
|
-
return this.uBuffer[this.index];
|
877
|
-
}
|
878
|
-
return Math$1.CesiumMath.lerp(this.first.getU(), this.second.getU(), this.ratio);
|
879
|
-
};
|
880
|
-
|
881
|
-
Vertex.prototype.getV = function () {
|
882
|
-
if (defaultValue.defined(this.index)) {
|
883
|
-
return this.vBuffer[this.index];
|
533
|
+
u = u * 2 + uOffset;
|
534
|
+
}
|
535
|
+
uBuffer[i] = u;
|
536
|
+
v = Math.round(vBuffer[i]);
|
537
|
+
if (v <= minV) {
|
538
|
+
southIndices.push(i);
|
539
|
+
v = 0;
|
540
|
+
} else if (v >= maxV) {
|
541
|
+
northIndices.push(i);
|
542
|
+
v = maxShort;
|
543
|
+
} else {
|
544
|
+
v = v * 2 + vOffset;
|
884
545
|
}
|
885
|
-
|
886
|
-
|
887
|
-
|
888
|
-
|
889
|
-
|
890
|
-
// In this case, we need a buffer to handle the recursion of getNormalX() and getNormalY().
|
891
|
-
let depth = -1;
|
892
|
-
const cartesianScratch1 = [new Matrix3.Cartesian3(), new Matrix3.Cartesian3()];
|
893
|
-
const cartesianScratch2 = [new Matrix3.Cartesian3(), new Matrix3.Cartesian3()];
|
894
|
-
function lerpOctEncodedNormal(vertex, result) {
|
895
|
-
++depth;
|
896
|
-
|
897
|
-
let first = cartesianScratch1[depth];
|
898
|
-
let second = cartesianScratch2[depth];
|
899
|
-
|
900
|
-
first = AttributeCompression.AttributeCompression.octDecode(
|
901
|
-
vertex.first.getNormalX(),
|
902
|
-
vertex.first.getNormalY(),
|
903
|
-
first
|
546
|
+
vBuffer[i] = v;
|
547
|
+
height = Math_default.lerp(
|
548
|
+
parentMinimumHeight,
|
549
|
+
parentMaximumHeight,
|
550
|
+
heightBuffer[i] / maxShort
|
904
551
|
);
|
905
|
-
|
906
|
-
|
907
|
-
|
908
|
-
|
909
|
-
|
910
|
-
|
911
|
-
|
912
|
-
|
913
|
-
|
914
|
-
|
552
|
+
if (height < minimumHeight) {
|
553
|
+
minimumHeight = height;
|
554
|
+
}
|
555
|
+
if (height > maximumHeight) {
|
556
|
+
maximumHeight = height;
|
557
|
+
}
|
558
|
+
heightBuffer[i] = height;
|
559
|
+
cartographicScratch.longitude = Math_default.lerp(west, east, u / maxShort);
|
560
|
+
cartographicScratch.latitude = Math_default.lerp(south, north, v / maxShort);
|
561
|
+
cartographicScratch.height = height;
|
562
|
+
ellipsoid.cartographicToCartesian(cartographicScratch, cartesian3Scratch);
|
563
|
+
cartesianVertices.push(cartesian3Scratch.x);
|
564
|
+
cartesianVertices.push(cartesian3Scratch.y);
|
565
|
+
cartesianVertices.push(cartesian3Scratch.z);
|
566
|
+
}
|
567
|
+
const boundingSphere = BoundingSphere_default.fromVertices(
|
568
|
+
cartesianVertices,
|
569
|
+
Cartesian3_default.ZERO,
|
570
|
+
3,
|
571
|
+
boundingSphereScratch
|
572
|
+
);
|
573
|
+
const orientedBoundingBox = OrientedBoundingBox_default.fromRectangle(
|
574
|
+
rectangle,
|
575
|
+
minimumHeight,
|
576
|
+
maximumHeight,
|
577
|
+
ellipsoid,
|
578
|
+
orientedBoundingBoxScratch
|
579
|
+
);
|
580
|
+
const occluder = new EllipsoidalOccluder_default(ellipsoid);
|
581
|
+
const horizonOcclusionPoint = occluder.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(
|
582
|
+
boundingSphere.center,
|
583
|
+
cartesianVertices,
|
584
|
+
3,
|
585
|
+
boundingSphere.center,
|
586
|
+
minimumHeight,
|
587
|
+
horizonOcclusionPointScratch
|
588
|
+
);
|
589
|
+
const heightRange = maximumHeight - minimumHeight;
|
590
|
+
const vertices = new Uint16Array(
|
591
|
+
uBuffer.length + vBuffer.length + heightBuffer.length
|
592
|
+
);
|
593
|
+
for (i = 0; i < uBuffer.length; ++i) {
|
594
|
+
vertices[i] = uBuffer[i];
|
595
|
+
}
|
596
|
+
let start = uBuffer.length;
|
597
|
+
for (i = 0; i < vBuffer.length; ++i) {
|
598
|
+
vertices[start + i] = vBuffer[i];
|
599
|
+
}
|
600
|
+
start += vBuffer.length;
|
601
|
+
for (i = 0; i < heightBuffer.length; ++i) {
|
602
|
+
vertices[start + i] = maxShort * (heightBuffer[i] - minimumHeight) / heightRange;
|
603
|
+
}
|
604
|
+
const indicesTypedArray = IndexDatatype_default.createTypedArray(
|
605
|
+
uBuffer.length,
|
606
|
+
indices
|
607
|
+
);
|
608
|
+
let encodedNormals;
|
609
|
+
if (hasVertexNormals) {
|
610
|
+
const normalArray = new Uint8Array(normalBuffer);
|
611
|
+
transferableObjects.push(
|
612
|
+
vertices.buffer,
|
613
|
+
indicesTypedArray.buffer,
|
614
|
+
normalArray.buffer
|
915
615
|
);
|
916
|
-
|
917
|
-
|
918
|
-
|
919
|
-
|
920
|
-
--depth;
|
921
|
-
|
922
|
-
return result;
|
616
|
+
encodedNormals = normalArray.buffer;
|
617
|
+
} else {
|
618
|
+
transferableObjects.push(vertices.buffer, indicesTypedArray.buffer);
|
923
619
|
}
|
924
|
-
|
925
|
-
|
926
|
-
|
927
|
-
|
928
|
-
|
929
|
-
|
930
|
-
|
931
|
-
|
932
|
-
|
933
|
-
|
934
|
-
|
935
|
-
|
936
|
-
|
937
|
-
}
|
938
|
-
|
939
|
-
encodedScratch = lerpOctEncodedNormal(this, encodedScratch);
|
940
|
-
return encodedScratch.y;
|
620
|
+
return {
|
621
|
+
vertices: vertices.buffer,
|
622
|
+
encodedNormals,
|
623
|
+
indices: indicesTypedArray.buffer,
|
624
|
+
minimumHeight,
|
625
|
+
maximumHeight,
|
626
|
+
westIndices,
|
627
|
+
southIndices,
|
628
|
+
eastIndices,
|
629
|
+
northIndices,
|
630
|
+
boundingSphere,
|
631
|
+
orientedBoundingBox,
|
632
|
+
horizonOcclusionPoint
|
941
633
|
};
|
942
|
-
|
943
|
-
|
944
|
-
|
945
|
-
|
946
|
-
|
947
|
-
|
948
|
-
|
949
|
-
|
950
|
-
|
951
|
-
|
952
|
-
|
953
|
-
|
954
|
-
|
955
|
-
|
956
|
-
|
957
|
-
|
958
|
-
|
959
|
-
|
960
|
-
|
961
|
-
|
962
|
-
|
963
|
-
|
964
|
-
|
965
|
-
|
966
|
-
|
967
|
-
|
968
|
-
|
969
|
-
|
970
|
-
|
971
|
-
|
972
|
-
|
973
|
-
|
974
|
-
|
975
|
-
|
976
|
-
|
977
|
-
|
978
|
-
|
979
|
-
|
980
|
-
|
981
|
-
|
982
|
-
|
983
|
-
|
984
|
-
|
985
|
-
|
986
|
-
|
987
|
-
|
988
|
-
|
989
|
-
|
990
|
-
|
991
|
-
|
634
|
+
}
|
635
|
+
function Vertex() {
|
636
|
+
this.vertexBuffer = void 0;
|
637
|
+
this.index = void 0;
|
638
|
+
this.first = void 0;
|
639
|
+
this.second = void 0;
|
640
|
+
this.ratio = void 0;
|
641
|
+
}
|
642
|
+
Vertex.prototype.clone = function(result) {
|
643
|
+
if (!defined_default(result)) {
|
644
|
+
result = new Vertex();
|
645
|
+
}
|
646
|
+
result.uBuffer = this.uBuffer;
|
647
|
+
result.vBuffer = this.vBuffer;
|
648
|
+
result.heightBuffer = this.heightBuffer;
|
649
|
+
result.normalBuffer = this.normalBuffer;
|
650
|
+
result.index = this.index;
|
651
|
+
result.first = this.first;
|
652
|
+
result.second = this.second;
|
653
|
+
result.ratio = this.ratio;
|
654
|
+
return result;
|
655
|
+
};
|
656
|
+
Vertex.prototype.initializeIndexed = function(uBuffer, vBuffer, heightBuffer, normalBuffer, index) {
|
657
|
+
this.uBuffer = uBuffer;
|
658
|
+
this.vBuffer = vBuffer;
|
659
|
+
this.heightBuffer = heightBuffer;
|
660
|
+
this.normalBuffer = normalBuffer;
|
661
|
+
this.index = index;
|
662
|
+
this.first = void 0;
|
663
|
+
this.second = void 0;
|
664
|
+
this.ratio = void 0;
|
665
|
+
};
|
666
|
+
Vertex.prototype.initializeFromClipResult = function(clipResult, index, vertices) {
|
667
|
+
let nextIndex = index + 1;
|
668
|
+
if (clipResult[index] !== -1) {
|
669
|
+
vertices[clipResult[index]].clone(this);
|
670
|
+
} else {
|
671
|
+
this.vertexBuffer = void 0;
|
672
|
+
this.index = void 0;
|
673
|
+
this.first = vertices[clipResult[nextIndex]];
|
674
|
+
++nextIndex;
|
675
|
+
this.second = vertices[clipResult[nextIndex]];
|
676
|
+
++nextIndex;
|
677
|
+
this.ratio = clipResult[nextIndex];
|
678
|
+
++nextIndex;
|
679
|
+
}
|
680
|
+
return nextIndex;
|
681
|
+
};
|
682
|
+
Vertex.prototype.getKey = function() {
|
683
|
+
if (this.isIndexed()) {
|
684
|
+
return this.index;
|
685
|
+
}
|
686
|
+
return JSON.stringify({
|
687
|
+
first: this.first.getKey(),
|
688
|
+
second: this.second.getKey(),
|
689
|
+
ratio: this.ratio
|
690
|
+
});
|
691
|
+
};
|
692
|
+
Vertex.prototype.isIndexed = function() {
|
693
|
+
return defined_default(this.index);
|
694
|
+
};
|
695
|
+
Vertex.prototype.getH = function() {
|
696
|
+
if (defined_default(this.index)) {
|
697
|
+
return this.heightBuffer[this.index];
|
698
|
+
}
|
699
|
+
return Math_default.lerp(this.first.getH(), this.second.getH(), this.ratio);
|
700
|
+
};
|
701
|
+
Vertex.prototype.getU = function() {
|
702
|
+
if (defined_default(this.index)) {
|
703
|
+
return this.uBuffer[this.index];
|
704
|
+
}
|
705
|
+
return Math_default.lerp(this.first.getU(), this.second.getU(), this.ratio);
|
706
|
+
};
|
707
|
+
Vertex.prototype.getV = function() {
|
708
|
+
if (defined_default(this.index)) {
|
709
|
+
return this.vBuffer[this.index];
|
710
|
+
}
|
711
|
+
return Math_default.lerp(this.first.getV(), this.second.getV(), this.ratio);
|
712
|
+
};
|
713
|
+
var encodedScratch = new Cartesian2_default();
|
714
|
+
var depth = -1;
|
715
|
+
var cartesianScratch1 = [new Cartesian3_default(), new Cartesian3_default()];
|
716
|
+
var cartesianScratch2 = [new Cartesian3_default(), new Cartesian3_default()];
|
717
|
+
function lerpOctEncodedNormal(vertex, result) {
|
718
|
+
++depth;
|
719
|
+
let first = cartesianScratch1[depth];
|
720
|
+
let second = cartesianScratch2[depth];
|
721
|
+
first = AttributeCompression_default.octDecode(
|
722
|
+
vertex.first.getNormalX(),
|
723
|
+
vertex.first.getNormalY(),
|
724
|
+
first
|
725
|
+
);
|
726
|
+
second = AttributeCompression_default.octDecode(
|
727
|
+
vertex.second.getNormalX(),
|
728
|
+
vertex.second.getNormalY(),
|
729
|
+
second
|
730
|
+
);
|
731
|
+
cartesian3Scratch = Cartesian3_default.lerp(
|
732
|
+
first,
|
733
|
+
second,
|
734
|
+
vertex.ratio,
|
735
|
+
cartesian3Scratch
|
736
|
+
);
|
737
|
+
Cartesian3_default.normalize(cartesian3Scratch, cartesian3Scratch);
|
738
|
+
AttributeCompression_default.octEncode(cartesian3Scratch, result);
|
739
|
+
--depth;
|
740
|
+
return result;
|
741
|
+
}
|
742
|
+
Vertex.prototype.getNormalX = function() {
|
743
|
+
if (defined_default(this.index)) {
|
744
|
+
return this.normalBuffer[this.index * 2];
|
745
|
+
}
|
746
|
+
encodedScratch = lerpOctEncodedNormal(this, encodedScratch);
|
747
|
+
return encodedScratch.x;
|
748
|
+
};
|
749
|
+
Vertex.prototype.getNormalY = function() {
|
750
|
+
if (defined_default(this.index)) {
|
751
|
+
return this.normalBuffer[this.index * 2 + 1];
|
752
|
+
}
|
753
|
+
encodedScratch = lerpOctEncodedNormal(this, encodedScratch);
|
754
|
+
return encodedScratch.y;
|
755
|
+
};
|
756
|
+
var polygonVertices = [];
|
757
|
+
polygonVertices.push(new Vertex());
|
758
|
+
polygonVertices.push(new Vertex());
|
759
|
+
polygonVertices.push(new Vertex());
|
760
|
+
polygonVertices.push(new Vertex());
|
761
|
+
function addClippedPolygon(uBuffer, vBuffer, heightBuffer, normalBuffer, indices, vertexMap, clipped, triangleVertices, hasVertexNormals) {
|
762
|
+
if (clipped.length === 0) {
|
763
|
+
return;
|
764
|
+
}
|
765
|
+
let numVertices = 0;
|
766
|
+
let clippedIndex = 0;
|
767
|
+
while (clippedIndex < clipped.length) {
|
768
|
+
clippedIndex = polygonVertices[numVertices++].initializeFromClipResult(
|
769
|
+
clipped,
|
770
|
+
clippedIndex,
|
771
|
+
triangleVertices
|
772
|
+
);
|
773
|
+
}
|
774
|
+
for (let i = 0; i < numVertices; ++i) {
|
775
|
+
const polygonVertex = polygonVertices[i];
|
776
|
+
if (!polygonVertex.isIndexed()) {
|
777
|
+
const key = polygonVertex.getKey();
|
778
|
+
if (defined_default(vertexMap[key])) {
|
779
|
+
polygonVertex.newIndex = vertexMap[key];
|
992
780
|
} else {
|
993
|
-
|
994
|
-
polygonVertex.
|
995
|
-
polygonVertex.
|
996
|
-
polygonVertex.
|
781
|
+
const newIndex = uBuffer.length;
|
782
|
+
uBuffer.push(polygonVertex.getU());
|
783
|
+
vBuffer.push(polygonVertex.getV());
|
784
|
+
heightBuffer.push(polygonVertex.getH());
|
997
785
|
if (hasVertexNormals) {
|
998
|
-
polygonVertex.
|
786
|
+
normalBuffer.push(polygonVertex.getNormalX());
|
787
|
+
normalBuffer.push(polygonVertex.getNormalY());
|
999
788
|
}
|
789
|
+
polygonVertex.newIndex = newIndex;
|
790
|
+
vertexMap[key] = newIndex;
|
791
|
+
}
|
792
|
+
} else {
|
793
|
+
polygonVertex.newIndex = vertexMap[polygonVertex.index];
|
794
|
+
polygonVertex.uBuffer = uBuffer;
|
795
|
+
polygonVertex.vBuffer = vBuffer;
|
796
|
+
polygonVertex.heightBuffer = heightBuffer;
|
797
|
+
if (hasVertexNormals) {
|
798
|
+
polygonVertex.normalBuffer = normalBuffer;
|
1000
799
|
}
|
1001
|
-
}
|
1002
|
-
|
1003
|
-
if (numVertices === 3) {
|
1004
|
-
// A triangle.
|
1005
|
-
indices.push(polygonVertices[0].newIndex);
|
1006
|
-
indices.push(polygonVertices[1].newIndex);
|
1007
|
-
indices.push(polygonVertices[2].newIndex);
|
1008
|
-
} else if (numVertices === 4) {
|
1009
|
-
// A quad - two triangles.
|
1010
|
-
indices.push(polygonVertices[0].newIndex);
|
1011
|
-
indices.push(polygonVertices[1].newIndex);
|
1012
|
-
indices.push(polygonVertices[2].newIndex);
|
1013
|
-
|
1014
|
-
indices.push(polygonVertices[0].newIndex);
|
1015
|
-
indices.push(polygonVertices[2].newIndex);
|
1016
|
-
indices.push(polygonVertices[3].newIndex);
|
1017
800
|
}
|
1018
801
|
}
|
1019
|
-
|
1020
|
-
|
1021
|
-
|
1022
|
-
|
1023
|
-
})
|
802
|
+
if (numVertices === 3) {
|
803
|
+
indices.push(polygonVertices[0].newIndex);
|
804
|
+
indices.push(polygonVertices[1].newIndex);
|
805
|
+
indices.push(polygonVertices[2].newIndex);
|
806
|
+
} else if (numVertices === 4) {
|
807
|
+
indices.push(polygonVertices[0].newIndex);
|
808
|
+
indices.push(polygonVertices[1].newIndex);
|
809
|
+
indices.push(polygonVertices[2].newIndex);
|
810
|
+
indices.push(polygonVertices[0].newIndex);
|
811
|
+
indices.push(polygonVertices[2].newIndex);
|
812
|
+
indices.push(polygonVertices[3].newIndex);
|
813
|
+
}
|
814
|
+
}
|
815
|
+
var upsampleQuantizedTerrainMesh_default = createTaskProcessorWorker_default(upsampleQuantizedTerrainMesh);
|
816
|
+
export {
|
817
|
+
upsampleQuantizedTerrainMesh_default as default
|
818
|
+
};
|