news 2026/5/12 17:21:22

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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,只是字段略有差异,下节课再展开。

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 4:24:49

25、Linux Mint系统升级与MATE版本使用指南

Linux Mint系统升级与MATE版本使用指南 1. Linux Mint版本选择与升级考量 在商业和企业环境中,建议使用支持5年的LTS版本。系统管理员若所在公司采用Linux Mint系统,使用非LTS版本会带来大量不必要的工作,因为版本过时后需要大规模重新安装。LTS版本适用于需要稳定且持久运…

作者头像 李华
网站建设 2026/5/1 7:24:28

Cesium快速入门18:Entity材质设置

前面的课程里,我们先后讲了 Entity(实体)和 Primitive(图元)这两种“物体”。 它们都能贴材质,只不过用法有简有繁。 今天先集中火力把 Entity 的材质系统 撸一遍,看看 Cesium 到底给我们备好了…

作者头像 李华
网站建设 2026/5/6 1:37:23

《安卓逆向这档事》demo2----正己大佬

demo2 第二关 文本定位 首先,观察界面,查看文字,任务要求是获取硬币并一键三连。主要的两个分别是 获取硬币​ 和 一键三连​,回到 MT 管理器,搜索(PS:MT 管理器如何提取安装包定位位置就不细…

作者头像 李华
网站建设 2026/5/2 17:26:00

SolidWorks特征工具设计思维介绍

SolidWorks 的特征工具是其参数化建模的核心,其设计思维深度融合了参数化设计理念、工程实践需求和用户操作直觉。理解特征工具的本质,需要从“特征是什么”“为何这样设计”“如何高效使用”三个维度展开,最终掌握“用特征表达设计意图”的能…

作者头像 李华
网站建设 2026/4/30 21:20:41

SolidWorks异形孔的类型介绍

一、核心理解:“异形孔向导”是什么它不是一个简单的“画孔”工具,而是一个基于标准的参数化特征生成器。其核心价值在于:标准化:内置了ISO、GB(国标)、ANSI、DIN、JIS等多种主流标准,确保设计的…

作者头像 李华
网站建设 2026/5/11 10:57:12

Python asyncio:解锁异步编程的魔法钥匙

一、引言:异步编程的奇妙世界在传统的同步编程中,程序就像一个按部就班的执行者,会顺序执行每一行代码,在遇到 I/O 操作(如文件读写、网络请求等)时,会老老实实等待该操作完成,才会继…

作者头像 李华