GameObject.CreatePrimitive(PrimitiveType.Cube);

GameObject.CreatePrimitive(PrimitiveType.Plane);

GameObject.CreatePrimitive(PrimitiveType.Sphere);

GameObject.CreatePrimitive(PrimitiveType.Cylinder);

然后设置transform组件:

using System;
using UnityEngine;
using UnityEditor; public class MatrixArray
{
private Vector3 scale;
private Vector3 angle;
private Matrix4x4 m_Materix;
private Quaternion m_Quaternion; private double[] init =
{
-7.143478,3.521163,-7.232108,,-1.87758,1.747491,2.705387,,2.692082,3.996646,-0.713207,,5.061553,4.274189,5.206913,
}; public MatrixArray()
{
SetScaleAndAngle();
} public Vector3 GetPosition()
{
float[] arr = DoubleToFloat(init);
Vector3 position = new Vector3(arr[], arr[], arr[]);
return position;
} public Vector3 GetScale()
{
return scale;
}
public Vector3 GetAngle()
{
return angle;
} private float[] DoubleToFloat(double[] arrs)
{
float[] outs = new float[arrs.Length];
float b = ;
int index = ;
foreach (var a in arrs)
{
b = (float) a;
outs[index] = b;
index++;
}
return outs;
} private void SetScaleAndAngle()
{
float[] arr = DoubleToFloat(init);
var te = arr;
var sx = Length(new Vector3(te[], te[], te[]));
var sy = Length(new Vector3(te[], te[], te[]));
var sz = Length(new Vector3(te[], te[], te[])); var det = Determinant();
if (det < )
{
sx = -sx;
} scale.x = sx;
scale.y = sy;
scale.z = sz; var invSX = / sx;
var invSY = / sy;
var invSZ = / sz; Vector4 v4;
for (int j = ; j < arr.Length; j++)
{
if (j % == )
{
v4 = new Vector4(arr[j - ], arr[j - ], arr[j - ], arr[j]);
m_Materix.SetColumn((int) (j / ), v4);
}
} m_Materix[] *= invSX;
m_Materix[] *= invSX;
m_Materix[] *= invSX; m_Materix[] *= invSY;
m_Materix[] *= invSY;
m_Materix[] *= invSY; m_Materix[] *= invSZ;
m_Materix[] *= invSZ;
m_Materix[] *= invSZ; QuaternionSetFromMatrix(m_Materix);
} private void QuaternionSetFromMatrix(Matrix4x4 m)
{
var trace = m.m00 + m.m11 + m.m22;
var s = 0f;
if (trace > )
{
s = 0.5f / Mathf.Sqrt(trace + 1.0f); m_Quaternion.w = 0.25f / s;
m_Quaternion.x = (m.m21 - m.m12) * s;
m_Quaternion.y = (m.m02 - m.m20) * s;
m_Quaternion.z = (m.m10 - m.m01) * s;
}
else if (m.m00 > m.m11 && m.m00 > m.m22)
{
s = 2.0f * Mathf.Sqrt(1.0f + m.m00 - m.m11 - m.m22); m_Quaternion.w = (m.m21 - m.m12) / s;
m_Quaternion.x = 0.25f * s;
m_Quaternion.y = (m.m10 + m.m01) / s;
m_Quaternion.z = (m.m20 + m.m02) / s;
}
else if (m.m11 > m.m22)
{
s = 2.0f * Mathf.Sqrt(1.0f + m.m11 - m.m00 - m.m22); m_Quaternion.w = (m.m02 - m.m20) / s;
m_Quaternion.x = (m.m10 + m.m01) / s;
m_Quaternion.y = 0.25f * s;
m_Quaternion.z = (m.m21 + m.m12) / s;
}
else
{
s = 2.0f * Mathf.Sqrt(1.0f + m.m22 - m.m00 - m.m11); m_Quaternion.w = (m.m10 - m.m01) / s;
m_Quaternion.x = (m.m20 + m.m02) / s;
m_Quaternion.y = (m.m21 + m.m12) / s;
m_Quaternion.z = 0.25f * s;
} SetFromRotationMatrix(MakeRotationFromQuaternion(m_Quaternion));
} private float[] MakeRotationFromQuaternion(Quaternion q)
{
float[] te = new float[];
te[] = te[] = te[] = te[] = ;
var x = q.x;
var y = q.y;
var z = q.z;
var w = q.w;
var x2 = x + x;
var y2 = y + y;
var z2 = z + z;
var xx = x * x2;
var xy = x * y2;
var xz = x * z2;
var yy = y * y2;
var yz = y * z2;
var zz = z * z2;
var wx = w * x2;
var wy = w * y2;
var wz = w * z2; te[] = - (yy + zz);
te[] = xy - wz;
te[] = xz + wy; te[] = xy + wz;
te[] = - (xx + zz);
te[] = yz - wx; te[] = xz - wy;
te[] = yz + wx;
te[] = - (xx + yy); // last column
te[] = ;
te[] = ;
te[] = ; // bottom row
te[] = ;
te[] = ;
te[] = ;
te[] = ; return te;
} private void SetFromRotationMatrix(float[] m)
{
var te = m;
var m11 = te[];
var m12 = te[];
var m13 = te[];
var m21 = te[];
var m22 = te[];
var m23 = te[];
var m31 = te[];
var m32 = te[];
var m33 = te[]; angle.y = Mathf.Asin(Mathf.Clamp(m13, -, )); if (Mathf.Abs(m13) < 0.99999)
{
angle.x = Mathf.Atan2(-m23, m33);
angle.z = Mathf.Atan2(-m12, m11);
}
else
{
angle.x = Mathf.Atan2(m32, m22);
angle.z = ;
} angle.x = angle.x * 180f / Mathf.PI;
angle.y = angle.y * 180f / Mathf.PI;
angle.z = angle.z * 180f / Mathf.PI; m_Quaternion = Quaternion.Euler(angle);
} private float Length(Vector3 vector3)
{
return Mathf.Sqrt(vector3.x * vector3.x + vector3.y * vector3.y + vector3.z * vector3.z);
} private float Determinant()
{
float[] arr = DoubleToFloat(init);
var te = arr; var n11 = te[];
var n12 = te[];
var n13 = te[];
var n14 = te[];
var n21 = te[];
var n22 = te[];
var n23 = te[];
var n24 = te[];
var n31 = te[];
var n32 = te[];
var n33 = te[];
var n34 = te[];
var n41 = te[];
var n42 = te[];
var n43 = te[];
var n44 = te[]; return (
n41 * (
+n14 * n23 * n32
- n13 * n24 * n32
- n14 * n22 * n33
+ n12 * n24 * n33
+ n13 * n22 * n34
- n12 * n23 * n34
) +
n42 * (
+n11 * n23 * n34
- n11 * n24 * n33
+ n14 * n21 * n33
- n13 * n21 * n34
+ n13 * n24 * n31
- n14 * n23 * n31
) +
n43 * (
+n11 * n24 * n32
- n11 * n22 * n34
- n14 * n21 * n32
+ n12 * n21 * n34
+ n14 * n22 * n31
- n12 * n24 * n31
) +
n44 * (
-n13 * n22 * n31
- n11 * n23 * n32
+ n11 * n22 * n33
+ n13 * n21 * n32
- n12 * n21 * n33
+ n12 * n23 * n31
)
);
}
}
MatrixArray类是解析
"matrix": [0.015579,0,0.999879,0,0,1,0,0,-0.999879,0,0.015579,0,-30.749359,4.370426,0,1]用的;
private void SetTransform(GameObject game)
{
MatrixArray matrix = new MatrixArray();
game.transform.position = matrix.GetPosition();
game.transform.localScale = matrix.GetScale();
game.transform.Rotate(new Vector3(matrix.GetAngle().x,,),Space.Self);
game.transform.Rotate(new Vector3(,matrix.GetAngle().y,),Space.Self);
game.transform.Rotate(new Vector3(,,matrix.GetAngle().z),Space.Self); game.transform.parent = gameObject.transform; Reverse(game.transform,matrix);
}

