From 149215ce4c7ff87541b5c4a79edfa4b0571b350c Mon Sep 17 00:00:00 2001
From: chenyao <1219716595@qq.com>
Date: Mon, 03 Mar 2025 08:52:01 +0800
Subject: [PATCH] 优化部分代码逻辑
---
src/views/hooks/droneFly.ts | 106 ++++++++++++++++++++++++++++++++++-------------------
1 files changed, 68 insertions(+), 38 deletions(-)
diff --git a/src/views/hooks/droneFly.ts b/src/views/hooks/droneFly.ts
index fd03248..4990445 100644
--- a/src/views/hooks/droneFly.ts
+++ b/src/views/hooks/droneFly.ts
@@ -45,8 +45,7 @@
let measure_target_altitude = 0;
- async function initDock(data:any, sn:any, dockSn:any, workspaceId:any, ssLinePath:any, viewDroneInfo:any) {
- // console.log('globalCesium查看是', globalCesium)
+ async function initDock(data:any, sn:String, dockSn:String, workspaceId:String, ssLinePath:String, viewDroneInfo:any) {
// 获取workspaceId
wId = workspaceId
// 给无人机参数赋值
@@ -211,21 +210,23 @@
measure_target_latitude = payloads.measure_target_latitude;
measure_target_altitude = payloads.measure_target_altitude;
- // if (laserEntity && laserEntity != null) {
- // laserEntity.position = new globalCesium.CallbackProperty(function () {
- // return position
- // }, false)
- // // laserEntity.orientation = new globalCesium.CallbackProperty(function () {
- // // return orientation
- // // }, false)
-
- // laserEntity.show = true
-
- // window.cesiumViewer.scene.requestRender()
- // } else {
+ if (laserEntity && laserEntity != null) {
+ laserEntity.position = new globalCesium.CallbackProperty(function () {
+ return position
+ }, false)
+
+ laserEntity.show = true
+ window.cesiumViewer.scene.requestRender()
+ } else {
removeById('laser_coordinate')
laserEntity = window.cesiumViewer.entities.add({
- position: globalCesium.Cartesian3.fromDegrees(payloads.measure_target_longitude, payloads.measure_target_latitude, payloads.measure_target_altitude),
+ position: new globalCesium.CallbackProperty(() => {
+ return globalCesium.Cartesian3.fromDegrees(
+ payloads.measure_target_longitude,
+ payloads.measure_target_latitude,
+ payloads.measure_target_altitude
+ )
+ }, false),
id: 'laser_coordinate',
billboard: {
image: imgLaser,
@@ -235,7 +236,7 @@
outlineWidth: 0,
}
})
- // }
+ }
// 增加激光扫射信息
laserEntity.label = new globalCesium.LabelGraphics({
text: `H:${Math.ceil(payloads.measure_target_altitude)}m-L:${Math.round(Math.ceil(payloads.measure_target_distance),)}m`,
@@ -252,17 +253,38 @@
console.log('起点',startPosition)
console.log('终点',position)
if (startPosition && position) {
- removeById('route_two_line')
- twoLineEntity = window.cesiumViewer.entities.add({
- id: 'route_two_line',
- polyline: {
- positions: new globalCesium.CallbackProperty(() => [startPosition, position], false),
- width: 3,
- material: globalCesium.Color.RED,
- zIndex: -1,
- clampToGround: false,
- }
- })
+ if (twoLineEntity && twoLineEntity != null) {
+ // 如果线实体已存在,只更新位置
+ twoLineEntity.polyline.positions = new globalCesium.CallbackProperty(() => {
+ return [
+ globalCesium.Cartesian3.fromDegrees(me_longitude, me_latitude, 0),
+ globalCesium.Cartesian3.fromDegrees(
+ payloads.measure_target_longitude,
+ payloads.measure_target_latitude,
+ payloads.measure_target_altitude
+ )
+ ]
+ }, false)
+ } else {
+ // 如果线实体不存在,创建新的线实体
+ twoLineEntity = window.cesiumViewer.entities.add({
+ polyline: {
+ positions: new globalCesium.CallbackProperty(() => {
+ return [
+ globalCesium.Cartesian3.fromDegrees(me_longitude, me_latitude, 0),
+ globalCesium.Cartesian3.fromDegrees(
+ payloads.measure_target_longitude,
+ payloads.measure_target_latitude,
+ payloads.measure_target_altitude
+ )
+ ]
+ }, false),
+ width: 2,
+ material: globalCesium.Color.fromCssColorString('red'),
+ clampToGround: false,
+ },
+ })
+ }
}
}
@@ -428,26 +450,34 @@
function getPhoneLocation(workspaceId:String) {
if (window.cesiumViewer == null) return
if (navigator.geolocation) {
- navigator.geolocation.watchPosition((position) => {
- console.log(me_longitude,position.coords.longitude)
- console.log(me_latitude,position.coords.latitude)
- if (me_longitude > 0 && me_longitude == position.coords.longitude && me_latitude > 0 && me_latitude == position.coords.latitude) return
- me_longitude = position.coords.longitude;
- me_latitude = position.coords.latitude;
- me_altitude = position.coords.altitude || 0;
- // 创建一个箭头实体
- removeById('me_dw')
+ // 如果实体不存在,先创建实体
+ if (!myAppEntity) {
myAppEntity = window.cesiumViewer.entities.add({
id: 'me_dw',
- position: globalCesium.Cartesian3.fromDegrees(me_longitude, me_latitude, me_altitude),
+ position: new globalCesium.CallbackProperty(() => {
+ return globalCesium.Cartesian3.fromDegrees(me_longitude, me_latitude, me_altitude)
+ }, false),
billboard: {
- image: meMapSrc, // 箭头图片路径
+ image: meMapSrc,
width: 30,
height: 30,
scale: 1.0,
outlineWidth: 0,
}
});
+ } else {
+ myAppEntity.position = new globalCesium.CallbackProperty(() => {
+ return globalCesium.Cartesian3.fromDegrees(me_longitude, me_latitude, me_altitude)
+ }, false);
+ }
+ navigator.geolocation.watchPosition((position) => {
+ if (me_longitude > 0 && me_longitude == position.coords.longitude &&
+ me_latitude > 0 && me_latitude == position.coords.latitude) return
+
+ me_longitude = position.coords.longitude;
+ me_latitude = position.coords.latitude;
+ me_altitude = position.coords.altitude || 0;
+
// 查看两条线直接距离和高度
getTwoHeightWidth(workspaceId)
}, (error) => {
--
Gitblit v1.9.3