【cesium-5】鼠标交互与数据查询

scene.pick返回的是包含给定窗口位置基元的对象

scene.drillpack返回的是给定窗口位置所有对象的列表

Globe.pick返回的是给光线和地形的交点

Cesium.ScreenSpaceEventType.MIDDLE_CLICK 鼠标中间点击事件

Cesium.ScreenSpaceEventType.MOUSE_MOVE 鼠标移入事件

Cesium.ScreenSpaceEventType.RIGHT_CLICK 鼠标右击事件

复制代码
Cesium.Ion.defaultAccessToken = '';

var viewer = new Cesium.Viewer('cesiumContainer', {
        animation: false,
        timeline: false
});

var position = new Cesium.Cartesian3.fromDegrees(116.39, 38.9, 0.0);
const entity = viewer.entities.add({
    id:'BlueModel',
    position: position,
    plane: {
        plane: new Cesium.Plane(Cesium.Cartesian3.UNIT_X, 0.0),
        dimensions: new Cesium.Cartesian2(400, 300),
        material: "../testdata/test.png",
        outline: true,
        outlineColor: Cesium.Color.BLACK  
    },
    description:`<div>
                <img width="100%" height="300px" src="../testdata/data.png">
                <h3>你好呀</h3>
                <h3>欢迎学习cesium</h3>
                </div>` 
}) 

viewer.trackedEntity = entity;  //将摄像机视口快速绑定到模型位置 

var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);
handler.setInputAction(function (movement){
    var pick = viewer.scene.pick(movement.position);
    if(Cesium.defined(pick) && (pick.id.id ==='BlueModel')){
        alert("欢迎加入")
    }
},Cesium.ScreenSpaceEventType.LEFT_CLICK);  //监听鼠标左键点击事件 

参考链接 9、cesium使用entity进行页面交互效果 - 哔哩哔哩

相关推荐
杉之17 分钟前
常见前端GET请求以及对应的Spring后端接收接口写法
java·前端·后端·spring·vue
喝拿铁写前端19 分钟前
字段聚类,到底有什么用?——从系统混乱到结构认知的第一步
前端
再学一点就睡22 分钟前
大文件上传之切片上传以及开发全流程之前端篇
前端·javascript
木木黄木木1 小时前
html5炫酷图片悬停效果实现详解
前端·html·html5
请来次降维打击!!!2 小时前
优选算法系列(5.位运算)
java·前端·c++·算法
難釋懷2 小时前
JavaScript基础-移动端常见特效
开发语言·前端·javascript
自动花钱机3 小时前
WebUI问题总结
前端·javascript·bootstrap·css3·html5
拉不动的猪3 小时前
简单回顾下pc端与mobile端的适配问题
前端·javascript·面试
拉不动的猪3 小时前
刷刷题49(react中几个常见的性能优化问题)
前端·react.js·面试
snowfoootball4 小时前
基于 Ollama DeepSeek、Dify RAG 和 Fay 框架的高考咨询 AI 交互系统项目方案
前端·人工智能·后端·python·深度学习·高考