关于Unity插件TriLib使用的一点儿心得

最近做一个项目的时候,由于要求动态加载fbx或者glb等格式文件,而我们自己开发加载插件难度又有点大,所以最后使用了TriLib这个插件,现在说一点使用心得。

由于文件加载之后要对加载的内容进行复制,比如加载一个柱子,然后会把这个柱子复制很多份之类的,并且在复制之后需要删除原始的物体。刚开始的时候发现一旦删除原始物体,复制出来的物体就看不到了,原因是物体中MeshFilter组件中的Mesh被删除了,也就是说复制出来的物体和原来的物体引用的是同一个Mesh,一旦删除原始物体的,其引用的Mesh也会被删除,这个主要是加载FBX时,TriLib插件给每个新加载的模型添加了AssetUnloader组件,只要这个组件被删除,那么对应被加载的模型的Mesh就会被删除。后来想了个办法,就是物体被加载之后,把物体使用的Mesh复制一份,让被加载的原始物体使用被复制的Mesh,而不是原始的,那个AssetUnloader组件不会删除复制的这份,这样在删除原始加载的物体之后就不会让复制出来物体的Mesh消失了,因为复制出来的物体使用的Mesh也是复制出来的,不是那个AssetUnloader组件里面记录的。

复制Mesh的代码参考如下:

cs 复制代码
MeshFilter[] filters = obj.GetComponentsInChildren<MeshFilter>();
for (int i = 0; i < filters.Length; i++)
{
	Mesh mesh = Instantiate(filters[i].sharedMesh);
	filters[i].sharedMesh = mesh;
}

而且后来发现材质引用的Texture也会被删除,干脆把Texture也复制了。

复制Texture的代码参考如下:

cs 复制代码
MeshRenderer[] renders = obj.GetComponentsInChildren<MeshRenderer>();
for (int i = 0; i < renders.Length; i++)
{
	MeshRenderer render = renders[i];
	Material[] mats = new Material[render.materials.Length];
	for (int j = 0; j < mats.Length; j++)
	{
		mats[j] = Instantiate(render.materials[j]);
		Texture tex = mats[j].GetTexture("_MainTex");
		if (tex != null) mats[j].SetTexture("_MainTex", Instantiate(tex));
	}
	render.materials = mats;
}

虽然上面的办法可以解决问题,但是我感觉还是能找到一些更好的办法,在想到更好的办法之前先这样吧。

相关推荐
空中海15 分钟前
第四篇:Unity高级阶段(架构级开发能力)
unity·架构·游戏引擎
小贺儿开发1 小时前
【MediaPipe】Unity3D 虚拟面具互动演示
unity·人机交互·shader·摄像头·面具·互动·脸部捕捉
DaLiangChen2 小时前
Unity URP 绘制参考网格 Shader 教程(抗锯齿 + 渐变淡出)
unity·游戏引擎
空中海3 小时前
第三篇:Unity进阶阶段(商业项目能力)
unity·游戏引擎
RReality8 小时前
【Unity Shader URP】屏幕空间扭曲后处理(Screen Space Distortion)实战教程
ui·unity·游戏引擎·图形渲染·材质
zcc85807976210 小时前
Unity 事件驱动架构
unity
心之所向,自强不息10 小时前
VSCode + EmmyLua 调试 Unity Lua(最简接入 + 不阻塞运行版)
vscode·unity·lua
空中海11 小时前
第六篇:Unity专项方向
unity·游戏引擎
mxwin12 小时前
Unity Shader 屏幕空间反射 (SSR) 原理解析
jvm·unity·游戏引擎·shader
心前阳光12 小时前
Unity之利用特性给ScriptableObject分组
unity·游戏引擎