Cesium中开启等高线渲染

简介: 最近接到一个需求,需要在Cesium中基于实时地形开启等高线效果,让用户可以看到真实效果。

最近接到一个需求,需要在Cesium中基于实时地形开启等高线效果,让用户可以看到真实效果。在网上看了一些资料,许多都是需要付费的或者不提供源码,于是在cesium官网找到了示例代码,以下将具体介绍如何在cesium中进行集成。

第一步:设置viewer开启光照

viewer.scene.globe.enableLighting=true;

第二步:定义等高线初始值

varminHeight=-414.0; // approximate dead sea elevationvarmaxHeight=8777.0; // approximate everest elevationvarcontourColor=Cesium.Color.RED.clone();
varcontourUniforms= {};
varshadingUniforms= {};

第三步:定义相关处理函数

functiongetElevationContourMaterial() {
// Creates a composite material with both elevation shading and contour linesreturnnewCesium.Material({
fabric: {
type: "ElevationColorContour",
materials: {
contourMaterial: {
type: "ElevationContour",
        },
elevationRampMaterial: {
type: "ElevationRamp",
        },
        },
components: {
diffuse:
"contourMaterial.alpha == 0.0 ? elevationRampMaterial.diffuse : contourMaterial.diffuse",
alpha:
"max(contourMaterial.alpha, elevationRampMaterial.alpha)",
        },
      },
translucent: false,
      });
    }
varelevationRamp= [0.0, 0.045, 0.1, 0.15, 0.37, 0.54, 1.0];
varslopeRamp= [0.0, 0.29, 0.5, Math.sqrt(2) /2, 0.87, 0.91, 1.0];
varaspectRamp= [0.0, 0.2, 0.4, 0.6, 0.8, 0.9, 1.0];
functiongetColorRamp(selectedShading) {
varramp=document.createElement("canvas");
ramp.width=100;
ramp.height=1;
varctx=ramp.getContext("2d");
varvalues;
if (selectedShading==="elevation") {
values=elevationRamp;
      } elseif (selectedShading==="slope") {
values=slopeRamp;
      } elseif (selectedShading==="aspect") {
values=aspectRamp;
      }
vargrd=ctx.createLinearGradient(0, 0, 100, 0);
grd.addColorStop(values[0], "#000000"); //blackgrd.addColorStop(values[1], "#2747E0"); //bluegrd.addColorStop(values[2], "#D33B7D"); //pinkgrd.addColorStop(values[3], "#D33038"); //redgrd.addColorStop(values[4], "#FF9742"); //orangegrd.addColorStop(values[5], "#ffd700"); //yellowgrd.addColorStop(values[6], "#ffffff"); //whitectx.fillStyle=grd;
ctx.fillRect(0, 0, 100, 1);
returnramp;
    }
// The viewModel tracks the state of our mini application.varviewModel= {
enableContour: false,
contourSpacing: 50.0,
contourWidth: 2.0,
selectedShading: "none",
changeColor: function () {
contourUniforms.color=Cesium.Color.fromRandom(
        { alpha: 1.0 },
contourColor      );
      },
    };
// Convert the viewModel members into knockout observables.Cesium.knockout.track(viewModel);
// Bind the viewModel to the DOM elements of the UI that call for it.vartoolbar=document.getElementById("toolbar");
Cesium.knockout.applyBindings(viewModel, toolbar);
functionupdateMaterial() {
varhasContour=viewModel.enableContour;
varselectedShading=viewModel.selectedShading;
varglobe=viewer.scene.globe;
varmaterial;
if (hasContour) {
if (selectedShading==="elevation") {
material=getElevationContourMaterial();
shadingUniforms=material.materials.elevationRampMaterial.uniforms;
shadingUniforms.minimumHeight=minHeight;
shadingUniforms.maximumHeight=maxHeight;
contourUniforms=material.materials.contourMaterial.uniforms;
      }else {
material=Cesium.Material.fromType("ElevationContour");
contourUniforms=material.uniforms;
      }
contourUniforms.width=viewModel.contourWidth;
contourUniforms.spacing=viewModel.contourSpacing;
contourUniforms.color=contourColor;
    } elseif (selectedShading==="elevation") {
material=Cesium.Material.fromType("ElevationRamp");
shadingUniforms=material.uniforms;
shadingUniforms.minimumHeight=minHeight;
shadingUniforms.maximumHeight=maxHeight;
    } 
if (selectedShading!=="none") {
shadingUniforms.image=getColorRamp(selectedShading);
    }
globe.material=material;
  }
