| | |
| | | * @Author: shuishen 1109946754@qq.com |
| | | * @Date: 2024-10-31 10:47:29 |
| | | * @LastEditors: shuishen 1109946754@qq.com |
| | | * @LastEditTime: 2024-11-24 03:30:37 |
| | | * @LastEditTime: 2024-11-23 17:09:04 |
| | | * @FilePath: \bigScreen\src\pages\layout\components\scomponents\layersControl.vue |
| | | * @Description: |
| | | * |
| | |
| | | }) |
| | | import panorama from './popup/panorama.vue' |
| | | import { getPage } from '@/api/indParkInfo' |
| | | import { getList } from "@/api/space/space" |
| | | import { getList, getGouQu } from "@/api/space/space" |
| | | import { getList as getRiskList } from "@/api/riskSource/riskSource" |
| | | import { getPanoramaList } from "@/api/panorama/" |
| | | import yqfw from "@/assets/json/yqfw" |
| | |
| | | divIcon.on(DC.MouseEventType.CLICK, incident) |
| | | addPupoLayers[attrParams.name].addOverlay(divIcon) |
| | | } |
| | | }, |
| | | { |
| | | id: '3-8', |
| | | label: '沟渠', |
| | | type: 'layer', |
| | | subType: 'geojsonPolygon', |
| | | method: getGouQu, |
| | | params: { |
| | | type: 8, |
| | | }, |
| | | backgroundIcon: VITE_APP_BASE + 'img/mapicon/xfs.png', |
| | | className: 'xfs-box', |
| | | showPanel: false, |
| | | layerName: 'gouqu' |
| | | } |
| | | ] |
| | | }, |
| | |
| | | // }) |
| | | |
| | | addTileLayers[item.layerName] = item.urlData.map(m => { |
| | | let tile = new DC.Tileset(m.url, { |
| | | let tile = new DC.Tileset(m.url, { |
| | | maximumMemoryUsage: 512, |
| | | maximumScreenSpaceError: 8, |
| | | skipLevels: 6, |
| | |
| | | baseScreenSpaceError: 1024 |
| | | }) |
| | | |
| | | tileLayers.addOverlay(tile) |
| | | tileLayers.addOverlay(tile) |
| | | |
| | | return tile |
| | | return tile |
| | | }) |
| | | } else { |
| | | addTileLayers[item.layerName].forEach(m => m.show = true) |
| | |
| | | } else { |
| | | addTileLayers[item.layerName].show = true |
| | | } |
| | | } else if (item.subType == 'geojsonPolygon') { |
| | | if (!addTileLayers[item.layerName]) { |
| | | addTileLayers[item.layerName] = new DC.VectorLayer(item.layerName) |
| | | window.$viewer.addLayer(addTileLayers[item.layerName]) |
| | | item.method(item.params).then(res => { |
| | | let data = res.data.data.records |
| | | data.forEach(i => { |
| | | let stl = ''; |
| | | try { |
| | | let geom = JSON.parse(i.geom); |
| | | if (geom && geom.coordinates && geom.coordinates[0]) { |
| | | stl = geom.coordinates[0][0].map(d => d[0] + ',' + d[1]).join(';'); |
| | | } else { |
| | | console.error('Invalid geom structure'); |
| | | } |
| | | } catch (error) { |
| | | console.error('Failed to parse geom:', error); |
| | | } |
| | | let polygon = new DC.Polygon(stl) |
| | | polygon.setStyle({ |
| | | width: 2, |
| | | material: DC.Color.BLUE, |
| | | clampToGround: true |
| | | }) |
| | | addTileLayers[item.layerName].addOverlay(polygon) |
| | | }) |
| | | }) |
| | | } else { |
| | | addTileLayers[item.layerName].show = true |
| | | } |
| | | } |
| | | } else { |
| | | if (addTileLayers[item.layerName]) { |
| | |
| | | } else if (item.subType == 'geojsonWall') { |
| | | addTileLayers[item.layerName].show = false |
| | | } else if (item.subType == 'geojsonPipe') { |
| | | addTileLayers[item.layerName].show = false |
| | | } else if (item.subType == 'geojsonPolygon') { |
| | | addTileLayers[item.layerName].show = false |
| | | } |
| | | } |
| | |
| | | // 飞到园区范围 |
| | | const flyToyqfw = () => { |
| | | window.$viewer.zoomToPosition(new DC.Position( |
| | | 115.1021, |
| | | 27.2360, |
| | | 5000, |
| | | 0, |
| | | -45, |
| | | 0 |
| | | ), () => { |
| | | }) |
| | | 115.1021, |
| | | 27.2360, |
| | | 5000, |
| | | 0, |
| | | -45, |
| | | 0 |
| | | ), () => { |
| | | }) |
| | | } |
| | | |
| | | EventBus.on('restHandleCheckChange', restHandleCheckChange) |