From 6f0c1938dff15c1625d97368786d2e93e293c32b Mon Sep 17 00:00:00 2001
From: shuishen <1109946754@qq.com>
Date: Fri, 27 Dec 2024 14:46:23 +0800
Subject: [PATCH] 应急空间点位增加可编辑

---
 src/pages/map/components/scomponents/layersControl.vue |   76 ++++++++++++++++++++++++++++++++++++-
 1 files changed, 73 insertions(+), 3 deletions(-)

diff --git a/src/pages/map/components/scomponents/layersControl.vue b/src/pages/map/components/scomponents/layersControl.vue
index fd782a6..f515d9e 100644
--- a/src/pages/map/components/scomponents/layersControl.vue
+++ b/src/pages/map/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-12-26 18:54:27
+ * @LastEditTime: 2024-12-27 14:45:27
  * @FilePath: \bigScreen\src\pages\map\components\scomponents\layersControl.vue
  * @Description:
  *
@@ -70,7 +70,7 @@
 import panorama from './popup/panorama.vue'
 import { getPage } from '@/api/indParkInfo'
 import { getPage as getfirmPage } from '@/api/firmInfo/firmInfo'
-import { getList, getGouQu } from "@/api/space/space"
+import { getList, getGouQu, updateSpace } from "@/api/space/space"
 import { getList as getRiskList } from "@/api/riskSource/riskSource"
 import { getPanoramaList } from "@/api/panorama/"
 import yqfw from "@/assets/json/yqfw"
@@ -82,8 +82,13 @@
 import EventBus from 'utils/bus'
 import { usePointStore } from 'store/usepoint'
 const pointStore = usePointStore()
+import { useMap } from 'store/map'
+const mapStore = useMap()
 import { useRouter } from 'vue-router'
 const router = useRouter()
+import {
+  ElMessage
+} from 'element-plus'
 
 const { VITE_APP_BASE } = import.meta.env
 // , '7', 
@@ -662,6 +667,8 @@
   }
 }
 
+let moveEntity = null
+
 const handleCheckChange = (data) => {
 
   let options = treeRef.value?.getCheckedNodes()
@@ -760,7 +767,11 @@
 
               if (item.incident) incident = item.incident
 
-              divIcon.on(DC.MouseEventType.CLICK, incident)
+              divIcon.on(DC.MouseEventType.CLICK, (e) => {
+                moveEntity = e
+                return
+                incident(e)
+              })
 
               addTileLayers[item.layerName].addOverlay(divIcon)
             })
@@ -966,6 +977,62 @@
 EventBus.on('flyToyqfw', flyToyqfw)
 EventBus.on('destroyPop', destroyPop)
 
+let tooltip = window.$viewer.tooltip
+
+const viewerMouseMove = (e) => {
+  if (mapStore.editPoint) {
+    if (moveEntity != null) {
+      if (e.wgs84Position) {
+        moveEntity.overlay.position = new DC.Position(e.wgs84Position.lng, e.wgs84Position.lat, e.wgs84Position.alt)
+      } else {
+        moveEntity.overlay.position = new DC.Position(e.wgs84SurfacePosition.lng, e.wgs84SurfacePosition.lat, e.wgs84SurfacePosition.alt)
+      }
+
+      tooltip.showAt({ x: e.windowPosition.x + 10, y: e.windowPosition.y }, '右键结束编辑')
+    } else {
+      tooltip.showAt({ x: e.windowPosition.x + 10, y: e.windowPosition.y }, '左键选中点位,开始编辑')
+    }
+  }
+}
+
+window.$viewer.on(DC.MouseEventType.MOUSE_MOVE, viewerMouseMove)
+
+const viewerRightClick = (e) => {
+  if (mapStore.editPoint && moveEntity != null) {
+    tooltip.enable = false
+    let lng, lat, ele
+
+    const { attrParams } = moveEntity.overlay
+
+    if (e.wgs84Position) {
+      lng = e.wgs84Position.lng
+      lat = e.wgs84Position.lat
+      ele = e.wgs84Position.alt
+    } else {
+      lng = e.wgs84SurfacePosition.lng
+      lat = e.wgs84SurfacePosition.lat
+      ele = e.wgs84SurfacePosition.alt
+    }
+
+    updateSpace({
+      id: attrParams.id,
+      lng,
+      lat,
+      ele: Math.ceil(ele)
+    }).then(res => {
+      moveEntity = null
+      mapStore.setEditPoint(false)
+
+      ElMessage({
+        message: '修改成功',
+        type: 'success',
+      })
+    })
+  }
+}
+
+window.$viewer.on(DC.MouseEventType.RIGHT_CLICK, viewerRightClick)
+
 onMounted(() => {
   handleCheckChange(data.filter(i => indexPoint.value.includes(i.id)))
 })
@@ -1054,6 +1121,9 @@
   destroyPop()
   addPopLayers = null
 
+  window.$viewer && window.$viewer.off(DC.MouseEventType.MOUSE_MOVE, viewerMouseMove)
+  window.$viewer && window.$viewer.off(DC.MouseEventType.RIGHT_CLICK, viewerRightClick)
+
   EventBus.off('restHandleCheckChange', restHandleCheckChange)
   EventBus.off('restHandleDelChange', restHandleDelChange)
   EventBus.off('flyToyqfw', flyToyqfw)

--
Gitblit v1.9.3