实验一OpenGL直线、圆的绘制_第1页
实验一OpenGL直线、圆的绘制_第2页
实验一OpenGL直线、圆的绘制_第3页
实验一OpenGL直线、圆的绘制_第4页
实验一OpenGL直线、圆的绘制_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验一 OpenG直线、圆的绘制实验一、OpenGLt线、圆的绘制1、实验目的1) 了解OpenGL图形库的功能和结构;2)学习了解OpenGL程序的基本结构,及常用函数;3 )学习使用OpenGL绘制基本图形(线、圆);2、 实验内容1 )使用OpenGL编写一个简单的C+福序,使该程序能够绘制出 直线。2 )使用OpenGL编写一个简单的C+理序,使该程序能够绘制出圆。3、实验过程1)在系统上配置好OpenGL勺环境(头文件,库文件,和链接库 文件);2)使用Visual V+6.0 新建一个C+位档,并创建相应的 工程;3)在文档中引入OpenGL勺头文件,编辑代码实现鼠标拖动 画直线,

2、画圆。4、实验结果可单击鼠标左键,然后拖动鼠标画出两条直线,并同时画出圆;可单击鼠标右键,然后拖动鼠标画出两个圆,并同时画出直线。 结果截图:1.鼠标左键主要控制绘制的直线或Ope忙酉线和国的绘制5、实验代码1. #include 2. #include 3.4. / GLint pNum = 0;5. GLint px1, py1, px2, py2, cx, cy, r;6. GLint winWidth=600, winHeight=600;7.8. 画直线9. void Draw_Bresenham(int pStartx,int pStarty,int pEndx,int pEndy

3、)10. /用Bresenham算法画直线11. int i;12.13. if(pStartx=pEndx)14. 15. / 为竖线16. if(pStarty=pEndy)17. 18. for(i=pStarty;i=pEndy;i+)19. glVertex2f(pStartx,i);20. 21. else22. 23. for(i=pEndy;i=pStarty;i+)24. glVertex2f(pStartx,i);25. 26.27. return;28. 29.30. /为横线31. if(pStarty=pEndy)32. 33. if(pStartx=pEndx)34

4、. 35. for(i=pStartx;i=pEndx;i+)36. glVertex2f(i,pStarty);37. 38. else39. 40. for(i=pEndx;i0 & m=1)53. 54. if(pStartxpEndx)55. 56. while(pStartx=0)60. 61. p+=2*m-2;62. pStarty+;63. 64. else65. p+=2*m;66. 67. 68. else69.70.while(pEndx=0)74. 75. p+=2*m-2;76. pEndy+;77. 78. else79. p+=2*m;80. 81. 82.83.

5、 return;84. 85.86. p=-2*m-1;87. if(m=-1)88. 89. if(pStartxpEndx)90. 91. while(pStartx=0)95. 96. p+=-2*m-2;97. pStarty-;98. 99. else100. p+=-2*m;101. 102. 103. else104. 105. while(pEndx=0)109. 110. p+=-2*m-2;111. pEndy-;112. 113. else114. p+=-2*m;115. 116. 117.118. return;119. 120.121. p=2/m-1;122. i

6、f(m1)123. 124. if(pStartypEndy)125. 126. while(pStarty=0)130. 131. p+=2/m-2;132. pStartx+;133. 134. else135. p+=2/m;136.137.138.139.140.141.142.143.144.145.146.147.148.149.150.151.152.153.154.155.156.157.elsewhile(pEndy=0)p+=2/m-2;pEndx+;elsep+=2/m;return;p=-2/m-1;if(pStartypEndy)158.159. while(pSta

7、rty=0)163. 164. p+=-2/m-2;165. pStartx-;166. 167. else168. p+=-2/m;169. 170. 171. else172. 173. while(pEndy=0)177. 178. p+=-2/m-2;179. pEndx-;180.181. else182. p+=-2/m;183. 184. 185. 186.187. /画圆 /188. / 其他象限绘制189. void CirclePoints(int x,int y)190. /第1象限191. glVertex2f(x,y);192. glVertex2f(y,x);193

8、. /第2象限194. glVertex2f(-x,y);195. glVertex2f(-y,x);196. /第3象限197. glVertex2f(-y,-x);198. glVertex2f(-x,-y);199. /第4象限200. glVertex2f(x,-y);201. glVertex2f(y,-x);202.203. 204. 中点算法画圆205. void DrawCircle(int cx,int cy,int radis)206.207. glPushMatrix();208. glTranslatef(cx,cy,0);209. glPointSize(l);210

