【Cesium】在着色器中计算片元的高程

问题提出

有时候在 Cesium 上做一些效果时,需要知道片元的高程。而渲染是基于笛卡尔坐标的,没有高程这个概念。怎么在着色器中计算片元的高程呢?

基本思路

通常做法是在着色器里对深度纹理采样,将片元的深度值转换为相机坐标。然后把相机坐标转换为世界坐标,世界坐标是片元相对于地球椭球中心的偏移量,下图中假设片元的世界坐标为 (x, y, z)。用世界坐标的模减去片元对应的椭球半径就可以得到高程。但是逐片元去计算它们对应的椭球半径在着色器里不好实现,在CPU中计算相机位置处的椭球半径(下图中的 earthRadius )来近似地作为相机观察范围内所有片元对应的椭球半径从性能和实现难度上都是更优解。

图1 计算片元高程基本思路 

具体步骤

1、在CPU中计算相机所在位置对应的地球半径,作为 uniform 变量传入着色器中:相机世界坐标的模 - 相机的高程

const earthRadius = Cartesian3.magnitude(camera.positionWC) - camera.positionCartographic.height

2、在着色器中做如下转换:深度值 -> 相机坐标 -> 世界坐标,最后用片元世界坐标的模 - 相机位置对应的地球半径即可,glsl 代码如表1所示。虽然是用相机位置处的椭球半径近似替代了片元处的地球半径,但是误差很难看得出来,这种方法适用于绝大部分应用场景。

float altitude = 0.0;
float depth = czm_unpackDepth(texture2D(depthTexture, texCoords));
if (depth == 0.0) {
	altitude = czm_infinity;
}
vec4 eyeCoordinate = czm_windowToEyeCoordinates(gl_FragCoord.xy, depth);
float distance = -eyeCoordinate.z / eyeCoordinate.w;
vec4 worldCoordinate4 = czm_inverseView * eyeCoordinate;
vec3 worldCoordinate = worldCoordinate4.xyz / worldCoordinate4.w;
altitude = length(worldCoordinate.xyz) - earthRadius;

表1 glsl 中计算片元的高程 

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-01 16:42:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-01 16:42:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-01 16:42:02       82 阅读
  4. Python语言-面向对象

    2024-02-01 16:42:02       91 阅读

热门阅读

  1. 美国服务器地址和端口及密码

    2024-02-01 16:42:02       55 阅读
  2. 服务器托管与虚拟主机租用有哪些区别?

    2024-02-01 16:42:02       56 阅读
  3. footer置于页面最底部

    2024-02-01 16:42:02       48 阅读
  4. 【力扣hot100】刷题笔记Day1

    2024-02-01 16:42:02       54 阅读
  5. QT中一种隐蔽的死锁

    2024-02-01 16:42:02       51 阅读
  6. OpenGL程序管线对象 Program Pipeline Objects

    2024-02-01 16:42:02       41 阅读
  7. C++不能直接返回数组

    2024-02-01 16:42:02       44 阅读
  8. 算法训练营day19,二叉树8-2

    2024-02-01 16:42:02       56 阅读
  9. postgresql和kingbase关于模糊查询大小写兼容问题

    2024-02-01 16:42:02       42 阅读
  10. 深度学习的进展

    2024-02-01 16:42:02       55 阅读
  11. 地毯进口报关全攻略:如何高效通关

    2024-02-01 16:42:02       52 阅读
  12. element plus dialog滚动条置顶问题

    2024-02-01 16:42:02       49 阅读