当前位置: 首页 > news >正文

友点网站建设网站专题栏目策划方案

友点网站建设,网站专题栏目策划方案,好公司网站建设价格,免费外国网站浏览器OpenGL光照贴图漫反射贴图镜面光贴图光照贴图 一个物体的不同部分是不同的材质,那么会有不同的环境光和漫反射颜色表现。 漫反射贴图 原理就是:纹理。 是对同样的原理使用了不同的名字:其实都是使用一张覆盖物体的图像,让我们能…

OpenGL

  • 光照贴图
    • 漫反射贴图
    • 镜面光贴图

光照贴图

一个物体的不同部分是不同的材质,那么会有不同的环境光和漫反射颜色表现。

漫反射贴图

原理就是:纹理。
是对同样的原理使用了不同的名字:其实都是使用一张覆盖物体的图像,让我们能够逐片段索引其独立的颜色值。是一个表现了物体所有的漫反射颜色的纹理图像。

在着色器中使用漫反射贴图的方法和纹理教程中是完全一样的。但这次我们会将纹理储存为Material结构体中的一个sampler2D。我们将之前定义的vec3漫反射颜色向量替换为漫反射贴图。
补充:sampler2D是所谓的不透明类型(Opaque Type),也就是说我们不能将它实例化,只能通过uniform来定义它。如果我们使用除uniform以外的方法(比如函数的参数)实例化这个结构体,GLSL会抛出一些奇怪的错误。这同样也适用于任何封装了不透明类型的结构体。

也需要移除环境光材质颜色向量,因为环境光颜色在几乎所有情况下都等于漫反射颜色,所以我们不需要将它们分开储存:

struct Material {sampler2D diffuse;vec3      specular;float     shininess;
}; 
...
in vec2 TexCoords;

在片段着色器中再次需要纹理坐标,所以我们声明一个额外的输入变量。接下来我们只需要从纹理中采样片段的漫反射颜色值即可:

vec3 diffuse = light.diffuse * diff * vec3(texture(material.diffuse, TexCoords));

将环境光的材质颜色设置为漫反射材质颜色同样的值:

vec3 ambient = light.ambient * vec3(texture(material.diffuse, TexCoords));

补充:
GLSL内建的texture()函数,可以得到一个纹理颜色,第一个参数纹理采样器,第二个参数纹理坐标。

上述这就是使用漫反射贴图的全部步骤了。
下面需要使用纹理坐标更新顶点数据,将它们作为顶点属性传递到片段着色器,加载材质并绑定材质到合适的纹理单元。
更新顶点着色器来以顶点属性的形式接受纹理坐标,并将它们传递到片段着色器中:

#version 330 core
layout (location = 0) in vec3 aPos;
layout (location = 1) in vec3 aNormal;
layout (location = 2) in vec2 aTexCoords;
...
out vec2 TexCoords;void main()
{...TexCoords = aTexCoords;
}

还需要更新两个VAO的顶点属性指针来匹配新的顶点数据,并加载箱子图像为一个纹理。在绘制箱子之前,我们希望将要用的纹理单元赋值到material.diffuse这个uniform采样器,并绑定箱子的纹理到这个纹理单元:

lightingShader.setInt("material.diffuse", 0);
...
glActiveTexture(GL_TEXTURE0);
glBindTexture(GL_TEXTURE_2D, diffuseMap);

镜面光贴图

想要让物体的某些部分以不同的强度显示镜面高光。
可以使用一个专门用于镜面高光的纹理贴图。这也就意味着我们需要生成一个黑白的(如果你想得话也可以是彩色的)纹理,来定义物体每部分的镜面光强度:
镜面高光的强度可以通过图像每个像素的亮度来获取。镜面光贴图上的每个像素都可以由一个颜色向量来表示,比如说黑色代表颜色向量vec3(0.0),灰色代表颜色向量vec3(0.5)。在片段着色器中,我们接下来会取样对应的颜色值并将它乘以光源的镜面强度。一个像素越「白」,乘积就会越大,物体的镜面光分量就会越亮。

要保证正确地加载图像并生成一个纹理对象。由于我们正在同一个片段着色器中使用另一个纹理采样器,我们必须要对镜面光贴图使用一个不同的纹理单元,所以我们在渲染之前先把它绑定到合适的纹理单元上:

lightingShader.setInt("material.specular", 1);
...
glActiveTexture(GL_TEXTURE1);
glBindTexture(GL_TEXTURE_2D, specularMap);

接下来更新片段着色器的材质属性,让其接受一个sampler2D而不是vec3作为镜面光分量:

struct Material {sampler2D diffuse;sampler2D specular;float     shininess;
};

采样镜面光贴图,来获取片段所对应的镜面光强度:

vec3 ambient  = light.ambient  * vec3(texture(material.diffuse, TexCoords));
vec3 diffuse  = light.diffuse  * diff * vec3(texture(material.diffuse, TexCoords));  
vec3 specular = light.specular * spec * vec3(texture(material.specular, TexCoords));
FragColor = vec4(ambient + diffuse + specular, 1.0);

通过使用镜面光贴图我们可以可以对物体设置大量的细节,比如物体的哪些部分需要有闪闪发光的属性,我们甚至可以设置它们对应的强度。镜面光贴图能够在漫反射贴图之上给予我们更高一层的控制。

http://www.yayakq.cn/news/551119/

相关文章:

  • 怎么免费做文学网站百度引流推广怎么收费
  • 合肥网站建设正规公司深圳网站营销型建设
  • p2p网站建设的步骤过程开源博客wordpress
  • 做微信扫码网站手机系统优化软件
  • 怎么做套板网站类似非小号的网站怎么做
  • seo网站排名推广网易企业邮箱pop3设置
  • 网站建设深圳哪家公司好长沙内容营销公司
  • 网站名注册wordpress后台界面修改
  • 游戏开奖网站建设百度推广优化
  • 武城网站建设价格谷歌网站 百度
  • 如何说服别人做网站wordpress single page
  • 建设银行梅州分行网站做英文网站的公司
  • 做淘宝联盟网站怎么学做网站制作
  • 如何管理wordpress网站模板百度指数1000搜索量有多少
  • 虎丘苏州网站建设济南seo公司案例
  • 成都网站建设优点界首网站优化公司
  • 建立网站的方式丰城建设网站
  • 中关村网站建设的公司徐州网站开发公司
  • 网站设计评价指标东莞百度首页优化
  • 为什么我的网站百度不收录做网站策划薪酬
  • 乐山网站建设免费p2p网站建设
  • 淄博网站建设与推广外汇返佣网站建设
  • 定制衣柜十大品牌排名百度seo搜搜
  • shuwon-成都网站建设-成都网站制作-成都网络公司-蜀美网络广州网站建设找哪家
  • 网站推广文章学院网站建设的目的及定位
  • 厦门网页设计如何做好网站针对搜索引擎的seo
  • 网站优化做网站优化代理网址在线
  • 网站联系方式设计健身器材网站源码
  • 个人网站如何做流量福建省住房和城乡建设厅网站首页
  • 企业网站制作流程图网站建设公司seo关键词