9、. glColor3f(0.5f, 0.5f, 1.0f);211. glBegin(GL_POINTS);212.213. int x,y;214. double p;215. x=0;216. y=radis;217. p=1.25-radis;218. while(x=0)y-;223. 224.225.p+=2.0*(x-y)+5;246.226. 227. else228. p+=2*x+3;229. 230. glEnd();231. glPopMatrix();232. 233.234.235. 绘制坐标轴236. void DrawOx()237. glColor3f(0.95

10、, 0.7, 0.8);238. glPointSize(1);239. glBegin(GL_LINES);240. glVertex2f(-winWidth/2,0);241. glVertex2f(winWidth/2,0);242. glVertex2f(0,winHeight/2);243. glVertex2f(0,-winHeight/2);244. glEnd();245. 247. 显示函数248. void Display()249. GL_COLOR_BUFFER_BIT(用背景颜色填充)250. glClear(GL_COLOR_BUFFER_BIT);251.252.

11、 DrawOx();253.254. glColor3f(0.0,0.0,1.0);255.256. glBegin(GL_POINTS);257. BresenhamLine(px1, py1, px2, py2);258. Draw_Bresenham(px1, py1,px2,py2);259. glEnd();260. glBegin(GL_POINTS);261. Draw_Bresenham(py1, px1,py2,px2);262. glEnd();263. glBegin(GL_LINES);264. /glVertex2f(px1,py1);265. /glVertex2f

12、(px2,py2);266. /glVertex2f(py1,px1);267. /glVertex2f(py2,px2);268. /glEnd();269.270. DrawCircle(cx,cy,r);271. DrawCircle(cy,cx,r);272.273. / 交换缓冲区274. glutSwapBuffers();275. glFlush(); 刷新绘图命令276. 277.278.279. /设置渲染状态(听起来满下人,实际上很简单)280. void SetupRC(void)281. 282. 清除颜色(这里为黑色,为了方便找画的那个点),可以理解成背景颜色283.

13、 / 和 glColor4f(1.0f,0.0f, 0.0f , 1.0f) 一样,所有参数都在0.0到1.0之间,后缀f是表示参数是浮点型的284. /最后的那个1.0f是透明度,0.0f表示全透明,1.0f是完全不透明285. glClearColor(1.0f, 1.0f, 1.0f,1.0f);286. 287.288. /当绘制的窗口大小改变时重新绘制,使绘制的图形同比例变化,289. /几乎所有OpenGL序中的这个函数都是一样的,所以,放心大胆的拷贝吧290. void ChangeSize(int w, int h)291. 292. winWidth = w;293. win

14、Height = h;294. /设置观察视野为窗口大小(用FLASHB面的话来说应该叫设置摄象机视野)295. glViewport(0,0,w,h);296. /重置坐标系统,指定设置投影参数297. glMatrixMode(GL_PROJECTION);298. / 调用单位矩阵,去掉以前的投影参数设置299. glLoadIdentity();300. /设置投影参数301. gluOrtho2D(-w/2,w/2,-h/2,h/2);302. 303.304. /鼠标点击305. void MousePlot(GLint button,GLint action,GLintxMous

15、e,GLint yMouse)&306. if(button=GLUT_LEFT_BUTTONaction=GLUT_DOWN)307. px1 = xMouse - winWidth/2;308. py1 = winHeight/2 - yMouse;309. 310. if(button=GLUT_LEFT_BUTTONaction=GLUT_UP)311. px2 = xMouse - winWidth/2;312. py2 = winHeight/2 - yMouse;313. glutPostRedisplay();314. 315. if(button=GLUT_RIGHT_BUT

16、TONaction=GLUT_DOWN)316. cx=xMouse-winWidth/2;317. cy=winHeight/2-yMouse;318. 319. 320. 鼠标移动321. void MouseMove(GLint xMouse,GLint yMouse)322. px2 = xMouse - winWidth/2;323. py2 = winHeight/2 - yMouse;324.r=sqrt(pow(xMouse-winWidth/2-cx),2)+pow(winHeight/2-yMouse-cy),2);325. glutPostRedisplay();326.

17、 327.328. /主函数329. int main(int argc, char* argv)330. 331. glutInit(&argc, argv);332. /设置显示模式333. glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB|GLUT_DEPTH);334. /设置窗口大小像素335. glutInitWindowSize(600, 600);336. /设置窗口出现在屏幕的位置337.glutInitWindowPosition(300,160);338. /建立一个叫OpenGL的窗口339. glutCreateWindow(OpenGL-Line);340.341. /调用函数Display进行绘制342. glutDisplayFunc(Display);343. / 调用鼠

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论