cesium,不想拖动地图,只想改变视角的实现

今天遇到这么个需求,本来以为可以通过cesium禁用掉部分属性就能简单搞定,没想到尝试过后并不太行,它的拖动地图和拖动视角是绑定在一起的,当你mousedown时点击位置选中地形就会拖动地图,选到天空盒就是拖动视角,无奈只能全部禁用重新写一个控制器

实现比较简单,但我最开始的设想很复杂,浪费了很多时间,所以在这里碎碎念发泄一下

多的不说,直接上代码

const setReviewViewAction = (viewer = reviewViewer, Cesium = window.Cesium) => { let isDragging = false; let lastPosition: Cartesian2

ini 复制代码
// 鼠标按下事件
const handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction(() => {
    isDragging = true;
}, Cesium.ScreenSpaceEventType.LEFT_DOWN);

// 鼠标移动事件
handler.setInputAction((movement: {startPosition: Cartesian2, endPosition: Cartesian2}) => {
    if (!isDragging) return;
    if(!lastPosition) {
        //防止获取不到startPostion
        lastPosition = movement.startPosition
        return
    }
    const curPosition = movement.endPosition

    const x = (curPosition.x - lastPosition.x) * 0.005
    const y = (curPosition.y - lastPosition.y) * 0.005

    let heading = viewer.camera.heading + x
    let pitch = viewer.camera.pitch + y
    // 设置最大值和最小值
    heading = heading > 2*Math.PI ? heading - 2*Math.PI : heading < 0 ? 2*Math.PI + heading : heading
    pitch = pitch > Math.PI/2 ? Math.PI/2 : pitch < -Math.PI/2 ? -Math.PI/2 : pitch

    viewer.camera.setView({
        destination:viewer.camera.position,
        orientation: {
            heading ,
            pitch,
            roll: viewer.camera.roll
        }
    })
}, Cesium.ScreenSpaceEventType.MOUSE_MOVE);

// 鼠标释放事件
handler.setInputAction(() => {
    isDragging = false;
}, Cesium.ScreenSpaceEventType.LEFT_UP);

}

相关推荐
YHHLAI几秒前
前端工程化调用 AI 多模态生图模型:Qwen Image Demo 实战
前端·人工智能
To_OC14 分钟前
我一直以为 Ajax 是个黑盒,直到我写了这 50 行代码
前端·后端·全栈
用户0595401744618 分钟前
RAG 记忆层踩坑实录:用户偏好凭空消失,我排查了 4 小时,最后用 LangChain + Chroma 搭了套自动化回归测试
前端·css
程序猿阿伟25 分钟前
《Chrome隔离机制的维度落地指南》
前端·chrome
用户0543243297026 分钟前
AI 生成的代码怎么在前端安全预览 + 一键运行:sandbox iframe 实战 🔒
前端
ALianBlank27 分钟前
一个 Unity 框架能做多少事?86 个模块 + 21 个小游戏平台
前端·后端·游戏开发
To_OC31 分钟前
搞懂二叉树递归遍历,我居然是从爬楼梯开始的
前端·javascript·数据结构
何何____36 分钟前
svg基本图形绘制介绍
前端·css
weedsfly36 分钟前
Sass 运算 vs CSS calc():你的计算该放在哪一层?
前端
在水一缸1 小时前
重塑前端开发认知:当 AI 遇见 HTML 的“不合理有效性”
前端·人工智能·html·ai编程·claude·前端开发