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

Cesium快速入门22:fabric自定义着色器

这节课,我们告别“傻瓜式”fromType,改用更灵活的Fabric写法,手把手自定义 Primitive 材质。
一句话:Fabric 就是“用 JSON 对象描述材质”,既能配 uniform,也能直接写 GLSL 源码,想怎么画就怎么画。


一、Fabric 基础格式

const material = new Cesium.Material({ fabric: { type: 'Color', // 材质类型(可省) uniforms: { /* 参数表 */ }, // 着色器里的外部变量 source: `/* 可选:完全自定义 GLSL */` } });
  • typefromType的第一参数对应,写不写都行;

  • uniforms里的值会原样传进着色器;

  • 一旦给出source,Cesium 就不再内置代码,而是把你写的字符串直接编译进片元着色器——自由度瞬间拉满。


二、把以前的纯色、贴图改用 Fabric 写

  1. 半透明红

const fbMaterial = new Cesium.Material({ fabric: { type: 'Color', uniforms: { color: Cesium.Color.RED.withAlpha(0.5), // 外部变量 } } });
  1. 贴图

const fbMaterial = new Cesium.Material({ fabric: { type: 'Image', uniforms: { image: './imgs/logo.png', // 图片路径 } } });

效果与fromType完全一致,只是换了个写法,为后面“手写着色器”热身。


三、完全自定义:手写 czmmaterial

Cesium 的片元着色器里会调用一个固定接口:

czm_material czm_getMaterial(czm_materialInput materialInput);

只要你在 Fabric 里提供source,系统就把这段字符串原封不动塞进最终着色器,想返回什么颜色都行。

示例:整面涂纯红

const rawMaterial = new Cesium.Material({ fabric: { uniforms: {}, // 暂无外部参数 source: ` czm_material czm_getMaterial(czm_materialInput materialInput) { czm_material mat = czm_getDefaultMaterial(materialInput); // 先拿默认结构 mat.diffuse = vec3(1.0, 0.0, 0.0); // 漫反射=红色 return mat; } ` } });
  • czm_getDefaultMaterial帮你把结构体初始化好;

  • mat.diffuse就是改表面颜色;

  • 想调透明度再动mat.alpha,想自发光就改mat.emission,全靠你发挥。


四、想看最终代码?Cesium 给你开“后台门”

把材质赋给 Appearance 后,运行时能直接拿到完整源码:

console.log(appearance.fragmentShaderSource);

打印结果里就能看到:

  • 变量v_st(UV)怎么来;

  • czm_getMaterial在哪被调用;

  • 最终gl_FragColor如何叠加光照。
    调错颜色、写崩语法时,把这里当“在线调试器”即可。


五、Fabric 能做什么

  • 改已有 uniform:换图、换色、换强度;

  • 写全新 GLSL:噪声、流动、扫描线、科技墙……随便玩;

  • 多材质合并:Fabric 支持components混搭,后面再进阶。


小结

  1. Fabric = JSON 描述材质,可配 uniform,可写 GLSL。

  2. 手写czm_getMaterial就能完全掌控像素颜色。

  3. 调错就打印vertexShaderSource / fragmentShaderSource,实时查看最终代码。

  4. 下节课我们在这份红布上再加噪声、做流动,让墙面自己“动起来”。

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

相关文章:

  • 终极OBS-NDI配置指南:5分钟解决视频流问题
  • HunyuanVideo-Foley音效生成引擎的技术架构剖析:从输入到输出全流程
  • HuggingFace模型卡撰写规范提升Qwen3-VL-30B曝光率
  • Windows虚拟显示器:3个步骤轻松扩展你的工作空间,你真的会用吗?
  • AI驱动虚拟角色:零代码打造智能交互新体验
  • python基于web的数学试题库组卷系统_k593i56u_pycharm Vue django flask项目源码
  • Tomcat11证书配置全指南
  • Notepad官网下载后如何编写Wan2.2-T2V-5B的自动化脚本?
  • macOS菜单栏智能管理解决方案:Ice工具深度解析
  • 2025年八大网盘直链下载完整指南:快速获取真实下载地址
  • 如何快速掌握Py-ART:气象雷达数据处理的完整实战指南
  • HuggingFace镜像网站推荐列表:国内高速下载Seed-Coder-8B-Base
  • 12、支持向量机与核分类算法详解
  • 快速掌握ZonyLrcToolsX:歌词下载的终极操作指南
  • VMware macOS虚拟机终极解锁指南:免费安装苹果系统的完整教程
  • 强力Cookie管理技巧:Get-cookies.txt-LOCALLY让数据安全触手可及
  • Live2D AI智能助手:重塑网页交互体验的革命性技术
  • Seed-Coder-8B-Base在Python项目中的函数生成能力实测
  • 《游戏活动效能升级与服务器压力精益管理的实战指南》
  • Maccy剪贴板管理器:macOS系统兼容性深度解析
  • 轮毂分类检测数据集介绍-855张 汽车制造质检 车辆维护和检测 智能交通系统 二手车评估 自动驾驶识别模块 工业机器人视觉系统
  • LangChain函数调用增强Qwen3-VL-30B的外部工具执行能力
  • 乳牛皮肤疾病检测数据集介绍-56张图片 智能养殖管理 农业疾病诊断辅助 畜牧业健康监控 图像分类模型训练与评测 教育与科研
  • 企业AI落地全攻略:从零代码到安全合规,开发者和管理者都该收藏的实战指南
  • 42、深入了解Xenomai实时系统:特性、架构与应用
  • 如何在浏览器中3分钟搞定串口调试?波特律动串口助手超详细使用指南
  • 5分钟搞定智慧树插件:让你的网课学习效率翻倍
  • 北大学者带你拖拽3D物体,像玩拼图一样让虚拟世界动起来
  • Vscode调试Python脚本运行ACE-Step:快速定位错误
  • PyTorch JIT编译提升Stable Diffusion 3.5 FP8运行效率可行性研究