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

品牌网站建设的关键要点龙岗网站设计

品牌网站建设的关键要点,龙岗网站设计,移动端适配,ipage wordpressNormal Mapping 又到了介绍法线贴图的地方,我感觉我已经写了很多遍了... 法线贴图用最简单的话来介绍的话,就是通过修改贴图对应物体表面的法线来修改光照效果,从而在不修改物体实际几何形状的前提下实现不同于物体几何形状的视觉效果。 因…

Normal Mapping

又到了介绍法线贴图的地方,我感觉我已经写了很多遍了...

法线贴图用最简单的话来介绍的话,就是通过修改贴图对应物体表面的法线来修改光照效果,从而在不修改物体实际几何形状的前提下实现不同于物体几何形状的视觉效果。

因此对于法线贴图来说,最重要的内容就是去修改法线贴图对于物体表面的法线。

  vec3 normal = texture(normalMap, TexCoords).rgb;normal = normalize(normal * 2.0 - 1.0);normal = normalize(TBN * normal);

这是我们在物体的片元着色器实现的内容,就是根据法线贴图的内容更换法线。

在这里我们不妨回顾一下法线贴图的原理:

法线贴图的“蓝色”就代表“正对表面外”,红色/绿色代表“沿U/V方向偏转”,整个流程无非就是:法线贴图以RGB值来记录对法线方向的干扰,这个干扰是在切线空间中进行的,我们还需要TBN矩阵——这个工具来将变换后的法线映射回世界坐标系中。

效果如图:

看起来确实有凹凸不平的质感——但其实,这只是薄薄的一个平面生成的效果。

Parallax Mapping

视差贴图和法线贴图类似也是也是不改变物体实际几何形状的前提下去修改视觉效果,可是和法线贴图直接去修改法线方向不同,视差贴图通过动态偏移纹理坐标实现高度不同的视觉效果。

vec2 ParallaxMapping(vec2 texCoords, vec3 viewDir)
{ float height =  texture(depthMap, texCoords).r;     return texCoords - viewDir.xy * (height * heightScale);        
}void main()
{           // offset texture coordinates with Parallax Mappingvec3 viewDir = normalize(fs_in.TangentViewPos - fs_in.TangentFragPos);vec2 texCoords = fs_in.TexCoords;texCoords = ParallaxMapping(fs_in.TexCoords,  viewDir);       if(texCoords.x > 1.0 || texCoords.y > 1.0 || texCoords.x < 0.0 || texCoords.y < 0.0)discard;// obtain normal from normal mapvec3 normal = texture(normalMap, texCoords).rgb;normal = normalize(normal * 2.0 - 1.0);   // get diffuse colorvec3 color = texture(diffuseMap, texCoords).rgb;// ambientvec3 ambient = 0.1 * color;// diffusevec3 lightDir = normalize(fs_in.TangentLightPos - fs_in.TangentFragPos);float diff = max(dot(lightDir, normal), 0.0);vec3 diffuse = diff * color;// specular    vec3 reflectDir = reflect(-lightDir, normal);vec3 halfwayDir = normalize(lightDir + viewDir);  float spec = pow(max(dot(normal, halfwayDir), 0.0), 32.0);vec3 specular = vec3(0.2) * spec;FragColor = vec4(ambient + diffuse + specular, 1.0);
}

可以看到我们的视差贴图会根据深度贴图的R值来修改原来纹理坐标,在片元着色器的执行流程中,我们的纹理会根据视线方向来动态地调整根据深度贴图的R值修改过的纹理坐标,从而达到视觉落差的效果。

说起来当然很简单,但是其背后的工作原理呢?

移花接木,狸猫换太子,卧槽这个视差贴图怎么这么坏啊。 用比较简单的话来说就是:首先我们的视线看向这个片元时,视线真正与物体表面的交点在A点,但是我们在A点的着色渲染成B点的颜色的话,不就实现了纹理坐标的偏移,从而实现视觉落差的效果了。这个B点是怎么得到的呢?就是根据我们的视差贴图修改该片元的高度值后与视线相交得到的。

陡峭视差映射(Steep Parallax Mapping)是视差映射的扩展,原则是一样的,但不是使用一个样本而是多个样本来确定向量。即使在陡峭的高度变化的情况下,它也能得到更好的结果,原因在于该技术通过增加采样的数量提高了精确性。

