<template>
|
<div id="currentTaskMap"></div>
|
</template>
|
<script setup>
|
import * as Cesium from 'cesium'
|
import AmapMercatorTilingScheme from '@/utils/cesium/AmapMercatorTilingScheme'
|
import { Cartesian3, Terrain, Viewer } from 'cesium'
|
import { addBlueFilter } from '@/utils/cesium/common'
|
import { useTaskWayline } from '@/hooks/useTaskWayline/useTaskWayline'
|
|
const { init: initTaskWayline } = useTaskWayline()
|
|
const imageryProvider_ammapSL = new Cesium.UrlTemplateImageryProvider({
|
url: 'https://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}',
|
layer: 'tdtVecBasicLayer',
|
style: 'default',
|
format: 'image/png',
|
tileMatrixSetID: 'GoogleMapsCompatible',
|
subdomains: ['0', '1', '2', '3', '4', '5', '6', '7'],
|
maximumLevel: 18,
|
tilingScheme: new AmapMercatorTilingScheme(),
|
credit: 'amap_SL',
|
})
|
|
const taskDetailsViewer = inject('taskDetailsViewer')
|
|
const taskDetails = inject('taskDetails')
|
const wsInfo = inject('wsInfo')
|
|
const initMap = () => {
|
taskDetailsViewer.value = new Viewer('currentTaskMap', {
|
terrain: Terrain.fromWorldTerrain(),
|
infoBox: false, // 禁用沙箱,解决控制台报错
|
animation: false, // 左下角的动画仪表盘
|
baseLayerPicker: false, // 右上角的图层选择按钮
|
geocoder: false, // 搜索框
|
homeButton: false, // home按钮
|
sceneModePicker: false, // 模式切换按钮
|
timeline: false, // 底部的时间轴
|
navigationHelpButton: false, // 右上角的帮助按钮,
|
selectionIndicator: false, // 是否显示选择指示器
|
baseLayer: false,
|
fullscreenButton: false,
|
})
|
const gdLayer = taskDetailsViewer?.value.imageryLayers.addImageryProvider(imageryProvider_ammapSL)
|
const options = {
|
bInvertColor: true,
|
bFilterColor: true,
|
filterColor: '#4e70a6',
|
}
|
// 添加蓝色滤镜
|
addBlueFilter(options, taskDetailsViewer?.value, gdLayer)
|
taskDetailsViewer?.value.scene.morphTo2D(0)
|
//设置默认点
|
taskDetailsViewer?.value.camera.setView({
|
destination: Cartesian3.fromDegrees(115.763819, 28.787374, 5000),
|
})
|
|
initTaskWayline(taskDetailsViewer.value, wsInfo, taskDetails)
|
}
|
|
const removeMap = () => {
|
taskDetailsViewer?.value.entities.removeAll()
|
taskDetailsViewer?.value.destroy()
|
}
|
|
onBeforeUnmount(() => {
|
removeMap()
|
})
|
|
onMounted(() => {
|
nextTick(() => {
|
initMap()
|
})
|
})
|
</script>
|
<style scoped lang="scss">
|
#currentTaskMap {
|
:deep() {
|
.cesium-viewer {
|
width: 100%;
|
height: 100%;
|
overflow: hidden;
|
|
.cesium-viewer-cesiumWidgetContainer {
|
width: 100%;
|
height: 100%;
|
|
.cesium-widget {
|
width: 100%;
|
height: 100%;
|
|
canvas {
|
width: 100%;
|
height: 100%;
|
}
|
}
|
}
|
}
|
|
.cesium-viewer-bottom {
|
display: none;
|
}
|
}
|
}
|
</style>
|