智慧园区前端大屏
linwe
2024-11-25 79ba6016983fbbc48a3481f9cca1fa59e0479b30
沟渠上图
3 files modified
85 ■■■■ changed files
src/api/space/space.js 8 ●●●●● patch | view | raw | blame | history
src/pages/layout/components/scomponents/layersControl.vue 72 ●●●● patch | view | raw | blame | history
src/views/pac/components/box/dataContent.vue 5 ●●●●● patch | view | raw | blame | history
src/api/space/space.js
@@ -19,4 +19,12 @@
        method: 'get',
        params,
    });
};
export const getGouQu = (params) => {
    const url = `/yw/emergencySpace/page`;
    return request({
        url,
        method: 'get',
        params,
    });
};
src/pages/layout/components/scomponents/layersControl.vue
@@ -2,7 +2,7 @@
 * @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:
 *
@@ -59,7 +59,7 @@
})
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"
@@ -435,6 +435,20 @@
          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'
      }
    ]
  },
@@ -661,7 +675,7 @@
          // })
          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,
@@ -671,9 +685,9 @@
              baseScreenSpaceError: 1024
            })
          tileLayers.addOverlay(tile)
            tileLayers.addOverlay(tile)
          return tile
            return tile
          })
        } else {
          addTileLayers[item.layerName].forEach(m => m.show = true)
@@ -778,6 +792,36 @@
        } 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]) {
@@ -788,6 +832,8 @@
        } 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
        }
      }
@@ -845,14 +891,14 @@
// 飞到园区范围
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)
src/views/pac/components/box/dataContent.vue
@@ -129,6 +129,11 @@
  if (row.type == 2 || row.type == 3) {
    EventBus.emit('restHandleCheckChange', `3-3-2`)
    EventBus.emit('restHandleCheckChange', `3-3-4`)
    if (row.type == 3) {
      EventBus.emit('restHandleCheckChange', `3-8`)
    } else {
      EventBus.emit('restHandleDelChange', `3-8`)
    }
  } else {
    EventBus.emit('restHandleDelChange', `3-3-2`)
    EventBus.emit('restHandleDelChange', `3-3-4`)