【计算机图形学】Cohen-Sutherland裁剪算法+中点分割直线段裁剪算法

Cohen-Sutherland裁剪算法

编码规则

Cohen-Sutherland算法又叫编码裁剪算法,主要将界面分为9个编码区
编码区域

4位二进制编码D3 D2 D1 D0
x < xwl ? D0 = 1 : D0 = 0
x > xwr ? D1 = 1 : D0 = 0
y > ywb ? D2 = 1 : D0 = 0
y < ywt ? D3 = 1 : D0 = 0
(三目运算符)
总结一下就是 : 裁剪窗口内编码为0,外为1 。只要有1,必在裁剪窗口外。

具体步骤

我们对线段的两个端点P1,P2进行编码。设其为code1code2。线段与窗口的位置分为以下三种情况:

1.code1 | code2 = 0(按位或 为0)表示 code1 = code2 = 0,说明两个端点都在窗口内,此时可以取整条线段。
简取
2.code1 & code2 != 0 (按位与 不为0)表示code1 和 code2 至少某一位同为1,两个端点在窗口外的同一侧,说明这时整条线段不在裁剪框内,丢弃。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值