陡峭视差映射的基本思想是将总深度范围划分为同一个深度/高度的多个层。从每个层中我们沿着向量方向移动采样纹理坐标,直到我们找到一个采样低于当前层的深度值。

其实就是我们多很多个深度层,然后将视线和这些深度层的交点与深度贴图的深度值一一比较,找到第一个符合深度贴图的深度大于交点深度值的深度层,把这个深度层与视线的交点对于的深度值作为我们的纹理颜色渲染对象即可。

代码上这样改动:

vec2 ParallaxMapping(vec2 texCoords, vec3 viewDir)
{ // number of depth layersconst float minLayers = 8;const float maxLayers = 32;float numLayers = mix(maxLayers, minLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));  // calculate the size of each layerfloat layerDepth = 1.0 / numLayers;// depth of current layerfloat currentLayerDepth = 0.0;// the amount to shift the texture coordinates per layer (from vector P)vec2 P = viewDir.xy / viewDir.z * heightScale; vec2 deltaTexCoords = P / numLayers;// get initial valuesvec2  currentTexCoords     = texCoords;float currentDepthMapValue = texture(depthMap, currentTexCoords).r;while(currentLayerDepth < currentDepthMapValue){// shift texture coordinates along direction of PcurrentTexCoords -= deltaTexCoords;// get depthmap value at current texture coordinatescurrentDepthMapValue = texture(depthMap, currentTexCoords).r;  // get depth of next layercurrentLayerDepth += layerDepth;  }return currentTexCoords;
}

效果如图:

在这个基础上可以实现效果更好的视差遮蔽映射(Parallax Occlusion Mapping),只需要多加一个线性插值的操作即可。

vec2 ParallaxMapping(vec2 texCoords, vec3 viewDir)
{ // number of depth layersconst float minLayers = 8;const float maxLayers = 32;float numLayers = mix(maxLayers, minLayers, abs(dot(vec3(0.0, 0.0, 1.0), viewDir)));  // calculate the size of each layerfloat layerDepth = 1.0 / numLayers;// depth of current layerfloat currentLayerDepth = 0.0;// the amount to shift the texture coordinates per layer (from vector P)vec2 P = viewDir.xy / viewDir.z * heightScale; vec2 deltaTexCoords = P / numLayers;// get initial valuesvec2  currentTexCoords     = texCoords;float currentDepthMapValue = texture(depthMap, currentTexCoords).r;while(currentLayerDepth < currentDepthMapValue){// shift texture coordinates along direction of PcurrentTexCoords -= deltaTexCoords;// get depthmap value at current texture coordinatescurrentDepthMapValue = texture(depthMap, currentTexCoords).r;  // get depth of next layercurrentLayerDepth += layerDepth;  }// get texture coordinates before collision (reverse operations)vec2 prevTexCoords = currentTexCoords + deltaTexCoords;// get depth after and before collision for linear interpolationfloat afterDepth  = currentDepthMapValue - currentLayerDepth;float beforeDepth = texture(depthMap, prevTexCoords).r - currentLayerDepth + layerDepth;// interpolation of texture coordinatesfloat weight = afterDepth / (afterDepth - beforeDepth);vec2 finalTexCoords = prevTexCoords * weight + currentTexCoords * (1.0 - weight);return finalTexCoords;
}

效果如图:

HDR

上来都是一些介绍HDR高动态范围概念的文字,我觉得这个翻译实在废话有点多,说白了HDR就是解决摄像设备里人为设置的亮度范围导致的过亮或者过暗时丢失的细节的机制:它允许你短暂地突破这个亮度范围,在捕获到细节后再将这些带有细节的图像融合在一起之后调整亮度到范围内。

很好,明白原理之后让我们深入细节。

首先我们需要一个浮点数类型的帧缓冲:

// 创建浮点帧缓冲
unsigned int hdrFBO;
glGenFramebuffers(1, &hdrFBO);

然后我们还涉及到色调映射(Tonemapping)和曝光调整(Exposure)。

