计算机图形学·21 梁友栋-Barsky直线裁剪算法与三维直线裁剪

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

1、对于上讲的GH和IJ无法区分的问题,我们考虑线段的参数化表示:p(α) = (1-α)p1+ αp2,其中1≥α≥0。参数表示的优点有普适性、几何意义明确、参数取值范围明确。在计算出来线段所在直线与窗口各边交点对应的α值后,我们可以通过这些参数值的顺序区分出各种情形:

按照参数方向,进行比较,是否重叠:

①考察2个起始边交点的最大值,参数表示

②考察2个终止边交点的最小值,参数表示

优势是和Cohen-Sutherland 算法一样很简单地接受或拒绝,并且应用α值使得不必要像Cohen-Sutherland算法那样反复应用代码,最多4次除法。

2、补充Angel教材没讲清楚的地方:

算法的基本思想其实是从A、B和P1三点中找出最靠近P2的点(图中这里为 P1点)、从C、D和P2三点中找出最靠近P1的点(图中这里为 C 点)。那么,P1C 就是P1P2线段上的可见部分。

如果点(x,y)满足:XWmin≤x≤XWmax、YWmin≤y≤YWmax,那么这个点在窗口内。下面,按参数化形式写出该式的裁剪条件:

这四个不等式的含义显然还是大于左边、小于右边、大于下边、小于上边。

pk非零时,不等式就可以变成u≤qk/pk或u≥qk/pk。如果把每条窗边看成有一个指向外侧的单位法向量nk(比如左边的外法线指向左:(−1,0)),那么可以把pk写成点积:pk=nk⋅d,也就是说pk告诉了你线段方向d在相对于该边外法线上的投影。

u=qk/pk的这个u就是线与该边相交的参数位置(如果交点在参数区间内的话就是实际的交点),如果pk<0(进入边),则u给出一个下界,反之则给出一个上界。


3、Cohen-Sutherland 算法和梁友栋-Barsky算法,这二种算法也可以推广到三维的情形。相比之下,一些其他高效的二维算法不能扩展到三维情形。

在三维空间中一般的裁剪需要计算线段与任意平面的交点,其中,求交需要6次乘法运算和1次浮点除法运算。

规范化过程是视图生成的一部分(在裁剪前进行)。在规范化后,我们相对于正平行六面体(立方体)进行裁剪,这时典型的求交计算只需要一次浮点减法,例如:是否x -- xmax > 0?

相关推荐
想用offer打牌2 分钟前
Reasoning + Acting: ReAct范式与ReAct Agent
人工智能·后端·llm
老蒋新思维3 分钟前
创客匠人分享:从“个人品牌”到“智能系统”,创始人IP如何穿越变现周期?
网络·人工智能·网络协议·tcp/ip·重构·创始人ip·创客匠人
KingRumn4 分钟前
Linux信号之信号安全
linux·算法
汉克老师5 分钟前
小学生0基础学大语言模型应用(第0课 课前准备)
人工智能·语言模型·自然语言处理·小学生0基础学习大语言模型
智驱力人工智能6 分钟前
从合规到习惯 海上作业未穿救生衣AI识别系统的工程实践与体系价值 未穿救生衣检测 AI救生衣状态识别 边缘计算救生衣监测设备
人工智能·深度学习·opencv·算法·目标检测·边缘计算
猎板PCB黄浩7 分钟前
高多层线路板工厂专业选型指南:全流程评估体系与猎板适配场景解析
大数据·人工智能·算法·pcb
悟道心9 分钟前
2.自然语言处理NLP - 文本预处理
人工智能·自然语言处理
霖大侠10 分钟前
Squeeze-and-Excitation Networks
人工智能·算法·机器学习·transformer
tangjunjun-owen24 分钟前
DINOv3 demo
python·深度学习·机器学习
天竺鼠不该去劝架27 分钟前
财务自动化怎么做?财务RPA选型清单与路径
人工智能·科技·自动化