第四讲计算机图形学基础.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四讲计算机图形学基础

第4讲 计算机图形学基础 1直线DDA算法 1.1算法原理 以下用直线的显式斜截式方程进行讨论,其中斜率。 假定端点坐标都是整数,让从到变化,每步递增1,依次计算,得到象素点。但其中每步都包含一个浮点乘法和圆整舍入运算,计算效率较低。 注意到,。 当时,,即增加1时,增加。 1.2伪代码 DDALine(x0, y0, x1, y1, color) { dx = x1 – x0; dy = y1 – y0; k = dy / dx; y = y0; for (x = x0; x = x1; x += 1) { DrawPixel(x, (int)(y+0.5), color); y = y + k; } //End of for } 1.3算法讨论 当斜率绝对值大于1时,必须把、互换,增加1时,增加。 DDA算法本质是用离散数值方法解微分方程,每一步的、是用前一步的值加上1个增量得到的,因此属于增量算法。 算法中和必须用浮点数表示,每一步必须进行舍入取整,精度和计算效率较低且不利于硬件实现。 2中点画线法 2.1算法原理 以下讨论假定直线斜率在0~1之间,其它情况可类似处理。 若直线在方向增加1个单位,则在方向上的增加只能在0~1之间。假定在坐标为的各象素点中,与直线最近的象素点已经确定为,则下一个与直线最近的象素点只能是正右方的或右上方的。 以表示的中点,以表示直线与垂直线理论上的交点,那么,若在的下方,则下一点取,否则取。 2.2实现过程推导 以下用直线的隐式方程进行讨论,其中,、、。 点在直线上, 点在直线上方, 点在直线下方, 判断下一点的依据,即在的上方还是下方,代入坐标到并判断符号即可。 构造判别式 当,在直线下方,取右上方的点。 当,在直线上方,取正右方的点。 当,两者均可,约定取正右方的点。 对每一个象素计算判别式,根据它的符号确定下一个象素。 注意到是的线性函数,应改用增量计算以提高效率。 当时取正右方的点,欲再判断下一个象素应该取哪一个,应该计算: 此时,的增量为。 当时取右上方的点,欲再判断下一个象素应该取哪一个,应该计算: 此时,的增量为。 再看的初值,显然第一个象素应该取左端点,判别式: 由于,故。 由于仅使用了的符号,且的增量均是整数,为避免计算初始增量,可以使用代替进行判断。 2.3伪代码 MidPointLine(x0, y0, x1, y1, color) { a = y0 – y1; b = x1 – x0; d = 2 * a + b; //初始增量 d1 = 2 * a; d2 = 2 * (a + b); x = x0; y = y0; DrawPixel(x, y, color); while (x x1) { if (d 0) //取右上方点 { x += 1; y += 1; d += d2; } else //取正右方点 { x += 1; d += d1; } DrawPixel(x, y, color); } //End of while } 3直线Bresenham生成算法 3.1算法原理 与中点画线法类似,Bresenham算法也是通过在每列象素中确定与理想直线最近的象素来进行直线的扫描转换的。 仍考虑直线斜率在0~1之间的情况,其它情况可类似处理。 若直线在方向增加1个单位,则在方向上的增量也在0~1之间。假定直线起点在象素中心,纵向截距的初始值为0,其增量。 显然,若,则下一点取,否则取。 为方便判断,可使总是处于0~1之间,即当时,执行。 令,则,问题变成仅判断的符号。 当递增到时,。 当时,下一点取。 当时,下一点取,此时执行,等价于时执行。 为避免作除法和浮点运算,令,且,作变换,则,问题变成判断的符号,需要计算出增量。 3.2伪代码 BresenhamLine(x0, y0, x1, y1, color) { dx = x1 – x0; dy = y1 – y0; x = x0; y = y0; e = -dx; for (i = 0; i = dx; i += 1) { DrawPixel(x, y, color); x += 1; e += 2dy; if (e = 0) { y += 1; e -= 2dx; } } //End of for } 4圆的扫描转换 圆的逐点生成算法、中点生成算法和Bresenham生成算法与直线类似。 逐点生成算法利用圆的参数方程,以角度作为参数进行计算。 中点生成算法和Bresenham生成算法的推导过程详见《计算机图形学》。 注意仅生成八分之一圆弧即可,其它部分利用对称性完成。 现代CAD系统的快速显示模块常使用离散生成算法(同样利用对称性)。 考

文档评论(0)

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

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

1亿VIP精品文档

相关文档