纹理贴图、法线贴图、切线空间法线贴图

前言:我好像弄懂了一点点,把这个再梳理一遍

一切都要从 Shader 说起

Shader 分为「顶点渲染器」和「片段渲染器」

  • 「顶点渲染器」

「顶点渲染器」保存三角形的三个顶点的 u v 值,给后续片段渲染器提供数据。但是返回 Viewport × Projection × ModelView × uv 值。

  • 「片段渲染器」

在调用「片段渲染器」之前,遍历属于三角形的最大矩形,用重心法算出比例。传递给「片段渲染器」,「片段渲染器」拿到这个比例以后就可以算出属于这个点的 u、v 值。通过 u、v 值从 diffuse 贴图中拿到颜色。

用图解就是这样

u = \alpha u_0 + \beta u_1 + \gamma u_2
v = \alpha v_0 + \beta v_1 + \gamma v_2

这就是不考虑光照的纹理贴图

法线贴图

当然通过\alpha ,\beta, \gamma 用插值的方法可以计算任一点的法线。

但是我们可以存储法线,像 diffuse 贴图那样通过 uv 访问。

存储法线的贴图

我们为什么需要法线贴图?

通过法线,我们可以计算该点的光照强度。使纹理感更强。

法线贴图的制作

可以看我这篇文章如何产生法线贴图
(我是翻译国外大神的,但是国外大神有点烂尾,有关键问题没有解决)

只要知道

  • 是可以从普通 「texture」贴图中计算法向量的。但是还有很多其他的办法

    左图为普通 texture,右图为由左图计算的法线贴图

这样的法线定义在切线空间中

还没完

这样的法线贴图,有一个问题

举个例子,有一个正方体,每一面都贴相同的图,而由相同的图来说,法向量永远一样。但是由于在空间中位置的不一样,每一面的世界坐标系的法向量不可能一样。所以有的面算光强度的时候就会失败!

再举个例子,我们把世界坐标系中物体的表面法向量不指向 z 轴附近,指向 y 轴附近。其他的不变,从贴图中得到的法向量还是指向 z 轴附近的。所以光照强度肯定还是错的!

明白了就给我点个赞吧

所以我们需要计算出一种矩阵,把法线从切线空间变换到一个不同的空间,这样在切线空间的法线就能和表面法线方向对齐了

一个神奇的矩阵

这个矩阵牛逼坏了

我们要计算的矩阵叫做「TBN 矩阵」。T B N 分别代表 Tangent(切线)、Bitangent(副切线) Normal(法向量)

下面叙述推导过程

  • 首先 N 是表面法向量

用差值算(用比例算)

n = \alpha n_0 + \beta n_1 + \gamma n_2

  • 看上图 T、B 的方向和纹理方向一致。

看上图可以写出,

E_1 = \Delta U_1T + \Delta V_1B
E_2 = \Delta U_2T + \Delta V_2B

可以写出

(E_{1x}, E_{1y}, E_{1z}) = \Delta U_1(T_x, T_y, T_z) + \Delta V_1(B_x, B_y, B_z)
(E_{2x}, E_{2y}, E_{2z}) = \Delta U_2(T_x, T_y, T_z) + \Delta V_2(B_x, B_y, B_z)

写出

\begin{bmatrix} E_{1x} & E_{1y} & E_{1z} \\ E_{2x} & E_{2y} & E_{2z} \end{bmatrix} = \begin{bmatrix} \Delta U_1 & \Delta V_1 \\ \Delta U_2 & \Delta V_2 \end{bmatrix} \begin{bmatrix} T_x & T_y & T_z \\ B_x & B_y & B_z \end{bmatrix}

最后得到

\begin{bmatrix} \Delta U_1 & \Delta V_1 \\ \Delta U_2 & \Delta V_2 \end{bmatrix}^{-1} \begin{bmatrix} E_{1x} & E_{1y} & E_{1z} \\ E_{2x} & E_{2y} & E_{2z} \end{bmatrix} = \begin{bmatrix} T_x & T_y & T_z \\ B_x & B_y & B_z \end{bmatrix}

算出 [T, B] 后记得要正则化噢,加上表面法向量 N

\begin{bmatrix}T_x & T_y & T_z \\ B_x & B_y & B_z \\ N_x & N_y & N_z \end{bmatrix}

还没完

哈哈,我骗你的啦。一切都结束了。最后你只要记得,在切线空间里得到的法向量乘以这个矩阵,就得到世界坐标系中的法向量啦

最后实现渲染器的代码

点个喜欢呗
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351