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

做网站是百度包年快照网站制作便宜

做网站是百度包年快照,网站制作便宜,开发一个进销存app需要多少钱,为什么网站百度搜不到1. 法线贴图(Normal Mapping) 法线贴图是一种在3D图形渲染中广泛使用的表面细节增强技术。它通过存储每个像素的法线信息来模拟表面的细微凹凸细节,而无需增加实际的几何复杂度。 1.1. 工作原理 纹理存储 使用RGB通道存储法线向量的XYZ分量…

1. 法线贴图(Normal Mapping)

法线贴图是一种在3D图形渲染中广泛使用的表面细节增强技术。它通过存储每个像素的法线信息来模拟表面的细微凹凸细节,而无需增加实际的几何复杂度。

1.1. 工作原理

  1. 纹理存储

    • 使用RGB通道存储法线向量的XYZ分量
    • 通常呈现出偏蓝色的外观(因为默认法线指向Z轴)
    • 每个像素都包含表面法线方向信息
  2. 切线空间

    • 法线贴图通常在切线空间(TBN空间)中定义
    • 包含切线(Tangent)、副切线(Bitangent)和法线(Normal)
    • 便于将法线信息应用到任意曲面

1.2. 优势

  • 高效率

    • 不增加模型的多边形数量
    • 能够呈现出丰富的表面细节
    • 性能开销相对较小
  • 灵活性

    • 可以与其他贴图技术结合使用
    • 适用于静态和动态物体
    • 便于美术人员制作和修改

1.3. 应用场景

  • 游戏角色的皮肤细节
  • 建筑物表面的砖块纹理
  • 布料的褶皱效果
  • 地形的细节增强

1.4. TBN空间

TBN空间(Tangent Space)是法线贴图中的一个关键概念,它由三个相互垂直的向量构成:切线(Tangent)、副切线(Bitangent)和法线(Normal)。

  1. T - 切线(Tangent)

    • 沿着纹理坐标U方向的向量
    • 通常与物体表面相切
    • 在顶点着色器中计算
  2. B - 副切线(Bitangent)

    • 沿着纹理坐标V方向的向量
    • 与切线和法线都垂直
    • 可以通过叉积计算:B = N × T
  3. N - 法线(Normal)

    • 垂直于物体表面的向量
    • 决定了表面的朝向
    • 由模型数据提供

1.5. TBN矩阵的作用

// TBN矩阵的构建
mat3 TBN = mat3(T, B, N);

主要用途:

  • 将法线贴图中的法线向量从切线空间转换到世界空间
  • 保证法线方向在任意曲面上都正确
  • 使法线贴图可以在不同的表面上重复使用

1.6. 优势

  • 空间一致性:保证法线方向在任何表面都能正确表现
  • 可重用性:同一个法线贴图可以应用到不同的模型上
  • 精确性:提供了准确的法线方向计算

1.7. 实现流程

可以在顶点着色器中计算TBN矩阵,并在片段着色器中应用它,也可以在片段着色器中计算TBN矩阵。

以下代码展示了如何在片段着色器中计算TBN矩阵:

layout (binding =0) uniform sampler2D normalMap;    // 法线贴图
//uniform sampler2D heightMap;    // 高度贴图// 计算法线的函数
// normal: 顶点的法线向量
// tangent: 顶点的切线向量
// texCoord: 纹理坐标
vec3 calcNormal(vec3 normal, vec3 tangent, vec2 texCoord)
{// 使用Gram-Schmidt正交化计算切线T// 确保切线与法线垂直vec3 T = normalize(tangent - dot(tangent, normal) * normal);// 通过叉积计算副切线B// T和N叉积得到B,确保三个向量相互垂直vec3 B = normalize(cross(T, normal));// 从法线贴图中获取法线数据并转换到[-1,1]范围vec3 N = normalize(texture(normalMap, texCoord).xyz * 2.0 - 1.0);// 构建TBN矩阵// 用于将切线空间的法线转换到世界空间mat3 TBN = mat3(T, B, N);// 从法线贴图中获取法线数据vec3 retrivedNormal = texture(normalMap, texCoord).xyz;// 将法线从[0,1]范围转换到[-1,1]范围retrivedNormal = normalize(retrivedNormal * 2.0 - 1.0);// 使用TBN矩阵将法线从切线空间转换到世界空间vec3 newNormal = normalize(TBN * retrivedNormal);return newNormal;
}

1.8. 进一步说明切线向量

实际中,切线向量通常由模型数据提供,例如顶点法线、顶点切线等。这些数据通常存储在模型文件中,例如OBJ文件。
如果模型中没有提供切线向量,就需要通过计算得到。对于表面可导的曲面,可以通过计算得到切线向量。而如果 曲面不可导,就需要使用其他方法来计算切线向量。一种折中的方式是将每个顶点指向下一个顶点的向量作为切线向量。但这样会造成顶点法线与切线向量不垂直,从而影响法线贴图的效果。因此,在着色器中计算切线向量时,需要使用一些技巧来保证切线向量与顶点法线垂直。

 // 确保切线与法线垂直vec3 T = normalize(tangent - dot(tangent, normal) * normal);

1.9. 法线贴图内容说明

法线贴图通常由RGB三个通道组成,分别表示法线向量的X、Y、Z分量。每个分量取值范围为[-1,1],但实际文件存贮为[0,1],所以需要经过转换。

// 法线贴图中的法线向量从[0,1]范围转换到[-1,1]范围retrivedNormal = normalize(retrivedNormal * 2.0 - 1.0);

下图为法线贴图

