From fee18d19a1d961847cd09469a20fc8231c1df46c Mon Sep 17 00:00:00 2001
From: 张含笑 <zhx18749296735@163.com>
Date: Thu, 10 Apr 2025 11:09:34 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/views/Home/useMapAggregation/useMapAggregation.js |   73 +++++++++++++++++-------------------
 1 files changed, 35 insertions(+), 38 deletions(-)

diff --git a/src/views/Home/useMapAggregation/useMapAggregation.js b/src/views/Home/useMapAggregation/useMapAggregation.js
index 1f6aeec..53ccd4a 100644
--- a/src/views/Home/useMapAggregation/useMapAggregation.js
+++ b/src/views/Home/useMapAggregation/useMapAggregation.js
@@ -199,17 +199,17 @@
     scalingJudgment.forEach(item => item.show && (item.outline = outlineGJson))
     const [longitude, latitude] = outlineGJson.features[0].properties.centroid
     const height = scalingJudgment[(hierarchy.length - 3) * (-1)].height
-    setCenterPosition({longitude, latitude,height})
+    setCenterPosition({ longitude, latitude, height })
     flyTo({ longitude, latitude }, 0, height)
   }
 
-  const userAreaPosition = computed(() => store.state.home.userAreaPosition);
+  const userAreaPosition = computed(() => store.state.home.userAreaPosition)
 
   const setCenterPosition = (position) => {
     store.commit('setCurrentAreaPosition', position)
-		if (!userAreaPosition.value.longitude){
-			store.commit('setUserAreaPosition', position)
-		}
+    if (!userAreaPosition.value.longitude) {
+      store.commit('setUserAreaPosition', position)
+    }
   }
 
 
@@ -235,7 +235,6 @@
         id: `aggregation-splashed-${index}`,
         position: Cesium.Cartesian3.fromDegrees(item.longitude, item.latitude),
         label: {
-          // 随机整数
           text: item.nickname,
           font: '12pt Source Han Sans CN',
           fillColor: Cesium.Color.WHITE,
@@ -262,28 +261,24 @@
   // 渲染轮廓
   const renderOutline = item => {
     item.outline &&
-    Cesium.GeoJsonDataSource.load(item.outline).then(dataSource => {
-      viewer.dataSources.add(dataSource)
-      const entities = dataSource.entities.values
-      entities.forEach(entity => {
-        // 隐藏多边形填充
-        entity.polygon.material = Cesium.Color.TRANSPARENT
-        entity.polygon.outline = false // 关闭原生轮廓
-        // 创建独立折线作为轮廓
-        const positions = entity.polygon.hierarchy.getValue().positions
-        viewer.entities.add({
-          polyline: {
-            positions: positions,
-            width: 5, // 直接设置宽度
-            material: new Cesium.PolylineGlowMaterialProperty({
-              glowPower: 0.5,
-              color: Cesium.Color.AQUA,
-            }),
-            clampToGround: true, // 贴地显示
-          },
+      Cesium.GeoJsonDataSource.load(item.outline).then(dataSource => {
+        const entities = dataSource.entities.values
+        entities.forEach((entity, index) => {
+          // 创建独立折线作为轮廓
+          const positions = entity.polygon.hierarchy.getValue().positions
+          viewer.entities.add({
+            id: `aggregation-outline-${index}`,
+            polyline: {
+              positions: positions,
+              width: 5, // 直接设置宽度
+              material: new Cesium.PolylineGlowMaterialProperty({
+                glowPower: 0.5,
+                color: Cesium.Color.AQUA,
+              }),
+            },
+          })
         })
       })
-    })
   }
 
   // 聚合机巢
@@ -301,7 +296,7 @@
     // 遍历特征并添加实体
     featuresList.forEach((feature, index) => {
       if (!feature.position) return
-      const position = Cesium.Cartesian3.fromDegrees(feature.position[0], feature.position[1],12000)
+      const position = Cesium.Cartesian3.fromDegrees(feature.position[0], feature.position[1], 12000)
       viewer.entities.add({
         position: position,
         id: `aggregation-name-${index}`,
@@ -348,10 +343,12 @@
       return arrColor[++index % arrColor.length]
     }
 
-    // 加载新的 GeoJSON 数据
+    // 加载边界
     Cesium.GeoJsonDataSource.load(item.gJson).then(dataSource => {
+      console.log(dataSource, item.gJson)
+
       viewer.dataSources.add(dataSource)
-      item.dataSource = dataSource // 保存数据源以便后续删除
+      item.BJDataSource = dataSource // 保存数据源以便后续删除
       // 获取数据源中的实体
       const entities = dataSource.entities.values
 
@@ -362,18 +359,14 @@
           alphaPower: 1.3
         })
 
-        entity.polygon.extrudedHeight = (entity.propertyNames.length || 1) * 500
+        entity.polygon.extrudedHeight = (entity.properties.childrenNum._value || 1) * 500
 
         entity.polygon.material = material
         entity.polygon.outline = false // 显示边框
       })
 
       needFly && viewer.flyTo(dataSource, {
-        offset: new Cesium.HeadingPitchRange(
-          0, // heading: 0 (朝向不变)
-          Cesium.Math.toRadians(-60), // pitch: -90° (垂直向下)
-          0 // range: 0 (默认距离)
-        ),
+        offset: new Cesium.HeadingPitchRange(0, Cesium.Math.toRadians(-60), 0),
         duration: 0.5,
       })
       needFly = false
@@ -415,7 +408,7 @@
     currentEntity = entity
     const entityPosition = entity?.position?._value
     if (!entityPosition) return
-    if (entityPosition){
+    if (entityPosition) {
       positionC3 = entityPosition
     }
     removeLabel()
@@ -449,8 +442,12 @@
 
   // 移除 点 和 gjson 实体
   const removeEntities = () => {
-    viewer.dataSources?.removeAll(true)
-    // viewer.entities?.removeAll();
+    // dataSources移除
+    scalingJudgment.forEach(item => {
+      item.BJDataSource && viewer.dataSources.remove(item.BJDataSource)
+      item.BJDataSource = null
+    })
+    // entities移除
     const entitiesIDs = viewer.entities.values.map(i => i.id)
     entitiesIDs.forEach(item => {
       item.includes('aggregation-') && viewer.entities.removeById(item)

--
Gitblit v1.9.3