Unity在UI界面上显示3D模型/物体,控制模型旋转

摘要:
UI界面上Unity3D对象的显示提供了整个过程,并提供了中文翻译。中国坚持为世界带来简单的生活方式!帮助快速使用UGUI在UI界面上完成3D对象的显示,为新手节省宝贵时间,避免挖坑!中文教程效果:1描述-教程描述2创建UI-创建UI元素3创建RenderTextureAndCamera-创建渲染纹理和相机4远程RawImage-将渲染纹理与图像5创建立方体-创建立方体,并查看3D效果6控制旋转-控制3D模型/对象旋转7项目-项目文件支持MayBe-进行开发,总有一天你必须做点什么!

Unity3D物体在UI界面的显示


本文提供全流程,中文翻译。

Chinar 坚持将简单的生活方式,带给世人!

(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例)


Chinar —— 心分享、心创新!

助力快速利用 UGUI 完成 3D 物体在 UI 界面的显示

为新手节省宝贵的时间,避免采坑!


Chinar 教程效果:
这里写图片描述



全文高清图片,点击即可放大观看 (很多人竟然不知道)


1

Description —— 教程描述


游戏开发过程中,我们时长会需要把 3D 游戏对象/模型显示在 UI 界面上

例如王者荣耀上的人物选择,可以旋转、交互、控制

例如商城购买时,我们可以旋转人物,看时装效果是否令我们满意

那么我们开发者就需要做到,让UI元素来显示3D模型/游戏对象,供玩家控制使用
举个栗子黑白88


2

Create UI —— 创建一个UI元素


Hierarchy / 层次面板中,创建一个 UI 元素 RawImage

创建 RawImage 是因为,我们稍后将要把相机记录的渲染纹理,赋值给 RawImage

用以显示3D图像
举个栗子黑白88
这里写图片描述


3

Create RenderTexture And Camera —— 创建渲染纹理与相机


新建一个相机,用来专门照射3D模型/游戏对象 —— 为了避免会影响到主视角,所以我们把位置设置到远一些的位置

新建一个 RenderTexture ,赋值新建的相机,用来记录相机渲染图像

注意:

RenderTexture 是可以设置分辨率的,默认只有256*256

所以显示3D模型的时候,可能会出现模糊不清的情况。那么只需要调高分辨率即可,这里我改为了1024*768

另外,移除新相机上的 Audio Listener 这里写图片描述组件,不然会报警说场景中存在2个

举个栗子黑白88
这里写图片描述


4

Relevance RawImage —— 将渲染纹理关联图片


RenderTexture 指定相机后,同样指定给最初创建的 Relevance RawImage

这样,新建相机下出现任何物体,都会被渲染纹理记录,并显示在 RawImage
举个栗子黑白88
这里写图片描述


5

Create Cube —— 创建一个立方体,看下3D效果


完成以上操作,我们在场景中创建一个 Cube ,并把位置调整到新建相机的视野中

我们即可在 Game 视窗中看到 3D 立体效果
举个栗子黑白88
这里写图片描述


6

Control The Rotation —— 控制3D模型/物体旋转


在新建的相机上加一个脚本来控制相机的旋转,来 360 度的全方位看我们的游戏对象 /Cube

UI 进行整理(这里我只是为了 Demo效果更便于新手理解,大家也可以不做整理依旧出效果)

注意:

以下代码,需要指定目标对象,需要将Cube 指定到 Pivot 属性中即可

运行后,右键即可控制UI上的3D物体进行旋转!

也可以写一个脚本,控制 游戏对象 /Cube 的旋转都行
举个栗子黑白88
这里写图片描述

using UnityEngine;


/// <summary>
/// 脚本挂载新建相机上 —— 新相机Clear Flags清除标记设置为:Solid Color,不然会显示天空盒
/// </summary>
public class ChinarSmoothUi3DCamera : MonoBehaviour
{
    public  Transform pivot;
    public  Vector3   pivotOffset = Vector3.zero;
    public  Transform target;
    public  float     distance       = 10.0f;
    public  float     minDistance    = 2f;
    public  float     maxDistance    = 15f;
    public  float     zoomSpeed      = 1f;
    public  float     xSpeed         = 250.0f;
    public  float     ySpeed         = 250.0f;
    public  bool      allowYTilt     = true;
    public  float     yMinLimit      = -90f;
    public  float     yMaxLimit      = 90f;
    private float     x              = 0.0f;
    private float     y              = 0.0f;
    private float     targetX        = 0f;
    private float     targetY        = 0f;
    public  float     targetDistance = 0f;
    private float     xVelocity      = 1f;
    private float     yVelocity      = 1f;
    private float     zoomVelocity   = 1f;


    private void Start()
    {
        var angles         = transform.eulerAngles;
        targetX        = x = angles.x;
        targetY        = y = ClampAngle(angles.y, yMinLimit, yMaxLimit);
        targetDistance = distance;
    }


