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

    球体Phong光照模型课程设计报告.docx

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

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

    球体Phong光照模型课程设计报告.docx

    计算机图形学课程设计课程设计球体Pho ng光照模型亠、实验目的(1)掌握双线性法矢插值模型;(2) 掌握ZBuffer算法的思想;(3) 掌握有效边表填充算法;二、实验要求1、 建立三维坐标系Oxyz,原点位于屏幕客户区中心,x轴水平向右为正,y轴垂直向 上为正,z轴垂直于屏幕指向观察者。2、 绘制体心和坐标系中心重合的球体表面,使用 Z-Buffer消隐算法进行消隐。3、使用单点光源对球体进行照射生成 Pho ng光照模型,光源位置位于球体右上方。4、背景色设置为RGB(128,0,0)。5、使用键盘方向键旋转球体。6使用鼠标左击缩小球体、右击增大球体。三、实验步骤建立球体的网格模型,使用地理划分法将球体北极和南极划分为三角形面片,其余部分划分为四边形面片,先对球体网格模型进行背面剔除,然后使用深度缓冲算法 进行消隐。计算面片各顶点的平均法矢量,然后采用双线性法失插值计算面片内各点 的法矢量。最终根据每点的法矢量对光源的朝向,通过简单光照模型计算所获得的光强。面片使用有效边表算法填1、Pho ng双线性法矢插值模型Gouraud双线性光强插值模型解决了相邻多边形之间的颜色突变问题,产生的真 实感图形颜色过渡均匀,图形显得非常光滑,这是它的优点,但是,由于采用光强插 值,其镜面反射光效果不太理想,而且相邻多边形边界处的马赫带效应并不能完全消 除。Phong模型提出的双线性法矢插值模型可以有效的解决上述问题,产生正确的高 光区域。Pho ng模型在进行光强插值的时候,需要先对面片的每一个顶点计算平均法 矢量,然后通过双线性法矢插值计算面片内每个点的法矢量,最后根据简单光照模型计算面片上各点的颜色值。基本算法如下。(1) 计算面片顶点的平均法矢量。i =1n由于球心位于三维坐标系原点,所以球面上任意面片的顶点平均法矢量就是该点的位置矢量。(2) 计算面片内部各点的法矢量。在图中,三角形面片的顶点坐标为 Po(xo,yo),法矢量为No; R(xi,yj,法矢量是Ni ; B(X2,y2),法矢量为N2。任一扫面线于三角形边PoR的交点为A(Xa,ya),法矢量为Na;与边PoB的交点为B(Xb,yb),法矢量为Nb;F(Xf,yf)为AB内的任意一点,法矢量 为Nf。Phong双线性法矢插值模型是依据三角形面片顶点R、R、P2的法矢量进行双线 性值插值计算三角形内点F的法矢量。边P0P边上任意一点A点的法矢量Na可以由R点的法矢量No和R点的法矢量Ni可以通过拉格朗日线性插值法得到:ya yiy。 yi上yoNiyi y。边PoP2边上B点的法矢量Nb可以由Po点的法矢量No和P2点的法矢量N2通过拉格 朗日线性插值法得到:Nbyb 一丫2yo y2yb -y。y2 一 yoN2扫描线AB上F点的法矢量N f可以由A点的法矢量Na和B点的法矢量Nb通过拉格 朗日线性插值法得到:NfXf _XbXa叽Xf _XaNa -Xb _XaNb2、修改CAET类获得该点颜色在CAET类内不仅包含边的起点坐标和终点坐标,同时增加起点和终点的法矢量3、修改 CZBuffer 类在CZBuffer类先对面片每个点的法矢量进行双线性插值获得面片内每一点的法矢量,然后再调用简单光照模型计算面片内每点的光强4、光照环境初始化在CTestView类的构造函数内设置光源个数为1,位于右上方,材质颜色为红色。5、绘制球面函数使用Phong双线性法矢量插值模型时,需要计算每个面片上的矢法量。定义了 Normal3数组存储三角形面片的顶点法矢量,定义了Normal4数组存储四边形面片的顶点法矢量。四、程序核心代码及思路1、程序设计中的主要思路及所使用的主要类在程序设计中,使用Phong双线性法矢量插值模型时,计算每个面片的顶点 坐标,同时计算每个面片的顶点法矢量。在CZBuffer类内定义了双线性法矢量插值函数Interpolation()计算面片内的每个点的法矢量。根据面片内每一点的法矢量调用CLighting类的成员函数Lighing()计算该点的光强。并在MyView构造函数中调用 了透视变化初始化函数InitParameter();构造顶点表函数ReadPoint();构造面表函数ReadFace(); 在OnDraw()函数中使用双缓冲函数,并使用绘制球面函数DrawObject ()函数,画出球体模型。设计使用的类如下:(1) 颜色类:CRGB成员函数:Normalize () 将颜色分量red、green、blue 规范化到0, 1 闭区间内。(2) 定义矢量类:CVector成员函数:double Mold ()求矢量的模CVector Unit ()单位矢量功能:在类中重载+、-、*、等运算符,并利用Dot ()计算矢量点积。(3) 定义边节点类:CAET 和 定义桶节点类:CBucket设置当前扫描线与有效边的交点的横坐标x定义扫描线ScanLine来求图形与有效边表的交点(4) 设计光源类:CLightvoid SetDiffuse(CRGB);设置光源的漫反射光void SetSpecular(CRGB);设置光源的镜面反射光void SetPositio n( double,double,double);设置光源的直角坐标系void SetGlobal(double,double,double);设置光源的球坐标void SetCoef(double,double,double);设置光强的衰减系数void SetO nO ff(bool);设置光源开关状态void GlobalToXYZ();球坐标转换为直角坐标(5) 设计材质类:CMaterialvoid SetAmbie nt(CRGB);设置材质对环境光的反射率void SetDiffuse(CRGB);设置材质对漫反射光的反射率void SetSpecular(CRGB);设置材质对镜面反射光的反射率void SetEmit(CRGB);设置材质自身辐射的颜色void SetExp(double);设置材质的高光指数(6) 、设置光照类:CLighting功能:在类中定义了光照函数Lighting(),计算物体表面网格顶点所获得的光照函数。在该函数中分五步来实现网格顶点的光亮度,第一,累加漫反射光 的颜色;第二,累加镜面反射光的颜色;第三,进行光强衰减;第四,加入环境光; 第五,返回所计算顶点的光强颜色。(7) 、定义 CZBuffer 类:void CreateBucket();在函数中使用CBucket类创建桶节点void CreateEdge();在函数中使用CAET类创建边表void Pho ng(CDC *pDC,CPi3 ViewPoi nt,CLighti ng *pLight,CMaterial*pMaterial); Phong填充函数void In itDeepBuffer(i nt,i nt,double);初始化深度缓存CVector In terpolatio n(double,double,double,CVector,CVector);法矢量线性插值(2) 程序中使用的重要函数及部分代码:(1) 、构造球体顶点表函数 ReadPoint()在函数中定义了片面夹角为gafa=gbeta= 10 ;纬度区域为N1=180/gafa=18,经度区域 N2=360/gbeta=36 ; 利用数组 P ( N1-1)*N2+2设置的 球体共有616个顶点,经纬网格的夹角为10 °。利用:P0.x=0,P0.y=r,P0.z=0;计算北极点坐标利用如下代码计算球体上的点坐标:for(i nt i=0;i<N1-1;i+)gafa1=(i+1)*gafa*3.14/180;for(i nt j=0;j<N2;j+)gbeta1=j*gbeta*3.14/180;Pi*N2+j+1.x=r*si n(gafa1)*si n( gbeta1);Pi*N2+j+1.y=r*cos(gafa1);Pi*N2+j+1.z=r*s in (gafa1)*cos(gbeta1);利用: P(N1-1)*N2+1.x=0,P(N1-1)*N2+1.y=-r,P(N1-1)*N2+1.z=0;计算南极点坐标(2) 、构造面片表函数 ReadFace()面片用二维数组表示,第一维按维度自北极向南极增加的方向定义,第 二维在同一纬度带上z轴正向开始,按逆时针方向定义。球体共有N1*N2个面,北极和南极各有N2个面,其余部分有(N1-2) *N2个面片。具体实现代码和算法见源程序。构造北极三角形面片代码:for(i nt j=0;j<N2;j+)int tempj=j+1;if(tempj=N2) tempj=0;int NorthI ndex3;NorthI ndex0=0;NorthI ndex1=j+1;North In dex2=tempj+1;F0j.SetEN(3);for(i nt k=0;k<F0j.E n;k+)F0j.pk=NorthI ndexk;F0j.SetNormal(PNorthl ndex0,PNorthl ndex1,PNorthl ndex2); 构造球体四边形面片代码:for(i nt i=1;i<N1-1;i+)for(i nt j=0;j<N2;j+)int tempi=i+1;int tempj=j+1;if(tempj=N2) tempj=0;int Body In dex4;BodyI ndex0=(i-1)*N2+j+1;BodyI ndex1=(tempi-1)*N2+j+1;BodyI ndex2=(tempi-1)*N2+tempj+1;BodyI ndex3=(i-1)*N2+tempj+1;Fij.SetEN(4);for(i nt k=0;k<Fij.E n;k+)Fij.pk=BodyI ndexk;Fij.SetNormal(PBodyl ndex0,PBodyl ndex1,PBodyl ndex2); (3) 、绘制球体函数 DrawObject (CDC *pDC使用Z-Buffer算法对球面进行深度消隐,然后使用有效边表算法进行填充,为减少 渲染的面片数,先使用凸多面体消隐算法对球体不可见面片进行剔除。然后使用 Z-Buffer算法对可见面进行消隐,最后使用有效边表算法进行填充。在函数中,使 用Pho ng双线性法矢量插值模型,计算每个面片上的矢法量。定义了 Normal3数组存 储三角形面片的顶点法矢量,定义了Normal4数组存储四边形面片的顶点法矢量。(4) 、使用键盘方向键 OnKeyDown(UINTiChar, UINT nRepCnt, UINTnFlags)消息响应窗口函数,代码如下:if(!Play)switch( nChar)case VK_UP:使用Phi每次自减5,按向上键使球体向里旋转Phi=Phi-5; break;case VK_DOWN:使用Phi每次自加5,按向下键使球体向外旋转Phi=Phi+5; break;case VK_LEFT:使用Theta 每次自加5,按向左键使球体向左旋转Theta=Theta+5; break;case VK_RIGHT: 使用Theta 每次自减5,按向左键使球体向右旋转 Theta=Theta-5; break;default: break; In itParameter();DoubleBuf(); (5) 、使用鼠标左右点击窗口响应函数,对球体进行放大和缩小void CMyView:O nLButto nDblClk(UINT nFlags, CPoi nt poi nt) R=R+30;在鼠标左击函数中视点半径每次增加30,使球体缩小DoubleBuf();CView:O nLButto nDblClk( nFlags, poi nt);void CMyView:O nRButto nDblClk(UINT nFlags, CPoi nt poi nt) R=R-30;在鼠标右击函数中视点半径每次减少30,使球体增大DoubleBuf();CView:O nRButto nDblClk( nFlags, poi nt); 五、程序运行结果(1)当球体半径r=150,面片夹角=10,纬度区间N1=18,经度区间N2=36时,球 体共有(N1-1) *N2+2=616个顶点,其运行结果如图:S计m憶刑学幕设计:球拡Phong複型宫息与计腳学100点王问前(2)使用键盘方向向左旋转球体,Theta=Theta+10 所示结果如图:(3) 使用鼠标右击函数, On RButto nDblClk(UINT nFlags, CPoi nt poi nt)使球体增大当R=R-30时运行结果如图:"酸计算或图形学渓程设计:球tPhongS.惜息訂计寡科学100150王向前交迂® 涓输巳全音M 帮助(H)(4) 利用半径窗口设置,if(m_Dlg.DoModal() = IDOK)R = m_Dlg.m_R;Invalidate(FALSE);改变视点在用户坐标系中的半径R=950时,结果如图:却牛旧曜止至吉;V)秘岳Mg i亠算睡形学蘭计:mPhang II息号计算帶lOOlffi 葩前六、实验总结本次程序实训利用MFC寸球体Pho ng光照模型,进行了绘制,在程序中使用地 理划分法将球体的两极划分为三角形面片,球体划分为四边形面片。

    注意事项

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

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




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开