unity技美32——将unity里多个含有多个mesh的资源,合并成导出成一个obj包共给第三方建模软件使用

我们在unity里经常会从商店下来很多资源,其中有些场景资源是由多个单一模型组成的,举个例子。
我门购买了一套城堡资源,资源里面墙面,树木,场景等。都是一个个单一的预制体,这个时候我们想把这些资源导出到第三方去做其他效果处理,但是从unity里面扒出来,单个物体都是归零的,我们还需要照着unity的dome重新搭积木一样搭建一次场景,这就给美术浪费了不必要的搭建时间。(如下图)
在这里插入图片描述
导出后在这里插入图片描述
如上图,这样一个个导出之后,还给从新拼凑一次。这个时候非常费劲。
下面上干货,公司的程序大牛(良少)单独就这个问题做了一个脚本。
1(私我)下载脚本在这里插入图片描述
2导入unity中。选中你要生成的预制体,如下图选择我们工具中的第三个选项。(如下图)在这里插入图片描述
3去ass目录下找到自动生成的obj文件托到你的第三方建模软件中(如下图)在这里插入图片描述
4见证神奇的时刻,你就会得到完整的max场景,并且还保留了你unity中的项目名称以及打组层级关系
在这里插入图片描述

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Unity中,可以使用以下代码将多个Mesh合并一个,并导出为.obj格式的模型文件,同时包含其使用的材质和贴图: ```csharp // 获取需要合并的所有Mesh MeshFilter[] meshFilters = gameObject.GetComponentsInChildren<MeshFilter>(); // 创建新的Mesh CombineInstance[] combineInstances = new CombineInstance[meshFilters.Length]; for (int i = 0; i < meshFilters.Length; i++) { combineInstances[i].mesh = meshFilters[i].sharedMesh; combineInstances[i].transform = meshFilters[i].transform.localToWorldMatrix; } Mesh newMesh = new Mesh(); newMesh.CombineMeshes(combineInstances); // 创建新的Material Renderer renderer = gameObject.GetComponent<Renderer>(); Material material = renderer.sharedMaterial; // 导出为.obj格式的模型文件 string path = "Assets/NewModel.obj"; ObjExporter.MeshToFile(newMesh, material, path); // 刷新AssetDatabase AssetDatabase.Refresh(); ``` 在上述代码中,首先获取需要合并的所有Mesh,并将其转换为CombineInstance数组。然后创建新的Mesh使用CombineMeshes方法将CombineInstance数组合并一个Mesh。接着获取需要导出的Material,并将其保存为一个新的Material。最后使用ObjExporter类中的MeshToFile方法将新的Mesh及其使用的Material和贴图导出为.obj格式的模型文件,并调用AssetDatabase.Refresh方法刷新AssetDatabase。 以下是修改后的ObjExporter类,支持将Mesh及其使用的Material和贴图导出为.obj格式的模型文件: ```csharp using System.Collections; using System.Collections.Generic; using System.IO; using UnityEngine; public static class ObjExporter { public static void MeshToFile(Mesh mesh, Material material, string path) { StreamWriter sw = new StreamWriter(path); sw.WriteLine("# Unity Mesh"); sw.WriteLine("mtllib " + Path.GetFileNameWithoutExtension(path) + ".mtl"); sw.WriteLine("g default"); for (int i = 0; i < mesh.vertices.Length; i++) { Vector3 v = mesh.vertices[i]; sw.WriteLine(string.Format("v {0} {1} {2}", -v.x, v.y, v.z)); } for (int i = 0; i < mesh.normals.Length; i++) { Vector3 n = mesh.normals[i]; sw.WriteLine(string.Format("vn {0} {1} {2}", -n.x, n.y, n.z)); } for (int i = 0; i < mesh.uv.Length; i++) { Vector2 uv = mesh.uv[i]; sw.WriteLine(string.Format("vt {0} {1}", uv.x, uv.y)); } for (int i = 0; i < mesh.subMeshCount; i++) { int[] triangles = mesh.GetTriangles(i); for (int j = 0; j < triangles.Length; j += 3) { int i1 = triangles[j] + 1; int i2 = triangles[j + 1] + 1; int i3 = triangles[j + 2] + 1; sw.WriteLine(string.Format("f {0}/{0}/{0} {1}/{1}/{1} {2}/{2}/{2}", i1, i2, i3)); } } sw.Close(); // 导出Material和贴图 string mtlPath = Path.GetDirectoryName(path) + "/" + Path.GetFileNameWithoutExtension(path) + ".mtl"; StreamWriter mtlSw = new StreamWriter(mtlPath); mtlSw.WriteLine("# Unity Material"); mtlSw.WriteLine("newmtl default"); mtlSw.WriteLine(string.Format("map_Kd {0}", Path.GetFileName(material.mainTexture.name))); mtlSw.Close(); string texPath = Path.GetDirectoryName(path) + "/" + material.mainTexture.name; File.Copy(AssetDatabase.GetAssetPath(material.mainTexture), texPath, true); } } ``` 在上述代码中,MeshToFile方法接受一个Mesh一个Material和一个文件路径作为参数,将Mesh及其使用的Material和贴图导出为.obj格式的模型文件并保存到指定文件路径下。在导出过程中,先将Material和贴图保存到.mtl和对应的文件中,再将Mesh的顶点、法线、UV等信息以及使用的Material的引用保存到.obj文件中。 需要注意的是,上述代码中的StreamWriter类和Path类需要使用System.IO命名空间,因此需要在代码中添加以下语句: ```csharp using System.IO; ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值