- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * 圆的扫描转换算法 下面仅以圆心在原点、半径R为整数的圆为例,讨论圆的生成算法。 假设圆的方程为: X2 + Y2 = R2 * * 圆弧扫描算法 X2 + Y2 = R2 Y = ?Sqrt(R2 - X2) 在一定范围内,每给定一 X值,可得一Y值。 当X取整数时,Y须取整。 缺点:浮点运算,开方, 取整,不均匀。 y x * * 角度DDA法 x = x0 + Rcos? y = y0 + Rsin? dx =- Rsin?d? dy = Rcos?d? xn+1 =x n + dx y n+1 =y n + dy xn+1 = x n + dx = x n - Rsin?d? =x n - (y n - y 0 )d? y n+1 = y n + dy = y n + Rcos?d? =y n + (x n - x 0 )d? 显然,确定x,y的初值及d?值后,即可以增量方式获得圆周上的坐标,然后取整可得象素坐标。但要采用浮点运算、乘法运算、取整运算。 * * 中点画圆法 利用圆的对称性,只须讨论1/8圆。第二个8分圆 P为当前点亮象素,那么,下一个点亮的象素可能是Q1(Xp+1,Yp)或Q2(Xp +1,Yp -1)。 M Q1 Q2 P0(Xp ,Yp ) Q 构造函数:F(X,Y)=X2 + Y2 - R2 ;则 F(X,Y)= 0 (X,Y)在圆上; F(X,Y) 0 (X,Y)在圆内; F(X,Y) 0 (X,Y)在圆外。 设M为Q1、Q2间的中点,M=(Xp+1,Yp-0.5) * * Q2 中点画圆法 M Q1 * * 中点画圆法 有如下结论: F(M) 0 -M在圆内- 取Q1 F(M)= 0 -M在圆外- 取Q2 为此,可采用如下判别式: Q2 M P0 Q1 * * d = F(M) = F(xp + 1, yp - 0.5) =(xp + 1)2 + (yp - 0.5) 2 - R2 若d0, 则Q1 为下一个象素,那么再下一个象素的判别式为: d1 = F(xp + 2, yp - 0.5) = (xp + 2)2 + (yp - 0.5) 2 - R2 = d + 2xp +3 即d 的增量为 2xp +3. 中点画圆法 M Q1 Q2 P0(xp,yp) 若d=0, 则Q2 为下一个象素,那么再下一个象素的判别式为: d1 = F(xp + 2, yp - 1.5) = (xp + 2)2 + (yp - 1.5) 2 - R2 = d + (2xp + 3)+(-2 yp + 2) 即d 的增量为 2 (xp - yp) +5. d的初值: d0 = F(1, R-0.5) = 1 + (R-0.5)2 - R2 = 1.25 - R * * Q2 中点画圆法 M Q1 P0(xp,yp) * * 中点画圆
文档评论(0)