From 06423460c9fe49c23c62bc57d02da0255ace5352 Mon Sep 17 00:00:00 2001
From: 罗广辉 <guanghui.luo@foxmail.com>
Date: Sat, 12 Apr 2025 09:37:59 +0800
Subject: [PATCH] feat: 弹框点击优化

---
 src/views/Home/useMapAggregation/useMapAggregation.js |   30 +++++++++++-------------------
 1 files changed, 11 insertions(+), 19 deletions(-)

diff --git a/src/views/Home/useMapAggregation/useMapAggregation.js b/src/views/Home/useMapAggregation/useMapAggregation.js
index 0153d50..8678176 100644
--- a/src/views/Home/useMapAggregation/useMapAggregation.js
+++ b/src/views/Home/useMapAggregation/useMapAggregation.js
@@ -48,7 +48,6 @@
   let viewer = null
   let active = null
   let handler = null
-  let positionC3 = null
   let currentEntity = null
 
   const store = useStore()
@@ -410,11 +409,12 @@
 
   // 弹框位置刷新
   const labelBoxRender = () => {
+    if (!currentEntity) return
     let dom = document.querySelector('#mapPopUpBox')
     if (!dom) {
       dom = getLabelDom(currentEntity.properties.customData._value.data)
     }
-    const screenPosition = viewer.scene.cartesianToCanvasCoordinates(positionC3)
+    const screenPosition = viewer.scene.cartesianToCanvasCoordinates(currentEntity?.position?._value)
     if (screenPosition) {
       dom.style.left = `${screenPosition.x}px`
       dom.style.top = `${screenPosition.y}px`
@@ -426,7 +426,7 @@
    * 根据条件获取项
    * @param {Array} arr 数据源
    * @param {Function} condition 条件
-   * @returns 
+   * @returns
    */
   const findTypeItem = (arr, condition) => {
     return arr.find(item => condition(item))
@@ -437,21 +437,14 @@
     let clickTargets = viewer.scene.drillPick(click.position).map(item => item.id)
     if (!clickTargets.length) return
 
-    let deviceAggregationFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type == 'deviceAggregation')
-    let deviceFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type == 'device')
-    let eventFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type == 'event')
-
-    const curEntity = deviceAggregationFind || deviceFind || eventFind
-
-    if (!curEntity) return
-
-    currentEntity = curEntity
-    const entityPosition = curEntity?.position?._value
-    if (!entityPosition) return
-    if (entityPosition) {
-      positionC3 = entityPosition
-    }
-
+    let deviceAggregationFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type === 'deviceAggregation')
+    let deviceFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type === 'device')
+    let eventFind = findTypeItem(clickTargets, (item) => item?.properties?.customData?._value?.data?.type === 'event')
+    currentEntity = deviceAggregationFind || deviceFind || eventFind
+    if (!currentEntity) return
+    if (!currentEntity?.position?._value) return
+    // 一定要移除
+    removeLabel()
     if (deviceAggregationFind || eventFind) {
       viewer.scene.postRender.addEventListener(labelBoxRender)
     }
@@ -498,7 +491,6 @@
     viewer = null
     active = null
     handler = null
-    positionC3 = null
     currentEntity = null
   }
   const init = () => {

--
Gitblit v1.9.3