UNPKG

vue-cesium

Version:
104 lines (101 loc) 6.74 kB
import '../../../composables/index.mjs'; import { $ } from '../../../utils/private/vm.mjs'; import { defineComponent, getCurrentInstance, h } from 'vue'; import useSelectionIndicatior from './use-selection-indicatior.mjs'; import { commonEmits } from '../../../utils/emits.mjs'; import useCommon from '../../../composables/use-common/index.mjs'; "use strict"; const selectionIndicatorProps = { show: { type: Boolean, default: true }, width: { type: Number, default: 50 }, height: { type: Number, default: 50 }, allowFeatureInfoRequests: { type: Boolean, default: true }, includeImageryIds: { type: Array, default: () => [] }, excludeImageryIds: { type: Array, default: () => [] }, limit: { type: Number, default: 25 } }; const emits = { ...commonEmits, pickEvt: (evt) => true }; var SelectionIndicator = defineComponent({ name: "VcSelectionIndicator", props: selectionIndicatorProps, emits, setup(props, ctx) { const instance = getCurrentInstance(); instance.cesiumClass = "VcSelectionIndicator"; instance.cesiumEvents = []; const commonState = useCommon(props, ctx, instance); if (commonState === void 0) { return; } const { $services } = commonState; let pickScreenSpaceEventHandler; const useSelectionIndicatiorState = useSelectionIndicatior(instance, props, $services); instance.createCesiumObject = async () => { const { viewer } = $services; const viewerElement = viewer._element; viewerElement.appendChild($(useSelectionIndicatiorState.rootRef)); return $(useSelectionIndicatiorState.rootRef); }; instance.mount = async () => { const { viewer } = $services; const { ScreenSpaceEventHandler, ScreenSpaceEventType } = Cesium; pickScreenSpaceEventHandler = new ScreenSpaceEventHandler(viewer.canvas); pickScreenSpaceEventHandler.setInputAction((movement) => { useSelectionIndicatiorState.pickFromScreenPosition(movement.position); }, ScreenSpaceEventType.LEFT_CLICK); viewer.scene.postRender.addEventListener(useSelectionIndicatiorState.onPostRender); return true; }; instance.unmount = async () => { const { viewer } = $services; const viewerElement = viewer._element; viewerElement.contains($(useSelectionIndicatiorState.rootRef)) && viewerElement.removeChild($(useSelectionIndicatiorState.rootRef)); viewer.scene.postRender.removeEventListener(useSelectionIndicatiorState.onPostRender); pickScreenSpaceEventHandler.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK); pickScreenSpaceEventHandler.destroy(); pickScreenSpaceEventHandler = void 0; return true; }; return () => { return h( "div", { ref: useSelectionIndicatiorState.rootRef, class: "vc-selection-indicator", style: useSelectionIndicatiorState.rootStyle }, h("img", { src: "", width: props.width, height: props.height }) ); }; } }); export { SelectionIndicator as default, selectionIndicatorProps }; //# sourceMappingURL=index.mjs.map