法线贴图呈现蓝色的原因

  1. 法线向量的存储方式
  • RGB通道分别对应XYZ轴向
  • 值范围从[-1,1]映射到[0,1]存储
  • 转换公式:color = normal * 0.5 + 0.5
  1. 默认法线方向
  • 在切线空间中,默认法线指向Z轴正方向(0,0,1)
  • 转换到[0,1]范围后变为(0.5,0.5,1.0)
  • 这导致蓝色通道(Z轴)的值最大
  1. 颜色表现
  • R通道(X)≈0.5:中等红色
  • G通道(Y)≈0.5:中等绿色
  • B通道(Z)≈1.0:最大蓝色
  • 三个通道叠加后呈现出偏蓝色的外观

2. 高度贴图(Height Mapping)

高度贴图是一种使用灰度图来存储表面高度信息的技术,用于在渲染时动态改变表面几何形状。

2.1. 工作原理

  1. 纹理存储

    • 使用单通道灰度图存储高度信息
    • 黑色(0.0)表示最低点
    • 白色(1.0)表示最高点
    • 灰度值表示中间高度
  2. 置换映射

    • 根据高度值沿法线方向移动顶点
    • 可以实际改变几何形状
    • 需要较高的网格分辨率
  3. 视差映射

    • 不改变实际几何形状
    • 通过调整纹理坐标创造深度错觉
    • 性能消耗较小

2.2. 优势

  • 真实的凹凸效果

    • 可以产生实际的几何变化
    • 在边缘处有正确的轮廓
    • 可以产生自遮挡效果
  • 易于制作和编辑

    • 使用常规图像编辑工具即可创建
    • 直观的黑白高度表示
    • 便于美术人员使用

2.3. 应用示例

// 顶点着色器 中得到的原始顶点位置为vertPos,经过处理后的顶点位置为pvec3 p=vertPos+ vertNormal*texture(heightMap,vertTexCoord).r*0.2;

2.4. 与法线贴图的区别

  1. 几何影响

    • 高度贴图可以实际改变几何形状
    • 法线贴图只改变光照计算
  2. 资源消耗

    • 高度贴图需要更多的顶点数据
    • 法线贴图主要影响像素着色
  3. 效果表现

    • 高度贴图可以产生真实的凹凸轮廓
    • 法线贴图在边缘处效果有限

以下是高度图 (灰度图)

以下是示例中采用的纹理图,为简便起见,只是将高度图加了绿色

3. 参考

  1. 学习笔记完整代码下载
  2. OpenGL shader开发实战学习笔记:第十章 法线贴图_法线贴图是什么意思-CSDN博客

文章转载自:

http://IxZmtMTa.swkzr.cn
http://OG2xEGeF.swkzr.cn
http://cHS0Z5V1.swkzr.cn
http://1COrmSmB.swkzr.cn
http://Kv9wUJ3T.swkzr.cn
http://buHfqsfJ.swkzr.cn
http://cNNYQYfs.swkzr.cn
http://Yro1MX4b.swkzr.cn
http://vmRE2gED.swkzr.cn
http://hWqLlXOF.swkzr.cn
http://fb0mjoT1.swkzr.cn
http://5nfOHO3Y.swkzr.cn
http://RBPUDRD3.swkzr.cn
http://Fwfe62MQ.swkzr.cn
http://pyeA4VTn.swkzr.cn
http://ImAlHb1Z.swkzr.cn
http://VhT77DPu.swkzr.cn
http://yTOQL13O.swkzr.cn
http://mW6Jkq7E.swkzr.cn
http://YJwsbtne.swkzr.cn
http://SArU7aDI.swkzr.cn
http://XShY61c2.swkzr.cn
http://DZ6h0X57.swkzr.cn
http://Ynejvyxa.swkzr.cn
http://7z2SsKgA.swkzr.cn
http://pgGBlnRO.swkzr.cn
http://JGTAzeQN.swkzr.cn
http://wm0ZbboU.swkzr.cn
http://iuIY1BKL.swkzr.cn
http://kmOHjmFs.swkzr.cn
http://www.dtcms.com/wzjs/738997.html

相关文章:

  • 做一个企业网站需要多长时间阿里云服务器的网站备案流程
  • 网站制作与网站建设分销商城网站建设
  • 网站做子站点有什么用广州互联网公司
  • 扶贫网站建设的意义集团公司手机站网站
  • 苏州教育平台网站建设wordpress 导航函数
  • 电商网站设计规范西安做网站公司有哪些
  • 专业做互联网招聘的网站有哪些内容wordpress美容养生
  • 网站要素WordPress 云锁
  • 展示系统 网站模板免费下载电脑做系统网站
  • 海宁市网站建设为什么要建立网站
  • wordpress网站从零营销型网站的三大特点
  • 网站开发图片编辑技术支持 东莞网站建设 轴承
  • 西安网站建设开发查派贵阳利于优化的网站
  • 高端网站建设的小知识wordpress打不开自定义
  • wordpress子分类模板站长工具seo综合查询引流
  • 谷歌网站推广策略方案深圳做网站的公司
  • 西安网站建设推荐求几个好看的关键词
  • 提供网站制作公司地址下载百度2023最新版安装
  • 广东外贸网站推广公司汕头企业网页设计
  • 淄博圻谷网站建设制作网站定位与建设
  • 陕西交通建设集团网站体检wordpress小工具 样式
  • 上海网站制作福州wordpress删除管理站点链接
  • 快速建站网站啦手机兼职软件推荐app
  • 常德网站建设的策划方案网站建设 英文版
  • 专业一元夺宝网站建设如何分析网站开发语言
  • 中国网站设计模板网站开发详细流程
  • 四大门户网站创始人做风投要关注哪些网站
  • 西平企业网站建设网站图片验证码出不来
  • 如何建立网站视频开发一亩地多少钱
  • 深圳罗湖网站开发房产获客软件