news 2026/6/23 15:58:02

Cesium快速入门15:图元Primitive创建图像物体

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Cesium快速入门15:图元Primitive创建图像物体

前面我们一直用 Entity——也就是“实体”——画矩形、椭球、走廊、圆柱、多边形、球体等等。Entity 把底层细节包得严严实实,一两行代码就能出效果。
可如果想再“底层”一点,自己捏顶点、配材质、写外观,那就得请出今天的主角:Primitive(图元)。
思路跟 Three.js 很像:先造几何体 → 再搞实例 → 再给外观 → 最后扔进场景。
步骤多了,但自由度直接拉满,后面甚至能自己写着色器做烟雾、流体等特效。

下面咱们把“ Entity 画矩形”快速复习一遍,然后再用 Primitive 一模一样地复现它,每一步都拆开讲透。


一、Entity 版:两行代码画矩形

需求:在地球上贴两张“完全贴地”的矩形,红色半透明。

// 1. 直接调实体接口 const redRect = viewer.entities.add({ rectangle: { // 西南角 + 东北角 两个点定矩形 coordinates: Cesium.Rectangle.fromDegrees(113.3, 23.0, 113.4, 23.2), material: Cesium.Color.RED.withAlpha(0.5) // 红色半透明 } });

完事儿!简单,但黑盒。


二、Primitive 版:五步走,每一步都能改

我们把上面同样的矩形,用 Primitive 手敲一遍,看看底层到底干了啥。

【第 1 步】造几何体(Geometry)
告诉 Cesium:顶点怎么摆、要不要挤出高度、顶点格式用哪种。

/* 1. 创建矩形几何体 */ const rectGeom = new Cesium.RectangleGeometry({ rectangle: Cesium.Rectangle.fromDegrees(113.3, 23.0, 113.4, 23.2), // 贴地区域 height: 0, // 离地 0 米——贴地 extrudedHeight: 500, // 向上挤出 500 米,形成“盒子” vertexFormat: Cesium.PerInstanceColorAppearance.VERTEX_FORMAT // 顶点格式:只保留“位置+颜色”属性,省内存,后面用实例颜色 });

小贴士

  • extrudedHeight大于height时,矩形会被“挤”成盒子。

  • vertexFormat决定每个顶点携带哪些属性(法线、UV、颜色等)。这里选“实例颜色”专用格式,省得带一堆用不到的数据。

【第 2 步】包成实例(GeometryInstance)
几何体是“模具”,实例才是“实物”。一个模具可以批量生产无数个实物,每个实物还能刷不同颜色。

/* 2. 创建几何实例,并给它刷颜色 */ const instance = new Cesium.GeometryInstance({ geometry: rectGeom, // 上面做的模具 attributes: { // 实例颜色属性:绿色半透明 color: Cesium.ColorGeometryInstanceAttribute.fromColor( Cesium.Color.GREEN.withAlpha(0.5)) } });

注意:
Cesium.ColorGeometryInstanceAttribute.fromColor是把普通颜色对象转成“实例属性”专用格式,别直接扔裸颜色进去。

【第 3 步】配外观(Appearance)
外观 = 材质 + 着色器 + 渲染状态。这里我们选“实例颜色外观”,意思是“颜色直接用实例里刷好的,不再贴纹理”。

/* 3. 定义外观(材质) */ const appearance = new Cesium.PerInstanceColorAppearance({ flat: true, // 关闭光照,颜色纯纯的,不受太阳角度影响 translucent: true // 允许半透明,方便看底层地形 });

【第 4 步】创建图元(Primitive)
把“实例”和“外观”合并成真正可渲染的“图元”。

/* 4. 生成图元(类似 Three.js 的 Mesh) */ const rectPrimitive = new Cesium.Primitive({ geometryInstances: instance, // 实物 appearance: appearance // 外观 });

【第 5 步】扔进场景

/* 5. 加入场景 */ viewer.scene.primitives.add(rectPrimitive);

三、小结:Entity vs Primitive

  • Entity:封装厚,代码少,适合快速出活。

  • Primitive:步骤多,粒度高,适合“想怎么画就怎么画”——顶点、索引、着色器、渲染状态全由你定。
    今天先开个头,后面我们拿 Primitive 写自定义着色器,做烟雾、水流、建筑生长动画,再慢慢感受它的威力。

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

MIFARE Classic Tool终极指南:2025年如何快速掌握NFC标签操作?

还在为NFC标签操作而烦恼吗?MIFARE Classic Tool作为Android平台最强大的免费开源NFC应用,让你轻松读取、写入、分析MIFARE Classic RFID标签。无论你是RFID技术新手还是专业开发者,这款工具都能帮你解决实际应用中的各种难题。 【免费下载链…

作者头像 李华
网站建设 2026/6/22 21:13:43

Wan2.2-T2V-A14B模型在糖尿病管理教育视频中的生活化呈现

Wan2.2-T2V-A14B模型在糖尿病管理教育视频中的生活化呈现技术演进与医疗内容生产的范式变革 当一位糖尿病患者打开手机APP,看到一个和自己年龄相仿、穿着相似的“虚拟邻居”正在厨房里用橄榄油炒西兰花,并认真记录血糖值时,那种代入感远比传统…

作者头像 李华
网站建设 2026/6/22 17:48:29

Markn轻量级Markdown查看器:提升文档阅读体验的终极指南

Markn轻量级Markdown查看器:提升文档阅读体验的终极指南 【免费下载链接】markn Lightweight markdown viewer. 项目地址: https://gitcode.com/gh_mirrors/ma/markn 你是否曾经在编写Markdown文档时,频繁在编辑器和预览模式之间切换而感到困扰&a…

作者头像 李华
网站建设 2026/6/22 14:17:30

大数据精准获客开启数据驱动的获客新篇章

大数据精准获客开启数据驱动的获客新篇章在数字经济时代,传统的获客方式已难以满足企业快速增长的需求。大数据精准获客作为一种创新手段,通过深度挖掘和分析海量用户数据,实现广告投放和营销策略的精准化。这一模式不仅大幅提升了获客效率&a…

作者头像 李华
网站建设 2026/6/23 18:56:32

ReplayBook终极指南:英雄联盟回放管理与数据分析完整教程

ReplayBook终极指南:英雄联盟回放管理与数据分析完整教程 【免费下载链接】ReplayBook Play, manage, and inspect League of Legends replays 项目地址: https://gitcode.com/gh_mirrors/re/ReplayBook 作为一名英雄联盟玩家,你是否曾经为找不到…

作者头像 李华
网站建设 2026/6/23 18:54:19

Wan2.2-T2V-A14B能否生成带有品牌专属开场动画的标准化输出?

Wan2.2-T2V-A14B能否生成带有品牌专属开场动画的标准化输出? 在数字营销节奏日益加快的今天,品牌方对内容生产效率的要求已经达到了前所未有的高度。一条宣传片从创意到上线,过去需要数周甚至数月,而现在,用户期望的是…

作者头像 李华