- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这与另一个问题(那里的图像)中描述的问题有关:
Opengl shader problems - weird light reflection artifacts
我有一个 .obj 导入器,它创建一个数据结构并计算切线和双切线。这是我的对象中第一个三角形的数据:
我对切线空间的理解是法线从顶点向外指向,切线与法线向量垂直(正交?)并指向纹理中正 S 的方向,而双切线则垂直于两者。我不确定你怎么称呼它,但我认为这 3 个向量形成了看起来像旋转或变换的 x、y、z 轴的东西。它们不会是 3 个随机方向的向量,对吗?
我的理解也是:法线贴图中的法线提供了一个新的法线向量。但是在切线空间纹理贴图中,rgb 编码法线和每顶点法线之间没有内置方向。因此,您可以使用 TBN 矩阵来弥合差距并将它们放在相同的空间中(或在正确的空间中获得照明)。
但是后来我看到了对象数据...我的结构有 270 个顶点,所有顶点的切线 Y 都为 0。切线数据是否正确?这些切线是否像顶点法线空间一样?或者他们只是看起来完全错误?或者我对它是如何工作的以及我的数据是否正确感到困惑?
为了更接近解决我在另一个问题中的问题,我需要确保我的数据是正确的,以及我对切线空间照明数学如何工作的理解。
最佳答案
切线和双切线向量指向纹理坐标的 S 和 T 分量的方向(U 和 V 对于不习惯 OpenGL 术语的人)。所以切线向量指向 S,双切点指向 T。
所以是的,这些不必与法线或彼此正交。它们遵循纹理映射的方向。实际上,这就是它们的目的:允许您将法线从模型空间转换到纹理空间。它们定义了从模型空间到纹理空间的映射。
如果该顶点处的 S 和 T 分量是正交的,则切线和副切线将仅相互正交。也就是说,如果纹理贴图没有切变。虽然大多数纹理映射算法会尽量减少切变,但它们无法消除它。所以如果你想要一个精确的矩阵,你需要一个非正交的切线和双切线。
关于math - 在 TBN 矩阵中,法线、切线和双切线向量总是垂直吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15433917/
许多贴图技术包括法线凹凸贴图、视差贴图和其他需要特殊的每顶点切线空间基础(切线、法线、副法线/双切线)。 这显然意味着我的模型不仅应该导出 顶点位置 , 纹理坐标和 近似每顶点法线 ,但也是切线空间基
如何绕过函数tan(x)未定义的角度,即x != Pi/2 + k * PI ? 我尝试使用条件: (x != 0) && (2 * x / M_PI - (int)(2 * x / M_PI ) )
我想绘制一个简单的图示,说明如何使用导数找出函数在任意点的斜率。它看起来有点像这样: 我已经使用这段代码绘制了一个简单的抛物线: import numpy as np from matplotlib
给定两个函数,我想找出两条曲线的公切线: 公切线的斜率可以通过以下方式获得: slope of common tangent = (f(x1) - g(x2)) / (x1 - x2) = f'(x1
我知道 tan(angle) 让我得到切线。但是,如何进行“反向切线”,以便在给定直角三角形两边长度的情况下得到角度? 我假设在 math.h 中有一个方法? 最佳答案 正如其他人所提到的,atan(
我是一名优秀的程序员,十分优秀!