任意斜率的中点画线算法
2017-03-17 22:54
106 查看
一、中点画线算法的基本原理
在画直线的过程中,当前像素点P(xp,yp),则下一个点与直线最接近的像素只能是P1或者P2,即P点的正右方或者右上角的点。设M(xp+1,yp+0.5)为P1与P2的中点,Q为与理想直线与x=xp+1线相交的点。当M在Q的下方时,则P2应为下一像素点;当M在Q的上方时,则P1应为下一像素点。
设直线的表达式 F(x+y)=ax+by+c,那么我们把M的数值代入到直线表达式中即可:
当 F(x,y) = 0 ,点在直线上,任意取P1或者P2都可以;
当 F(x,y) > 0 ,点在直线上方,取P1,P1坐标为(xp+1,yp)
当 F(x,y) < 0 ,点在直线下方,取P2,P2坐标为(xp+1,yp+1)
我们只需要判断F符号,可知Q点在中点M的上方还是下方,就可以判断下一个点是P1还是P2。
二、 中点画线算法的具体分类
1. 0<=k<=1
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+1,y_p+0.5)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+1,y_p+0.5)=a(x_p+1)+b(y_p+0.5)+c
此时分两种情况:
①若d_0<0,则取P2点,即右上点;
②若d_0>0,则取P1点,即正右点。
下面对两种情况进行分别讨论:
当d0<0时,即下一像素点为P2,下下一个像素点位置为M(xp+2,yp+1.5):
d1=F(M)=F(xp+2,yp+1.5)=a(xp+1)+b(yp+0.5)+c+a+b=d0+a+b
当d0>0时,即下一像素点为P1,下下一个像素点位置为M(xp+2,yp+0.5):
d1=F(M)=F(xp+2,yp+0.5)=a(xp+1)+b(yp+0.5)+c+a=d0+a
2. -1<=k<0
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+1,y_p-0.5)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+1,y_p-0.5)=a(x_p+1)+b(y_p-0.5)+c
此时分两种情况:
①若d_0<0,则取P1点,即正右点;
②若d_0>0,则取P2点,即右下点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P1,下下一个像素点位置为M(x_p+2,y_p-0.5):
d_1=F(M)=F(x_p+2,y_p-0.5)=a(x_p+1)+b(y_p-0.5)+c+a=d_0+a
当d_0>0时,即下一像素点为P2,下下一个像素点位置为M(x_p+2,y_p-1.5):
d_1=F(M)=F(x_p+2,y_p-1.5)=a(x_p+1)+b(y_p-0.5)+c+a-b=d_0+a-b
3. K>1
1时直线的位置" title="">
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+0.5,y_p+1)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+0.5,y_p+1)=a(x_p+0.5)+b(y_p+1)+c
此时分两种情况:
①若d_0<0,则取P1点,即正上点;
②若d_0>0,则取P2点,即右上点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P1,下下一个像素点位置为M(x_p+0.5,y_p+2):
d_1=F(M)=F(x_p+0.5,y_p+2)=a(x_p+0.5)+b(y_p+1)+c+b=d_0+b
当d_0>0时,即下一像素点为P2,下下一个像素点位置为M(x_p+1.5,y_p+2):
d_1=F(M)=F(x_p+1.5,y_p+2)=a(x_p+0.5)+b(y_p+1)+c+a+b=d_0+a+b
4. K<-1
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+0.5,y_p-1)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+0.5,y_p-1)=a(x_p+0.5)+b(y_p-1)+c
此时分两种情况:
①若d_0<0,则取P2点,即右下点;
②若d_0>0,则取P1点,即正下点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P2,下下一个像素点位置为M(x_p+1.5,y_p-2):
d_1=F(M)=F(x_p+1.5,y_p-2)=a(x_p+0.5)+b(y_p-1)+c+a-b=d_0+a-b
当d_0>0时,即下一像素点为P1,下下一个像素点位置为M(x_p+0.5,y_p-2):
d_1=F(M)=F(x_p+0.5,y_p-2)=a(x_p+0.5)+b(y_p-1)+c-b=d_0-b
在画直线的过程中,当前像素点P(xp,yp),则下一个点与直线最接近的像素只能是P1或者P2,即P点的正右方或者右上角的点。设M(xp+1,yp+0.5)为P1与P2的中点,Q为与理想直线与x=xp+1线相交的点。当M在Q的下方时,则P2应为下一像素点;当M在Q的上方时,则P1应为下一像素点。
设直线的表达式 F(x+y)=ax+by+c,那么我们把M的数值代入到直线表达式中即可:
当 F(x,y) = 0 ,点在直线上,任意取P1或者P2都可以;
当 F(x,y) > 0 ,点在直线上方,取P1,P1坐标为(xp+1,yp)
当 F(x,y) < 0 ,点在直线下方,取P2,P2坐标为(xp+1,yp+1)
我们只需要判断F符号,可知Q点在中点M的上方还是下方,就可以判断下一个点是P1还是P2。
二、 中点画线算法的具体分类
1. 0<=k<=1
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+1,y_p+0.5)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+1,y_p+0.5)=a(x_p+1)+b(y_p+0.5)+c
此时分两种情况:
①若d_0<0,则取P2点,即右上点;
②若d_0>0,则取P1点,即正右点。
下面对两种情况进行分别讨论:
当d0<0时,即下一像素点为P2,下下一个像素点位置为M(xp+2,yp+1.5):
d1=F(M)=F(xp+2,yp+1.5)=a(xp+1)+b(yp+0.5)+c+a+b=d0+a+b
当d0>0时,即下一像素点为P1,下下一个像素点位置为M(xp+2,yp+0.5):
d1=F(M)=F(xp+2,yp+0.5)=a(xp+1)+b(yp+0.5)+c+a=d0+a
2. -1<=k<0
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+1,y_p-0.5)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+1,y_p-0.5)=a(x_p+1)+b(y_p-0.5)+c
此时分两种情况:
①若d_0<0,则取P1点,即正右点;
②若d_0>0,则取P2点,即右下点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P1,下下一个像素点位置为M(x_p+2,y_p-0.5):
d_1=F(M)=F(x_p+2,y_p-0.5)=a(x_p+1)+b(y_p-0.5)+c+a=d_0+a
当d_0>0时,即下一像素点为P2,下下一个像素点位置为M(x_p+2,y_p-1.5):
d_1=F(M)=F(x_p+2,y_p-1.5)=a(x_p+1)+b(y_p-0.5)+c+a-b=d_0+a-b
3. K>1
1时直线的位置" title="">
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+0.5,y_p+1)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+0.5,y_p+1)=a(x_p+0.5)+b(y_p+1)+c
此时分两种情况:
①若d_0<0,则取P1点,即正上点;
②若d_0>0,则取P2点,即右上点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P1,下下一个像素点位置为M(x_p+0.5,y_p+2):
d_1=F(M)=F(x_p+0.5,y_p+2)=a(x_p+0.5)+b(y_p+1)+c+b=d_0+b
当d_0>0时,即下一像素点为P2,下下一个像素点位置为M(x_p+1.5,y_p+2):
d_1=F(M)=F(x_p+1.5,y_p+2)=a(x_p+0.5)+b(y_p+1)+c+a+b=d_0+a+b
4. K<-1
设当前点P(x_p,y_p),则下一点P1和P2中点M点坐标为M(x_p+0.5,y_p-1)。
将M点带入F(x,y):
d_0=F(M)=F(x_p+0.5,y_p-1)=a(x_p+0.5)+b(y_p-1)+c
此时分两种情况:
①若d_0<0,则取P2点,即右下点;
②若d_0>0,则取P1点,即正下点。
下面对两种情况进行分别讨论:
当d_0<0时,即下一像素点为P2,下下一个像素点位置为M(x_p+1.5,y_p-2):
d_1=F(M)=F(x_p+1.5,y_p-2)=a(x_p+0.5)+b(y_p-1)+c+a-b=d_0+a-b
当d_0>0时,即下一像素点为P1,下下一个像素点位置为M(x_p+0.5,y_p-2):
d_1=F(M)=F(x_p+0.5,y_p-2)=a(x_p+0.5)+b(y_p-1)+c-b=d_0-b
相关文章推荐
- 计算机图形学:中点划线法(任意斜率)
- 中点画线算法(任意斜率)
- Bresenham算法实现任意斜率直线绘制
- 机械版CG 附加实验1 中点画线算法
- 机械版CG 附加实验1 中点画线算法
- n个点中求任意两点组成斜率的最大值
- 画线算法 中点画线 Bresenham DDA
- Bresenham画直线,任意斜率
- 任意斜率下的Bresenham算法实现
- UESTC 1425 求任意区间的LIS 线段树区间更新区间查询
- UVALive 5097(斜率dp)
- 整型数组处理算法(九)给定任意一个正整数,求比这个数大且最小的“不重复数”[2014百度笔试题]
- 运用Floyd算法求得带权有向图任意两点间的最短路径C/C++
- 求二叉树中任意两结点的距离
- 输出任意次方的后三位数
- 第7周项目:任意输入三个数(整数),求它们的最大值和最小值
- bzoj-1096 1096: [ZJOI2007]仓库建设(斜率优化dp)
- [转]产生任意Duty的PWM波形验证
- hdu 3045 Picnic Cows(斜率优化DP)