From 3dfd37087e095c63f65d73751186f91871d57095 Mon Sep 17 00:00:00 2001
From: shuishen <1109946754@qq.com>
Date: Tue, 08 Apr 2025 18:29:44 +0800
Subject: [PATCH] feat: 初始化定位及缩放定位

---
 src/views/Home/useMapAggregation/useMapAggregation.js |   57 +++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 37 insertions(+), 20 deletions(-)

diff --git a/src/views/Home/useMapAggregation/useMapAggregation.js b/src/views/Home/useMapAggregation/useMapAggregation.js
index eb59787..432d330 100644
--- a/src/views/Home/useMapAggregation/useMapAggregation.js
+++ b/src/views/Home/useMapAggregation/useMapAggregation.js
@@ -49,25 +49,35 @@
 
 
   // 确定缩放比例
-  const determineScaling = () => {
+  const determineScaling = (currentState) => {
     // console.log('确定缩放比例');
-    if (!viewer) return
-    let height = viewer.camera.positionCartographic.height
-    // 根据高度展示对应的 gJson
-    for (let [index, item] of scalingJudgment.entries()) {
-      if (!item.show) return
-      if (height > item.value[0] && height <= item.value[1]) {
-        if (active === item.name) return
-        active = item.name
-        removeEntities()
-        removeLabel()
-        renderOutline(item)
-        if (!item.gJson && !item.splashedList?.length) return
-        item.gJson ? aggregation(item) : splashed(item)
-        break
+    return () => {
+      if (!viewer) return
+      let height = viewer.camera.positionCartographic.height
+      // 根据高度展示对应的 gJson
+      for (let [index, item] of scalingJudgment.entries()) {
+        if (!item.show) return
+        if (height > item.value[0] && height <= item.value[1]) {
+          if (active === item.name) return
+          active = item.name
+          removeEntities()
+          removeLabel()
+          renderOutline(item)
+          if (!item.gJson && !item.splashedList?.length) return
+          item.gJson ? aggregation(item, currentState.flyTo) : splashed(item)
+
+          currentState.flyTo && currentState.stopFlyTo && (currentState.flyTo = false)
+          break
+        }
       }
     }
   }
+
+  let currentState = {
+    flyTo: true,
+    stopFlyTo: false
+  }
+  const handlerDetermineScaling = () => determineScaling(currentState)()
 
   // 转换为目录结构, 返回数组,
   function convertToHierarchy (code) {
@@ -205,9 +215,11 @@
     selectedAreaCode,
     async (newValue, oldValue) => {
       if (!viewer) return
-      viewer.scene.postRender.removeEventListener(determineScaling)
+      currentState.flyTo = true
+
+      viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
       initMapData(newValue).then(() => {
-        viewer.scene.postRender.addEventListener(determineScaling)
+        viewer.scene.postRender.addEventListener(handlerDetermineScaling)
       })
     },
     { deep: true }
@@ -444,11 +456,13 @@
 
   // 移除所有监听事件,变量置空
   const removeAll = () => {
+    currentState.flyTo = false
+
     if (!viewer) return
     removeEntities()
     removeLabel()
     // viewer.camera.moveEnd.removeEventListener(determineScaling);
-    viewer.scene.postRender.removeEventListener(determineScaling)
+    viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
     handler?.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK)
     handler?.destroy()
     viewer = null
@@ -458,10 +472,13 @@
     currentEntity = null
   }
   const init = () => {
+    currentState.flyTo = true
+    currentState.stopFlyTo = true
+
     viewer = window.$viewer
-    viewer.scene.postRender.removeEventListener(determineScaling)
+    viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
     initMapData(selectedAreaCode.value || userAreaCode.value).then(() => {
-      viewer.scene.postRender.addEventListener(determineScaling)
+      viewer.scene.postRender.addEventListener(handlerDetermineScaling)
     })
     handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas)
     handler.setInputAction(singleMachineEvent, Cesium.ScreenSpaceEventType.LEFT_CLICK)

--
Gitblit v1.9.3