使用RenderTexture实现3D模型与UI的组合显示
发表于2018-12-13
游戏中常见的功能如角色创建选择,NPC对话等功能中,需要3D模型与UI的组合显示,该如何实现呢?
data:image/s3,"s3://crabby-images/8d6f6/8d6f6c610e39836ec59fa86343937a83f01a86bd" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/e3f68/e3f680b0c2ec868ddf530f1a28f6fec9c7826e22" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/f2d76/f2d76efd72e321cccf579374a96423bb3dcade63" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/1a19f/1a19f7a53c084a134d2759dea47d9095511c7ce8" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/dc9a0/dc9a0a9d1ccc0b42ddace9db02d5aab3932d29b4" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/2855a/2855a94cf2322b900b383dc38fed70bdd34108c9" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/8d6f6/8d6f6c610e39836ec59fa86343937a83f01a86bd" alt="使用RenderTexture实现3D模型与UI的组合显示"
data:image/s3,"s3://crabby-images/e3f68/e3f680b0c2ec868ddf530f1a28f6fec9c7826e22" alt="使用RenderTexture实现3D模型与UI的组合显示"
如何实现
首先想到添加一个3D camera将3D模型画出来,利用Camera中的Target Texture属性来缓存绘制的3D形象,再设置相应的位置,旋转等属性。
实现环境
利用NGUI\Examples\Scenes\Example X - Character的场景来进行实验。
原生运行状态:
data:image/s3,"s3://crabby-images/f2d76/f2d76efd72e321cccf579374a96423bb3dcade63" alt="使用RenderTexture实现3D模型与UI的组合显示"
1.在2D UIPanel下创建UITexture组件用来显示缓存的renderTexture
data:image/s3,"s3://crabby-images/1a19f/1a19f7a53c084a134d2759dea47d9095511c7ce8" alt="使用RenderTexture实现3D模型与UI的组合显示"
2.创建一个3D camera用以缓存Target Texture
data:image/s3,"s3://crabby-images/dc9a0/dc9a0a9d1ccc0b42ddace9db02d5aab3932d29b4" alt="使用RenderTexture实现3D模型与UI的组合显示"
源代码
3.缓存TargetTexture,设置Texture。
using System.Collections; using System.Collections.Generic; using UnityEngine; public class CombineTexture : MonoBehaviour { [SerializeField] private Camera _cam; private RenderTexture _tex; void OnGUI() { if (GUI.Button(new Rect(100f, 100f, 100f, 50f), "Combine Texture")) { _tex = new RenderTexture(500, 500, 16); // 创建临时变量RenderTexture缓存Target Texture if (_cam != null) { _cam.targetTexture = _tex; } gameObject.GetComponent<UITexture>().mainTexture = _tex; // 设置UITexture的Texture属性 } } void OnDisable() { // 释放资源 if (_cam != null) _cam.targetTexture = null; gameObject.GetComponent<UITexture>().mainTexture = null; Destroy(_tex); _tex = null; } }
运行结果
data:image/s3,"s3://crabby-images/2855a/2855a94cf2322b900b383dc38fed70bdd34108c9" alt="使用RenderTexture实现3D模型与UI的组合显示"
在右侧的小窗口内会有一个动态的模型,与屏幕中间的模型同步显示。
注意点
在NGUI中一个UITexture对应一个drawcall,要做好对UITexture的管理;
如果要实现快照,对模型的截图等需求时,只需将RenderTexture的某一帧保存即可;
还能做什么
Render Texture
This will place the camera’s view onto a Texture that can then be applied to another object. This makes it easy to create sports arena video monitors, surveillance cameras, reflections etc.
官方的说辞:还可以实现视频监视器, 监控显示器,反射等。