@vcmap/ui 5.0.0-rc.18 → 5.0.0-rc.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -6
- package/build/build.js +2 -2
- package/build/buildCesium.js +3 -3
- package/build/buildHelpers.js +2 -1
- package/config/base.config.json +0 -4
- package/config/dev.config.json +35 -14
- package/config/www.config.json +4 -0
- package/dist/assets/cesium/Workers/ArcType-ce2e50ab.js +37 -0
- package/dist/assets/cesium/Workers/AttributeCompression-b646d393.js +716 -0
- package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-ff186ccc.js +258 -0
- package/dist/assets/cesium/Workers/BoundingRectangle-be5924f4.js +369 -0
- package/dist/assets/cesium/Workers/BoxGeometry-12eeccaf.js +884 -0
- package/dist/assets/cesium/Workers/Check-666ab1a0.js +290 -0
- package/dist/assets/cesium/Workers/Color-a84038cb.js +2262 -0
- package/dist/assets/cesium/Workers/ComponentDatatype-f7b11d02.js +341 -0
- package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-3272c1b3.js +132 -0
- package/dist/assets/cesium/Workers/CorridorGeometryLibrary-0170e093.js +498 -0
- package/dist/assets/cesium/Workers/CylinderGeometry-7c5da648.js +467 -0
- package/dist/assets/cesium/Workers/CylinderGeometryLibrary-372c07d8.js +63 -0
- package/dist/assets/cesium/Workers/EllipseGeometry-797d580e.js +1304 -0
- package/dist/assets/cesium/Workers/EllipseGeometryLibrary-2939e1dc.js +366 -0
- package/dist/assets/cesium/Workers/EllipseOutlineGeometry-8b50870f.js +443 -0
- package/dist/assets/cesium/Workers/EllipsoidGeodesic-98c62a56.js +520 -0
- package/dist/assets/cesium/Workers/EllipsoidGeometry-21c0e3a5.js +637 -0
- package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-eff247c8.js +454 -0
- package/dist/assets/cesium/Workers/EllipsoidRhumbLine-19756602.js +741 -0
- package/dist/assets/cesium/Workers/EllipsoidTangentPlane-214683dc.js +373 -0
- package/dist/assets/cesium/Workers/EncodedCartesian3-81f70735.js +171 -0
- package/dist/assets/cesium/Workers/FrustumGeometry-ac42a6d9.js +2512 -0
- package/dist/assets/cesium/Workers/GeometryAttribute-7d6f1732.js +619 -0
- package/dist/assets/cesium/Workers/GeometryAttributes-f06a2792.js +91 -0
- package/dist/assets/cesium/Workers/GeometryInstance-451dc1cd.js +121 -0
- package/dist/assets/cesium/Workers/GeometryOffsetAttribute-04332ce7.js +16 -0
- package/dist/assets/cesium/Workers/GeometryPipeline-ce4339ed.js +3690 -0
- package/dist/assets/cesium/Workers/IndexDatatype-a55ceaa1.js +200 -0
- package/dist/assets/cesium/Workers/IntersectionTests-f6e6bd8a.js +1836 -0
- package/dist/assets/cesium/Workers/Math-2dbd6b93.js +1330 -0
- package/dist/assets/cesium/Workers/Matrix2-13178034.js +7086 -0
- package/dist/assets/cesium/Workers/Matrix3-315394f6.js +4283 -0
- package/dist/assets/cesium/Workers/OrientedBoundingBox-04920dc7.js +1257 -0
- package/dist/assets/cesium/Workers/Plane-900aa728.js +309 -0
- package/dist/assets/cesium/Workers/PolygonGeometryLibrary-a8680d96.js +1074 -0
- package/dist/assets/cesium/Workers/PolygonPipeline-844aab0a.js +1345 -0
- package/dist/assets/cesium/Workers/PolylinePipeline-32f36d2a.js +573 -0
- package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-a510d657.js +781 -0
- package/dist/assets/cesium/Workers/PrimitivePipeline-ba38434a.js +966 -0
- package/dist/assets/cesium/Workers/RectangleGeometryLibrary-bdba697e.js +280 -0
- package/dist/assets/cesium/Workers/RuntimeError-06c93819.js +68 -0
- package/dist/assets/cesium/Workers/TerrainEncoding-833187da.js +1227 -0
- package/dist/assets/cesium/Workers/Transforms-40229881.js +14696 -0
- package/dist/assets/cesium/Workers/VertexFormat-6b480673.js +312 -0
- package/dist/assets/cesium/Workers/WallGeometryLibrary-919eed92.js +211 -0
- package/dist/assets/cesium/Workers/WebGLConstants-a8cc3e8c.js +620 -0
- package/dist/assets/cesium/Workers/WebMercatorProjection-13a90d41.js +151 -0
- package/dist/assets/cesium/Workers/arrayRemoveDuplicates-c2038105.js +129 -0
- package/dist/assets/cesium/Workers/cesiumWorkerBootstrapper.js +1336 -4
- package/dist/assets/cesium/Workers/combine-ca22a614.js +82 -0
- package/dist/assets/cesium/Workers/combineGeometry.js +17 -25
- package/dist/assets/cesium/Workers/createBoxGeometry.js +12 -25
- package/dist/assets/cesium/Workers/createBoxOutlineGeometry.js +313 -25
- package/dist/assets/cesium/Workers/createCircleGeometry.js +213 -25
- package/dist/assets/cesium/Workers/createCircleOutlineGeometry.js +160 -25
- package/dist/assets/cesium/Workers/createCoplanarPolygonGeometry.js +586 -25
- package/dist/assets/cesium/Workers/createCoplanarPolygonOutlineGeometry.js +236 -25
- package/dist/assets/cesium/Workers/createCorridorGeometry.js +1407 -25
- package/dist/assets/cesium/Workers/createCorridorOutlineGeometry.js +603 -25
- package/dist/assets/cesium/Workers/createCylinderGeometry.js +12 -25
- package/dist/assets/cesium/Workers/createCylinderOutlineGeometry.js +265 -25
- package/dist/assets/cesium/Workers/createEllipseGeometry.js +14 -25
- package/dist/assets/cesium/Workers/createEllipseOutlineGeometry.js +14 -25
- package/dist/assets/cesium/Workers/createEllipsoidGeometry.js +12 -25
- package/dist/assets/cesium/Workers/createEllipsoidOutlineGeometry.js +15 -25
- package/dist/assets/cesium/Workers/createFrustumGeometry.js +12 -25
- package/dist/assets/cesium/Workers/createFrustumOutlineGeometry.js +251 -25
- package/dist/assets/cesium/Workers/createGeometry.js +55 -25
- package/dist/assets/cesium/Workers/createGroundPolylineGeometry.js +2134 -25
- package/dist/assets/cesium/Workers/createPlaneGeometry.js +250 -25
- package/dist/assets/cesium/Workers/createPlaneOutlineGeometry.js +115 -25
- package/dist/assets/cesium/Workers/createPolygonGeometry.js +1420 -25
- package/dist/assets/cesium/Workers/createPolygonOutlineGeometry.js +683 -25
- package/dist/assets/cesium/Workers/createPolylineGeometry.js +571 -25
- package/dist/assets/cesium/Workers/createPolylineVolumeGeometry.js +411 -25
- package/dist/assets/cesium/Workers/createPolylineVolumeOutlineGeometry.js +301 -25
- package/dist/assets/cesium/Workers/createRectangleGeometry.js +1476 -25
- package/dist/assets/cesium/Workers/createRectangleOutlineGeometry.js +535 -25
- package/dist/assets/cesium/Workers/createSimplePolylineGeometry.js +458 -25
- package/dist/assets/cesium/Workers/createSphereGeometry.js +123 -25
- package/dist/assets/cesium/Workers/createSphereOutlineGeometry.js +126 -25
- package/dist/assets/cesium/Workers/createTaskProcessorWorker.js +127 -25
- package/dist/assets/cesium/Workers/createVectorTileClampedPolylines.js +535 -25
- package/dist/assets/cesium/Workers/createVectorTileGeometries.js +445 -25
- package/dist/assets/cesium/Workers/createVectorTilePoints.js +79 -25
- package/dist/assets/cesium/Workers/createVectorTilePolygons.js +406 -25
- package/dist/assets/cesium/Workers/createVectorTilePolylines.js +254 -25
- package/dist/assets/cesium/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +640 -25
- package/dist/assets/cesium/Workers/createVerticesFromHeightmap.js +2711 -27
- package/dist/assets/cesium/Workers/createVerticesFromQuantizedTerrainMesh.js +994 -25
- package/dist/assets/cesium/Workers/createWallGeometry.js +623 -25
- package/dist/assets/cesium/Workers/createWallOutlineGeometry.js +432 -25
- package/dist/assets/cesium/Workers/decodeDraco.js +381 -25
- package/dist/assets/cesium/Workers/decodeGoogleEarthEnterprisePacket.js +3687 -25
- package/dist/assets/cesium/Workers/decodeI3S.js +1040 -0
- package/dist/assets/cesium/Workers/defaultValue-0a909f67.js +51 -0
- package/dist/assets/cesium/Workers/package.js +2 -2
- package/dist/assets/cesium/Workers/transcodeKTX2.js +1516 -25
- package/dist/assets/cesium/Workers/transferTypedArrayTest.js +18 -2
- package/dist/assets/cesium/Workers/upsampleQuantizedTerrainMesh.js +1023 -25
- package/dist/assets/{cesium.2f992f.js → cesium.49585c.js} +112161 -108735
- package/dist/assets/cesium.js +1 -1
- package/dist/assets/{core.cb0408.js → core.59d4d1.js} +1616 -1629
- package/dist/assets/core.js +1 -1
- package/dist/assets/{index.bccdf969.js → index.a3861d4e.js} +1 -1
- package/dist/assets/{ol.5e3fd0.js → ol.c1c512.js} +6992 -6972
- package/dist/assets/ol.js +1 -1
- package/dist/assets/ui.80175f.css +1 -0
- package/dist/assets/{ui.08c48f.js → ui.80175f.js} +6121 -6785
- package/dist/assets/ui.js +1 -1
- package/dist/assets/{vue.228ead.js → vue.a08ab1.js} +0 -0
- package/dist/assets/vue.js +2 -2
- package/dist/assets/{vuetify.0b5039.css → vuetify.efc158.css} +0 -0
- package/dist/assets/{vuetify.0b5039.js → vuetify.efc158.js} +1 -1
- package/dist/assets/vuetify.js +2 -2
- package/dist/index.html +1 -1
- package/index.js +2 -1
- package/lib/cesium.js +1 -1
- package/package.json +3 -4
- package/plugins/{simple-graph → @vcmap/simple-graph}/README.md +1 -1
- package/plugins/{simple-graph → @vcmap/simple-graph}/SimpleGraphComponent.vue +0 -0
- package/plugins/{simple-graph → @vcmap/simple-graph}/index.js +0 -0
- package/plugins/{simple-graph → @vcmap/simple-graph}/package.json +0 -0
- package/plugins/{simple-graph → @vcmap/simple-graph}/simpleGraphView.js +0 -0
- package/plugins/@vcmap-show-case/README.md +20 -0
- package/plugins/{buttonExamples/ButtonExamples.vue → @vcmap-show-case/buttons-example/ButtonsExample.vue} +1 -1
- package/plugins/@vcmap-show-case/buttons-example/README.md +4 -0
- package/plugins/{buttonExamples → @vcmap-show-case/buttons-example}/index.js +16 -8
- package/plugins/@vcmap-show-case/buttons-example/package.json +5 -0
- package/plugins/{categoryTest → @vcmap-show-case/category-tester}/Categories.vue +7 -6
- package/plugins/{categoryTest → @vcmap-show-case/category-tester}/Category.vue +4 -3
- package/plugins/@vcmap-show-case/category-tester/README.md +3 -0
- package/plugins/{categoryTest → @vcmap-show-case/category-tester}/index.js +12 -4
- package/plugins/@vcmap-show-case/category-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/config-editor/README.md +3 -0
- package/plugins/{test → @vcmap-show-case/config-editor}/editor.vue +0 -0
- package/plugins/@vcmap-show-case/config-editor/index.js +47 -0
- package/plugins/@vcmap-show-case/config-editor/package.json +5 -0
- package/plugins/@vcmap-show-case/context-menu-tester/README.md +3 -0
- package/plugins/@vcmap-show-case/context-menu-tester/index.js +33 -0
- package/plugins/@vcmap-show-case/context-menu-tester/package.json +5 -0
- package/plugins/{@vcmap/pluginExample/pluginExampleComponent.vue → @vcmap-show-case/form-inputs-example/FormInputsExample.vue} +14 -13
- package/plugins/@vcmap-show-case/form-inputs-example/README.md +4 -0
- package/plugins/@vcmap-show-case/form-inputs-example/config.json +5 -0
- package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example}/exampleActions.js +1 -1
- package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example}/index.js +23 -22
- package/plugins/@vcmap-show-case/form-inputs-example/package.json +5 -0
- package/plugins/{@vcmap/pluginExample → @vcmap-show-case/form-inputs-example}/validation.js +0 -0
- package/plugins/@vcmap-show-case/icons-example/README.md +5 -0
- package/plugins/@vcmap-show-case/icons-example/allIconsComponent.vue +51 -0
- package/plugins/@vcmap-show-case/icons-example/index.js +44 -0
- package/plugins/@vcmap-show-case/icons-example/package.json +5 -0
- package/plugins/{test/testList.vue → @vcmap-show-case/list-example/ListExample.vue} +1 -1
- package/plugins/@vcmap-show-case/list-example/README.md +3 -0
- package/plugins/@vcmap-show-case/list-example/index.js +44 -0
- package/plugins/@vcmap-show-case/list-example/package.json +5 -0
- package/plugins/@vcmap-show-case/notifier-tester/README.md +3 -0
- package/plugins/{notifier → @vcmap-show-case/notifier-tester}/index.js +11 -6
- package/plugins/{notifier → @vcmap-show-case/notifier-tester}/notifierTester.vue +0 -0
- package/plugins/@vcmap-show-case/notifier-tester/package.json +5 -0
- package/plugins/@vcmap-show-case/textfields-example/README.md +3 -0
- package/plugins/{example/mySuperComponent.vue → @vcmap-show-case/textfields-example/TextfieldsExample.vue} +1 -7
- package/plugins/{example → @vcmap-show-case/textfields-example}/index.js +58 -62
- package/plugins/@vcmap-show-case/textfields-example/package.json +5 -0
- package/plugins/@vcmap-show-case/window-tester/README.md +3 -0
- package/plugins/{test/windowManagerExample.vue → @vcmap-show-case/window-tester/WindowExample.vue} +36 -20
- package/plugins/{test → @vcmap-show-case/window-tester}/emptyComponent.vue +8 -3
- package/plugins/@vcmap-show-case/window-tester/index.js +62 -0
- package/plugins/{test → @vcmap-show-case/window-tester}/myCustomHeader.vue +0 -0
- package/plugins/@vcmap-show-case/window-tester/package.json +5 -0
- package/plugins/{test → @vcmap-show-case/window-tester}/toolbox-data.js +9 -9
- package/plugins/{test/vcsContent.vue → @vcmap-show-case/window-tester/windowExampleContent.vue} +1 -5
- package/plugins/@vcmap-show-case/wizard-example/README.md +3 -0
- package/plugins/{wizardExample → @vcmap-show-case/wizard-example}/index.js +12 -6
- package/plugins/@vcmap-show-case/wizard-example/package.json +5 -0
- package/plugins/@vcmap-show-case/wizard-example/wizardExample.vue +95 -0
- package/plugins/package.json +2 -1
- package/src/actions/actionHelper.js +1 -3
- package/src/actions/stateRefAction.js +0 -10
- package/src/application/VcsApp.vue +42 -23
- package/src/application/VcsMap.vue +9 -0
- package/src/components/buttons/VcsActionButtonList.vue +1 -0
- package/src/components/form-inputs-controls/VcsCheckbox.vue +3 -1
- package/src/components/form-inputs-controls/VcsWizard.vue +17 -20
- package/src/components/form-inputs-controls/VcsWizardStep.vue +160 -0
- package/src/{icons → components/icons}/+all.js +0 -0
- package/src/{icons → components/icons}/2DAreaIcon.vue +0 -0
- package/src/{icons → components/icons}/2DDistanceIcon.vue +0 -0
- package/src/{icons → components/icons}/3DAreaIcon.vue +0 -0
- package/src/{icons → components/icons}/3DDistanceIcon.vue +0 -0
- package/src/{icons → components/icons}/3DHeightIcon.vue +0 -0
- package/src/{icons → components/icons}/AngleIcon.vue +0 -0
- package/src/{icons → components/icons}/AssociationsIcon.vue +0 -0
- package/src/{icons → components/icons}/AxisIcon.vue +0 -0
- package/src/{icons → components/icons}/BoundingBoxIcon.vue +0 -0
- package/src/{icons → components/icons}/CheckboxCheckedIcon.vue +0 -0
- package/src/{icons → components/icons}/CheckboxIcon.vue +0 -0
- package/src/{icons → components/icons}/CheckboxIndeterminateIcon.vue +0 -0
- package/src/{icons → components/icons}/CircleIcon.vue +0 -0
- package/src/{icons → components/icons}/ClippingHorizontalIcon.vue +0 -0
- package/src/{icons → components/icons}/ClippingIcon.vue +0 -0
- package/src/{icons → components/icons}/ClippingVerticalIcon.vue +0 -0
- package/src/{icons → components/icons}/ColorPickerIcon.vue +0 -0
- package/src/{icons → components/icons}/ColorSwatchIcon.vue +0 -0
- package/src/{icons → components/icons}/CommentIcon.vue +0 -0
- package/src/{icons → components/icons}/CompassIcon.vue +0 -0
- package/src/{icons → components/icons}/ComponentsIcon.vue +0 -0
- package/src/{icons → components/icons}/ConeIcon.vue +0 -0
- package/src/{icons → components/icons}/DimensionsHouseIcon.vue +0 -0
- package/src/{icons → components/icons}/EditIcon.vue +0 -0
- package/src/{icons → components/icons}/ElevationProfileIcon.vue +0 -0
- package/src/{icons → components/icons}/ExportAreaIcon.vue +0 -0
- package/src/{icons → components/icons}/ExportFlightIcon.vue +0 -0
- package/src/{icons → components/icons}/ExportIcon.vue +0 -0
- package/src/{icons → components/icons}/ExternalLinkIcon.vue +0 -0
- package/src/{icons → components/icons}/EyeIcon.vue +0 -0
- package/src/{icons → components/icons}/FastForwardIcon.vue +0 -0
- package/src/{icons → components/icons}/FilterIcon.vue +0 -0
- package/src/{icons → components/icons}/GlobalTerrainIcon.vue +0 -0
- package/src/{icons → components/icons}/GlobeNatureIcon.vue +0 -0
- package/src/{icons → components/icons}/GroundIcon.vue +0 -0
- package/src/{icons → components/icons}/HealthCareIndustriesIcon.vue +0 -0
- package/src/{icons → components/icons}/HelpIcon.vue +0 -0
- package/src/{icons → components/icons}/HideIcon.vue +0 -0
- package/src/{icons → components/icons}/HomePointIcon.vue +0 -0
- package/src/{icons → components/icons}/HospitalsIcon.vue +0 -0
- package/src/{icons → components/icons}/HouseIcon.vue +0 -0
- package/src/{icons → components/icons}/ImportIcon.vue +0 -0
- package/src/{icons → components/icons}/InfoIcon.vue +0 -0
- package/src/{icons → components/icons}/KebabIcon.vue +0 -0
- package/src/{icons → components/icons}/LabelIcon.vue +0 -0
- package/src/{icons → components/icons}/LayersIcon.vue +0 -0
- package/src/{icons → components/icons}/LegendIcon.vue +0 -0
- package/src/{icons → components/icons}/LineIcon.vue +0 -0
- package/src/{icons → components/icons}/LinkIcon.vue +0 -0
- package/src/{icons → components/icons}/LogoutIcon.vue +0 -0
- package/src/{icons → components/icons}/MapIcon.vue +0 -0
- package/src/{icons → components/icons}/MenuIcon.vue +0 -0
- package/src/{icons → components/icons}/MinusIcon.vue +0 -0
- package/src/{icons → components/icons}/ObjectAttributeIcon.vue +0 -0
- package/src/{icons → components/icons}/ObjectSelectIcon.vue +0 -0
- package/src/{icons → components/icons}/ObliqueViewIcon.vue +0 -0
- package/src/{icons → components/icons}/PdfIcon.vue +0 -0
- package/src/{icons → components/icons}/PedestrianIcon.vue +0 -0
- package/src/{icons → components/icons}/PenIcon.vue +0 -0
- package/src/{icons → components/icons}/PlayCircleIcon.vue +0 -0
- package/src/{icons → components/icons}/PlusIcon.vue +0 -0
- package/src/{icons → components/icons}/PoiIcon.vue +0 -0
- package/src/{icons → components/icons}/PointSelectIcon.vue +0 -0
- package/src/{icons → components/icons}/PolygonIcon.vue +0 -0
- package/src/{icons → components/icons}/PresentationModeIcon.vue +0 -0
- package/src/{icons → components/icons}/ProgressIcon.vue +0 -0
- package/src/{icons → components/icons}/QueryIcon.vue +0 -0
- package/src/{icons → components/icons}/RectangleIcon.vue +0 -0
- package/src/{icons → components/icons}/ReturnIcon.vue +0 -0
- package/src/{icons → components/icons}/RewindIcon.vue +0 -0
- package/src/{icons → components/icons}/RotateLeftIcon.vue +0 -0
- package/src/{icons → components/icons}/RotateRightIcon.vue +0 -0
- package/src/{icons → components/icons}/ScreenshotIcon.vue +0 -0
- package/src/{icons → components/icons}/SearchIcon.vue +0 -0
- package/src/{icons → components/icons}/ShadowIcon.vue +0 -0
- package/src/{icons → components/icons}/ShapesIcon.vue +0 -0
- package/src/{icons → components/icons}/ShareIcon.vue +0 -0
- package/src/{icons → components/icons}/SimpleCircleFilledIcon.vue +0 -0
- package/src/{icons → components/icons}/SimpleCircleHalfFilledIcon.vue +0 -0
- package/src/{icons → components/icons}/SimpleCircleOutlinedIcon.vue +0 -0
- package/src/{icons → components/icons}/SkipNextIcon.vue +0 -0
- package/src/{icons → components/icons}/SkipPreviousIcon.vue +0 -0
- package/src/{icons → components/icons}/SplitViewIcon.vue +0 -0
- package/src/{icons → components/icons}/TerrainBoxIcon.vue +0 -0
- package/src/{icons → components/icons}/TextStyleIcon.vue +0 -0
- package/src/{icons → components/icons}/ThreeDimensionsIcon.vue +0 -0
- package/src/{icons → components/icons}/ToolsIcon.vue +0 -0
- package/src/{icons → components/icons}/TouchIcon.vue +0 -0
- package/src/{icons → components/icons}/TrashCanIcon.vue +0 -0
- package/src/{icons → components/icons}/TriangleIcon.vue +0 -0
- package/src/{icons → components/icons}/TwoDimensionsIcon.vue +0 -0
- package/src/{icons → components/icons}/UploadIcon.vue +0 -0
- package/src/{icons → components/icons}/UserProfileIcon.vue +0 -0
- package/src/{icons → components/icons}/UserShareIcon.vue +0 -0
- package/src/{icons → components/icons}/VideoRecorderIcon.vue +0 -0
- package/src/{icons → components/icons}/ViewpointFlightIcon.vue +0 -0
- package/src/{icons → components/icons}/ViewpointIcon.vue +0 -0
- package/src/{icons → components/icons}/Viewshed360Icon.vue +0 -0
- package/src/{icons → components/icons}/ViewshedConeIcon.vue +0 -0
- package/src/{icons → components/icons}/ViewshedIcon.vue +0 -0
- package/src/{icons → components/icons}/WalkingIcon.vue +0 -0
- package/src/{icons → components/icons}/WallIcon.vue +0 -0
- package/src/{icons → components/icons}/WandIcon.vue +0 -0
- package/src/components/lists/VcsList.vue +21 -12
- package/src/components/lists/VcsTreeviewLeaf.vue +14 -2
- package/src/components/notification/VcsTooltip.vue +1 -1
- package/src/featureInfo/abstractFeatureInfoView.js +1 -1
- package/src/featureInfo/addressBalloonFeatureInfoView.js +1 -1
- package/src/featureInfo/balloonFeatureInfoView.js +1 -1
- package/src/featureInfo/balloonHelper.js +6 -6
- package/src/featureInfo/featureInfo.js +2 -2
- package/src/i18n/de.js +2 -6
- package/src/i18n/en.js +2 -6
- package/src/legend/legendHelper.js +4 -3
- package/src/legend/vcsLegend.vue +21 -2
- package/src/manager/window/WindowComponent.vue +42 -4
- package/src/manager/window/WindowComponentHeader.vue +1 -1
- package/src/manager/window/windowHelper.js +7 -11
- package/src/manager/window/windowManager.js +15 -11
- package/src/navigation/mapNavCompass.vue +13 -7
- package/src/navigation/mapNavigation.vue +66 -4
- package/src/navigation/orientationToolsButton.vue +1 -1
- package/src/navigation/overviewMap.js +26 -10
- package/src/navigation/vcsCompass.vue +4 -73
- package/src/setup.js +1 -1
- package/src/vuePlugins/vuetify.js +1 -1
- package/dist/assets/cesium/Workers/ArcType-c9b2b290.js +0 -25
- package/dist/assets/cesium/Workers/AttributeCompression-7b0f288d.js +0 -25
- package/dist/assets/cesium/Workers/AxisAlignedBoundingBox-d0c22774.js +0 -25
- package/dist/assets/cesium/Workers/BoundingRectangle-201b1a81.js +0 -25
- package/dist/assets/cesium/Workers/BoxGeometry-4985457c.js +0 -25
- package/dist/assets/cesium/Workers/Color-cc8c18b3.js +0 -25
- package/dist/assets/cesium/Workers/ComponentDatatype-0200bf8c.js +0 -25
- package/dist/assets/cesium/Workers/CoplanarPolygonGeometryLibrary-4345acdf.js +0 -25
- package/dist/assets/cesium/Workers/CorridorGeometryLibrary-850a6c35.js +0 -25
- package/dist/assets/cesium/Workers/CylinderGeometry-57a1051a.js +0 -25
- package/dist/assets/cesium/Workers/CylinderGeometryLibrary-62ce5a1f.js +0 -25
- package/dist/assets/cesium/Workers/EllipseGeometry-8627398f.js +0 -25
- package/dist/assets/cesium/Workers/EllipseGeometryLibrary-e5919563.js +0 -25
- package/dist/assets/cesium/Workers/EllipseOutlineGeometry-96fd4ae1.js +0 -25
- package/dist/assets/cesium/Workers/EllipsoidGeodesic-8bfefbff.js +0 -25
- package/dist/assets/cesium/Workers/EllipsoidGeometry-377329b9.js +0 -25
- package/dist/assets/cesium/Workers/EllipsoidOutlineGeometry-e6e16e49.js +0 -25
- package/dist/assets/cesium/Workers/EllipsoidRhumbLine-03528f73.js +0 -25
- package/dist/assets/cesium/Workers/EllipsoidTangentPlane-c080fd1b.js +0 -25
- package/dist/assets/cesium/Workers/EncodedCartesian3-ea0e408f.js +0 -25
- package/dist/assets/cesium/Workers/FrustumGeometry-a8b5d817.js +0 -25
- package/dist/assets/cesium/Workers/GeometryAttribute-8458a8fd.js +0 -25
- package/dist/assets/cesium/Workers/GeometryAttributes-ac0f8485.js +0 -25
- package/dist/assets/cesium/Workers/GeometryInstance-ee3aa3ba.js +0 -25
- package/dist/assets/cesium/Workers/GeometryOffsetAttribute-08ae0c50.js +0 -25
- package/dist/assets/cesium/Workers/GeometryPipeline-33ca229c.js +0 -25
- package/dist/assets/cesium/Workers/IndexDatatype-e713bfd2.js +0 -25
- package/dist/assets/cesium/Workers/IntersectionTests-eb4db8e0.js +0 -25
- package/dist/assets/cesium/Workers/Matrix2-eefef8eb.js +0 -25
- package/dist/assets/cesium/Workers/OrientedBoundingBox-5193f9a2.js +0 -25
- package/dist/assets/cesium/Workers/Plane-b0299683.js +0 -25
- package/dist/assets/cesium/Workers/PolygonGeometryLibrary-b61295f3.js +0 -25
- package/dist/assets/cesium/Workers/PolygonPipeline-eb527514.js +0 -25
- package/dist/assets/cesium/Workers/PolylinePipeline-0f23dd84.js +0 -25
- package/dist/assets/cesium/Workers/PolylineVolumeGeometryLibrary-2d903430.js +0 -25
- package/dist/assets/cesium/Workers/PrimitivePipeline-e2640413.js +0 -25
- package/dist/assets/cesium/Workers/RectangleGeometryLibrary-ae8bf8a5.js +0 -25
- package/dist/assets/cesium/Workers/RuntimeError-5baf5c66.js +0 -25
- package/dist/assets/cesium/Workers/TerrainEncoding-bc10ab54.js +0 -25
- package/dist/assets/cesium/Workers/Transforms-d2e5867e.js +0 -63
- package/dist/assets/cesium/Workers/VertexFormat-5ec0d9ff.js +0 -25
- package/dist/assets/cesium/Workers/WallGeometryLibrary-1a33e416.js +0 -25
- package/dist/assets/cesium/Workers/WebGLConstants-5b50ced1.js +0 -25
- package/dist/assets/cesium/Workers/WebMercatorProjection-cd2f30c2.js +0 -25
- package/dist/assets/cesium/Workers/_commonjsHelpers-bc29abbc.js +0 -25
- package/dist/assets/cesium/Workers/arrayRemoveDuplicates-f13aceb1.js +0 -25
- package/dist/assets/cesium/Workers/combine-7533016d.js +0 -25
- package/dist/assets/cesium/Workers/defaultValue-0c475b81.js +0 -25
- package/dist/assets/cesium/Workers/package.json +0 -1
- package/dist/assets/ui.08c48f.css +0 -1
- package/plugins/@vcmap/pluginExample/config.json +0 -6
- package/plugins/@vcmap/pluginExample/package.json +0 -7
- package/plugins/categoryTest/ItemEditor.vue +0 -13
- package/plugins/test/allIconsComponent.vue +0 -50
- package/plugins/test/index.js +0 -209
- package/plugins/wizardExample/wizardExample.vue +0 -77
- package/src/components/form-inputs-controls/VcsColorPicker.vue +0 -85
@@ -0,0 +1,573 @@
|
|
1
|
+
define(['exports', './Matrix3-315394f6', './defaultValue-0a909f67', './Check-666ab1a0', './EllipsoidGeodesic-98c62a56', './EllipsoidRhumbLine-19756602', './IntersectionTests-f6e6bd8a', './Math-2dbd6b93', './Matrix2-13178034', './Plane-900aa728'], (function (exports, Matrix3, defaultValue, Check, EllipsoidGeodesic, EllipsoidRhumbLine, IntersectionTests, Math$1, Matrix2, Plane) { 'use strict';
|
2
|
+
|
3
|
+
/**
|
4
|
+
* @private
|
5
|
+
*/
|
6
|
+
const PolylinePipeline = {};
|
7
|
+
|
8
|
+
PolylinePipeline.numberOfPoints = function (p0, p1, minDistance) {
|
9
|
+
const distance = Matrix3.Cartesian3.distance(p0, p1);
|
10
|
+
return Math.ceil(distance / minDistance);
|
11
|
+
};
|
12
|
+
|
13
|
+
PolylinePipeline.numberOfPointsRhumbLine = function (p0, p1, granularity) {
|
14
|
+
const radiansDistanceSquared =
|
15
|
+
Math.pow(p0.longitude - p1.longitude, 2) +
|
16
|
+
Math.pow(p0.latitude - p1.latitude, 2);
|
17
|
+
|
18
|
+
return Math.max(
|
19
|
+
1,
|
20
|
+
Math.ceil(Math.sqrt(radiansDistanceSquared / (granularity * granularity)))
|
21
|
+
);
|
22
|
+
};
|
23
|
+
|
24
|
+
const cartoScratch = new Matrix3.Cartographic();
|
25
|
+
PolylinePipeline.extractHeights = function (positions, ellipsoid) {
|
26
|
+
const length = positions.length;
|
27
|
+
const heights = new Array(length);
|
28
|
+
for (let i = 0; i < length; i++) {
|
29
|
+
const p = positions[i];
|
30
|
+
heights[i] = ellipsoid.cartesianToCartographic(p, cartoScratch).height;
|
31
|
+
}
|
32
|
+
return heights;
|
33
|
+
};
|
34
|
+
|
35
|
+
const wrapLongitudeInversMatrix = new Matrix2.Matrix4();
|
36
|
+
const wrapLongitudeOrigin = new Matrix3.Cartesian3();
|
37
|
+
const wrapLongitudeXZNormal = new Matrix3.Cartesian3();
|
38
|
+
const wrapLongitudeXZPlane = new Plane.Plane(Matrix3.Cartesian3.UNIT_X, 0.0);
|
39
|
+
const wrapLongitudeYZNormal = new Matrix3.Cartesian3();
|
40
|
+
const wrapLongitudeYZPlane = new Plane.Plane(Matrix3.Cartesian3.UNIT_X, 0.0);
|
41
|
+
const wrapLongitudeIntersection = new Matrix3.Cartesian3();
|
42
|
+
const wrapLongitudeOffset = new Matrix3.Cartesian3();
|
43
|
+
|
44
|
+
const subdivideHeightsScratchArray = [];
|
45
|
+
|
46
|
+
function subdivideHeights(numPoints, h0, h1) {
|
47
|
+
const heights = subdivideHeightsScratchArray;
|
48
|
+
heights.length = numPoints;
|
49
|
+
|
50
|
+
let i;
|
51
|
+
if (h0 === h1) {
|
52
|
+
for (i = 0; i < numPoints; i++) {
|
53
|
+
heights[i] = h0;
|
54
|
+
}
|
55
|
+
return heights;
|
56
|
+
}
|
57
|
+
|
58
|
+
const dHeight = h1 - h0;
|
59
|
+
const heightPerVertex = dHeight / numPoints;
|
60
|
+
|
61
|
+
for (i = 0; i < numPoints; i++) {
|
62
|
+
const h = h0 + i * heightPerVertex;
|
63
|
+
heights[i] = h;
|
64
|
+
}
|
65
|
+
|
66
|
+
return heights;
|
67
|
+
}
|
68
|
+
|
69
|
+
const carto1 = new Matrix3.Cartographic();
|
70
|
+
const carto2 = new Matrix3.Cartographic();
|
71
|
+
const cartesian = new Matrix3.Cartesian3();
|
72
|
+
const scaleFirst = new Matrix3.Cartesian3();
|
73
|
+
const scaleLast = new Matrix3.Cartesian3();
|
74
|
+
const ellipsoidGeodesic = new EllipsoidGeodesic.EllipsoidGeodesic();
|
75
|
+
let ellipsoidRhumb = new EllipsoidRhumbLine.EllipsoidRhumbLine();
|
76
|
+
|
77
|
+
//Returns subdivided line scaled to ellipsoid surface starting at p1 and ending at p2.
|
78
|
+
//Result includes p1, but not include p2. This function is called for a sequence of line segments,
|
79
|
+
//and this prevents duplication of end point.
|
80
|
+
function generateCartesianArc(
|
81
|
+
p0,
|
82
|
+
p1,
|
83
|
+
minDistance,
|
84
|
+
ellipsoid,
|
85
|
+
h0,
|
86
|
+
h1,
|
87
|
+
array,
|
88
|
+
offset
|
89
|
+
) {
|
90
|
+
const first = ellipsoid.scaleToGeodeticSurface(p0, scaleFirst);
|
91
|
+
const last = ellipsoid.scaleToGeodeticSurface(p1, scaleLast);
|
92
|
+
const numPoints = PolylinePipeline.numberOfPoints(p0, p1, minDistance);
|
93
|
+
const start = ellipsoid.cartesianToCartographic(first, carto1);
|
94
|
+
const end = ellipsoid.cartesianToCartographic(last, carto2);
|
95
|
+
const heights = subdivideHeights(numPoints, h0, h1);
|
96
|
+
|
97
|
+
ellipsoidGeodesic.setEndPoints(start, end);
|
98
|
+
const surfaceDistanceBetweenPoints =
|
99
|
+
ellipsoidGeodesic.surfaceDistance / numPoints;
|
100
|
+
|
101
|
+
let index = offset;
|
102
|
+
start.height = h0;
|
103
|
+
let cart = ellipsoid.cartographicToCartesian(start, cartesian);
|
104
|
+
Matrix3.Cartesian3.pack(cart, array, index);
|
105
|
+
index += 3;
|
106
|
+
|
107
|
+
for (let i = 1; i < numPoints; i++) {
|
108
|
+
const carto = ellipsoidGeodesic.interpolateUsingSurfaceDistance(
|
109
|
+
i * surfaceDistanceBetweenPoints,
|
110
|
+
carto2
|
111
|
+
);
|
112
|
+
carto.height = heights[i];
|
113
|
+
cart = ellipsoid.cartographicToCartesian(carto, cartesian);
|
114
|
+
Matrix3.Cartesian3.pack(cart, array, index);
|
115
|
+
index += 3;
|
116
|
+
}
|
117
|
+
|
118
|
+
return index;
|
119
|
+
}
|
120
|
+
|
121
|
+
//Returns subdivided line scaled to ellipsoid surface starting at p1 and ending at p2.
|
122
|
+
//Result includes p1, but not include p2. This function is called for a sequence of line segments,
|
123
|
+
//and this prevents duplication of end point.
|
124
|
+
function generateCartesianRhumbArc(
|
125
|
+
p0,
|
126
|
+
p1,
|
127
|
+
granularity,
|
128
|
+
ellipsoid,
|
129
|
+
h0,
|
130
|
+
h1,
|
131
|
+
array,
|
132
|
+
offset
|
133
|
+
) {
|
134
|
+
const start = ellipsoid.cartesianToCartographic(p0, carto1);
|
135
|
+
const end = ellipsoid.cartesianToCartographic(p1, carto2);
|
136
|
+
const numPoints = PolylinePipeline.numberOfPointsRhumbLine(
|
137
|
+
start,
|
138
|
+
end,
|
139
|
+
granularity
|
140
|
+
);
|
141
|
+
start.height = 0.0;
|
142
|
+
end.height = 0.0;
|
143
|
+
const heights = subdivideHeights(numPoints, h0, h1);
|
144
|
+
|
145
|
+
if (!ellipsoidRhumb.ellipsoid.equals(ellipsoid)) {
|
146
|
+
ellipsoidRhumb = new EllipsoidRhumbLine.EllipsoidRhumbLine(undefined, undefined, ellipsoid);
|
147
|
+
}
|
148
|
+
ellipsoidRhumb.setEndPoints(start, end);
|
149
|
+
const surfaceDistanceBetweenPoints =
|
150
|
+
ellipsoidRhumb.surfaceDistance / numPoints;
|
151
|
+
|
152
|
+
let index = offset;
|
153
|
+
start.height = h0;
|
154
|
+
let cart = ellipsoid.cartographicToCartesian(start, cartesian);
|
155
|
+
Matrix3.Cartesian3.pack(cart, array, index);
|
156
|
+
index += 3;
|
157
|
+
|
158
|
+
for (let i = 1; i < numPoints; i++) {
|
159
|
+
const carto = ellipsoidRhumb.interpolateUsingSurfaceDistance(
|
160
|
+
i * surfaceDistanceBetweenPoints,
|
161
|
+
carto2
|
162
|
+
);
|
163
|
+
carto.height = heights[i];
|
164
|
+
cart = ellipsoid.cartographicToCartesian(carto, cartesian);
|
165
|
+
Matrix3.Cartesian3.pack(cart, array, index);
|
166
|
+
index += 3;
|
167
|
+
}
|
168
|
+
|
169
|
+
return index;
|
170
|
+
}
|
171
|
+
|
172
|
+
/**
|
173
|
+
* Breaks a {@link Polyline} into segments such that it does not cross the ±180 degree meridian of an ellipsoid.
|
174
|
+
*
|
175
|
+
* @param {Cartesian3[]} positions The polyline's Cartesian positions.
|
176
|
+
* @param {Matrix4} [modelMatrix=Matrix4.IDENTITY] The polyline's model matrix. Assumed to be an affine
|
177
|
+
* transformation matrix, where the upper left 3x3 elements are a rotation matrix, and
|
178
|
+
* the upper three elements in the fourth column are the translation. The bottom row is assumed to be [0, 0, 0, 1].
|
179
|
+
* The matrix is not verified to be in the proper form.
|
180
|
+
* @returns {Object} An object with a <code>positions</code> property that is an array of positions and a
|
181
|
+
* <code>segments</code> property.
|
182
|
+
*
|
183
|
+
*
|
184
|
+
* @example
|
185
|
+
* const polylines = new Cesium.PolylineCollection();
|
186
|
+
* const polyline = polylines.add(...);
|
187
|
+
* const positions = polyline.positions;
|
188
|
+
* const modelMatrix = polylines.modelMatrix;
|
189
|
+
* const segments = Cesium.PolylinePipeline.wrapLongitude(positions, modelMatrix);
|
190
|
+
*
|
191
|
+
* @see PolygonPipeline.wrapLongitude
|
192
|
+
* @see Polyline
|
193
|
+
* @see PolylineCollection
|
194
|
+
*/
|
195
|
+
PolylinePipeline.wrapLongitude = function (positions, modelMatrix) {
|
196
|
+
const cartesians = [];
|
197
|
+
const segments = [];
|
198
|
+
|
199
|
+
if (defaultValue.defined(positions) && positions.length > 0) {
|
200
|
+
modelMatrix = defaultValue.defaultValue(modelMatrix, Matrix2.Matrix4.IDENTITY);
|
201
|
+
const inverseModelMatrix = Matrix2.Matrix4.inverseTransformation(
|
202
|
+
modelMatrix,
|
203
|
+
wrapLongitudeInversMatrix
|
204
|
+
);
|
205
|
+
|
206
|
+
const origin = Matrix2.Matrix4.multiplyByPoint(
|
207
|
+
inverseModelMatrix,
|
208
|
+
Matrix3.Cartesian3.ZERO,
|
209
|
+
wrapLongitudeOrigin
|
210
|
+
);
|
211
|
+
const xzNormal = Matrix3.Cartesian3.normalize(
|
212
|
+
Matrix2.Matrix4.multiplyByPointAsVector(
|
213
|
+
inverseModelMatrix,
|
214
|
+
Matrix3.Cartesian3.UNIT_Y,
|
215
|
+
wrapLongitudeXZNormal
|
216
|
+
),
|
217
|
+
wrapLongitudeXZNormal
|
218
|
+
);
|
219
|
+
const xzPlane = Plane.Plane.fromPointNormal(
|
220
|
+
origin,
|
221
|
+
xzNormal,
|
222
|
+
wrapLongitudeXZPlane
|
223
|
+
);
|
224
|
+
const yzNormal = Matrix3.Cartesian3.normalize(
|
225
|
+
Matrix2.Matrix4.multiplyByPointAsVector(
|
226
|
+
inverseModelMatrix,
|
227
|
+
Matrix3.Cartesian3.UNIT_X,
|
228
|
+
wrapLongitudeYZNormal
|
229
|
+
),
|
230
|
+
wrapLongitudeYZNormal
|
231
|
+
);
|
232
|
+
const yzPlane = Plane.Plane.fromPointNormal(
|
233
|
+
origin,
|
234
|
+
yzNormal,
|
235
|
+
wrapLongitudeYZPlane
|
236
|
+
);
|
237
|
+
|
238
|
+
let count = 1;
|
239
|
+
cartesians.push(Matrix3.Cartesian3.clone(positions[0]));
|
240
|
+
let prev = cartesians[0];
|
241
|
+
|
242
|
+
const length = positions.length;
|
243
|
+
for (let i = 1; i < length; ++i) {
|
244
|
+
const cur = positions[i];
|
245
|
+
|
246
|
+
// intersects the IDL if either endpoint is on the negative side of the yz-plane
|
247
|
+
if (
|
248
|
+
Plane.Plane.getPointDistance(yzPlane, prev) < 0.0 ||
|
249
|
+
Plane.Plane.getPointDistance(yzPlane, cur) < 0.0
|
250
|
+
) {
|
251
|
+
// and intersects the xz-plane
|
252
|
+
const intersection = IntersectionTests.IntersectionTests.lineSegmentPlane(
|
253
|
+
prev,
|
254
|
+
cur,
|
255
|
+
xzPlane,
|
256
|
+
wrapLongitudeIntersection
|
257
|
+
);
|
258
|
+
if (defaultValue.defined(intersection)) {
|
259
|
+
// move point on the xz-plane slightly away from the plane
|
260
|
+
const offset = Matrix3.Cartesian3.multiplyByScalar(
|
261
|
+
xzNormal,
|
262
|
+
5.0e-9,
|
263
|
+
wrapLongitudeOffset
|
264
|
+
);
|
265
|
+
if (Plane.Plane.getPointDistance(xzPlane, prev) < 0.0) {
|
266
|
+
Matrix3.Cartesian3.negate(offset, offset);
|
267
|
+
}
|
268
|
+
|
269
|
+
cartesians.push(
|
270
|
+
Matrix3.Cartesian3.add(intersection, offset, new Matrix3.Cartesian3())
|
271
|
+
);
|
272
|
+
segments.push(count + 1);
|
273
|
+
|
274
|
+
Matrix3.Cartesian3.negate(offset, offset);
|
275
|
+
cartesians.push(
|
276
|
+
Matrix3.Cartesian3.add(intersection, offset, new Matrix3.Cartesian3())
|
277
|
+
);
|
278
|
+
count = 1;
|
279
|
+
}
|
280
|
+
}
|
281
|
+
|
282
|
+
cartesians.push(Matrix3.Cartesian3.clone(positions[i]));
|
283
|
+
count++;
|
284
|
+
|
285
|
+
prev = cur;
|
286
|
+
}
|
287
|
+
|
288
|
+
segments.push(count);
|
289
|
+
}
|
290
|
+
|
291
|
+
return {
|
292
|
+
positions: cartesians,
|
293
|
+
lengths: segments,
|
294
|
+
};
|
295
|
+
};
|
296
|
+
|
297
|
+
/**
|
298
|
+
* Subdivides polyline and raises all points to the specified height. Returns an array of numbers to represent the positions.
|
299
|
+
* @param {Object} options Object with the following properties:
|
300
|
+
* @param {Cartesian3[]} options.positions The array of type {Cartesian3} representing positions.
|
301
|
+
* @param {Number|Number[]} [options.height=0.0] A number or array of numbers representing the heights of each position.
|
302
|
+
* @param {Number} [options.granularity = CesiumMath.RADIANS_PER_DEGREE] The distance, in radians, between each latitude and longitude. Determines the number of positions in the buffer.
|
303
|
+
* @param {Ellipsoid} [options.ellipsoid=Ellipsoid.WGS84] The ellipsoid on which the positions lie.
|
304
|
+
* @returns {Number[]} A new array of positions of type {Number} that have been subdivided and raised to the surface of the ellipsoid.
|
305
|
+
*
|
306
|
+
* @example
|
307
|
+
* const positions = Cesium.Cartesian3.fromDegreesArray([
|
308
|
+
* -105.0, 40.0,
|
309
|
+
* -100.0, 38.0,
|
310
|
+
* -105.0, 35.0,
|
311
|
+
* -100.0, 32.0
|
312
|
+
* ]);
|
313
|
+
* const surfacePositions = Cesium.PolylinePipeline.generateArc({
|
314
|
+
* positons: positions
|
315
|
+
* });
|
316
|
+
*/
|
317
|
+
PolylinePipeline.generateArc = function (options) {
|
318
|
+
if (!defaultValue.defined(options)) {
|
319
|
+
options = {};
|
320
|
+
}
|
321
|
+
const positions = options.positions;
|
322
|
+
//>>includeStart('debug', pragmas.debug);
|
323
|
+
if (!defaultValue.defined(positions)) {
|
324
|
+
throw new Check.DeveloperError("options.positions is required.");
|
325
|
+
}
|
326
|
+
//>>includeEnd('debug');
|
327
|
+
|
328
|
+
const length = positions.length;
|
329
|
+
const ellipsoid = defaultValue.defaultValue(options.ellipsoid, Matrix3.Ellipsoid.WGS84);
|
330
|
+
let height = defaultValue.defaultValue(options.height, 0);
|
331
|
+
const hasHeightArray = Array.isArray(height);
|
332
|
+
|
333
|
+
if (length < 1) {
|
334
|
+
return [];
|
335
|
+
} else if (length === 1) {
|
336
|
+
const p = ellipsoid.scaleToGeodeticSurface(positions[0], scaleFirst);
|
337
|
+
height = hasHeightArray ? height[0] : height;
|
338
|
+
if (height !== 0) {
|
339
|
+
const n = ellipsoid.geodeticSurfaceNormal(p, cartesian);
|
340
|
+
Matrix3.Cartesian3.multiplyByScalar(n, height, n);
|
341
|
+
Matrix3.Cartesian3.add(p, n, p);
|
342
|
+
}
|
343
|
+
|
344
|
+
return [p.x, p.y, p.z];
|
345
|
+
}
|
346
|
+
|
347
|
+
let minDistance = options.minDistance;
|
348
|
+
if (!defaultValue.defined(minDistance)) {
|
349
|
+
const granularity = defaultValue.defaultValue(
|
350
|
+
options.granularity,
|
351
|
+
Math$1.CesiumMath.RADIANS_PER_DEGREE
|
352
|
+
);
|
353
|
+
minDistance = Math$1.CesiumMath.chordLength(granularity, ellipsoid.maximumRadius);
|
354
|
+
}
|
355
|
+
|
356
|
+
let numPoints = 0;
|
357
|
+
let i;
|
358
|
+
|
359
|
+
for (i = 0; i < length - 1; i++) {
|
360
|
+
numPoints += PolylinePipeline.numberOfPoints(
|
361
|
+
positions[i],
|
362
|
+
positions[i + 1],
|
363
|
+
minDistance
|
364
|
+
);
|
365
|
+
}
|
366
|
+
|
367
|
+
const arrayLength = (numPoints + 1) * 3;
|
368
|
+
const newPositions = new Array(arrayLength);
|
369
|
+
let offset = 0;
|
370
|
+
|
371
|
+
for (i = 0; i < length - 1; i++) {
|
372
|
+
const p0 = positions[i];
|
373
|
+
const p1 = positions[i + 1];
|
374
|
+
|
375
|
+
const h0 = hasHeightArray ? height[i] : height;
|
376
|
+
const h1 = hasHeightArray ? height[i + 1] : height;
|
377
|
+
|
378
|
+
offset = generateCartesianArc(
|
379
|
+
p0,
|
380
|
+
p1,
|
381
|
+
minDistance,
|
382
|
+
ellipsoid,
|
383
|
+
h0,
|
384
|
+
h1,
|
385
|
+
newPositions,
|
386
|
+
offset
|
387
|
+
);
|
388
|
+
}
|
389
|
+
|
390
|
+
subdivideHeightsScratchArray.length = 0;
|
391
|
+
|
392
|
+
const lastPoint = positions[length - 1];
|
393
|
+
const carto = ellipsoid.cartesianToCartographic(lastPoint, carto1);
|
394
|
+
carto.height = hasHeightArray ? height[length - 1] : height;
|
395
|
+
const cart = ellipsoid.cartographicToCartesian(carto, cartesian);
|
396
|
+
Matrix3.Cartesian3.pack(cart, newPositions, arrayLength - 3);
|
397
|
+
|
398
|
+
return newPositions;
|
399
|
+
};
|
400
|
+
|
401
|
+
const scratchCartographic0 = new Matrix3.Cartographic();
|
402
|
+
const scratchCartographic1 = new Matrix3.Cartographic();
|
403
|
+
|
404
|
+
/**
|
405
|
+
* Subdivides polyline and raises all points to the specified height using Rhumb lines. Returns an array of numbers to represent the positions.
|
406
|
+
* @param {Object} options Object with the following properties:
|
407
|
+
* @param {Cartesian3[]} options.positions The array of type {Cartesian3} representing positions.
|
408
|
+
* @param {Number|Number[]} [options.height=0.0] A number or array of numbers representing the heights of each position.
|
409
|
+
* @param {Number} [options.granularity = CesiumMath.RADIANS_PER_DEGREE] The distance, in radians, between each latitude and longitude. Determines the number of positions in the buffer.
|
410
|
+
* @param {Ellipsoid} [options.ellipsoid=Ellipsoid.WGS84] The ellipsoid on which the positions lie.
|
411
|
+
* @returns {Number[]} A new array of positions of type {Number} that have been subdivided and raised to the surface of the ellipsoid.
|
412
|
+
*
|
413
|
+
* @example
|
414
|
+
* const positions = Cesium.Cartesian3.fromDegreesArray([
|
415
|
+
* -105.0, 40.0,
|
416
|
+
* -100.0, 38.0,
|
417
|
+
* -105.0, 35.0,
|
418
|
+
* -100.0, 32.0
|
419
|
+
* ]);
|
420
|
+
* const surfacePositions = Cesium.PolylinePipeline.generateRhumbArc({
|
421
|
+
* positons: positions
|
422
|
+
* });
|
423
|
+
*/
|
424
|
+
PolylinePipeline.generateRhumbArc = function (options) {
|
425
|
+
if (!defaultValue.defined(options)) {
|
426
|
+
options = {};
|
427
|
+
}
|
428
|
+
const positions = options.positions;
|
429
|
+
//>>includeStart('debug', pragmas.debug);
|
430
|
+
if (!defaultValue.defined(positions)) {
|
431
|
+
throw new Check.DeveloperError("options.positions is required.");
|
432
|
+
}
|
433
|
+
//>>includeEnd('debug');
|
434
|
+
|
435
|
+
const length = positions.length;
|
436
|
+
const ellipsoid = defaultValue.defaultValue(options.ellipsoid, Matrix3.Ellipsoid.WGS84);
|
437
|
+
let height = defaultValue.defaultValue(options.height, 0);
|
438
|
+
const hasHeightArray = Array.isArray(height);
|
439
|
+
|
440
|
+
if (length < 1) {
|
441
|
+
return [];
|
442
|
+
} else if (length === 1) {
|
443
|
+
const p = ellipsoid.scaleToGeodeticSurface(positions[0], scaleFirst);
|
444
|
+
height = hasHeightArray ? height[0] : height;
|
445
|
+
if (height !== 0) {
|
446
|
+
const n = ellipsoid.geodeticSurfaceNormal(p, cartesian);
|
447
|
+
Matrix3.Cartesian3.multiplyByScalar(n, height, n);
|
448
|
+
Matrix3.Cartesian3.add(p, n, p);
|
449
|
+
}
|
450
|
+
|
451
|
+
return [p.x, p.y, p.z];
|
452
|
+
}
|
453
|
+
|
454
|
+
const granularity = defaultValue.defaultValue(
|
455
|
+
options.granularity,
|
456
|
+
Math$1.CesiumMath.RADIANS_PER_DEGREE
|
457
|
+
);
|
458
|
+
|
459
|
+
let numPoints = 0;
|
460
|
+
let i;
|
461
|
+
|
462
|
+
let c0 = ellipsoid.cartesianToCartographic(
|
463
|
+
positions[0],
|
464
|
+
scratchCartographic0
|
465
|
+
);
|
466
|
+
let c1;
|
467
|
+
for (i = 0; i < length - 1; i++) {
|
468
|
+
c1 = ellipsoid.cartesianToCartographic(
|
469
|
+
positions[i + 1],
|
470
|
+
scratchCartographic1
|
471
|
+
);
|
472
|
+
numPoints += PolylinePipeline.numberOfPointsRhumbLine(c0, c1, granularity);
|
473
|
+
c0 = Matrix3.Cartographic.clone(c1, scratchCartographic0);
|
474
|
+
}
|
475
|
+
|
476
|
+
const arrayLength = (numPoints + 1) * 3;
|
477
|
+
const newPositions = new Array(arrayLength);
|
478
|
+
let offset = 0;
|
479
|
+
|
480
|
+
for (i = 0; i < length - 1; i++) {
|
481
|
+
const p0 = positions[i];
|
482
|
+
const p1 = positions[i + 1];
|
483
|
+
|
484
|
+
const h0 = hasHeightArray ? height[i] : height;
|
485
|
+
const h1 = hasHeightArray ? height[i + 1] : height;
|
486
|
+
|
487
|
+
offset = generateCartesianRhumbArc(
|
488
|
+
p0,
|
489
|
+
p1,
|
490
|
+
granularity,
|
491
|
+
ellipsoid,
|
492
|
+
h0,
|
493
|
+
h1,
|
494
|
+
newPositions,
|
495
|
+
offset
|
496
|
+
);
|
497
|
+
}
|
498
|
+
|
499
|
+
subdivideHeightsScratchArray.length = 0;
|
500
|
+
|
501
|
+
const lastPoint = positions[length - 1];
|
502
|
+
const carto = ellipsoid.cartesianToCartographic(lastPoint, carto1);
|
503
|
+
carto.height = hasHeightArray ? height[length - 1] : height;
|
504
|
+
const cart = ellipsoid.cartographicToCartesian(carto, cartesian);
|
505
|
+
Matrix3.Cartesian3.pack(cart, newPositions, arrayLength - 3);
|
506
|
+
|
507
|
+
return newPositions;
|
508
|
+
};
|
509
|
+
|
510
|
+
/**
|
511
|
+
* Subdivides polyline and raises all points to the specified height. Returns an array of new {Cartesian3} positions.
|
512
|
+
* @param {Object} options Object with the following properties:
|
513
|
+
* @param {Cartesian3[]} options.positions The array of type {Cartesian3} representing positions.
|
514
|
+
* @param {Number|Number[]} [options.height=0.0] A number or array of numbers representing the heights of each position.
|
515
|
+
* @param {Number} [options.granularity = CesiumMath.RADIANS_PER_DEGREE] The distance, in radians, between each latitude and longitude. Determines the number of positions in the buffer.
|
516
|
+
* @param {Ellipsoid} [options.ellipsoid=Ellipsoid.WGS84] The ellipsoid on which the positions lie.
|
517
|
+
* @returns {Cartesian3[]} A new array of cartesian3 positions that have been subdivided and raised to the surface of the ellipsoid.
|
518
|
+
*
|
519
|
+
* @example
|
520
|
+
* const positions = Cesium.Cartesian3.fromDegreesArray([
|
521
|
+
* -105.0, 40.0,
|
522
|
+
* -100.0, 38.0,
|
523
|
+
* -105.0, 35.0,
|
524
|
+
* -100.0, 32.0
|
525
|
+
* ]);
|
526
|
+
* const surfacePositions = Cesium.PolylinePipeline.generateCartesianArc({
|
527
|
+
* positons: positions
|
528
|
+
* });
|
529
|
+
*/
|
530
|
+
PolylinePipeline.generateCartesianArc = function (options) {
|
531
|
+
const numberArray = PolylinePipeline.generateArc(options);
|
532
|
+
const size = numberArray.length / 3;
|
533
|
+
const newPositions = new Array(size);
|
534
|
+
for (let i = 0; i < size; i++) {
|
535
|
+
newPositions[i] = Matrix3.Cartesian3.unpack(numberArray, i * 3);
|
536
|
+
}
|
537
|
+
return newPositions;
|
538
|
+
};
|
539
|
+
|
540
|
+
/**
|
541
|
+
* Subdivides polyline and raises all points to the specified height using Rhumb Lines. Returns an array of new {Cartesian3} positions.
|
542
|
+
* @param {Object} options Object with the following properties:
|
543
|
+
* @param {Cartesian3[]} options.positions The array of type {Cartesian3} representing positions.
|
544
|
+
* @param {Number|Number[]} [options.height=0.0] A number or array of numbers representing the heights of each position.
|
545
|
+
* @param {Number} [options.granularity = CesiumMath.RADIANS_PER_DEGREE] The distance, in radians, between each latitude and longitude. Determines the number of positions in the buffer.
|
546
|
+
* @param {Ellipsoid} [options.ellipsoid=Ellipsoid.WGS84] The ellipsoid on which the positions lie.
|
547
|
+
* @returns {Cartesian3[]} A new array of cartesian3 positions that have been subdivided and raised to the surface of the ellipsoid.
|
548
|
+
*
|
549
|
+
* @example
|
550
|
+
* const positions = Cesium.Cartesian3.fromDegreesArray([
|
551
|
+
* -105.0, 40.0,
|
552
|
+
* -100.0, 38.0,
|
553
|
+
* -105.0, 35.0,
|
554
|
+
* -100.0, 32.0
|
555
|
+
* ]);
|
556
|
+
* const surfacePositions = Cesium.PolylinePipeline.generateCartesianRhumbArc({
|
557
|
+
* positons: positions
|
558
|
+
* });
|
559
|
+
*/
|
560
|
+
PolylinePipeline.generateCartesianRhumbArc = function (options) {
|
561
|
+
const numberArray = PolylinePipeline.generateRhumbArc(options);
|
562
|
+
const size = numberArray.length / 3;
|
563
|
+
const newPositions = new Array(size);
|
564
|
+
for (let i = 0; i < size; i++) {
|
565
|
+
newPositions[i] = Matrix3.Cartesian3.unpack(numberArray, i * 3);
|
566
|
+
}
|
567
|
+
return newPositions;
|
568
|
+
};
|
569
|
+
var PolylinePipeline$1 = PolylinePipeline;
|
570
|
+
|
571
|
+
exports.PolylinePipeline = PolylinePipeline$1;
|
572
|
+
|
573
|
+
}));
|