上面代码为unity的对象还原位移旋转缩放。

private void Reverse(Transform form,MatrixArray matrixParse)
{
//反转
Vector3 pos = matrixParse.GetPosition();
form.position = new Vector3(-pos.x,pos.y,pos.z); Vector3 scale = matrixParse.GetScale();
form.localScale = new Vector3(scale.x,-scale.y,-scale.z); form.Rotate(new Vector3(,,),Space.World);
}

由于three.js是右手坐标系,unity是左手坐标系,摄像机看到的场景会反向,上述代码解决。

unity还原three导出的json——基本模型,位移,旋转,缩放的更多相关文章

  1. unity还原three——顶点,三角面,uv

    public class Geometry { public Geometry(string name, Data data, Hashtable hash) { Debug.Log("解析 ...

  2. Blender模型导入进Unity,旋转缩放的调整

    Blender跟Unity的XYZ轴不同的原因,导致Blender模型导入Unity之后会发生模型朝向不对. 请先看看下边这个情况: 首先,Blender物体模式下,对模型进行 旋转 缩放,将会在右边 ...

  3. unity还原three之旋转

    http://www.360doc.com/content/16/0829/14/12282510_586760119.shtml unity使用左手坐标系,另外在做旋转的时候必须弄清楚旋转坐标轴和旋 ...

  4. 【Mongodb】数据库操作--备份、还原、导出和导入

    文章转载自点这里 mongodb数据备份和还原主要分为二种,一种是针对于库的mongodump和mongorestore,一种是针对库中表的mongoexport和mongoimport. mongo ...

  5. Twaver的mono-desiner导出的json文件解析

    以画的交换机为例,其他大概都差不多. 利用Twaver做出交换机模型如图1所示,其中,每一个端口都是一个单独的对象.具体Twaver操作流程参见网址:http://twaver.servasoft.c ...

  6. consul备份还原导入导出

    工作中要保证生产环境部署的consul的集群能够安全稳定地对外提供服务,即使出现系统故障也能快速恢复,这里将讲述部分的备份还原操作及KV的导入导出操作. 备份与还原 需要备份的主要有两类数据:cons ...

  7. Elasticsearch集群状态脚本及grafana监控面板导出的json文件

    脚本文件: #!/usr/bin/env python import datetime import time import urllib import json import urllib2 imp ...

  8. grafana日志分析界面及导出的json文件

    日志分析面板导出的json文件,效果图如下: 下载地址:http://files.cnblogs.com/files/xiaoming279/%E9%9D%A2%E6%9D%BF.zip 主机面板 主 ...

  9. apache poi 读取xlsx并导出为json(没考虑xls)

    1.用到的jar包:fastjson-1.2.9.poi(poi-3.15.poi-ooxml-3.15.poi-ooxml-schemas-3.15.xmlbeans-2.6.0.commons-c ...

随机推荐

  1. js正则表达式详解及示例讲解

    所谓正则表达式,简单来说就是一种规则,一种计算机能读懂的规则.js中的正则表达式语法是Perl5(一种很早的编程语言)的正则语法的子集.本文将在基础知识的基础上添加示例帮助快速理解正则表达式. 学习正 ...

  2. CentOS 中 YUM 安装桌面环境(转)

    使用 yum groupinstall 指令很容易就能安装上图形界面的桌面系统. 1. yum 的 group 指令 yum 可以以程序组的模式来安装成套的软件包.支持的软件包可以通过, # yum ...

  3. block、块级作用域

    block:语句块 (或其他语言中的 复合语句) 用来组织零个或多条语句. 包含在{ }里面 通常在流程控制语句 (如 if, for, while)中使用 块级作用域:通过var声明的变量没有块级作 ...

  4. poptest老李谈jvm的GC

    poptest老李谈jvm的GC   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:90882 ...

  5. 结合ThreadLocal来看spring事务源码,感受下清泉般的洗涤!

    在我的博客spring事务源码解析中,提到了一个很关键的点:将connection绑定到当前线程来保证这个线程中的数据库操作用的是同一个connection.但是没有细致的讲到如何绑定,以及为什么这么 ...

  6. HibernateTemplate的使用

    HibernateTemplate 提供了非常多的常用方法来完成基本的操作,比如增加.删除.修改及查询等操作,Spring 2.0 更增加对命名 SQL 查询的支持,也增加对分页的支持.大部分情况下, ...

  7. druid查询

    查询是发送HTTP请求到,Broker, Historical或者Realtime节点.查询的JSON表达和每种节点类型公开相同的查询接口. Queries are made using an HTT ...

  8. 字典树 Trie树

    什么是Trie树? 形如 其中从根节点到红色节点的路径上的字母所连成的字符串即为一个Trie树上所存的字符串. 比如,这个trie树上有ab,abc,bd,dda这些字符串. 至于怎么构建和查找或添加 ...

  9. javascript中json对象json数组json字符串互转及取值

    今天用到了json数组和json对象和json类型字符串之间互转及取值,记录一下: 1.json类型的字符串转换为json对象及取值 var jsonString = '{"bar" ...

  10. 鸟哥linux私房菜学习笔记,U盘安装centos5.3不能正常引导的问题

    前言: 一直都想学习linux,毕竟是做测试的标配.听过鸟哥的linux私房菜大名,作为新手我淘来了第三版,到手看到书的厚度,心都凉了半截,本着不能浪费的原则,还是学吧! 过程:        开始看 ...