现代计算机图形学笔记(五)——深度测试、着色

可见性与遮挡(Z-buffering)

根据常识,我们很容易的想到画家在作画的时候如何体现遮挡。在作画时一般都是先画远处的物体,之后再画近处的物体,这样画出的画就可以体现出遮挡,该算法称为画家算法

image-20210331172208489

画家算法需要先对所有物体的深度进行排序(最少需要 n log ⁡ n n\log n nlogn的时间复杂度),然后依次按顺序画在屏幕上(光栅化)。画家算法虽然思想简单,但并不能解决所有的遮挡问题,比如下图的情况

image-20210331172717046

为了解决画家算法的缺点,在图形学中引入了深度缓存算法(Z-Buffer)。

Z-Buffer算法同时维护一个渲染图(Rendering)和深度图(Depth / Z buffer),如果某一三角形深度较浅,则在光栅化时就会遮挡到之前画的像素。下图是Z-Buffer算法维护的两张图,右侧的是深度图,即物体中的三角形距离我们越近颜色就越黑,越远颜色就越白。

image-20210331175205890

在算法处理到其他物体时,Z-Buffer算法会根据当前物体深度信息更新渲染结果并更新深度图。算法的伪代码大致如下

// 初始时,zbuffer数组为∞
for (each triangle T)
	for (each sample (x,y,z) in T)
		if (z < zbuffer[x,y]) // closest sample so far
			framebuffer[x,y] = rgb; // update color
			zbuffer[x,y] = z; // update depth
		else
			; // do nothing, this sample is occluded

图解过程:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值