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

Cesium 海量面线教程

海量面线 ·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/lineCollectionadd()方法 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 开源仓库
http://www.jsqmd.com/news/1070399/

相关文章:

  • 2026年微信小程序需不需要搭建服务器?
  • 破解AI代码能力评测迷局:LiveCodeBench如何重塑无污染评估体系
  • AI 智能电动窗帘智能功率覆盖 H 桥电机驱动、电源管理完整选型方案
  • 3种简单方法彻底卸载Microsoft Edge:EdgeRemover完整使用指南
  • 5分钟解锁Foobar2000的逐字歌词魔法:让音乐拥有灵魂字幕
  • 三色交响乐:Alibaba Dragonwell17 如何重写云原生Java性能方程式
  • 存储带宽瓶颈正在扼杀大模型训练效率,SITS 2026实测数据曝光:仅19%企业通过存储成熟度L4认证
  • 挖鼻孔背后隐藏的秘密
  • 如何用AppleRa1n在5分钟内绕过iOS 15-16激活锁:开发者实战指南
  • 植物大战僵尸终极修改器PvZ Tools:重新定义经典游戏的无限可能
  • AltSnap:5分钟学会Windows窗口管理黑科技,效率提升300%
  • GRETNA 2.0.0脑网络分析工具包:从数据处理到统计检验的完整实战指南
  • 5分钟掌握Windows和Office永久激活:KMS智能脚本完整指南
  • 终极指南:如何用Harepacker复活版自由定制你的MapleStory游戏世界
  • 音乐自由革命:一键解锁加密音频的终极方案
  • 四川展厅设计公司有哪些值得推荐的公司?这三家值得关注
  • 现在不做AI成熟度评估,3个月后将多花217%成本重构:基于2026奇点大会217家样本企业的ROI衰减实证分析
  • Spek音频频谱分析器:免费开源的音频可视化终极指南
  • 大龄程序员的现状和出路是什么?
  • 脑网络分析不再难!GRETNA 2.0.0:MATLAB图论分析的神奇工具箱
  • AI伦理成熟度建设,为什么83%的企业卡在L2→L3跃迁?SITS 2026最新评估数据+3类典型失分场景诊断
  • 终极免费AI虚拟背景解决方案:OBS Background Removal完整指南
  • 你的AI中台正在“伪成熟”?——用奇点大会认证的12项可观测性探针,5分钟完成真实成熟度快筛
  • 狼享Lite版(LAN Share Lite) 教程
  • 终极指南:2分钟搞定iPhone在Windows的USB网络共享驱动问题
  • webpack:前端模块打包的基石
  • AI工程方法论成熟度:2026奇点大会唯一授权落地工具包(含成熟度自评SaaS链接+审计 checklist)
  • ZIP文件打不开?不用下软件,键盘敲几行命令就能解压
  • 抽奖小程式
  • 性价比高的中高端整装家居公司