首页
社区
课程
招聘
[作品提交]DDA与Bresenham直线算法
2008-6-30 18:14 7691

[作品提交]DDA与Bresenham直线算法

2008-6-30 18:14
7691
算法分析
1.DDA法画线段
端点位置间水平和垂直差值赋给参数dx和dy。绝对值的参数参数steps的值。从像素位置(Xa,Ya)开始,确定沿线段生成下一个像素位置的每一步所需的偏移量,并循环上述过程steps次。

Bresenham画线法与中点画线法相似,,它通过每列象素中确定与理想直线最近的象素来进行直线的扫描的转换的。通过各行,各列的象素中心构造一组虚拟网格线的交点,然后确定该列象素中与此交点最近的的象素。该算法的巧妙之处在于可以采用增量计算,使得对于每一列,只要检查一个误差项的符号,就可以确定该列的所求对象。三.算法设计与分析假设x列的象素已确定,其行下标为y。那么下一个象素的列坐标必为x+1。而行坐标要么不变,要么递增1。是否递增1取决于如图所示的误差项d的值。因为直线的起始点在象素中心,所以误差项d的初始值为0。X下标每增加1,d的值相应递增直线的斜率值,即d=d+k(k=y/x为直线斜率)。一旦d>=1时,就把它减去,这样保证d始终在0、1之间。当d>0.5时,直线与x+1垂直网络线交点最接近于当前象素(x,y)的右上方象素(x+1,y+1);而当d=0时,下一象素的y下标增加1,而当e〈0时,下一象素的y下标不增。E的初始值为-0.5
附件中有详细算法及图示说明

[培训]二进制漏洞攻防(第3期);满10人开班;模糊测试与工具使用二次开发;网络协议漏洞挖掘;Linux内核漏洞挖掘与利用;AOSP漏洞挖掘与利用;代码审计。

上传的附件:
收藏
点赞7
打赏
分享
最新回复 (4)
雪    币: 372
活跃值: (31)
能力值: ( LV12,RANK:410 )
在线值:
发帖
回帖
粉丝
vxin 10 2008-6-30 18:36
2
0
沙发                              .
雪    币: 266
活跃值: (50)
能力值: ( LV9,RANK:290 )
在线值:
发帖
回帖
粉丝
sislcb 7 2008-6-30 18:38
3
0
大量涌现算法作品,支持
雪    币: 156
活跃值: (23)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
sbright 2 2008-7-3 23:12
4
0
这个比较简单了,比不上台球啊,...不过我只会用c写..
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
niyanru 2008-7-15 20:56
5
0
这个程序也太简单了吧
游客
登录 | 注册 方可回帖
返回