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

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

2008-6-30 18:14
8222

算法分析
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
附件中有详细算法及图示说明


[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

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