unity3d的矩阵元素存储方式

想知道u3d矩阵各个元素的存储方式,所以测试了一下

Matrix4x4 m = Matrix4x4.TRS(new Vector3(1, 2, 3), Quaternion.Euler(0, 0, 30), new Vector3(1, 1, 1));
        for (int i = 0; i < 4; i++)
        {
            for (int j = 0; j<4; j++)
            {
                Debug.Log(m[i, j]);
            }
        }
        for (int i = 0; i < 16; i++)
        {
            Debug.Log(m[i]);
        }  

结果输出 0.866  -0.5   0   1    0.5  0.866 0 2  0  0   1  3   0  0  0  1

0.866  0.5 0   0     -0.5   0.866  0  0  0  0  1  0   1  2  3  1

从输出可以看到unity的矩阵采用矩阵左乘法,及向量用列向量表示, 也正是因为采用列向量表示,  矩阵的16个元素前面是个是第一列,然后是第二列,第三列和第四列。

时间: 2024-10-27 07:34:52

unity3d的矩阵元素存储方式的相关文章

&lt;15&gt;【掌握】一维数组的存储方式+【掌握】一维数组长度计算方法+【了解】一维数组元素地址+【掌握】一维数组长度计算方法 +【掌握】一维数组的越界问题+【掌握】应用:找最大值

[掌握]一维数组的存储方式 存储方式: 1)分配一块连续的存储空间 2)数组名称代表数组的首地址,从首地址开始,依此存入数组的第一个,第二个...第n个元素 3)每个元素占用相同的字节数(取决于数组类型) 4)元素之间的地址说连续. [了解]一维数组元素地址 #include <stdio.h> int main(int argc, const char * argv[]) { //定义两个数组 int x[]={1,2}; char ca[5]={'a','B','C','D','E'};

OpenCV快速遍历矩阵元素方法

OpenCV中Mat矩阵data数据的存储方式和二维数组不一致,二维数组按照行优先的顺序依次存储,而Mat中还有一个标示行步进的变量Step.使用Mat.ptr<DataTyte>(row) 行指针的方式定位到每一行,可快速遍历矩阵.例程如下: 1 std::cout << "The inverse matrix of K is:" << std::endl; 2 for(int i=0;i<3;i++) 3 { 4 float* data =

MATLAB基础知识——1.4矩阵元素的引用

矩阵元素的引用方式 (1)通过下标引用矩阵元素,下标必须为正整数,且用圆括号括起来. (2)通过序号来引用,在MATLAB中矩阵元素按列存储.序号与下标是一一对应的,以m*n的矩阵A为例,矩阵A(i,j)的序号就是(j-1)*m+i sub2ind函数:将矩阵中指定元素的行.列下标转换成存储的序号.调用格式为 D=sub2ind(S,I,J),S说明要转换的矩阵的行数和列数,通常有size函数获取:I是要转换元素的行下标,J是列下标,如果I和J是矩阵的话,表示要将矩阵中多个元素的行列下标进行转换

数组模拟堆栈的存储方式代码实践

堆栈的模式是先进后出,取出后堆栈中就没有取出的元素了,所以在模拟时候要注意这些问题. 1 import java.util.Arrays; 2 3 /* 4 5 需求:编写一个类使用数组模拟堆栈的存储方式. 6 7 堆栈存储特点: 先进后出,后进先出. 8 9 注意: 不再使用的对象,应该不要让变量指向该对象,要让该对象尽快的被垃圾回收期回收. 10 11 12 */ 13 class StackList{ 14 15 Object[] elements; 16 17 int index = 0

iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist)

一.ios应用常用的数据存储方式 1.plist(XML属性列表归档) 2.偏好设置 3.NSKeydeArchiver归档(存储自定义对象) 4.SQLite3(数据库,关系型数据库,不能直接存储对象,要编写一些数据库的语句,将对象拆开存储) 5.Core Data(对象型的数据库,把内部环节屏蔽) 二.应用沙盒 每个iOS应用都有?己的应?沙盒(应用沙盒就是文件系统目录),与其他文件系统隔离.应?必须待在?己的沙盒里,其他应用不能访问该沙盒(提示:在IOS8中已经开放访问) 应?沙盒的文件系

Js之Dom学习-三种获取页面元素的方式、事件、innerText和innerHTML的异同

一.三种获取页面元素的方式: getElementById:通过id来获取 <body> <input type="text" value="请输入一个值:" id="txt"/> <input type="button" value="按钮" id="btn"/> <script> var txt=document.getElementB

HTML5 Web 客户端五种离线存储方式汇总

最近折腾HTML5游戏需要离线存储功能,便把目前可用的几种HTML5存储方式研究了下,基于HT for Web写了个综合的实例,分别利用了Cookie.WebStorage.IndexedDB以及FileSystem四种本地离线存储方式,对燃气监控系统的表计位置.朝向.开关以及表值等信息做了CURD的存取操作. HTML5的存储还有一种Web SQL Database方式,虽然还有浏览器支持,是唯一的关系数据库结构的存储,但W3C以及停止对其的维护和发展,所以这里我们也不再对其进行介绍:Bewa

Python之美[从菜鸟到高手]--读&quot;一道面试题看 HashMap 的存储方式&quot;的联想

今天在伯乐在线 上看到一篇文章,一道面试题看 HashMap 的存储方式,也就是问: 在 HashMap 中存放的一系列键值对,其中键为某个我们自定义的类型.放入 HashMap 后,我们在外部把某一个 key 的属性进行更改,然后我们再用这个 key 从 HashMap 里取出元素,这时候 HashMap 会返回什么? 如何面试者直接答"这要看自定义类型的hash值了",我想面试官会非常满意. 联想到python中dict的实现,python中字典一般不存在这个问题,因为key的ha

7 线性表-栈-顺序存储的拓展-迎面增长的存储方式

描述:设有两个栈,S1和S2,都采用顺序栈的存储方式.两个栈共享一个存储区:[0,--maxsize-1]目的:可以尽量利用空间,减少溢出的可能,采用栈顶相向.迎面增长的存储方式 PS:要注意判断栈满栈空的检查 #include<stdio.h> #include<stdlib.h> #include<iostream> using namespace std; #define maxsize 100 /*栈结构的定义*/ typedef struct { int st