当前位置: 首页 > news >正文

Cesium快速入门17:与entity和primitive交互

上节课我们学会了“一个图元里塞多个物体”。
新问题来了:鼠标随便点一下,我怎么知道到底点中了谁?能不能像 Three.js 那样“指谁打谁”?
答案当然是可以,套路还是那条老路——屏幕射线拾取(pick)
Cesium 已经把鼠标事件封装得服服帖帖,我们直接拿来用就行。

下面分三步:

  1. 先建“鼠标监听器”;

  2. 再拿屏幕坐标去拾取;

  3. 拾到谁,就改谁的颜色,给它一个“被选中的”反馈。


一、创建鼠标监听器

Cesium 贴心地提供了ScreenSpaceEventHandler,专门对付鼠标、触摸、键盘组合键。
它能监听左键按下、抬起、双击、右键、中键滚轮等十几种事件,今天咱们只关心“左键单击”。

/* 1. 在 canvas 上布一个监听器 */ const handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);

二、监听左键单击

监听器建好后,给它注册一个回调:
只要用户在地球任意处“咔哒”一下,我们就把鼠标位置拿出来做拾取。

/* 2. 注册左键单击事件 */ handler.setInputAction((movement) => { console.log(movement); // 先打印看一眼结构,心里有底 const pick = viewer.scene.pick(movement.position); // 核心:拾取函数 /* 3. 如果拾到东西,并且是个带 id 的实例,就换颜色 */ if (Cesium.defined(pick) && typeof pick === 'object' && Object.hasOwn(pick, 'id')) { rectPrimitive.getGeometryInstanceAttributes(pick.id).color = Cesium.ColorGeometryInstanceAttribute.toValue(Cesium.Color.ORANGE); } }, Cesium.ScreenSpaceEventType.LEFT_CLICK);

代码讲解:

  • movement.position就是屏幕二维坐标(左上角为原点)。

  • viewer.scene.pick(...)会返回一个对象,若没点中则返回undefined

  • 点中 Primitive 里的某个实例时,返回的对象自带id字段,内容就是我们当初在GeometryInstance里填的字符串 id。

  • 拿到 id 后,用getGeometryInstanceAttributes(id)就能直接改颜色,无需重建 Primitive。


三、拾取结果长啥样

{ position: Cartesian2 {x: 1234, y: 567}, // 屏幕坐标 // 可能还有 ctrlKey、shiftKey 等组合键标志 }
{ id: 'ellipsoid', // 我们之前写的实例 id primitive: rectPrimitive, // 所属图元 // 其余内部字段略 }

只要pick.id是字符串,就能确定“点中的是 Primitive 里的某个实例”,后续想高亮、隐藏、改大小,都照这个套路来。


四、小结

  • 任何鼠标交互,先上ScreenSpaceEventHandler

  • 想拾取,就scene.pick(屏幕坐标),返回对象里自带 id。

  • 拾到后,实例属性随便改,颜色、显隐、矩阵都能实时生效。

  • 同一套代码既适用于 Primitive,也适用于 Entity,只是字段略有差异,下节课再展开。

把这条“监听 → 拾取 → 改属性”的流水线记住,后面做点击高亮、弹窗、属性编辑,全都照搬即可。

http://www.cnnetsun.cn/news/28052.html

相关文章:

  • 第十章 for循环
  • WebRTC 是什么?能做什么?(概览篇)
  • Dubbo学习(三):深入 Remoting
  • AI设计新突破:QWEN溶图LoRA模型助力品牌视觉创作升级
  • 突破实时视频生成瓶颈:Krea Realtime 14B模型革新文本到视频技术
  • 【项目实战】Vercel 是一个让你的网站“瞬间上线”的云平台。Vercel 现在确实是技术圈的“当红炸子鸡”,尤其是在个人博客和前端开发领域。
  • Day28~实现strlen、strcpy、strncpy、strcat、strncat
  • 空洞骑士模组管理大师课:5个关键技巧让Scarab成为你的游戏管家
  • 实用方法:轻松实现NCM文件格式转换的完整解析
  • C++课后习题训练记录Day49
  • LeetCode 189. 旋转数组 | 三步反转最优解全拆解
  • downkyi视频下载:告别卡顿与画质损失的终极解决方案
  • 教你如何玩转DPDK开发中的KNI与内核交互,让网络速度翻倍!
  • Openresty驱动下的高性能Web网关实战
  • 百度网盘下载工具终极指南:快速突破限速的完整教程
  • C语言实现hashmap(附带源码)
  • jsonnet介绍和使用
  • 喜马拉雅音频数据采集:API接口分析与加密音频链接解密实战
  • 角色影像生成新纪元:Pony V7-Base引领AI创作革命
  • 论文格式修改排名:9大平台+在线一键优化
  • 论文写作效率低?十大AI生成平台,AIGC降重+赶due不熬夜
  • 文献引用规范考核要点解析与实践指南
  • 文献综述写作期末指南:方法、结构与常见问题解析
  • 期末文献研究论文的撰写方法与实践路径探讨
  • 基于 HID 协议的扩展功能指令定义方案
  • 模拟IC设计:集成电路与运算放大器大观
  • 6、Oracle数据库管理:文件与目录操作全解析
  • 12、Oracle数据库Linux服务器软件管理全攻略
  • 某聘新版AST解混淆(青春版)
  • 基于Spring Boot框架和vue的的诗词鉴赏与交流网站的设计与实现_96fdvu1s