圆和椭圆的生成算法.docVIP

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
贵州大学实验报告 学院:计算机科学与信息学院 专业:软件工程 班级:102 姓名 学号 实验组 实验时间 指导教师 成绩 实验项目名称 实验二:圆和椭圆的生成算法 实验目的 掌握圆和椭圆的中点算法及二次差分法,了解并掌握在光栅显示系统中圆和椭圆的生成和显示算法,并在自己熟悉的平台上实现相应的测试代码。 实验要求 掌握圆的基本特性(八对称性) 掌握椭圆的基本特性(四对称性) 掌握中点算法和二次差分法的思想 熟练的编写出测试代码 实验原理 中点算法画圆和椭圆的实验原理 画圆 因为圆具有八对称性,可以先画出第二个八分圆,利用八对称性画出其它八分圆。已知圆弧的隐函数的形式为:F(x,y)=x2+y2-R2=0。所以可知: F(x,y)0,(x,y)在园外; F(x,y)0,(x,y)在园内, F(x,y)=0,(x,y)在园上。 假设(xi,yi)为已确定的象素坐标,则下一个象素只能是正右方的T点或右下方的B点。 设M是T和B的中点,则M的坐标为(xi+1,yi-0.5) 如F(M)0,则M在园内,下一点取正右方T点; 如F(M)0,则M在园外,下一点取右下方B点; 如F(M)=0,则M在园上,下一点取T点或B点均可。 构造判别式:d=F(M)=F(xi+1,yi-0.5)=(xi+1)2+(yi-0.5)2-R2 (1)d0,中点在圆内,选正右方的T点,再下一个象素的判别式为: dnew=F(xi+2,yi-0.5) =(xi+2)2+(yi-0.5)2-R2=d+(2xi+3) 则d的增量为:ΔT = 2xi+3 (2) d=0,中点在圆外,选右下方的B点,再下一个象素的判别式为: dnew=F(xi+2,yi-1.5) =(xi+2)2+(yi-1.5)2-R2=d+(2xi+3)+(- yi+2) =d+2(xi-yi)+5 则d的增量为:ΔB = 2(xi-yi)d初始值为:d0=F(1,R-0.5) =1+(R-0.5)2-R2 =1.25-R 因为在d的运算中包含了浮点数的运算,使复杂度提高,为了消除d中的浮点数运算,可以令d = 1-r. 画椭圆 为方便说明,可以选取中心在原点的椭圆,方程为:x2/a2+y2/b2 = 1。则隐函数的形式为:F(x,y)= b2 x2+ a2y2-(ab)2=0.因为椭圆具有四对称性,可只考虑第一象限的椭圆,其他的椭圆弧可以通过对称求得。 椭圆上的法向量可以将椭圆弧分为上下两个部分,在上半部分,x的增量大于y的增量,在下半部分,y的增量大于x的增量。可以得到这样的一个不等式来判别椭圆弧是否已从上半部分过度到下半部分:b2 (Xp+1) a2 (Yp-0.5)(椭圆弧进入下半部分时,不等式会改变方向)。 椭圆的正负划分性: F(X,Y) = 0:(X,Y) 在椭圆上 F(X,Y) 0:(X,Y) 在椭圆内 F(X,Y) 0:(X,Y) 在椭圆外 (1)对于椭圆弧的上半部分: 假设Pi(xi,yi)已确定,则下一对待选像素的中点是:M(xi+1,yi-0.5) d = F(M) = F(xi+1,yi-0.5)=b2(xi+1)2+a2(yi-0.5)2-a2b2 初始点为(0,b),则M为(1,b-0.5),d的初值为:d0=F(1,b-0.5)=b2+a2/(-b+1/4) (a)当d0(取T点)时,下一点(i+1)点的坐标为(xi+1,Yi),为确定i+2点取的下一个中点M的坐标为:(xi+2,yi-0.5).则d1=F(xi+2,yi-0.5),故增量为:b2(2xi+3) (b)当d=0(取B点)时,下一点(i+1)点的坐标为(xi+1,Yi-1),为确定i+2点取的下一个中点M的坐标为:(xi+2,Yi -1.5) .则d2=F(xi+2,yi-1.5),故增量为:b2(2xi+3)+a2(-2yi+2). (2)对于椭圆弧的下半部分 在每一次迭代中都要判断椭圆是否已从上半部进入了下半部,如果b2x=a2y,则椭圆进入下半部份,此时令△y=1,且:d0=b2(x+0.5)2+a2(y-1)2-a2b2 (a)若d0,则M在椭圆内部,取右下方像素R,则d=F(xp+1.5,yp-2),增量为2(b2xi+1-a2yi+1)+a2 (b)若d=0,M在椭圆的外部,取正下方像素L,则d=F(xp+0.5,yp-2),增量为:a2(-2yi+1+1) 下半部分的终止条件为y=0 二次差分法画圆和椭圆的实验原理 (一)画圆 二次差分法的基本思想就是在现选像素点的基础上进行二次选择,计算增量,从而达到消除中点算法中的乘法运算,降低增量阶数的目的。 假设现有点为P(xp,yp),在中心法画圆中已求得正右

文档评论(0)

lingyun51 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档