cesium 漫游飞行_Cesium三维漫游

本文介绍如何利用Cesium实现三维地图的漫游飞行功能,包括路径漫游、飞行控制(视角跟随、俯视)、速度与高度调节,以及线路绘制与保存。用户可以选择保存的线路进行漫游体验。
摘要由CSDN通过智能技术生成

1、简介:

Cesium 三维漫游,按路径漫游。

支持飞行控制,包括视角跟随和俯视,速度和高度控制等;

支持绘制线路,线路保存到列表中;

支持选择线路列表中的线路进行漫游;

5e1f6dcef6c7841c698a7ab73ba25193.png

65a52bbc7ae2ddb9cb6842e33d2ebd9c.png 

0902868cccf51a3842a9c2c67b73e979.png 

dff92da739f8fb200588d96372c97629.png

二、代码

fbddeb50622c01defd525f83bc946ab5.png

function doFly() {
    
if(pathsData && pathsData.geometry){
var positionA = pathsData.geometry.coordinates;
var position = [];
if(positionA.length>0){
for (var i = 0; i < positionA.length; i++) {
var x = positionA[i][0];
var y = positionA[i][1];
position.push({ x: x, y: y });
}
}else{
return;
}
function computeCirclularFlight() {
var property = new Cesium.SampledPositionProperty();
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Cesium三维漫游飞行效果可以通过以下步骤实现: 1. 创建一个Cesium Viewer对象: ``` var viewer = new Cesium.Viewer('cesiumContainer'); ``` 2. 通过Camera控制视角和位置: ``` viewer.camera.setView({ destination: Cesium.Cartesian3.fromDegrees(longitude, latitude, height), orientation: { heading: Cesium.Math.toRadians(heading), pitch: Cesium.Math.toRadians(pitch), roll: Cesium.Math.toRadians(roll) } }); ``` 3. 为视角添加动画效果: ``` var duration = 5.0; // 动画时间,单位为秒 Cesium.CameraFlightPath.createAnimationCartographic(viewer.scene, { destination: Cesium.Cartographic.fromDegrees(longitude, latitude, height), orientation: { heading: Cesium.Math.toRadians(heading), pitch: Cesium.Math.toRadians(pitch), roll: Cesium.Math.toRadians(roll) }, duration: duration }); ``` 4. 添加键盘和鼠标事件: ``` // 飞行到指定位置 function flyTo(longitude, latitude, height, heading, pitch, roll) { viewer.camera.flyTo({ destination: Cesium.Cartesian3.fromDegrees(longitude, latitude, height), orientation: { heading: Cesium.Math.toRadians(heading), pitch: Cesium.Math.toRadians(pitch), roll: Cesium.Math.toRadians(roll) } }); } // 监听键盘和鼠标事件 document.addEventListener('keydown', function(event) { switch (event.keyCode) { case 87: // W viewer.camera.moveForward(1000.0); break; case 83: // S viewer.camera.moveBackward(1000.0); break; case 65: // A viewer.camera.moveLeft(1000.0); break; case 68: // D viewer.camera.moveRight(1000.0); break; case 38: // Up arrow viewer.camera.lookUp(0.1); break; case 40: // Down arrow viewer.camera.lookDown(0.1); break; case 37: // Left arrow viewer.camera.lookLeft(0.1); break; case 39: // Right arrow viewer.camera.lookRight(0.1); break; default: return; } event.preventDefault(); }, false); ``` 通过以上步骤,即可实现Cesium三维漫游飞行效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值