OpenGL-实验2直线生成算法实现.docxVIP

  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文档。上传文档
查看更多
OpenGL-实验2直线生成算法实现

实验2 直线生成算法实现实验目的理解基本图形元素光栅化的基本原理, 掌握一种基本图形元素光栅化算法, 利用0penGL实现直线光栅化的 DDA算法。实验内容(1)根据所给的直线光栅化的示范源程序, 在计算机上编译运行, 输出正确结果。(2)指出示范程序采用的算法, 以此为基础将其改造为中点线算法或 Bresenham算法,写入实验报告。(3)根据示范代码,将其改造为圆的光栅化算法,写入实验报告。(4)了解和使用 OpenGL的生成直线的命令,来验证程序运行结果。实验原理示范代码原理DDA算法。下面介绍 OpenGL画线的一些基础知识和glutReshapeFunc()函数。 (1)数学上的直线没有宽度,但0penGL的直线则是有宽度的。同时, OpenGL的直线必须是有限长度,而不是像数学概念那样是无限的。可以认为, OpenGL的“直线”概念与数学上的“线段”接近,它可以由两个端点来确定。这里的线由一系列顶点顺次连接而成, 有闭合和不闭合两种 。前面的实验已经知道如何绘“点”,那么 OpenGL是如何知道拿这些顶点来做什么呢? 是依次画出来,还是连成线? 或者构成一个多边形? 或是做其他事情? 为了解决这一问题, OpenGL要求:指定顶点的命令必须包含在 glBegin函数之后, glEnd函数之前(否则指定的顶点将被忽略),并由 glBegin来指明如何使用这些点。例如: glBegin(GL P0INTS) ,glVertex2f(0.0f, 0.0f);glVertex2f(0.5f, 0.0f);glEnd();则这两个点将分别被画出来。如果将 GL_POINTS替换成 GL_LINES,则两个点将被认为是直线的两个端点, OpenGL将会画出一条直线。 还可以指定更多的顶点, 然后画出更复杂的图形。另一方面, glBegin支持的方式除了 GL_POINTS和 GL_LINES,还有GL LINE STRIP、 GL LINE L0〇P、 GL TRIANGLES、 GL TRIANGLE STRIP、 GL TRIANGLE_FAN等几何图元。(2) 首次打开窗口、移动窗口和改变窗口大小时, 窗口系统都将发送一个事件, 以通知程序员 。如果使用的是 GLUT,通知将自动完成,并调用向 glutReshapeFunc注册的函数。 该函数必须完成下列工作:①重新建立用作新渲染画布的矩形区域。②定义绘制物体时使用的坐标系 。如:void Reshape(int w, int h){glViewport(0, 0, (GLsizei) w, (GLsizei) h);glMatrixMode(GL_PROJECTION) ;glLoadIdentity() ;gluOrtho2D(0.0, (GLdouble) w,0.0,(Gldouble)h);}在 GLUT内部, 将给该函数传递两个参数: 窗口被移动或修改大小后的宽度和高度, 单位为像素。 glViewport()调整像素矩形,用于绘制整个窗口。接下来三个函数调整绘图坐标系,使左下角坐标为(0,0),右上角坐标为(w,h)。实验代码#includeGL/glut.hvoid SetPixel(int x,int y){//画点glBegin(GL_POINTS);glVertex2i(x,y);//设置点坐标glEnd();}void swap(int *a,int *b)//交换函数{int temp=*a;*a=*b;*b=temp;}int abs(int a,int b){if(ab)return (a-b);else return (b-a);}void Bres_Line(int x0,int y0,int x1,int y1)// Bresenham算法{glColor3f(1.0f,0.0f,0.0f);SetPixel(x0,y0);int dx=abs(x1,x0);//200int dy=abs(y1,y0);//300if(dx==0dy==0)return ;int flag=0;if(dxdy){flag=1;swap(x0,y0);swap(x1,y1);swap(dx,dy);}int tx=(x1-x0)0?1:-1;int ty=(y1-y0)0?1:-1;int curx=x0;int cury=y0;int dS=2*dy;int dT=2*(dy-dx);int d=dS-dx;while(curx!=x1){if(d0)d+=dS;else{cury+=ty; d+=dT;}glPointSize(2);if(flag){SetPixel(cury,curx);}else{SetPixel(curx,cury);

文档评论(0)

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

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

1亿VIP精品文档

相关文档