| | |
| | | * @Author: shuishen 1109946754@qq.com |
| | | * @Date: 2024-10-31 10:47:29 |
| | | * @LastEditors: shuishen 1109946754@qq.com |
| | | * @LastEditTime: 2024-11-23 17:09:04 |
| | | * @LastEditTime: 2024-11-24 03:30:37 |
| | | * @FilePath: \bigScreen\src\pages\layout\components\scomponents\layersControl.vue |
| | | * @Description: |
| | | * |
| | |
| | | const treeRef = ref(null) |
| | | const Cesium = DC.getLib('Cesium') |
| | | |
| | | console.log(Cesium, 45646465) |
| | | |
| | | const treeProps = { |
| | | indent: 16, |
| | | showLabelLine: true, |
| | |
| | | type: 'layer', |
| | | subType: '3Dtile', |
| | | urlData: [ |
| | | // { |
| | | // url: VITE_APP_BASE + 'mx/tileset.json', |
| | | // label: 'tile_01' |
| | | // }, |
| | | { |
| | | url: VITE_APP_BASE + 'mx/tile_01/Data/tileset.json', |
| | | url: VITE_APP_BASE + 'newMx/mx/tile_01/tileset.json', |
| | | label: 'tile_01' |
| | | }, |
| | | { |
| | | url: VITE_APP_BASE + 'newMx/mx/tile_02/tileset.json', |
| | | label: 'tile_02' |
| | | }, |
| | | { |
| | | url: VITE_APP_BASE + 'newMx/mx/tile_03/tileset.json', |
| | | label: 'tile_03' |
| | | }, |
| | | { |
| | | url: VITE_APP_BASE + 'newMx/mx/tile_04/tileset.json', |
| | | label: 'tile_04' |
| | | }, |
| | | { |
| | | url: VITE_APP_BASE + 'newMx/mx/tile_05/tileset.json', |
| | | label: 'tile_05' |
| | | } |
| | | ], |
| | | layerName: 'hgyq' |
| | |
| | | addPupoLayers[attrParams.name] = new DC.HtmlLayer(attrParams.name) |
| | | window.$viewer.addLayer(addPupoLayers[attrParams.name]) |
| | | let iconEl = `<div class="marsBlueGradientPnl"> |
| | | <div>${attrParams.fullName}</div> |
| | | <div>${attrParams.fullName}</div> |
| | | <img src="${attrParams.imageUrl}" /> |
| | | </div>` |
| | | let divIcon = new DC.DivIcon( |
| | |
| | | }, |
| | | ] |
| | | |
| | | console.log(data, 12112213213) |
| | | |
| | | const defaultProps = { |
| | | children: 'children', |
| | | label: 'label', |
| | |
| | | } |
| | | } |
| | | |
| | | window.addTileLayers = {} |
| | | window.tileLayers = new DC.TilesetLayer('tileLayers') |
| | | window.$viewer.addLayer(window.tileLayers) |
| | | let addTileLayers = {} |
| | | let tileLayers = new DC.TilesetLayer('tileLayers') |
| | | window.$viewer.addLayer(tileLayers) |
| | | |
| | | const handleCheckChange = (data) => { |
| | | let options = treeRef.value?.getCheckedNodes() |
| | |
| | | |
| | | // const Cesium = DC |
| | | if (item.subType == '3Dtile') { |
| | | if (!window.addTileLayers[item.layerName]) { |
| | | // window.addTileLayers[item.layerName] = [] |
| | | if (!addTileLayers[item.layerName]) { |
| | | // addTileLayers[item.layerName] = [] |
| | | // let tile = window.$viewer.delegate.scene.primitives.add(new Cesium.Cesium3DTileset({ |
| | | // url: '/zhyq/mx/tile_01/tileset.json', |
| | | // })) |
| | |
| | | |
| | | // }) |
| | | |
| | | |
| | | |
| | | window.addTileLayers[item.layerName] = item.urlData.map(i => { |
| | | let tile = new DC.Tileset(i.url, { |
| | | maximumMemoryUsage: 256, |
| | | maximumScreenSpaceError: 4, |
| | | skipLevels: 5, |
| | | addTileLayers[item.layerName] = item.urlData.map(m => { |
| | | let tile = new DC.Tileset(m.url, { |
| | | maximumMemoryUsage: 512, |
| | | maximumScreenSpaceError: 8, |
| | | skipLevels: 6, |
| | | skipLevelOfDetail: true, |
| | | skipScreenSpaceErrorFactor: 128 |
| | | skipScreenSpaceErrorFactor: 256, |
| | | progressiveResolutionHeightFraction: 0.5, |
| | | baseScreenSpaceError: 1024 |
| | | }) |
| | | |
| | | window.tileLayers.addOverlay(tile) |
| | | return tile |
| | | tileLayers.addOverlay(tile) |
| | | |
| | | return tile |
| | | }) |
| | | } else { |
| | | window.addTileLayers[item.layerName].forEach(i => i.show = true) |
| | | addTileLayers[item.layerName].forEach(m => m.show = true) |
| | | } |
| | | } else if (item.subType == 'labelPoint') { |
| | | if (!window.addTileLayers[item.layerName]) { |
| | | window.addTileLayers[item.layerName] = new DC.HtmlLayer(item.layerName) |
| | | window.$viewer.addLayer(window.addTileLayers[item.layerName]) |
| | | if (!addTileLayers[item.layerName]) { |
| | | addTileLayers[item.layerName] = new DC.HtmlLayer(item.layerName) |
| | | window.$viewer.addLayer(addTileLayers[item.layerName]) |
| | | |
| | | item.method(item.params).then(res => { |
| | | let data = res.data.data.records |
| | |
| | | |
| | | divIcon.on(DC.MouseEventType.CLICK, incident) |
| | | |
| | | window.addTileLayers[item.layerName].addOverlay(divIcon) |
| | | addTileLayers[item.layerName].addOverlay(divIcon) |
| | | }) |
| | | }) |
| | | } else { |
| | | window.addTileLayers[item.layerName].show = true |
| | | addTileLayers[item.layerName].show = true |
| | | } |
| | | } else if (item.subType == 'geojsonWall') { |
| | | if (!window.addTileLayers[item.layerName]) { |
| | | window.addTileLayers[item.layerName] = new DC.VectorLayer(item.layerName) |
| | | window.$viewer.addLayer(window.addTileLayers[item.layerName]) |
| | | if (!addTileLayers[item.layerName]) { |
| | | addTileLayers[item.layerName] = new DC.VectorLayer(item.layerName) |
| | | window.$viewer.addLayer(addTileLayers[item.layerName]) |
| | | |
| | | item.source.features.forEach(i => { |
| | | let wall = new DC.Wall( |
| | |
| | | speed: 8 |
| | | }) |
| | | }) |
| | | window.addTileLayers[item.layerName].addOverlay(wall) |
| | | addTileLayers[item.layerName].addOverlay(wall) |
| | | }) |
| | | } else { |
| | | window.addTileLayers[item.layerName].show = true |
| | | addTileLayers[item.layerName].show = true |
| | | } |
| | | // 飞到园区范围 |
| | | window.$viewer.flyTo(addTileLayers[item.layerName]) |
| | | // console.log('flyToyqfw********2222222222*******************************', addTileLayers[item.layerName]) |
| | | } else if (item.subType == 'geojsonPipe') { |
| | | if (!window.addTileLayers[item.layerName]) { |
| | | window.addTileLayers[item.layerName] = new DC.VectorLayer(item.layerName) |
| | | window.$viewer.addLayer(window.addTileLayers[item.layerName]) |
| | | if (!addTileLayers[item.layerName]) { |
| | | addTileLayers[item.layerName] = new DC.VectorLayer(item.layerName) |
| | | window.$viewer.addLayer(addTileLayers[item.layerName]) |
| | | |
| | | function computeCircle(radius) { |
| | | var positions = [] |
| | |
| | | polylineVolume.setStyle({ |
| | | material: item.color |
| | | }) |
| | | window.addTileLayers[item.layerName].addOverlay(polylineVolume) |
| | | addTileLayers[item.layerName].addOverlay(polylineVolume) |
| | | }) |
| | | } else { |
| | | window.addTileLayers[item.layerName].show = true |
| | | addTileLayers[item.layerName].show = true |
| | | } |
| | | } |
| | | } else { |
| | | if (window.addTileLayers[item.layerName]) { |
| | | if (addTileLayers[item.layerName]) { |
| | | if (item.subType == '3Dtile') { |
| | | window.addTileLayers[item.layerName].forEach(i => i.show = false) |
| | | addTileLayers[item.layerName].forEach(m => m.show = false) |
| | | } else if (item.subType == 'labelPoint') { |
| | | window.addTileLayers[item.layerName].show = false |
| | | addTileLayers[item.layerName].show = false |
| | | } else if (item.subType == 'geojsonWall') { |
| | | window.addTileLayers[item.layerName].show = false |
| | | addTileLayers[item.layerName].show = false |
| | | } else if (item.subType == 'geojsonPipe') { |
| | | window.addTileLayers[item.layerName].show = false |
| | | addTileLayers[item.layerName].show = false |
| | | } |
| | | } |
| | | } |
| | |
| | | |
| | | // 飞到园区范围 |
| | | const flyToyqfw = () => { |
| | | // console.log('flyToyqfw***************************************', addTileLayers['yqfw']) |
| | | window.$viewer.flyTo(addTileLayers['yqfw']) |
| | | window.$viewer.zoomToPosition(new DC.Position( |
| | | 115.1021, |
| | | 27.2360, |
| | | 5000, |
| | | 0, |
| | | -45, |
| | | 0 |
| | | ), () => { |
| | | }) |
| | | } |
| | | |
| | | EventBus.on('restHandleCheckChange', restHandleCheckChange) |
| | |
| | | EventBus.on('flyToyqfw', flyToyqfw) |
| | | |
| | | onMounted(() => { |
| | | handleCheckChange(data.filter(i => indexPoint.value.includes(i.id))) |
| | | setTimeout(() => { |
| | | handleCheckChange(data.filter(i => indexPoint.value.includes(i.id))) |
| | | }, 2000) |
| | | }) |
| | | |
| | | // const sharedData = computed(() => pointStore.sharedData); |
| | |
| | | } |
| | | |
| | | onUnmounted(() => { |
| | | window.tileLayers && window.$viewer.removeLayer(window.tileLayers) |
| | | delete window.tileLayers |
| | | let arr = Object.keys(window.addTileLayers) |
| | | if (tileLayers) { |
| | | tileLayers.clear() |
| | | window.$viewer.removeLayer(tileLayers) |
| | | tileLayers = null |
| | | } |
| | | |
| | | let arr = Object.keys(addTileLayers) |
| | | arr.filter(i => i != 'hgyq').forEach(i => { |
| | | addTileLwindow.addTileLayersayers[i] && window.$viewer.removeLayer(window.addTileLayers[i]) |
| | | addTileLayers[i] && window.$viewer.removeLayer(addTileLayers[i]) |
| | | }) |
| | | // 弹窗销毁 |
| | | destroy() |
| | | |
| | | EventBus.off('restHandleCheckChange', restHandleCheckChange) |
| | | EventBus.off('restHandleDelChange', restHandleDelChange) |
| | | EventBus.off('flyToyqfw', flyToyqfw) |
| | | }) |
| | | </script> |
| | | |