欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOC文档下载  

    长方体体的光照效果计算机图形学课程设计1.doc

    • 资源ID:2926580       资源大小:335.50KB        全文页数:29页
    • 资源格式: DOC        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    长方体体的光照效果计算机图形学课程设计1.doc

    西安科技大学计算机图形学课程设计题目: 长方体体的光照效果目录一 课程设计题目 31.题目要求 32.任务 3二 任务分析算法介绍 3 1.任务分析 3 2.算法介绍 4三 总体设计 5 1.定义三维齐次向量结构体 5 2.定义三维齐次坐标结构 53.定义面的结构 64.定义点的结构 65.长方体顶点定义及初始化 7 6. 面表 77.定义点光源、视线方向、光照方向 88.各面可见性计算和判断 99.窗口-视区变换 1110.路径填充 12四 流程图 13五 源程序 14六 程序运行效果图 27七 总结 28参考文献 29一、 课程设计题目 长方体体的光照效果1.题目要求对长方体,建立一个点光源,采用环境光和点光源漫反射光的光照模型,应用FLAT明暗处理方法,显示平行投影后的长方体光照效果。2.任务本题目主要包括五个任务,1)长方体表面模型的建立 2)长方体的可见面判断 3)可见面的背光性判断4)可见面光照计算5)可见面光照效果显示附加:通过键盘上下左右按键对图形进行旋转二、 任务分析算法介绍1.任务分析任务1)中,定义三维齐次坐标结构和面的结构;定义顶点表和面表,对长方体绕X轴旋转和绕Y轴旋转。任务2)中对每一个面计算其外法向量及可见性任务3)中对每个可见面计算其光线向量,并判断其是否为背光面。任务4)计算每个见光面的环境光和点光源的漫反射分量。任务5)用该面的光强显示该可见面附加: 人机交互2.算法介绍1)旋转变换绕X轴旋转变换的坐标表示绕Y轴旋转变换的坐标表示2) 平行投影在XOY平面投影后坐标3) 环境光模型 物体没有受到光源的直射,但其表面仍有一定亮度,这是由于环境光的作用。表示环境光反射强度表示环境光反射率表示环境光入射强度4)漫反射光模型漫反射光可认为是在点光源的照射下,光被物体表面吸收后,然后重新反射出来的光。表示漫反射光强度表示漫反射反射率表示点光源入射强度大小入射光与物体表面法矢量夹角三、总体设计1.定义三维齐次向量结构体typedef struct Vector3D float x; float y; float z; int f; /f表示所在的平面的编号VECTOR;2. 定义三维齐次坐标结构typedef struct tagHOMOCOORDfloat x;float y;float z;float w;HOMOCOORD;3.定义面的结构typedef struct tagPLANEint v0, v1, v2, v3;VECTOR n; /外法向量HOMOCOORD center; /中心点float Id; /漫反射光强int flag;/标识符float kd; /漫反射率float ka; /环境光反射率float Ie; /环境光反射光强float I; /光强PLANE;4.定义点的结构typedef struct tagMYPOINTfloat x,y;MYPOINT;5.长方体顶点定义及初始化pts=new HOMOCOORDptn; pts0.x= 1;pts0.y= 2; pts0.z= 1; pts0.w=1;pts1.x= -1; pts1.y= 2; pts1.z= 1; pts1.w=1;pts2.x= -1; pts2.y= -2; pts2.z= 1; pts2.w=1;pts3.x= 1;pts3.y= -2; pts3.z= 1; pts3.w=1;pts4.x= 1;pts4.y= 2; pts4.z= -1; pts4.w=1;pts5.x= -1; pts5.y= 2; pts5.z= -1; pts5.w=1;pts6.x= -1; pts6.y= -2; pts6.z= -1; pts6.w=1;pts7.x= 1;pts7.y= -2; pts7.z= -1; pts7.w=1;6.面表 fn=6;faces=new PLANEfn;faces0.v0=0; faces0.v1=1; faces0.v2=2; faces0.v3=3; faces1.v0=4; faces1.v1=5; faces1.v2=1; faces1.v3=0; faces2.v0=5; faces2.v1=6; faces2.v2=2; faces2.v3=1; faces3.v0=6; faces3.v1=7; faces3.v2=3; faces3.v3=2; faces4.v0=7; faces4.v1=4; faces4.v2=0; faces4.v3=3; faces5.v0=7; faces5.v1=6; faces5.v2=5; faces5.v3=4;7.定义点光源、视线方向、光照方向1)点光源illuminant.x = -100;illuminant.y = -100;illuminant.z = 100;Ia = 0.5;/环境光入射强度Ip = 0.5;/漫反射入射光强度2)视线方向VECTOR eye_vec;eye_vec.x = 0;eye_vec.y = 0;eye_vec.z = -1;3)定义光照方向light_vec = new VECTORfn;VECTORvector62 ;for(i=0; i<6; i+)vectori0 = CalculateVector(ptsfacesi.v0, pts facesi.v1, i );vectori1 = CalculateVector(ptsfacesi.v0, pts facesi.v2, i );8.各面可见性计算和判断1)计算各个面的外法向量faces0.n = VecCross(vector00, vector01 );for(i=0; i<6; i+)facesi.n = VecCross(vectori0, vectori1 );2)各个面的可见性判定float cos_angle;for(i=0; i<6; i+)cos_angle = (-1.0)*(InnerProduct(facesi.n, eye_vec)/(GetModule(facesi.n)*GetModule(eye_vec);if(cos_angle>0)facesi.flag = VISIABLE; elsefacesi.flag = UNVISIABLE;3)计算各个面的中心点for(i=0; i<fn; i+)facesi.center.x = (ptsfacesi.v0.x+ptsfacesi.v1.x+ptsfacesi.v2.x+ptsfacesi.v3.x)/4.0f ;facesi.center.y = (ptsfacesi.v0.y+ptsfacesi.v1.y+ptsfacesi.v2.y+ptsfacesi.v3.y)/4.0f ;facesi.center.z = (ptsfacesi.v0.z+ptsfacesi.v1.z+ptsfacesi.v2.z+ptsfacesi.v3.z)/4.0f ;facesi.center.w = (ptsfacesi.v0.w+ptsfacesi.v1.w+ptsfacesi.v2.w+ptsfacesi.v3.w)/4.0f ;4)计算各个面的光照方向for(i=0; i<fn; i+)light_veci = CalculateVector(illuminant, facesi.center, EOF);5)计算各个面的漫反射光强for(i=0; i<fn; i+)facesi.Id = Ip*facesi.kd*(-1)*(InnerProduct(facesi.n, light_veci)/(GetModule(facesi.n)*GetModule(light_veci);6)计算各个面环境光反射光强for(i=0; i<fn; i+)facesi.Ie = facesi.ka*Ia;7)计算各个面光强(漫反射光强和环境反射光强之和)for(i=0; i<fn; i+)facesi.I = facesi.Id+facesi.Ie ;/窗口-视区变换实现过程float wxl=-5,wxr=5,wyb=-5,wyt=5;int vxl=0,vxr=800,vyb=0,vyt=600;9.窗口-视区变换int a = (int)(vxr-vxl)/(wxr-wxl);int b = (int)(vxl-wxl*a);int c = (int)(vyt-vyb)/(wyt-wyb);int d = (int)(vyb-wyb*c);for(i=0;i<ptn;i+)pts2Di.x = a*ptsi.x+b;pts2Di.y = c*ptsi.y+d;10. 路径填充CBrush Brush;Brush.CreateSolidBrush(RGB(facesj.I*255,facesj.I*255,facesj.I*255+40);pd.SelectObject(&Brush);pd.BeginPath();pd.MoveTo(p0);for(int i=1;i<4;i+)pd.LineTo(pi);pd.LineTo(p0);pd.EndPath();pd.FillPath();Brush.DeleteObject();四、流程图五、源程序Draw3DView.h文件/定义三维齐次向量结构体typedef struct Vector3Dfloat x;float y;float z;int f; /f表示所在的平面的编号VECTOR;/定义三维齐次坐标结构typedef struct tagHOMOCOORDfloat x;float y;float z;float w;HOMOCOORD;/定义面的结构typedef struct tagPLANEint v0, v1, v2, v3;VECTOR n; /外法向量HOMOCOORD center; /中心点float Id; /漫反射光强int flag;float kd; /漫反射率float ka; /环境光反射率float Ie; /环境光反射光强float I; /光强PLANE;/定义点的结构,需要浮点数的x,ytypedef struct tagMYPOINTfloat x,y;MYPOINT;public:VECTOR CalculateVector(HOMOCOORD start, HOMOCOORD end, int face);/计算一个3维向量的函数,/从start点指向end点的属于face面的向量VECTOR VecCross(VECTOR vec1, VECTOR vec2);/计算两个向量叉积,即外法向量float InnerProduct(VECTOR vec1, VECTOR vec2);/计算两个向量的内积float GetModule(VECTOR vec); /计算向量的模void RotateY(int angle); /绕y轴逆时针旋转void RotateX(int angle); /绕x轴逆时针旋转void DrawMy3DGraphics(); /绘制长方体virtual CDraw3DView();protected:HOMOCOORD illuminant; /定义光源坐标float Ip; /定义光源光强float Ia; /环境光光强VECTOR *light_vec; /各个面的光照方向指针HOMOCOORD *pts; /三维顶点指针MYPOINT *pts2D; /自定义的二维浮点数结构,表示变换后的二维点PLANE *faces; /长方体的面指针int ptn,fn; /顶点个数与面的个数Draw3DView.cpp文件int x_angle = 0;int y_angle = 0;void CDraw3DView:DrawMy3DGraphics()int i;/形体定义ptn=8;pts=new HOMOCOORDptn; /设置长方体pts0.x=1;pts0.y=2;pts0.z=1; pts0.w=1;pts1.x=-1; pts1.y=2;pts1.z=1; pts1.w=1;pts2.x=-1; pts2.y=-2; pts2.z=1; pts2.w=1;pts3.x=1;pts3.y=-2; pts3.z=1; pts3.w=1;pts4.x=1;pts4.y=2;pts4.z=-1; pts4.w=1;pts5.x=-1; pts5.y=2;pts5.z=-1; pts5.w=1;pts6.x=-1; pts6.y=-2; pts6.z=-1; pts6.w=1;pts7.x=1;pts7.y=-2; pts7.z=-1; pts7.w=1;/给定义面的指针分配内存;fn=6;faces=new PLANEfn;/设置立方体各面faces0.v0=0; faces0.v1=1; faces0.v2=2; faces0.v3=3; faces1.v0=4; faces1.v1=5; faces1.v2=1; faces1.v3=0; faces2.v0=5; faces2.v1=6; faces2.v2=2; faces2.v3=1; faces3.v0=6; faces3.v1=7; faces3.v2=3; faces3.v3=2; faces4.v0=7; faces4.v1=4; faces4.v2=0; faces4.v3=3; faces5.v0=7; faces5.v1=6; faces5.v2=5; faces5.v3=4; pts2D=new MYPOINTptn;for(i=0; i<fn; i+)facesi.ka = 0.8;facesi.kd = 0.8;/定义点光源illuminant.x = -100;illuminant.y = -100;illuminant.z = 100;Ia = 0.5;Ip = 0.5;/定义视线方向VECTOR eye_vec;eye_vec.x = 0;eye_vec.y = 0;eye_vec.z = -1;/定义光照方向light_vec = new VECTORfn;/旋转调用RotateX(x_angle); RotateY(y_angle);/定义并计算各个面的两条相交的向量VECTORvector62 ;for(i=0; i<6; i+)vectori0 = CalculateVector(ptsfacesi.v0, pts facesi.v1, i );vectori1 = CalculateVector(ptsfacesi.v0, pts facesi.v2, i );/计算各个面的外法向量faces0.n = VecCross(vector00, vector01 );for(i=0; i<6; i+)facesi.n = VecCross(vectori0, vectori1 );/各个面的可见性判定float cos_angle;for(i=0; i<6; i+)cos_angle = (-1.0)*(InnerProduct(facesi.n, eye_vec)/(GetModule(facesi.n)*GetModule(eye_vec);if(cos_angle>0)facesi.flag = VISIABLE; elsefacesi.flag = UNVISIABLE;/计算各个面的中心点for(i=0; i<fn; i+)facesi.center.x = (ptsfacesi.v0.x+ptsfacesi.v1.x+ptsfacesi.v2.x+ptsfacesi.v3.x)/4.0f ;facesi.center.y = (ptsfacesi.v0.y+ptsfacesi.v1.y+ptsfacesi.v2.y+ptsfacesi.v3.y)/4.0f ;facesi.center.z = (ptsfacesi.v0.z+ptsfacesi.v1.z+ptsfacesi.v2.z+ptsfacesi.v3.z)/4.0f ;facesi.center.w = (ptsfacesi.v0.w+ptsfacesi.v1.w+ptsfacesi.v2.w+ptsfacesi.v3.w)/4.0f ;/计算各个面的光照方向for(i=0; i<fn; i+)light_veci = CalculateVector(illuminant, facesi.center, EOF);/计算各个面的漫反射光强for(i=0; i<fn; i+)facesi.Id = Ip*facesi.kd*(-1)*(InnerProduct(facesi.n, light_veci)/(GetModule(facesi.n)*GetModule(light_veci);/计算各个面环境光反射光强for(i=0; i<fn; i+)facesi.Ie = facesi.ka*Ia;/计算各个面光强for(i=0; i<fn; i+)facesi.I = facesi.Id+facesi.Ie ;/平行投影变换for(i=0;i<ptn;i+)ptsi.x=ptsi.x;ptsi.y=ptsi.y;/ 窗口-视区变换int a = (int)(vxr-vxl)/(wxr-wxl);int b = (int)(vxl-wxl*a);int c = (int)(vyt-vyb)/(wyt-wyb);int d = (int)(vyb-wyb*c);for(i=0;i<ptn;i+)pts2Di.x = a*ptsi.x+b;pts2Di.y = c*ptsi.y+d;/图形显示CClientDC pd(this);CPoint p4;for(int j=0; j<6; j+)if(facesj.flag=VISIABLE)p0=CPoint(pts2Dfacesj.v0.x,pts2Dfacesj.v0.y);p1=CPoint(pts2Dfacesj.v1.x,pts2Dfacesj.v1.y);p2=CPoint(pts2Dfacesj.v2.x,pts2Dfacesj.v2.y);p3=CPoint(pts2Dfacesj.v3.x,pts2Dfacesj.v3.y);/dc.SelectObject(pOld); /把画笔设置为原来的CBrush Brush;/(DKGRAY_BRUSH,RGB(64,64,64);Brush.CreateSolidBrush(RGB(facesj.I*255,facesj.I*255,facesj.I*255+40);pd.SelectObject(&Brush);pd.BeginPath();pd.MoveTo(p0);for(int i=1;i<4;i+)pd.LineTo(pi);pd.LineTo(p0);pd.EndPath();pd.FillPath();Brush.DeleteObject();void CDraw3DView:RotateX(int angle) /绕x轴逆时针旋转float a=angle*PI/180;for(int i=0;i<ptn;i+)float y,z;y=ptsi.y; z=ptsi.z;ptsi.y=y*cos(a)-z*sin(a);ptsi.z=y*sin(a)+z*cos(a);void CDraw3DView:RotateY(int angle) /绕y轴逆时针旋转float b=angle*PI/180;for(int i=0;i<ptn;i+)float x,z;x=ptsi.x; z=ptsi.z;ptsi.x=x*cos(b)+z*sin(b);ptsi.z=-x*sin(b)+z*cos(b);VECTOR CDraw3DView:CalculateVector(HOMOCOORD start, HOMOCOORD end, int face)/计算一个3维向量的函数,从start点指向end点的属于face面的向量 VECTOR tempVector;tempVector.x = end.x-start.x;tempVector.y = end.y-start.y;tempVector.z = end.z-start.z;tempVector.f = face;return tempVector;VECTOR CDraw3DView:VecCross(VECTOR vec1, VECTOR vec2)/计算两个向量叉积,即外法向量VECTOR tempNVector;tempNVector.x = (1)*(vec1.y*vec2.z - vec2.y*vec1.z);tempNVector.y = (-1)*(vec1.x*vec2.z-vec2.x*vec1.z);tempNVector.z = (1)*(vec1.x*vec2.y - vec2.x*vec1.y);return tempNVector;float CDraw3DView:InnerProduct(VECTOR vec1, VECTOR vec2)/计算两个向量的内积return (vec1.x*vec2.x + vec1.y*vec2.y + vec1.z*vec2.z);float CDraw3DView:GetModule(VECTOR vec)/计算向量的模return (sqrt(vec.x*vec.x+vec.y*vec.y+vec.z*vec.z);void CDraw3DView:OnKeyLeft() / TODO: Add your command handler code herey_angle-;RedrawWindow();void CDraw3DView:OnKeyUp() / TODO: Add your command handler code herex_angle+;RedrawWindow();void CDraw3DView:OnKeyRight() / TODO: Add your command handler code herey_angle+;RedrawWindow();void CDraw3DView:OnKeyDown() / TODO: Add your command handler code herex_angle-;RedrawWindow();六、程序运行效果图运行开始效果 按键旋转后效果七、总结 通过这次课程设计,加深了我们对计算机图形学这门课的学习,也让我们体会到完成一个设计任务的方法和思路,培养了我们独立思考的能力,在完成任务的同时,也锻炼了我们团队分工协作的能力。这一周里,感谢老师对我们在课设上不厌其烦的指导,让我们我产生的疑问一一的被解答,正是这些疑问的解答才使得我们的课设内容能够做得更加完美,也让我感受到了,计算机图形学课程的魅力所在,使我对这门课程的学习有了更大的乐趣。 我们的设计的内容长方体体的光照效果,在听了老师的仔细讲解,我们小组的几个成员通过进一步的设计改进,探讨和研究,最终在老师的细心指导下顺利完成了课设。 虽然我们已经有过几次课程设计的经验,但是每次都有不同的收获,尤其是在和老师交流时我们总能发现自己知识的局限,感谢老师的指导,让我们在不断的探讨和进步中顺利地完成设计任务参考文献1 谭浩强.C+面向对象程序设计M.北京:清华大学出版社,20062 孔令德,张岳新,马锐.VisualC+程序设计与实验指导M.北京:兵器工业出版社,20043 孔令德,叶瑶,杨慧炯. C+程序设计案列精编M.北京:中国铁道工业出版社,20044 孔令德.计算机图形学基础教程(VisualC+版)M.北京:清华大学出版社,2008

    注意事项

    本文(长方体体的光照效果计算机图形学课程设计1.doc)为本站会员(文库蛋蛋多)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开