思考题
对于前述几种直线生成算法和程序:
1.当最大位移方向是y时,应如何修改? 2. 要达到通用时,应如何修改?
5.2 圆的扫描转换
解决的问题:
绘出圆心在原点,半径为整数R的圆 x2+y2==R2
■八分法画圆
y y=-x
(-y,x)
(y,x)
y=x
(-x,y) (-x,-y)
(x,y)
(x,-y)
改进1:令e=d-0.5
xi 1 xi 1 y yi 1 (e 0) i 1 yi (e 0)
•e初=-0.5, •每走一步有e=e+k。 •if (e>0) then e=e-1
算法步骤为:
1.输入直线的两端点P0(x0,y0)和P1(x1,y1)。 2.计算初始值△x、△y、e=-0.5、x=x0、y=y0。 3.绘制点(x,y)。 4.e更新为e+k,判断e的符号。若e>0,则(x,y)更新 为(x+1,y+1),同时将e更新为e-1;否则(x,y)更新为 (x+1,y)。
初始值d的计算
d 0 F ( x0 1, y0 0.5) y0 0.5 k ( x0 1) b y0 k x0 b k 0.5 0 .5 k
P(x i,y i) Pu(x i+1,y i+1) Q M(x i+1,y i+1/2) Pd(x i+1,y i)
y F(x,y)=0 F(x,y)>0 x F(x,y)<0 F(x,y)=0
y
F(x,y)>0
F(x,y)<0
x
图5-4