    private void LateUpdate()
    {
        if (!pivot) return;
        var scroll = Input.GetAxis("Mouse ScrollWheel");
        if (scroll      > 0.0f) targetDistance -= zoomSpeed;
        else if (scroll < 0.0f)
            targetDistance += zoomSpeed;
        targetDistance = Mathf.Clamp(targetDistance, minDistance, maxDistance);
        if (Input.GetMouseButton(1) || (Input.GetMouseButton(0) && (Input.GetKey(KeyCode.LeftControl) || Input.GetKey(KeyCode.RightControl))))
        {
            targetX += Input.GetAxis("Mouse X") * xSpeed * 0.02f;
            if (allowYTilt)
            {
                targetY -= Input.GetAxis("Mouse Y") * ySpeed * 0.02f;
                targetY =  ClampAngle(targetY, yMinLimit, yMaxLimit);
            }
        }

        x = Mathf.SmoothDampAngle(x, targetX, ref xVelocity, 0.3f);
        y = allowYTilt ? Mathf.SmoothDampAngle(y, targetY, ref yVelocity, 0.3f) : targetY;
        Quaternion rotation = Quaternion.Euler(y, x, 0);
        distance = Mathf.SmoothDamp(distance, targetDistance, ref zoomVelocity, 0.5f);
        Vector3 position = rotation * new Vector3(0.0f, 0.0f, -distance) + pivot.position + pivotOffset;
        transform.rotation = rotation;
        transform.position = position;
    }


    private static float ClampAngle(float angle, float min, float max)
    {
        if (angle < -360) angle += 360;
        if (angle > 360) angle  -= 360;
        return Mathf.Clamp(angle, min, max);
    }
}

7

Project —— 项目文件


项目文件为 unitypackage 文件包:

下载导入 Unity 即可使用

Demo 仅29K
举个栗子黑白88
点击下载 —— 项目资源 (积分支持)

点击下载 —— 项目资源 (Chinar免费)


支持

May Be —— 搞开发,总有一天要做的事!


拥有自己的服务器,无需再找攻略!

Chinar 提供一站式教程,闭眼式创建!

为新手节省宝贵时间,避免采坑!


先点击领取 —— 阿里全产品优惠券 (享受最低优惠)


1 —— 云服务器超全购买流程 (新手必备!)

2 —— 阿里ECS云服务器自定义配置 - 购买教程(新手必备!)

3—— Windows 服务器配置、运行、建站一条龙 !

4 —— Linux 服务器配置、运行、建站一条龙 !



Unity在UI界面上显示3D模型/物体,控制模型旋转第15张

技术交流群:806091680 ! Chinar 欢迎你的加入


END

本博客为非营利性个人原创,除部分有明确署名的作品外,所刊登的所有作品的著作权均为本人所拥有,本人保留所有法定权利。违者必究

对于需要复制、转载、链接和传播博客文章或内容的,请及时和本博主进行联系,留言,Email: ichinar@icloud.com

对于经本博主明确授权和许可使用文章及内容的,使用时请注明文章或内容出处并注明网址

免责声明:文章转载自《Unity在UI界面上显示3D模型/物体,控制模型旋转》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇C# asp Aspose.Cells 教程,包含增加勾选框,单元格,字体设置Solr——Solr Admin页面Query查询界面各个字段参数解释下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

unity Mathf 数学运算汇总

在使用unity做游戏的过程中难免会遇到这样那样的数学运算,比如简单的正弦,余弦等。其实,在c#的Mathf 函数中 还有很多方便我们开发使用的 数学函数。在此,分享下比较全面的Mathf解析(由网上收集),方便大家参考 使用。 Mathf 数学运算 Mathf.Abs绝对值 计算并返回指定参数 f 绝对值。 Mathf.Acos反余弦 static fu...

Unity3D特效-场景淡入淡出

        最近公司开始搞Unity3D..整个游戏..特效需求还是比较多的.关于UI部分的特效淡入淡出.看网上用的方法都是用个黑东东遮挡然后设置alpha这么搞....本大神感觉非常的low.而且很渣.故奋笔疾书借此文鄙视那些low方式. 关于这种处理用shader配合Material非常简单的.先来介绍下使用了哪些东东. 1.肯定是需要一个脚本的....

unity之初级工程师

一.值类型与引用类型 值类型的变量直接存储数据,而引用类型的变量持有的是数据的引用,数据存储在数据堆中。值类型变量声明后,不管是否已经赋值,编译器为其分配内存。值类型的实例通常是在线程栈上分配的(静态分配)。 引用类型声明时并没有为其分配堆上的内存空间。引用类型的对象总是在进程堆中分配(动态分配)。 值类型(value type):byte,short,...

Unity3D实践系列01,创建项目

下载并安装Unity5软件客户端。 打开软件,注册Unity帐号,并用注册帐号登录。 点击"创建Project"按钮。 把项目命名为"My First Unity Project"。 点击左下方的"Assert packages"按钮,点击"select all"文字,点击"Done"按钮,点击"Create project"按钮。 创建完毕,多了一个与项...

如何防止Unity3D代码被反编译?

欢迎访问网易云社区,了解更多网易技术产品运营经验。 网易云易盾移动游戏安全技术专家陈士留在2018年Unity技术路演演讲内容中对这个问题有过比较详细的介绍,摘录如下: 防止Unity3D代码被反编译其实就是常见的Unity手游风险中的破解风险。 一、Unity面临的破解风险 Unity的破解风险主要有Unity mono脚本解密、Unity il2...

Unity3D中使用委托和事件

Unity3D中使用委托和事件  c#语言规范 阅读目录 1.C#中的委托、事件引入 2.方法的参数是方法 前言: 本来早就想写写和代码设计相关的东西了,以前做2DX的时候就有过写写观察者设计模式的想法,但是实践不多。现在转到U3D的怀抱中,倒是接触了不少委托事件的写法,那干脆就在此总结一下吧。 回到目录 1.C#中的委托、事件引入 本想去找...