|
|
@ -17,15 +17,9 @@ let options = {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
showSun: false,
|
|
|
|
showSun: false,
|
|
|
|
showMoon: false,
|
|
|
|
showMoon: false,
|
|
|
|
showSkyBox: false,
|
|
|
|
showSkyBox: true,
|
|
|
|
showSkyAtmosphere: false,
|
|
|
|
showSkyAtmosphere: true,
|
|
|
|
fog: false,
|
|
|
|
fog: false,
|
|
|
|
// backgroundColor: "#363635", // 天空背景色
|
|
|
|
|
|
|
|
globe: {
|
|
|
|
|
|
|
|
baseColor: "#363635", // 地球地面背景色
|
|
|
|
|
|
|
|
showGroundAtmosphere: false,
|
|
|
|
|
|
|
|
enableLighting: false,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
clock: {
|
|
|
|
clock: {
|
|
|
|
currentTime: "2023-11-01 12:00:00", // 固定光照时间
|
|
|
|
currentTime: "2023-11-01 12:00:00", // 固定光照时间
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -62,8 +56,39 @@ let options = {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const params = reactive({
|
|
|
|
|
|
|
|
lat: 31.162232,
|
|
|
|
|
|
|
|
lng: 120.734077,
|
|
|
|
|
|
|
|
altitude: 3000,
|
|
|
|
|
|
|
|
heading: 0, //当前朝向
|
|
|
|
|
|
|
|
pitch: 0, //保当前俯仰角
|
|
|
|
|
|
|
|
roll: 0, //当前翻滚角
|
|
|
|
|
|
|
|
correction: 1,
|
|
|
|
|
|
|
|
speed: 800,
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
const EARTH_RADIUS = 6371000;
|
|
|
|
|
|
|
|
let isUav = true
|
|
|
|
|
|
|
|
const DIRECTION = {
|
|
|
|
|
|
|
|
UP: "w",
|
|
|
|
|
|
|
|
DOWN: "s",
|
|
|
|
|
|
|
|
LEFT: "a",
|
|
|
|
|
|
|
|
RIGHT: "d",
|
|
|
|
|
|
|
|
SPEED_UP: "q",
|
|
|
|
|
|
|
|
SPEED_DOWN: "e",
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const keyboardMap = {
|
|
|
|
|
|
|
|
[DIRECTION.UP]: false,
|
|
|
|
|
|
|
|
[DIRECTION.DOWN]: false,
|
|
|
|
|
|
|
|
[DIRECTION.LEFT]: false,
|
|
|
|
|
|
|
|
[DIRECTION.RIGHT]: false,
|
|
|
|
|
|
|
|
[DIRECTION.SPEED_UP]: false,
|
|
|
|
|
|
|
|
[DIRECTION.SPEED_DOWN]: false,
|
|
|
|
|
|
|
|
};
|
|
|
|
let map = null;
|
|
|
|
let map = null;
|
|
|
|
|
|
|
|
let list = [];
|
|
|
|
|
|
|
|
let uav = null
|
|
|
|
const mapLayer = {};
|
|
|
|
const mapLayer = {};
|
|
|
|
const mapLoad = (mapInstance) => {
|
|
|
|
const mapLoad = (mapInstance) => {
|
|
|
|
map = mapInstance;
|
|
|
|
map = mapInstance;
|
|
|
@ -73,24 +98,136 @@ const mapLoad = (mapInstance) => {
|
|
|
|
});
|
|
|
|
});
|
|
|
|
map.addLayer(mapLayer.markerLayer);
|
|
|
|
map.addLayer(mapLayer.markerLayer);
|
|
|
|
//创建无人机固定巡航
|
|
|
|
//创建无人机固定巡航
|
|
|
|
initUav()
|
|
|
|
// initUav()
|
|
|
|
// 绘制停机场矩形
|
|
|
|
// // 绘制停机场矩形
|
|
|
|
initRectangle();
|
|
|
|
// initRectangle();
|
|
|
|
initMarker();
|
|
|
|
// initMarker();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
boostrapUav()
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const boostrapUav = () => {
|
|
|
|
|
|
|
|
// initUav()
|
|
|
|
|
|
|
|
// onAddKeyboardListener()
|
|
|
|
|
|
|
|
// const renderer = () => {
|
|
|
|
|
|
|
|
// onAdjustParams();
|
|
|
|
|
|
|
|
// onAdjustAttitude();
|
|
|
|
|
|
|
|
// requestAnimationFrame(renderer);
|
|
|
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
// renderer();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//开启按键监听
|
|
|
|
|
|
|
|
const onAddKeyboardListener = () => {
|
|
|
|
|
|
|
|
document.addEventListener("keydown", (e) => {
|
|
|
|
|
|
|
|
if (Object.keys(keyboardMap).includes(e.key)) {
|
|
|
|
|
|
|
|
keyboardMap[e.key] = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
document.addEventListener("keyup", (e) => {
|
|
|
|
|
|
|
|
if (Object.keys(keyboardMap).includes(e.key)) {
|
|
|
|
|
|
|
|
keyboardMap[e.key] = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//开启飞行参数调整
|
|
|
|
|
|
|
|
const onAdjustParams = () => {
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.SPEED_UP]) {
|
|
|
|
|
|
|
|
params.speed += 100;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.SPEED_DOWN]) {
|
|
|
|
|
|
|
|
if (params.speed >= 500) {
|
|
|
|
|
|
|
|
params.speed -= 100;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//机体爬升
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.UP] && params.pitch <= 0.3) {
|
|
|
|
|
|
|
|
params.pitch += 0.005;
|
|
|
|
|
|
|
|
if (params.pitch > 0) {
|
|
|
|
|
|
|
|
const { speed, pitch } = params;
|
|
|
|
|
|
|
|
const temp = (params.speed / 60 / 60 / 60) * 110;
|
|
|
|
|
|
|
|
//1经纬度约等于110km
|
|
|
|
|
|
|
|
params.altitude += temp * Math.sin(pitch);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//机体俯冲
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.DOWN] && params.pitch >= -0.3) {
|
|
|
|
|
|
|
|
params.pitch -= 0.006;
|
|
|
|
|
|
|
|
if (params.pitch < 0) {
|
|
|
|
|
|
|
|
const { speed, pitch } = params;
|
|
|
|
|
|
|
|
//1经纬度约等于110km
|
|
|
|
|
|
|
|
const temp = (params.speed / 60 / 60 / 60) * 110;
|
|
|
|
|
|
|
|
params.altitude += temp * Math.sin(pitch);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//机体左转
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.LEFT]) {
|
|
|
|
|
|
|
|
params.heading -= 0.115;
|
|
|
|
|
|
|
|
if (params.roll > -10) {
|
|
|
|
|
|
|
|
params.roll -= 0.115;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//机体右转
|
|
|
|
|
|
|
|
if (keyboardMap[DIRECTION.RIGHT]) {
|
|
|
|
|
|
|
|
params.heading += 0.115;
|
|
|
|
|
|
|
|
if (params.roll < 10) {
|
|
|
|
|
|
|
|
params.roll += 0.115;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
const { heading, pitch, roll } = params;
|
|
|
|
|
|
|
|
const { abs, cos } = Math;
|
|
|
|
|
|
|
|
params.correction = abs(cos(heading) * cos(pitch));
|
|
|
|
|
|
|
|
if (abs(heading) < 0.001) params.heading = 0;
|
|
|
|
|
|
|
|
if (abs(roll) < 0.001) params.roll = 0;
|
|
|
|
|
|
|
|
if (abs(pitch) < 0.001) params.pitch = 0;
|
|
|
|
|
|
|
|
//方向自动回正
|
|
|
|
|
|
|
|
// if (params.heading > 0) params.heading -= 0.0025
|
|
|
|
|
|
|
|
// if (params.heading < 0) params.heading += 0.0025
|
|
|
|
|
|
|
|
if (params.roll > 0) params.roll -= 0.003;
|
|
|
|
|
|
|
|
if (params.roll < 0) params.roll += 0.003;
|
|
|
|
|
|
|
|
if (params.pitch < 0) params.pitch += 0.005;
|
|
|
|
|
|
|
|
if (params.pitch > 0) params.pitch -= 0.003;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 开启飞行姿态调整/
|
|
|
|
|
|
|
|
const onAdjustAttitude = () => {
|
|
|
|
|
|
|
|
const temp = params.speed / 60 / 60 / 60 / 110;
|
|
|
|
|
|
|
|
params.lng += temp * Math.cos(params.heading);
|
|
|
|
|
|
|
|
params.lat -= temp * Math.sin(params.heading);
|
|
|
|
|
|
|
|
const { lng, lat, altitude, heading, pitch, roll } = params;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
params.altitude += temp * Math.sin(pitch) * 110 * 1000 * 10;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const position = Cesium.Cartesian3.fromDegrees(lng, lat, altitude);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
uav.model.setStyle({
|
|
|
|
|
|
|
|
heading,
|
|
|
|
|
|
|
|
pitch,
|
|
|
|
|
|
|
|
roll
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
uav.addTimePosition(position);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const initUav = () => {
|
|
|
|
const initUav = () => {
|
|
|
|
let list = []
|
|
|
|
if (list.length == 0) {
|
|
|
|
PointJson.map(item=>{
|
|
|
|
PointJson.map((item) => {
|
|
|
|
list.push(item.wz.split(",").map(Number))
|
|
|
|
list.push(item.wz.split(",").map(Number));
|
|
|
|
})
|
|
|
|
});
|
|
|
|
const uav = new mars3d.graphic.Route({
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
uav = new mars3d.graphic.Route({
|
|
|
|
id: "uav",
|
|
|
|
id: "uav",
|
|
|
|
name: "无人机模型",
|
|
|
|
name: "无人机模型",
|
|
|
|
position: {
|
|
|
|
position: {
|
|
|
|
type: "time", // 时序动态坐标
|
|
|
|
type: "time", // 时序动态坐标
|
|
|
|
speed: 100,
|
|
|
|
speed: 100,
|
|
|
|
list: list
|
|
|
|
list: list,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
model: {
|
|
|
|
model: {
|
|
|
|
url: "https://data.mars3d.cn/gltf/mars/wrj.glb",
|
|
|
|
url: "https://data.mars3d.cn/gltf/mars/wrj.glb",
|
|
|
@ -98,13 +235,15 @@ const initUav = ()=>{
|
|
|
|
minimumPixelSize: 0.1,
|
|
|
|
minimumPixelSize: 0.1,
|
|
|
|
runAnimations: true,
|
|
|
|
runAnimations: true,
|
|
|
|
mergeOrientation: true,
|
|
|
|
mergeOrientation: true,
|
|
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
camera: {
|
|
|
|
camera: {
|
|
|
|
type: "gs",
|
|
|
|
type: "gs",
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
});
|
|
|
|
mapLayer.markerLayer.addGraphic(uav);
|
|
|
|
mapLayer.markerLayer.addGraphic(uav);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
const initRectangle = () => {
|
|
|
|
const initRectangle = () => {
|
|
|
|
const graphic = new mars3d.graphic.RectanglePrimitive({
|
|
|
|
const graphic = new mars3d.graphic.RectanglePrimitive({
|
|
|
@ -124,7 +263,6 @@ const initRectangle = () => {
|
|
|
|
mapLayer.markerLayer.addGraphic(graphic);
|
|
|
|
mapLayer.markerLayer.addGraphic(graphic);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* 渲染所有点位
|
|
|
|
* 渲染所有点位
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|