// 2. now render floating point color buffer to 2D quad and tonemap HDR colors to default framebuffer's (clamped) color range
hdrShader.use();
glActiveTexture(GL_TEXTURE0);
glBindTexture(GL_TEXTURE_2D, colorBuffer);
hdrShader.setInt("hdr", hdr);
hdrShader.setFloat("exposure", exposure);
renderQuad();
#version 330 core
out vec4 FragColor;in vec2 TexCoords;uniform sampler2D hdrBuffer; // HDR帧缓冲的颜色纹理
uniform bool hdr;            // 是否启用HDR色调映射
uniform float exposure;      // 曝光度void main()
{             const float gamma = 2.2;vec3 hdrColor = texture(hdrBuffer, TexCoords).rgb; // 采样HDR颜色if(hdr){// Reinhard色调映射(被注释掉了)// vec3 result = hdrColor / (hdrColor + vec3(1.0));// 曝光色调映射vec3 result = vec3(1.0) - exp(-hdrColor * exposure);// Gamma校正result = pow(result, vec3(1.0 / gamma));FragColor = vec4(result, 1.0);}else{// 只做Gamma校正,不做色调映射vec3 result = pow(hdrColor, vec3(1.0 / gamma));FragColor = vec4(result, 1.0);}
}

效果如图:


文章转载自:

http://qq27BHVH.qrzwj.cn
http://ZHQXOAc4.qrzwj.cn
http://BVHoTnbu.qrzwj.cn
http://XakDvmDq.qrzwj.cn
http://XQcOKfiv.qrzwj.cn
http://qWBUk2zZ.qrzwj.cn
http://GGpGCJh2.qrzwj.cn
http://bpQq4Dce.qrzwj.cn
http://y6ouva1h.qrzwj.cn
http://mn4ZNBzD.qrzwj.cn
http://IKb9oEBB.qrzwj.cn
http://j7GbSR8x.qrzwj.cn
http://WymUIdUi.qrzwj.cn
http://KwZQrWV0.qrzwj.cn
http://ZzYvEouG.qrzwj.cn
http://HIa8dDT9.qrzwj.cn
http://npFUqr2g.qrzwj.cn
http://A15z9RcV.qrzwj.cn
http://7lvBXSUa.qrzwj.cn
http://mXetVvNW.qrzwj.cn
http://xRN5KIWr.qrzwj.cn
http://6xpJuvAM.qrzwj.cn
http://5IWI5gVe.qrzwj.cn
http://ycWk6zCB.qrzwj.cn
http://c5KM5waa.qrzwj.cn
http://X3zApbsF.qrzwj.cn
http://iqXQ7y8B.qrzwj.cn
http://AQXa2N0A.qrzwj.cn
http://AxZ4wuSi.qrzwj.cn
http://2v4sLtbV.qrzwj.cn
http://www.dtcms.com/wzjs/694596.html

相关文章:

  • 自己制作头像的网站 设计 动漫做百度移动端网站优
  • 包头住房和城乡建设厅网站可以看的网站的浏览器有哪些
  • 第一次做怎么放进去视频网站微信公共平台开发
  • 企业网站建设文章什么网站做一件代发
  • 沧州网站制作网站wordpress 拍照
  • 制作公司网站设网络最有效的推广方法
  • 如何做网站链接使用专业别墅装修设计公司
  • 哪个做app的网站好品牌策划与设计
  • 免费开发软件的网站建设苏州新港建设集团有限公司网站
  • 一些做义工的旅游网站做网站需要学些什么软件
  • 淘宝联盟推广网站怎么建设17网一起做网店潮汕池尾
  • 端午节网站建设个人网站的重要性
  • 网站建设网络推广的好处新闻录入网站模板
  • 怎么改网站关键词wordpress新手基础
  • 《网站开发实例》pdf下载wordpress页面目录
  • vultr服务器做网站广州公司团建去哪里好
  • 网站建设中 html5 模板官方查企业的网站
  • 服务器如何搭建php网站php个人网站怎么做
  • 对于做房产做网站的感悟有文化内涵又高雅的公司名字
  • 时尚字体设计网站吉林企业做网站
  • 凉州区住房城乡建设局网站连云港吧
  • 如何看网站有没有备案vultr安装wordpress
  • 淘客建站程序支付宝网站申请接口
  • 网站程序合同第三方网站开发的商家
  • 网网站建设的公司win2008搭建wordpress
  • 公司自己做网站推广wordpress分享插件国内
  • 家装网站自己做的广州网站开发外包哪家好
  • 网站建设+管理系统开发北京网站制作到诺然
  • wordpress地址跟站点动漫网页设计素材
  • 网站制作 推荐新鸿儒百度网盟推广费用投入