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

更新时间:2023-07-15 23:10:56 阅读: 评论:0

计算机图形学课程设计
             
     
    课程设计 球体Phong光照模型
一、实验目的
  (1)掌握双线性法矢插值模型;
  (2)掌握ZBuffer算法的思想;
  (3)掌握有效边表填充算法; 
美发培训机构二、实验要求
1、建立三维坐标系Oxyz,原点位于屏幕客户区中心,x轴水平向右为正,y轴垂直向上为正,z轴垂直于屏幕指向观察者。
2、绘制体心和坐标系中心重合的球体表面,使用Z-Buffer消隐算法进行消隐。
3、使用单点光源对球体进行照射生成Phong光照模型,光源位置位于球体右上方。
4、背景色设置为RGB(128,0,0)。
5、使用键盘方向键旋转球体。
6、使用鼠标左击缩小球体、右击增大球体。
三、实验步骤
    建立球体的网格模型,使用地理划分法将球体北极和南极划分为三角形面片,其余部分划分为四边形面片,先对球体网格模型进行背面剔除,然后使用深度缓冲算法进行消隐。计算面片各顶点的平均法矢量,然后采用双线性法失插值计算面片内各点的法矢量。最终根据每点的法矢量对光源的朝向,通过简单光照模型计算所获得的光强。面片使用有效边表算法填
1、Phong双线性法矢插值模型
Gouraud双线性光强插值模型解决了相邻多边形之间的颜色突变问题,产生的真实感图形颜色过渡均匀,图形显得非常光滑,这是它的优点,但是,由于采用光强插值,其镜面反射光效果不太理想,而且相邻多边形边界处的马赫带效应并不能完全消除。Phong模型提出的双线性法矢插值模型可以有效的解决上述问题,产生正确的高光区域。Phong模型在进行光强插值的时候,需要先对面片的每一个顶点计算平均法矢量,然后通过双线性法矢插值计算面片内每个点的法矢量,最后根据简单光照模型计算面片上各点的颜色值。基本算法如下。
(1)计算面片顶点的平均法矢量。
由于球心位于三维坐标系原点,所以球面上任意面片的顶点平均法矢量就是该点的位置矢量。
(2)计算面片内部各点的法矢量。
在图中,三角形面片的顶点坐标为,法矢量为emba和mba的区别法矢量是任一扫面线于三角形边
进行双线性值插值计算三角形内点F的法矢量。
边上任意一点A点的法矢量可以通过拉格朗日线性插值法得到:
   
边上B点的法矢量通过拉格朗日线性插值法得到:
   
扫描线AB上F点的法矢量通过拉格朗日线性插值法得到:
    中英文在线翻译器
惠存(3)对面片内的每一点根据简单光照模型计算光强,获得该点颜色。
y     
                 
交朋友的英文
        A  F  B
                       
 
2、修改CAET类
    在CAET类内不仅包含边的起点坐标和终点坐标,同时增加起点和终点的法矢量。
3、修改CZBuffer类
在CZBuffer类先对面片每个点的法矢量进行双线性插值获得面片内每一点的法矢量,然后再调用简单光照模型计算面片内每点的光强。
4、光照环境初始化
在CTestView类的构造函数内设置光源个数为1,位于右上方,材质颜色为红色。
5、绘制球面函数
    使用Phong双线性法矢量插值模型时,需要计算每个面片上的矢法量。定义了Normal3数组存储三角形面片的顶点法矢量,定义了Normal4数组存储四边形面片的顶点法矢量。
netherlands四、程序核心代码及思路
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)设计光源类: CLight 
        void SetDiffu(CRGB);    设置光源的漫反射光
        免费日语翻译void SetSpecular(CRGB);  设置光源的镜面反射光
        void SetPosition(double,double,double);  设置光源的直角坐标系
    生活哲理文章    void SetGlobal(double,double,double);  设置光源的球坐标
        void SetCoef(double,double,double);    设置光强的衰减系数
        void SetOnOff(bool);      设置光源开关状态
        void GlobalToXYZ();      球坐标转换为直角坐标
  (5)设计材质类: CMaterial
        void SetAmbient(CRGB);borne是什么意思  设置材质对环境光的反射率
        pitchvoid SetDiffu(CRGB);  设置材质对漫反射光的反射率
        void SetSpecular(CRGB);  设置材质对镜面反射光的反射率

本文发布于:2023-07-15 23:10:56,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/78/1098599.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:模型   面片   球体   使用
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图