From e6e213ab22cb09c260410b3ea2d91da8510cbba5 Mon Sep 17 00:00:00 2001
From: 罗广辉 <guanghui.luo@foxmail.com>
Date: Wed, 09 Apr 2025 10:09:49 +0800
Subject: [PATCH] feat: 飞行逻辑调整
---
src/views/Home/useMapAggregation/useMapAggregation.js | 105 +++++++++++++++++++++++-----------------------------
1 files changed, 46 insertions(+), 59 deletions(-)
diff --git a/src/views/Home/useMapAggregation/useMapAggregation.js b/src/views/Home/useMapAggregation/useMapAggregation.js
index 7cf680d..7d92182 100644
--- a/src/views/Home/useMapAggregation/useMapAggregation.js
+++ b/src/views/Home/useMapAggregation/useMapAggregation.js
@@ -49,35 +49,25 @@
// 确定缩放比例
- const determineScaling = (currentState) => {
+ const determineScaling = () => {
// console.log('确定缩放比例');
- 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
- }
+ 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
}
}
}
-
- let currentState = {
- flyTo: true,
- stopFlyTo: false
- }
- const handlerDetermineScaling = () => determineScaling(currentState)()
// 转换为目录结构, 返回数组,
function convertToHierarchy (code) {
@@ -223,16 +213,16 @@
}
+ let needFly = true
watch(
selectedAreaCode,
async (newValue, oldValue) => {
+ needFly = true
if (!viewer) return
- currentState.flyTo = true
-
- viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
+ viewer.scene.postRender.removeEventListener(determineScaling)
initMapData(newValue).then(() => {
- viewer.scene.postRender.addEventListener(handlerDetermineScaling)
+ viewer.scene.postRender.addEventListener(determineScaling)
})
},
{ deep: true }
@@ -272,32 +262,32 @@
// 渲染轮廓
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 => {
+ 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, // 贴地显示
+ },
})
})
+ })
}
// 聚合机巢
- const aggregation = (item, flyTo) => {
+ const aggregation = (item) => {
if (!item.gJson) return
const featuresList = item.gJson.features.map(item1 => {
// const {lng,lat} = getCenterPoint(item1.geometry.coordinates[0][0])
@@ -378,7 +368,7 @@
entity.polygon.outline = false // 显示边框
})
- flyTo && viewer.flyTo(dataSource, {
+ needFly && viewer.flyTo(dataSource, {
offset: new Cesium.HeadingPitchRange(
0, // heading: 0 (朝向不变)
Cesium.Math.toRadians(-60), // pitch: -90° (垂直向下)
@@ -386,6 +376,7 @@
),
duration: 0.5,
})
+ needFly = false
})
}
@@ -431,6 +422,7 @@
case 'deviceAggregation':
viewer.scene.postRender.addEventListener(labelBoxRender)
break
+ // todo 待对接
case 'device':
store.commit('setSingleUavHome', { id: '123' })
break
@@ -469,13 +461,11 @@
// 移除所有监听事件,变量置空
const removeAll = () => {
- currentState.flyTo = false
-
if (!viewer) return
removeEntities()
removeLabel()
// viewer.camera.moveEnd.removeEventListener(determineScaling);
- viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
+ viewer.scene.postRender.removeEventListener(determineScaling)
handler?.removeInputAction(Cesium.ScreenSpaceEventType.LEFT_CLICK)
handler?.destroy()
viewer = null
@@ -485,13 +475,10 @@
currentEntity = null
}
const init = () => {
- currentState.flyTo = true
- currentState.stopFlyTo = true
-
viewer = window.$viewer
- viewer.scene.postRender.removeEventListener(handlerDetermineScaling)
+ viewer.scene.postRender.removeEventListener(determineScaling)
initMapData(selectedAreaCode.value || userAreaCode.value).then(() => {
- viewer.scene.postRender.addEventListener(handlerDetermineScaling)
+ viewer.scene.postRender.addEventListener(determineScaling)
})
handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas)
handler.setInputAction(singleMachineEvent, Cesium.ScreenSpaceEventType.LEFT_CLICK)
--
Gitblit v1.9.3