计算机图形学·25 消隐2 区域子分算法-光线投射算法

本文为记录专业课计算机图形学的部分笔记,参考教材为Angel的第八版交互式计算机图形学------基于WebGL 2.0的自顶向下方法。

1、区域子分算法的由来:①Z缓存器算法,将像素孤立来考虑,未利用相邻像素之间存在的属性的连贯性,即区域的连贯性,所以算法效率不高;②区间扫描线Z缓存器算法仅利用了扫描线的连贯性。实际上,可见多边形至少覆盖了绘图窗内的一块区域,如果能将这类区域找出来,则避免了在每个像素处计算深度值,消隐问题也就解决了。

基本思路:

首先,将场景中的多边形投影到绘图窗口内(假设它为边长为k的正方形)

然后,判断窗口/多边形关系是否足够简单:

若是足够简单,则按简单关系来处理,并且算法结束;

否则将窗口进一步分为四块(左上,右上,左下,右下)。对此四个小窗口重复上述过程,直到窗口仅为一个像素大小。

此时可能有多个多边形覆盖了该像素,计算它们的深度值,以最靠近观察点的颜色显示该像素即可。

何谓"窗口/多边形关系足够简单?"

存在下列情况之一,即可称为窗口/多边形关系足够简单:

①窗口为空,即多边形与窗口的关系是分离的------取背景色,图中(a)

②窗口仅内含一个多边形,或者一个多边形与窗口相交------此时先对多边形投影进行裁剪,再对裁剪结果进行分别上色,图中(b)和(c)

③有一个多边形的投影包围了窗口,并且它是最靠近观察点的------,以该多边形颜色上色,图中(d)

如何判别多边形与窗口的分离与包围关系?可以使用例如编码方法------区域编码:多边形顶点的编码/多边形边的编码/多边形的编码。

2、光线投射算法(Ray casting)基本思路:

①将通过绘图窗口内每一个像素的投影线与场景中的所有多边形求交。

②如果有交点,用深度值z最大 (视点最近/小的) 的交点所属的多边形的颜色显示相应的像素;

③如果没有交点,说明没有多边形的投影覆盖此像素,用背景色显示即可。

相关推荐
Tisfy17 小时前
LeetCode 3507.移除最小数对使数组有序 I:纯模拟
算法·leetcode·题解·模拟·数组
才思喷涌的小书虫17 小时前
打破 3D 感知瓶颈:OVSeg3R 如何推动开集 3D 实例分割应用落地
人工智能·目标检测·计算机视觉·3d·具身智能·数据标注·图像标注
努力学算法的蒟蒻17 小时前
day63(1.22)——leetcode面试经典150
算法·leetcode·面试
言之。17 小时前
2026 年 1 月 15 日 - 21 日国内外 AI 科技大事及热点深度整理报告
人工智能·科技
weisian15118 小时前
进阶篇-4-数学篇-3--深度解析AI中的向量概念:从生活到代码,一文吃透核心逻辑
人工智能·python·生活·向量
这儿有一堆花18 小时前
AI视频生成的底层逻辑与技术架构
人工智能·音视频
Fairy要carry18 小时前
面试-Encoder-Decoder预训练思路
人工智能
杭州泽沃电子科技有限公司18 小时前
“不速之客”的威胁:在线监测如何筑起抵御小动物的智能防线
人工智能·在线监测
梵尔纳多18 小时前
第一个 3D 图像
c++·图形渲染·opengl
MistaCloud18 小时前
Pytorch进阶训练技巧(二)之梯度层面的优化策略
人工智能·pytorch·python·深度学习