updateMaterial();
Cesium.knockout.getObservable(viewModel, "enableContour").subscribe(function (newValue) {
updateMaterial();
    });
Cesium.knockout.getObservable(viewModel, "contourWidth").subscribe(function (newValue) {
contourUniforms.width=parseFloat(newValue);
    });
Cesium.knockout.getObservable(viewModel, "contourSpacing").subscribe(function (newValue) {
contourUniforms.spacing=parseFloat(newValue);
    });
Cesium.knockout.getObservable(viewModel, "selectedShading").subscribe(function (value) {
updateMaterial();
    });

第四步:绑定页面控件

<divclass="demo-container"><label><inputtype="radio"name="shadingMaterials"value="none"data-bind="checked: selectedShading">无渲染</label> <label><inputtype="radio"name="shadingMaterials"value="elevation"data-bind="checked: selectedShading">高程渲染</label></div><divclass="demo-container"><div><label><inputtype="checkbox"data-bind="checked: enableContour">等高线</label></div><div>高程<inputstyle="width: 136px; float: left; width: 100px;"type="range"min="1.0"max="500.0"step="1.0"data-bind="value: contourSpacing, valueUpdate: 'input', enable: enableContour"><spandata-bind="text: contourSpacing"></span>m</div><div>线宽<inputstyle="width: 125px; float: left; width: 100px;"type="range"min="1.0"max="10.0"step="1.0"data-bind="value: contourWidth, valueUpdate: 'input', enable: enableContour"><spandata-bind="text: contourWidth"></span>px</div><div><buttontype="button"data-bind="click: changeColor, enable: enableContour">颜色</button></div></div>

完成上述代码后,运行页面即可看到如下效果:

image.png

点击等高线,即可看到效果

image.png

还可以开启高程渲染效果:

image.png

通过以上步骤即可完成cesium下等高线的展示。

目录
相关文章
|
定位技术 API 网络架构
地图图层接入:从mapbox转向cesium
由于地图坐标系的不统一,地图图商提供的图层服务也各有特色,在图层对接的开发过程中常会遇到许多坑,从二维图层到三维图层,地图引擎mapbox再到cesium,本文将分享笔者在近期地图图层接入过程中总结的一些经验。
3696 10
|
2月前
Cesium绘制透明光圈
这篇文章介绍了如何在Cesium中绘制具有透明度的圆形光圈,并提供了实现这一功能的具体代码和步骤。
117 3
Cesium绘制透明光圈
|
2月前
|
定位技术
Cesium修改地球的贴图为视频或者图片
这篇文章说明了如何在Cesium中修改地球的贴图,替换为自定义的图像或视频纹理。
119 1
Cesium修改地球的贴图为视频或者图片
|
2月前
cesium自带的组件显示与隐藏
这篇文章讲解了如何控制Cesium中自带组件的显示与隐藏,包括了各个组件的属性名称及其对应的显示隐藏操作方法。
109 0
cesium自带的组件显示与隐藏
|
2月前
ThreeJs创建圆环
这篇文章介绍了如何在Three.js中创建一个圆环(torus),包括设置圆环的几何形状、材质以及将其添加到场景中的具体步骤。
63 0
ThreeJs创建圆环
|
2月前
|
开发框架 前端开发 定位技术
在Mars3d实现cesium的ImageryLayer自定义瓦片的层级与原点
通过上述步骤,您可以成功在Mars3D平台上集成Cesium,并实现自定义瓦片图层的层级与原点配置。这一过程不仅提升了地图应用的定制化程度,也为处理特定数据集和优化用户体验提供了灵活的解决方案。在实际开发过程中,不断测试和微调是确保图层展示效果与性能的关键。
150 0
|
4月前
|
存储 缓存 数据可视化
Cesium渲染一帧中用到的图形技术
Cesium渲染一帧中用到的图形技术
141 0
Cesium渲染一帧中用到的图形技术
cesium加载魔方立方体
【8月更文挑战第16天】
|
4月前
|
缓存 前端开发 定位技术
Cesium加载Mapbox自定义地图
Cesium加载Mapbox自定义地图
134 0
|
5月前
|
Web App开发 前端开发
canvas系列教程04 —— 渐变、阴影、路径、状态、Canvas对象、图形重叠模式
canvas系列教程04 —— 渐变、阴影、路径、状态、Canvas对象、图形重叠模式
492 0