实例介绍
一、 1.Please download and install the glut library. 2.Write a complete program using the following codes to draw a Sierpinski gasket. void myinit() { // attributes glClearColor(1.0,1.0,1.0,1.0); glColor3f(1.0,0.0,0.0); // set up viewing glMatrixMode(GL_PROJECTION); glLoadIdentity(); gluOrtho2D(0.0, 50.0,0.0,50.0); glMatrixMode(GL_MODELVIEW); } void display() { GLfloat vertices[3][3] = {{0.0,0.0,0.0}, {25.0, 50.0,0.0}, {50.0,0.0,0.0}}; // an arbitrary triangle in the plane z = 0; GLfloat p[3] = {7.5, 5.0, 0.0}; // or set any desired initial point which is inside the triangle; int j,k; int rand(); glBegin(GL_POINTS); for (k = 0; k < 5000; k++) { /* pick a random vertex from 0, 1, 2*/ j = rand()%3; // compute new location; p[0] = (p[0]+vertices[j][0])/2; p[1] = (p[1]+vertices[j][1])/2; // display new point glVertex3fv(p); } glEnd(); glFlush(); } #include void main(int argc, char **argv) { glutInit(&argc;, argv); glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB); glutInitAWindowSize(500,500); glutInitWindowPosition(0,0); glutCreateWindow(“Simple OpenGL Example”); glutDisplayFunc(display); myinit(); glutMainLoop(); } 3.实现 DDA 和 Bresenham 画线算法 (1)画10万以上随机生成的直线段,比较两个算法的平均时间. (2)分别把屏幕上的1*1,5*5, 9*9像素当作直线段上的一个点,观察线段的走样情况. 二、 请写一个OpenGL (如果熟悉WebGL也可以用)程序完成如下任务 (1)读入三维网格模型的obj文件; (2)用OpenGL函数glTranslatef()对模型模型进行平移,使得其重心位于原点; (3)用函数glLookAt()设置视点,并且要求试点绕模型一周,以便用透视投影观察各个侧面; (4)要求利用真实感绘制对模型进行渲染. (利用OpenGL函数设置光源,材质,计算好每个三角形的法向量后,利用OpenGL的glNormal函数给待绘制的三角形设置法向量). 绘制的结果大概如下: 三、 本实验为综合实验, 任务是利用光线跟踪算法进行Whitted全局光照计算,并对读入场景进行真实感绘制。(特别提醒: 网上类似的projects可以参考,但不能照抄. 如http://tobias.isenberg.cc/graphics/LabSessions/RaytracingProject, http://physbam.stanford.edu/links/ray_tracing/project_ray_tracing.html https://www.cs.utexas.edu/~fussell/courses/cs354/assignments/raytracing/handout.shtml ) (1)参加对象: 本实验针对所有选课同学,3-5人组成一个小组,共同实现;非15级同学在组队方面有困难的话可与老师沟通. (2)实验结果提交: 每人都要求提交一份. 内容包括 a.源程序; 可执行代码; 三维场景数据; 同组的同学这部
【实例截图】
【核心代码】
计算机图形学.zip
└── 计算机图形学
├── 一
│ ├── 作业1-画Sierpinski gasket
│ │ └── homework1
│ │ ├── Debug
│ │ │ ├── homework1.exe
│ │ │ ├── homework1.ilk
│ │ │ └── homework1.pdb
│ │ ├── homework1
│ │ │ ├── 1.cpp
│ │ │ ├── Debug
│ │ │ │ ├── 1.obj
│ │ │ │ ├── 2.obj
│ │ │ │ ├── 3.obj
│ │ │ │ ├── homework1.log
│ │ │ │ ├── homework1.tlog
│ │ │ │ │ ├── CL.command.1.tlog
│ │ │ │ │ ├── CL.read.1.tlog
│ │ │ │ │ ├── CL.write.1.tlog
│ │ │ │ │ ├── homework1.lastbuildstate
│ │ │ │ │ ├── link.command.1.tlog
│ │ │ │ │ ├── link.read.1.tlog
│ │ │ │ │ └── link.write.1.tlog
│ │ │ │ ├── vc140.idb
│ │ │ │ └── vc140.pdb
│ │ │ ├── homework1.vcxproj
│ │ │ └── homework1.vcxproj.filters
│ │ ├── homework1.sln
│ │ └── homework1.VC.db
│ ├── 作业2-画10万条线
│ │ └── homework2
│ │ ├── Debug
│ │ │ ├── homework2.exe
│ │ │ ├── homework2.ilk
│ │ │ └── homework2.pdb
│ │ ├── homework2
│ │ │ ├── 1.cpp
│ │ │ ├── Debug
│ │ │ │ ├── 1.obj
│ │ │ │ ├── homework2.Build.CppClean.log
│ │ │ │ ├── homework2.log
│ │ │ │ ├── homework2.tlog
│ │ │ │ │ ├── CL.command.1.tlog
│ │ │ │ │ ├── CL.read.1.tlog
│ │ │ │ │ ├── CL.write.1.tlog
│ │ │ │ │ ├── homework2.lastbuildstate
│ │ │ │ │ ├── link.command.1.tlog
│ │ │ │ │ ├── link.read.1.tlog
│ │ │ │ │ └── link.write.1.tlog
│ │ │ │ ├── vc140.idb
│ │ │ │ └── vc140.pdb
│ │ │ ├── homework2.vcxproj
│ │ │ └── homework2.vcxproj.filters
│ │ ├── homework2.sln
│ │ └── homework2.VC.db
│ └── 作业3-走样
│ └── homework3
│ ├── Debug
│ │ ├── homework3.exe
│ │ ├── homework3.ilk
│ │ └── homework3.pdb
│ ├── homework3
│ │ ├── 1.cpp
│ │ ├── Debug
│ │ │ ├── 1.obj
│ │ │ ├── homework3.Build.CppClean.log
│ │ │ ├── homework3.log
│ │ │ ├── homework3.tlog
│ │ │ │ ├── CL.command.1.tlog
│ │ │ │ ├── CL.read.1.tlog
│ │ │ │ ├── CL.write.1.tlog
│ │ │ │ ├── homework3.lastbuildstate
│ │ │ │ ├── link.command.1.tlog
│ │ │ │ ├── link.read.1.tlog
│ │ │ │ └── link.write.1.tlog
│ │ │ ├── vc140.idb
│ │ │ └── vc140.pdb
│ │ ├── homework3.vcxproj
│ │ └── homework3.vcxproj.filters
│ ├── homework3.sln
│ └── homework3.VC.db
├── 三
│ └── 大作业-rayTracerR
│ ├── Camera.h
│ ├── Color.h
│ ├── Light.h
│ ├── main.cpp
│ ├── Object.h
│ ├── Plane.h
│ ├── Ray.h
│ ├── Source.h
│ ├── Sphere.h
│ └── Vect.h
└── 二
└── 作业-obj
└── sourcecode
├── Debug
│ ├── test2.exe
│ ├── test2.ilk
│ └── test2.pdb
├── test2
│ ├── Debug
│ │ ├── main.obj
│ │ ├── test2.log
│ │ ├── test2.tlog
│ │ │ ├── CL.command.1.tlog
│ │ │ ├── CL.read.1.tlog
│ │ │ ├── CL.write.1.tlog
│ │ │ ├── link.command.1.tlog
│ │ │ ├── link.read.1.tlog
│ │ │ ├── link.write.1.tlog
│ │ │ └── test2.lastbuildstate
│ │ ├── vc140.idb
│ │ └── vc140.pdb
│ ├── main.cpp
│ ├── test2.vcxproj
│ └── test2.vcxproj.filters
├── test2.sln
└── test2.VC.db
29 directories, 90 files
标签:
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论