Cesium三维地形渲染

// 复制代码
viewer.terrainProvider = Cesium.createWorldTerrain({
    requestWaterMask: true,   // 请求海岸线水效果
    requestVertexNormals: true // 请求光照法线数据
});

离线地形:通过CesiumTerrainProvider加载本地切片(如CTB工具生成的terrain文件夹)

viewer.terrainProvider = new Cesium.CesiumTerrainProvider({ url: './local_terrain_tiles' }); 2.场景初始化

const 复制代码
    terrainProvider: Cesium.createWorldTerrain(),
    baseLayerPicker: false // 简化基础图层选择
});

3.地形夸张效果(可选)

viewer.scene.terrainExaggeration 复制代码

二、关键技术点

  1. 地形精度优化

LOD控制 :通过viewer.scene.globe.maxScreenSpaceError降低远距离地形精度(默认2.0,值越低越精细) 裁剪优化 :启用viewer.scene.globe.depthTestAgainstTerrain确保实体与地形精准贴合 2.地形水面融合

viewer.scene.globe.oceanNormalMapUrl 复制代码
viewer.scene.globe.enableLighting = true; // 开启光照增强立体感

3.自定义地形着色器

通过CustomShader修改地形渲染效果(如夜间热力图):

const 复制代码
    uniforms: {
        u_time: { value: 0 }
    },
    fragmentShaderText: `
        void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial material) {
            float height = fsInput.attributes.positionMC.z;
            material.diffuse = mix(vec3(0,0,1), vec3(1,0,0), height/1000.0);
        }`
});
viewer.scene.globe.customShaders = [terrainShader];

三、性能优化方案

策略 | 实现方式

| 地形预加载 | viewer.scene.globe.preloadSiblings = true 提前加载相邻瓦片 | | 动态分辨率适配 | viewer.scene.dynamicScreenSpaceError = true 根据帧率自动调整细节层次 | | 地形剔除优化 | viewer.scene.camera.frustumSplits = [0.01, 0.1, 0.5, 1.0] 分级裁剪远距离地形

四、常见问题解决

  • 地形闪烁问题
    启用viewer.scene.farToNear = true 优化深度缓冲区冲突

  • 白膜地形(无纹理)
    检查地形服务是否包含availability属性,确保瓦片范围正确

  • 坐标偏移问题
    使用Cesium.Transforms.headingPitchRollToFixedFrame校正局部坐标系

    五、扩展应用

  1. 地形挖洞分析
    使用ClippingPlane切割地形剖面:
const 复制代码
viewer.scene.globe.clippingPlanes = new Cesium.ClippingPlaneCollection({ planes: [clippingPlane] });

2.动态地形修改

通过GeometryInstance实时修改地形高程:

const 复制代码
    position: Cesium.Cartesian3.fromDegrees(116.39, 39.9),
    ellipse: {
        semiMinorAxis: 5000,
        semiMajorAxis: 5000,
        height: -50 // 下压地形50米
    }
});
相关推荐
古夕10 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
Ruihong10 小时前
Vue withDefaults 转 React:VuReact 怎么处理?
vue.js·react.js·面试
YuePeng12 小时前
写了五年注解的低代码框架,2.0 决定让你连注解都不用写了
github·产品
稀土熊猫君12 小时前
一个人能做出什么开源项目?
vue.js·后端·开源
小白ai12 小时前
从"能 ping 通吗"到"为什么上不了网"——我写了一个网络故障诊断引擎
github
徐小夕14 小时前
jitword 协同文档3.2发布:打造浏览器中最强word编辑器
前端·架构·github
齐翊16 小时前
分享一个在 Claude Code 里 [同时] 用多个 ApiKey 的方法
程序员·github·agent
A_Lonely_Cat16 小时前
记一次 GitHub 幽灵协作者大清洗:强制重写 Git 历史与穿透 CDN 缓存实践
git·github
极光技术熊1 天前
Spring AI 从入门到精通:构建你的 AI 开发知识体系
后端·github
用户39483951075531 天前
怎么让我的 Agent 真正"懂"我?——关于记忆、经验学习与预测的一些真实体验
github