Cesium快速入门26:加载渲染GeoJson数据

用 Cesium 做地理信息可视化,最常见的数据来源就是 GeoJSON

今天带你把"四川地图"整个搬进来,一行代码加载,一行代码上色,比用 Three.js 自己解析省十倍功夫。


一、GeoJSON 长啥样?

GeoJSON 里存的是"经纬度 + 属性",可以是省界、道路、点位,甚至航拍区域。

阿里 DataV 免费提供了全国省市区数据,今天拿"四川省"练手:

地址:https://datav.aliyun.com/portal/school/atlas/area_selector

(想换广东、江苏、道路网,同理复制链接即可)


二、最简加载:两步到位

  1. 把下载好的 四川省.geojson 扔进项目 /geojson/ 文件夹;

  2. 两行代码直接渲染:

    /* 1. 加载 GeoJSON(返回 Promise) */
    const scGeoJson = Cesium.GeoJsonDataSource.load('./geojson/四川省.geojson');

    /* 2. 添加到场景 */
    viewer.dataSources.add(scGeoJson);

刷新地球------四川省


三、等加载完成?用 await 更直观

load 本质是 Ajax,想等数据就位后再统一处理,可以顺手 await:

复制代码
const scGeoJson = await Cesium.GeoJsonDataSource.load('./geojson/四川省.geojson');
viewer.dataSources.add(scGeoJson);

这样后续想缩放、染色、弹窗,都能立刻拿到完整对象。


四、一次配好色:stroke、fill、线宽都能传

Cesium 把 GeoJSON 所有样式参数都包成配置项,加载时一起丢进去即可:

复制代码
const scGeoJson = Cesium.GeoJsonDataSource.load('./geojson/四川省.geojson', {
  stroke: Cesium.Color.HOTPINK,     // 边线颜色
  fill: Cesium.Color.PINK.withAlpha(0.2), // 填充颜色
  strokeWidth: 3,                   // 边线像素宽
  markerSymbol: '?'                 // 如果是点,就显示问号图标
});

viewer.dataSources.add(scGeoJson);

效果:粉红边 + 半透明桃心填充,比默认好看一百倍。


五、跟 Three.js 比,快在哪里?

步骤 Three.js Cesium
解析文件 手写 JSON 遍历 一行 load 自动完成
坐标转换 自己转经纬度→世界 内部自动转
面/线生成 手动搭 Geometry 自动根据类型生成
渲染 自己写材质 可选默认或自定义

一句话:Cesium 把"解析→转换→生成→渲染"全链路封装好,我们只需把 GeoJSON 文件喂给它。


六、小结与拓展

  • 任何 GeoJSON(省界、道路、楼栋)都用同一套路:load→add

  • 样式在加载时一次配完,后期也可通过 entities 数组再细调。

  • 数据更新?dataSources.removeAll() 清掉旧数据,重新 load 新文件即可。

下节课,我们给这些行政区做"悬浮高亮 + 点击弹窗",让地图真正"活"起来。

相关推荐
UltraLAB-F1 天前
GPU显存不足时的分配策略:渲染与仿真的显存争夺战解决方案
图像处理·算法·3d·ai·硬件架构
康谋自动驾驶1 天前
3DGS 与 OpenMATERIAL:场景表示与材质标准的分层协同
3d·材质·仿真·3dgs·openmaterial
小白天下第一1 天前
java+三角测量(两个工业级)+人体3d骨骼关键点获取(yolov8+HRNET_w48_2d)
java·yolo·3d·三角测量
Yao.Li1 天前
自定义数据集 Pose 生成与坐标系约定内部文档
人工智能·3d·具身智能
做cv的小昊2 天前
结合代码读3DGS论文(12)——NeurIPS 2024 Spotlight 3DGS经典Backbone工作3DGS-MCMC论文及代码解读
论文阅读·计算机视觉·3d·图形渲染·游戏开发·计算机图形学·3dgs
云飞云共享云桌面2 天前
SolidWorks三维设计不用单独买电脑,1台服务器10个设计用
运维·服务器·数据库·3d·电脑
syncon122 天前
手机液晶显示屏薄膜电路开路短路检测及液晶线路激光修复原理
科技·3d·制造
三维搬砖者3 天前
AI 解密大厂 Three.js 三维引擎开发 03|从经纬度到三维世界的坐标解码
webgl·three.js
2401_863801463 天前
如何在Blender中压缩/缩小3D模型的尺寸GLB、GLTF、DAE、FBX、OBJ......
3d·blender