cesium实现飞机与键盘交互[HPR][plane][fps]

本文介绍如何在Cesium中使用键盘控制飞行器的姿态(heading、pitch、roll),包括监听键盘事件并调整飞行器的位置与角度,实现第一人称视角等功能。

在cesium中实现键盘监听控制飞机的heading pitch roll

主要参考例子:

https://sandcastle.cesium.com/index.html?src=HeadingPitchRoll.html

上述例子中的第一人称视角处理有纰漏,改进后的效果和实现的代码如下:

在这里插入图片描述

            let canvas = viewer.canvas;
            canvas.setAttribute("tabindex", "0"); // needed to put focus on the canvas
            canvas.addEventListener("click", function () {
   
   
                canvas.focus();
            });
            canvas.focus();

            let scene = viewer.scene;

            let pathPosition = new SampledPositionProperty();
            this.planePath = viewer.entities.add({
   
   
                id: "keyboardDemoPlanePath",
                position: pathPosition,
                // name: "path",
                path: {
   
   
                    show: true,
                    leadTime: 0,
                    trailTime: 60,
                    width: 10,
                    resolution: 1,
                    material: new PolylineGlowMaterialProperty({
   
   
                        glowPower: 0.3,
                        taperPower: 0.3,
                        color: Color.PALEGOLDENROD
                    })
                }
            });

            let camera = viewer.camera;
            let controller = scene.screenSpaceCameraController;
            let r = 0;
            let center = new Cartesian3();

            let hpRoll = new HeadingPitchRoll();
            let hpRange = new HeadingPitchRange();
            let speed = 1;
            let deltaRadians = _Math.toRadians(3.0);

            let position = Cartesian3.fromDegrees(
                114.4152843,
                30.512368,
                5000.0
            );
            let speedVector = new Cartesian3();
            let fixedFrameTransform = Transforms.localFrameToFixedFrameGenerator
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值