在上一篇文章中,我们推演了矩阵几何计算。
在这篇文章中,我们来推导一下 观察空间(摄像机空间)。
可以根据上篇文章的推导得出:
Pview = [Wview] * Pworld
[Wview] = [Vworld]-1 = [Vworld]T
Pview = [Vworld]T * Pworld
现在只知道 Z轴,还需要求 X Y轴。
最后,得到的就是 视图空间坐标轴方向上的向量,归一化后即可作为基向量使用
V ? w o r l d X x ? V ? w o r l d Y x ? V ? w o r l d Z x ? V ? w o r l d X y ? V ? w o r l d Y y ? V ? w o r l d Z y ? V ? w o r l d X z ? V ? w o r l d Y z ? V ? w o r l d Z z ? \begin{matrix} V~worldXx~&V~worldYx~&V~worldZx~\\ V~worldXy~&V~worldYy~&V~worldZy~\\ V~worldXz~&V~worldYz~&V~worldZz~\\ \end{matrix} V?worldXx?V?worldXy?V?worldXz??V?worldYx?V?worldYy?V?worldYz??V?worldZx?V?worldZy?V?worldZz??
这里原本是求逆矩阵,但是基向量矩阵是正交矩阵,所以逆矩阵 = 转置矩阵
V ? w o r l d X x ? V ? w o r l d X y ? V ? w o r l d X z ? V ? w o r l d Y x ? V ? w o r l d Y y ? V ? w o r l d Y z ? V ? w o r l d Z x ? V ? w o r l d Z y ? V ? w o r l d Z z ? \begin{matrix} V~worldXx~&V~worldXy~&V~worldXz~\\ V~worldYx~&V~worldYy~&V~worldYz~\\ V~worldZx~&V~worldZy~&V~worldZz~\\ \end{matrix} V?worldXx?V?worldYx?V?worldZx??V?worldXy?V?worldYy?V?worldZy??V?worldXz?V?worldYz?V?worldZz??
在之前的步骤中,我们只完成坐标系的旋转转化。
但是,我们的 观察空间 和 世界空间 的原点不在同一地方。
所以,需要进行平移变换
1 0 0 ? T ? x ? 0 1 0 ? T ? y ? 0 0 1 ? T ? z ? 0 0 0 1 \begin{matrix} 1&0&0&-T~x~\\ 0&1&0&-T~y~\\ 0&0&1&-T~z~\\ 0&0&0&1\\ \end{matrix} 1000?0100?0010??T?x??T?y??T?z?1?
? ( V ? w o r l d X ? d o t T ) ? ( V ? w o r l d Y ? d o t T ) ? ( V ? w o r l d Z ? d o t T ) 1 \begin{matrix} -(V~worldX~ dot T) \\ -(V~worldY~ dot T) \\ -(V~worldZ~ dot T) \\ 1\\ \end{matrix} ?(V?worldX?dotT)?(V?worldY?dotT)?(V?worldZ?dotT)1?