计算机图形学10陈永强.ppt
1,基本概念简单光照模型基于简单光照模型的多边形绘制,第十章 真实感图形绘制,2,真实感图形绘制:通过综合利用数学、物理学、计算机以及心理学等知识在计算机图形输出设备上绘制出能够以假乱真的美丽景象。光强(度):描述物体表面朝某方向辐射光的颜色,它既能表示光能大小又能表示其色彩组成的物理量。,基本概念,3,光照模型(Illumination model),也称明暗模型,主要用于物体表面某点处的光强度计算。简单的光照模型复杂的光照模型,基本概念,4,真实感图形绘制过程 根据假定的光照条件和景物外观因素,依据一定的光照模型,计算可见面投射到观察者眼中的光强度大小,并将它转换成适合图形设备的颜色值,生成投影画面上每一个象素的光强度,使观察者产生身临其境的感觉。,基本概念,5,真实感图形绘制步骤在计算机中进行场景造型;进行取景变换和透视变换;进行消隐处理;进行真实感图形绘制。,基本概念,6,简单光照模型环境光漫反射光镜面反射光光强衰减颜色处理,10.1 简单光照模型,7,简单光照模型中只考虑反射光的作用。反射光由环境光、漫反射光和镜面反射光三部分组成。,简单光照模型,8,特点:照射在物体上的光来自周围各个方向,又均匀地向各个方向反射。P点对环境光的反射强度为,环境光(Background Light),图1 环境光的反射,9,一个粗糙的、无光泽的表面呈现为漫反射。特点:光源来自一个方向,反射光均匀地射向各个方向。由Lambert余弦定理可得点P处漫反射光的强度为:,漫反射光(Diffuse Reflection),图2 漫反射,10,若L和N都已规格化为单位矢量,则有,漫反射光(Diffuse Reflection),图2 漫反射,11,对于彩色,漫反射光(Diffuse Reflection),对于多个漫反射光源,12,镜面反射遵循反射定律,入射光和反射光分别位于表面法矢的两侧。如果观察者正好处在P点的镜面反射方向上,就会看到一个比周围亮得多的高光点。,镜面反射光,图3 镜面反射,13,镜面反射情况由Phong模型给出:,镜面反射光,图3 镜面反射,若R和V已规格化为单位矢量,则:,14,从视点观察到物体上任一点P处的光强度I应为环境光反射光强度Ie、漫反射光强度Id以及镜面反射光的光强度Is的总和:,物体表面光强计算,15,光在传播的过程中,其能量会发生衰减。光照模型中必须考虑光强衰减,否则会影响生成图形的真实效果。光强的衰减可以采用常数衰减、一次函数衰减和二次函数衰减等。,光强衰减,16,常用的二次衰减函数,光强衰减,17,选择颜色模型(color model)面向硬件的颜色模型:RGB、CYM面向视觉感知的颜色模型:HSI为颜色分量指定光照模型,颜色,18,以RGB颜色模型为例环境光强度:入射光强度:环境光反射系数:漫反射系数:镜面反射系数:,颜色,19,光强计算公式:,颜色,20,恒定光强Gouraud明暗处理Phong明暗处理,10.2 基于简单光照模型的多边形绘制,21,只用一种颜色绘制整个多边形光源在无穷远处,则多边形上所有点的LN为常数,衰减函数也是一个常数。视点在无穷远处,则多边形上所有点的VR为常数。多边形是景物表面的精确表示,即不是一个含曲线面景物的近似表示。,恒定光强,22,Gouraud明暗处理方法,又称为亮度插值明暗处理,它通过对多边形顶点颜色进行线性插值来绘制其内部各点,其步骤为:计算每个多边形顶点处的平均单位法矢量;对每个顶点根据简单光照模型来计算其光强;在多边形表面上将顶点光强度进行线性插值。,Gouraud明暗处理,23,双线性插值方法,Gouraud明暗处理,图4 Gouraud 明暗处理的双线性插值,24,Phong明暗处理方法,又称为法矢量插值明暗处理,它对多边形顶点的法矢量进行插值以产生中间各点的法矢量,其步骤为:计算每个多边形顶点处的平均单位法矢量;用双线性插值方法求得多边形内部各点的法矢量。最后按光照模型确定多边形内部各点的光强。,Phong明暗处理,25,矢量双线性插值方法,Phong明暗处理,图5 Phong明暗处理的矢量双线性插值,26,10.3 透明处理,图6 透明表面的光强包括反射光和折射光,27,透明处理,图7 简单的透明处理,28,透明处理,图8 光的折射,29,10.4 产生阴影,阴影是由于物体截断了光线而产生的,所以如果光源位于物体一侧的话,阴影总是位于物体的另一侧,也就是与光源相反的一侧。从理论上来说,从视点以及从光源看过去都是可见的面不会落在阴影中,只有那些从视点看过去是可见的,而从光源看过去是不可见的面,肯定落在阴影之内。,30,产生阴影,产生具有阴影的图形绘制算法将视点移到光源位置,用多边形区域排序消隐算法,将多边形分成两大类:向光多边形和背光多边形。将视点移到原来的观察位置,对向光多边形和背光多边形进行消隐,并选用一种光照模型计算多边形的亮度,就可得到有阴影效果的图形。,31,10.5 模拟景物表面细节,颜色纹理:通过颜色色彩或明暗度的变化体现出来的表面细节。几何纹理:由于不规则的细小凹凸造成的。颜色纹理取决于物体表面的光学属性,而几何纹理由物体表面的微观几何形状决定。,32,模拟景物表面细节,用多边形模拟表面细节纹理的定义和映射凹凸映射,33,多边形模拟表面细节,简单地模拟景物表面细节的方法是用多边形,称为表面图案多边形,来模拟纹理的结构和模式。处理时,首先根据待生成的颜色纹理构造表面图案多边形,然后将表面图案多边形覆盖到物体的表面上。,34,纹理映射和定义,生成颜色纹理的一般方法,是预先定义纹理模式,然后建立物体表面的点与纹理模式的点之间的对应。当物体表面的可见点确定之后,以纹理模式的对应点参与光照模型进行计算,就可把纹理模式附到物体表面上。这种方法称为纹理映射(Texture Mapping)。,35,纹理映射和定义,图9 纹理映射中纹理空间、物体空间和像素空间的变换,36,纹理映射和定义,图10 由像素空间向纹理空间的映射,37,凹凸映射,1978年,Blinn提出了一种无需修改表面几何模型,即能模拟表面凹凸不平效果的有效方法凹凸映射技术(Bump Mapping)。,38,10.6 整体光照模型与光线跟踪,整体光照模型Whitted光照模型光线跟踪算法,39,整体光照模型,一个完整的光照明模型应该包括由光源和环境引起的漫反射分量、镜面反射分量、规则透射分量以及漫透射分量等。仅考虑由光源引起的漫反射分量和镜面反射分量,而环境反射分量则简单地用一常数来代替,这类光照模型称为局部光照模型。能同时模拟光源和环境照明效果的光照模型称为整体光照模型。,40,Whitted光照模型,Whitted在简单光照模型中增加了环境镜面反射光和环境规则透射光,以模拟周围环境的光投射在景物表面上产生的理想镜面反射和规则透射现象。,图11 物体表面的镜面反射和透射,41,光线跟踪算法,光线跟踪(Ray Tracing)方法基于几何光学的原理,通过模拟光的传播路径来确定反射、折射和阴影等。,图12 光线跟踪算法,42,光线跟踪算法步骤,从视点出发,确定穿过每个像素中心的光线路径,然后,沿这束光线累计光强,并将最终值赋给相应像素。对于每一像素光线,对场景中的所有物体表面进行测试以确定其是否与该光线相交,并计算出交点的深度,深度最大(z值)的交点即为该像素对应的可见点。然后,继续考察通过该可见点的从属光线(Secondary Rays)。,43,光线跟踪算法步骤,对每条从属光线重复过程:与场景中的所有物体求交。然后递归地在沿从属光线方向最近的物体表面上生成下一折射和反射光线。当由每个像素出发的光线在场景中被反射和折射时,逐个将相交物体表面加入到一个二叉光线跟踪树中。当树中的一束光线到达预定的最大深度或到达某光源时,就停止跟踪。,44,光线跟踪算法步骤,图13 光线跟踪及光线跟踪树,45,光线跟踪算法步骤,可以从光线跟踪树的叶结点开始,累计光强贡献以确定某像素处的光强大小。树中每个结点的光强由树中的子结点处继承而来,但光强大小随距离而衰减。像素光强是光线树根结点处的衰减光强的总和。,46,光线跟踪反走样,将光线跟踪算法与过采样方式结合起来,可归纳如下:(1)对每一像素的角点计算光线跟踪的光强。(2)比较像素4个角点的光强,确定要进行细分的像素。(3)对细分后新增的角点计算光线跟踪的光强。然后,重复(2)和(3),直到各角点的光强比较接近为止。(4)加权平均求出投影平面上各像素点的光强。,47,10.7 OpenGL中的光照处理,点光源全局光照表面材质透明处理,48,点光源,在OpenGL场景描述中可以包含多个点光源,光源的各种属性设置使用下面的函数指定。void glLightif(GLenum light,GLenum pname,TYPE param);void glLightifv(GLenum light,GLenum pname,TYPE*param);,49,点光源,50,点光源,点光源的颜色点光源的位置和类型聚光灯光强度衰减,51,点光源,在OpenGL中,必须明确启用或禁用光照。默认情况下,不启用光照,此时使用当前颜色绘制图形,不进行法线矢量、光源、光照模型、材质属性的相关的计算。要启用光照,可以使用函数:glEnable(GL_LIGHTING);指定了光源的参数后,需要使用函数启用light指定的光源:glEnable(light);,52,OpenGL全局光照,在OpenGL中,下面的函数用于指定全局光照 void glLightModeif(GLenum pname,TYPE param);void glLightModeifv(GLenum pname,TYPE*param);,53,OpenGL材质属性,在OpenGL中,下面的函数用于指定材质属性 void glMaterialif(GLenum face,GLenum pname,TYPE param);void glMaterialifv(GLenum face,GLenum pname,TYPE*param);,54,OpenGL材质属性,OpenGL提供颜色材质模式:glEnable(GL_COLOR_MATERIAL);void glColorMaterial(GLenum face,GLenum mode);颜色材质模式中,可以通过glColor函数来指定物体表面的颜色,而相应的材质属性将通过颜色值和光源的RGB值计算出来。,55,透明处理,OpenGL中使用混合实现透明处理。混合操作是指将输入对象(源)的颜色值与当前存储在帧缓存中的像素(目标)颜色值合并的过程。,56,透明处理,开启混合操作glEnable(GL_BLEND);指定计算源因子和目标因子的计算方式 void glBlendFunc(GLenum srcfactor,GLenum destfactor);,57,透明处理,58,透明处理,进行混合计算假定计算出的源和目标混合因子分别为(Sr,Sg,Sb,Sa)和(Dr,Dg,Db,Da),并且分别使用下标s和d区分表示源和目标的RGBA值,则混合后的RGBA值如下:(RsSr+RdDr,GsSg+Gd Dg,BsSb+BdDb,AsSa+AdDa),59,10.8 OpenGL中的纹理映射,void glTexImage1D(GLenum target,GLint level,GLint components,GLsizei width,GLint border,GLenum format,GLenum type,const GLvoid*texels);void glTexImage2D(GLenum target,GLint level,GLint components,GLsizei width,GLsizei height,GLint border,GLenum format,GLenum type,const GLvoid*texels);void glTexImage3D(GLenum target,GLint level,GLint components,GLsizei width,GLsizei height,GLsizei depth,GLint border,GLenum format,GLenum type,const GLvoid*texels);,60,纹理映射,启用纹理glEnable(GL_TEXTURE_1D);glEnable(GL_TEXTURE_2D);glEnable(GL_TEXTURE_3D);,61,纹理映射,在启用纹理之后,需要建立物体表面上的点与纹理空间的对应关系。在绘制基本图元时,在glVertex函数调用之间调用glTexCoord函数明确指定当前顶点所对应的纹理坐标。让OpenGL自动生成纹理坐标。,