尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Cesium 海量面线教程

Cesium 海量面线教程
📅 发布时间:2026/6/24 3:45:34

海量面线 ·Mass Polygons & Polylines· ▶ 在线运行案例

  • 案例合集:三维可视化功能案例(threehub.cn)
  • 开源仓库github地址:https://github.com/z2586300277/three-cesium-examples
  • 400个案例代码:网盘链接

你将学到什么

  • GeometryInstance收集大量面/线几何
  • 单个Primitive一次 draw 多种 instance
  • PerInstanceColorAppearance/PolylineColorAppearance

效果说明

随机生成10000个三角形面 + 对应边框线,红绿交替填充,白线描边。

核心概念

合批模式

// 收集阶段

faceCollection.instances.push(new Cesium.GeometryInstance({ geometry: new Cesium.PolygonGeometry({ polygonHierarchy: new Cesium.PolygonHierarchy( Cesium.Cartesian3.fromDegreesArray(positions) ), height: 0, vertexFormat: Cesium.PerInstanceColorAppearance.VERTEX_FORMAT, }), attributes: { color: Cesium.ColorGeometryInstanceAttribute.fromColor(color), }, id: 'face' + i, }));

// 提交阶段 — 一个 Primitive 渲染全部面 viewer.scene.primitives.add(new Cesium.Primitive({ geometryInstances: faceCollection.instances, appearance: new Cesium.PerInstanceColorAppearance({ closed: true }), }));

线集合同理,用PolylineGeometry+PolylineColorAppearance。

positions 格式

本案例positions为[lon1, lat1, lon2, lat2, lon3, lat3]三角面三顶点(度)。

实现步骤

  • 封装faceCollection/lineCollection带add()方法 push instance
  • 循环 10000 次随机经纬生成三角
  • callback 结束后各 add 一个 Primitive
  • 代码要点

    import * as Cesium from 'cesium'

    const box = document.getElementById('box')

    const viewer = new Cesium.Viewer(box, {

    animation: false,//是否创建动画小器件,左下角仪表

    baseLayerPicker: false,//是否显示图层选择器,右上角图层选择按钮

    baseLayer: Cesium.ImageryLayer.fromProviderAsync(Cesium.ArcGisMapServerImageryProvider.fromUrl('https://server.arcgisonline.com/arcgis/rest/services/World_Imagery/MapServer')),

    fullscreenButton: false,//是否显示全屏按钮,右下角全屏选择按钮

    timeline: false,//是否显示时间轴

    infoBox: false,//是否显示信息框

    })

    setFaceCollection(viewer, (faceCollection, lineCollection) => {

    for (var i = 0; i < 10000; i++) {

    var longitude = Math.random() * 360 - 180;

    var latitude = Math.random() * 180 - 90;

    var positions = [longitude, latitude, longitude + Math.random(), latitude, longitude, latitude + Math.random()];

    faceCollection.add({ positions, color: i % 2 == 0 ? 'red' : 'green', id: 'face' + i, opacity: 1 })

    lineCollection.add({ positions, color: '#fff', id: 'line' + i, width: 1.0, opacity: 0.5 })

    }

    })

    // 创建大量面和线段 function setFaceCollection(viewer, callback) {

    const lineCollection = {

    instances: [],

    add({ positions, color = '#fff', id = '', width = 1.0, opacity = 1 }) {

    if (!positions) return

    this.instances.push(new Cesium.GeometryInstance({

    geometry: new Cesium.PolylineGeometry({

    positions: Cesium.Cartesian3.fromDegreesArray(positions),

    width: width * 3,

    vertexFormat: Cesium.PolylineColorAppearance.VERTEX_FORMAT

    }),

    attributes: {

    color: Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(color).withAlpha(opacity))

    },

    id

    }))

    }

    }

    const faceCollection = {

    instances: [],

    add({ positions, color = '#fff', id = '', opacity = 1 }) {

    if (!positions) return

    this.instances.push(new Cesium.GeometryInstance({

    geometry: new Cesium.PolygonGeometry({

    polygonHierarchy: new Cesium.PolygonHierarchy(Cesium.Cartesian3.fromDegreesArray(positions)),

    height: 0,

    vertexFormat: Cesium.PerInstanceColorAppearance.VERTEX_FORMAT

    }),

    attributes: {

    color: Cesium.ColorGeometryInstanceAttribute.fromColor(Cesium.Color.fromCssColorString(color).withAlpha(opacity))

    },

    id

    }))

    }

    }

    if (callback) callback(faceCollection, lineCollection)

    // 增加面集合到场景中 viewer.scene.primitives.add(

    new Cesium.Primitive({

    geometryInstances: faceCollection.instances,

    appearance: new Cesium.PerInstanceColorAppearance({

    closed: true

    })

    })

    )

    // 增加线集合到场景中 viewer.scene.primitives.add(new Cesium.Primitive({

    geometryInstances: lineCollection.instances,

    appearance: new Cesium.PolylineColorAppearance()

    }))

    }

    完整源码:GitHub

    小结

    • 本文提供海量面线完整 Cesium.js 源码与在线 Demo,建议先运行案例再改 uniform/参数做二次实验
    • 更多 Cesium.js 实战案例见 three-cesium-examples 合集 与 GitHub 开源仓库

相关新闻

  • 5分钟解锁Foobar2000的逐字歌词魔法:让音乐拥有灵魂字幕
  • KMS_VL_ALL_AIO:终极Windows和Office智能激活完整指南
  • 音乐自由革命:一键解锁加密音频的终极方案

最新新闻

  • 张量退化∃R完全性:超行列式计算与确定性算法的理论障碍
  • 机器人控制新范式:ReconVLA如何通过不确定性引导与故障感知提升系统鲁棒性
  • 数据分析师的终结?Code Interpreter 与 Agent
  • DALC-CT:基于指令追踪的恒定时间验证工具原理与实践
  • Transformer状态跟踪困境:前馈网络无状态性与循环架构的潜力
  • 我的AI辅助开发工具链2026版:从编码助手到工业视觉检测的全栈实践

日新闻

  • 终极指南:如何用shadPS4在电脑上免费畅玩PS4游戏
  • 打造个性化Instagram Clone:主题定制与用户体验优化技巧
  • 未来展望:RoseTTAFold-All-Atom的发展路线图与社区支持资源汇总

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号