news 2026/2/12 16:42:20

Cesium快速入门25:自定义MaterialProperty

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Cesium快速入门25:自定义MaterialProperty

上一节课,我们能在 Primitive 里徒手写着色器;今天把“魔杖”伸回Entity——让它也用上完全自定义的材质。
思路一句话:Entity 只认MaterialProperty接口,我们手写一个类,把 Fabric + GLSL 塞进去,就能像官方材质一样随取随用。


一、MaterialProperty 接口长啥样?

官方把MaterialProperty当“抽象基类”,规定必须实现:

  • getType()—— 返回材质字符串 ID;

  • getValue(time, result)—— 每帧把最新 uniform 值写进 result;

  • definitionChanged—— 事件对象,通知 Entity“我变了,请重绘”。

照猫画虎,自己写个类即可。


二、最小能跑的案例:CustomMaterialProperty

步骤:

  1. 先在 Cesium 材质缓存里注册一个同名 Fabric;

  2. 再在getValue里不停刷新 uniform;

  3. Entity 里当普通材质用。

class CustomMaterialProperty { constructor() { // 1. 通知系统“我要变”的事件 this.definitionChanged = new Cesium.Event(); // 2. 把 Fabric 写进全局缓存,ID 叫 'CustomMaterial' Cesium.Material._materialCache.addMaterial('CustomMaterial', { fabric: { type: 'CustomMaterial', uniforms: { uTime: 0.0 // 初始值 }, source: ` czm_material czm_getMaterial(czm_materialInput materialInput) { czm_material mat = czm_getDefaultMaterial(materialInput); mat.diffuse = vec3(materialInput.st, uTime); // UV+时间当颜色 return mat; } ` } }); } // 3. 返回材质 ID getType() { return 'CustomMaterial'; } // 4. 每帧被 Entity 调用,把最新时间写回 uniform getValue(time, result) { result.uTime = (performance.now() / 1000) % 1; // 0~1 循环 return result; } }

代码写完后,当普通材质直接用:

const customMaterial = new CustomMaterialProperty(); viewer.entities.add({ name: 'Red translucent rectangle', rectangle: { coordinates: Cesium.Rectangle.fromDegrees(114.0, 23.4, 114.4, 23.6), extrudedHeight: 30000.0, material: customMaterial, // 自己的材质 }, });

刷新场景,矩形立刻带上“UV 彩条”,并且红色通道随时间流动——自定义成功!


三、想更平滑?交给 GSAP 去补间

performance.now()虽然简单,但节奏固定。
想要“呼吸”效果,可把 uniform 外包给 GSAP:

// 1. 先在构造函数里准备参数对象 this.params = { uTime: 0.0 }; gsap.to(this.params, { uTime: 1.0, duration: 2.0, repeat: -1, ease: 'linear' }); // 2. getValue 只负责“搬运” getValue(time, result) { result.uTime = this.params.uTime; return result; }

现在条纹会像扫描线一样来回走动,完全平滑。


四、常见坑提醒

  • ID 必须对应:Fabric 的type/getType()/ 缓存 key 三处要完全一致;

  • getValue里一定要return result,否则 Entity 拿不到新值;

  • 想刷新画面就触发this.definitionChanged.raiseEvent(this),Entity 才会重绘。


五、小结与展望

  • Entity 自定义材质 = 实现MaterialProperty接口 + 注册同名 Fabric。

  • 时间动画既能用performance.now(),也能让 GSAP 补间参数。

  • 下一步:把“UV+时间”换成“距离+时间”,一个标准“雷达扫描圈”就呼之欲出了。

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

双十二投影仪哪款值得推荐?这4个价位段最值得买的一款

双十二大促是2025年入手投影仪最后的黄金窗口期。面对琳琅满目的产品,如何根据自身需求和预算快速锁定最佳选择?本文直接从预算与场景入手,为大家带来覆盖全价位段的四款高性价比投影仪,从便携入门到专业影院级,一步到…

作者头像 李华
网站建设 2026/2/12 5:46:22

常用接口抓包以及接口测试工具总结

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 接口统称为API,程序与程序之间的对接、交接。接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点,主要是为了检验不…

作者头像 李华
网站建设 2026/2/4 14:43:41

练题100天——DAY29:岛屿的周长+寻找两个正序数组的中位数

今天的两道题都是有点硬的骨头,勉勉强强能做出来,但是想不到特定的解决方法,算法难度★★★★。深度优先算法和二分查找以为自己会,遇到这两道题算是给了我当头两棒:根本不知道何时用、怎么用深度优先算法,…

作者头像 李华
网站建设 2026/2/6 1:31:54

EtherCAT 转 Modbus RTU 网关:实现倍福 PLC 与宇电 AI-516 温控器协同联动

一、项目背景 某精密机械制造企业的数控加工生产线面临异构设备通信难题:生产线核心控制采用倍福 CX5140 PLC(支持 EtherCAT 协议),负责主轴运转、工序联动及整体流程控制,而现场 18 台数控加工机床的温度调控依赖宇电…

作者头像 李华
网站建设 2026/2/11 9:06:50

平台生态:生成式AI的差异化规则与适配策略

主流AI平台的生态特征不同生成式AI平台基于其训练数据、技术架构和商业策略,形成了各具特色的“生态偏好”。理解这些差异是制定有效GEO策略的前提。OpenAI的ChatGPT表现出对权威来源和近期内容的明显偏好。研究显示,ChatGPT在回答事实性问题时&#xff…

作者头像 李华