本文主要是介绍在unity里实现Hi-z occlusion,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
先看效果:
可以看到,随着相机的移动,被相机平截头和深度遮挡的物体,就会被剔除。因为考虑到计算精度的问题,所以也会有个别物体漏过去,这个只能暂时忽略。
hi-z算法流程如下:
1、使用上一帧场景深度buffer,构造分层深度图像 hi-z map.这些分层图像实对深度缓冲区进行mip-map,每个mip级别中,包含此块中的最大深度值
2、将当前待绘制的物体分为两个集合:集合1,上一帧已有的物体,2当前帧新增的物体
3、先处理集合1,对集合1中的每个物体,使用包围盒计算其是否可见
4、根据第三步的结构,更新深度buffer
5、处理集合2,使用新的深度图,对集合2进行剔除
6、绘制集合2中可见的物体
unity如果完全实现上述算法的话,需要使用urp或者hdrp。由于我项目并没有使用urp,所以无法将物体分两批进行绘制。可以采用简略的方法,即不分成两个集合,都使用上一帧深度进行判断即可。这样在转动的时候,会有一些边角地区出现猛的出现一个物体,
但是项目中使用了运动模糊和其它的一些小技巧,来弥补掉这个问题,看起来也还行。而且降低了多次调用compute shader的消耗。
这篇关于在unity里实现Hi-z occlusion的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!