IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 【虚拟仿真】Unity3D中实现UI跟随3D模型旋转移动、UI一直面朝屏幕 -> 正文阅读

[游戏开发]【虚拟仿真】Unity3D中实现UI跟随3D模型旋转移动、UI一直面朝屏幕

推荐阅读

大家好,我是佛系工程师☆恬静的小魔龙☆,不定时更新Unity开发技巧,觉得有用记得一键三连哦。

一、前言

前段时间有小伙伴问我,如何让UI跟着3D模型移动,如何在鼠标点击模型的时候出现UI,如何让UI一直面向屏幕。

好家伙,问题不少呀。

二、分析问题,解决问题

我们逐个分析:

首先,让UI跟随3D模型移动,我首先想到的是将UI的渲染模式改为World Space(世界模式),这时候UI就变成3D世界中的一个对象了,然后调整UI到指定位置,然后把UI的父对象设置为模型就可以了。

这是一种比较简便的方法,人物的血条通常也可以这么制作,就是调整UI的位置,调整UI的缩放还是比较麻烦的,优点是设置完调整比较方便。

点击模型出现UI,这个也简单,UI都是一个对象了,控制对象隐藏和显示还不简单吗?

UI一直面向屏幕,这个就有点麻烦了,需要获取到所有的UI对象,然后使用lookAt函数,让UI一直面向摄像机对象即可,参考代码:

//target就是摄像机的位置,transform就是当前的UI对象,给每个UI对象加上这个脚本
Vector3 tar = target.position;
tar.y = transform.position.y;
transform.LookAt(tar);

当然,不仅仅只有上面这一种实现方法。

还有一种实现方法:

那就是不改变UI的渲染模式,UI还是2D的,然后在Update函数里面将3D对象的位置坐标转化为屏幕坐标,然后再赋值给UI对象,这样UI对象还是实时跟随3D对象。

效果图:
在这里插入图片描述
下面,我们就来分别实现这两种方法。

三、实现第一种方案:UI改成3D模式

第一步:将UI渲染模式改成WorldSpace

为了方便演示,随便制作了一个UI面板:
在这里插入图片描述
然后将UI的Canvas的Canvas组件的RenderMode改成WorldSpace:
在这里插入图片描述

第二步:调整UI的相对位置

拖拖拽拽:
在这里插入图片描述
可以看到UI还是很大的,我们控制UI的缩放:
在这里插入图片描述

提示一下:最好是将Image放大到整个Canvas,然后直接缩放Canvas,不然只缩放Image,然后Canvas整体给3D对象后,3D对象的旋转就成了问题,如下图所示:
在这里插入图片描述
旋转中心点都跑到姥姥家了啊喂!

第三步:设置UI的父节点到3D对象上

将整个Canvas设置为3D对象的子对象,只拖Image过去是不行的(因为UI只有在Canvas节点下才显示):
在这里插入图片描述

第四步:移动3D对对象

在这里插入图片描述
效果还是可以的。

第五步:UI一直面向屏幕

新建一个UI看摄像机的脚本LookCamera.cs:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class LookCamera : MonoBehaviour
{
    private Transform target;//摄像机对象
    // Start is called before the first frame update
    void Start()
    {
        target = GameObject.Find("Main Camera").GetComponent<Transform>();
    }

    // Update is called once per frame
    void Update()
    {
        Vector3 tar = target.position;
        tar.y = transform.position.y;
        transform.LookAt(tar);
    }
}

将脚本添加到UI身上即可。

四、实现第二种方案:3D坐标转屏幕坐标

第一步:搭建UI

简单做一个UI面板:
在这里插入图片描述

第二步:编写代码,进行坐标转换

参考代码:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Test01 : MonoBehaviour
{
    public GameObject Cube;//3D对象
    public GameObject Image;//UI对象

    void Update()
    {
        Vector3 pos = Camera.main.WorldToScreenPoint(Cube.transform.position);
        //x轴偏移100,要不然盖住3D对象了
        Image.transform.position = new Vector3(pos.x + 100, pos.y, pos.z);
    }
}

将对应对象拖入对应卡槽中:
在这里插入图片描述
完成了:
在这里插入图片描述

第三步:实现点击模型出现UI

参考代码:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Test01 : MonoBehaviour
{
    public GameObject Cube;//3D对象
    public GameObject Image;//UI对象

    private void Start()
    {
        //先隐藏
        Image.gameObject.SetActive(false);
    }
    void Update()
    {
        Vector3 pos = Camera.main.WorldToScreenPoint(Cube.transform.position);
        //x轴偏移100,要不然盖住3D对象了
        Image.transform.position = new Vector3(pos.x + 100, pos.y, pos.z);

        if (Input.GetMouseButtonDown(0))
        {
            //从摄像机发出到点击坐标的射线
            Ray ray = Camera.main.ScreenPointToRay(Input.mousePosition);
            RaycastHit hit;
            if (Physics.Raycast(ray, out hit))
            {
                if (hit.collider.name == "Cube")
                {
                    Image.gameObject.SetActive(true);
                }
            }
        }
    }
}

效果图:
在这里插入图片描述
更多射线介绍,可以看我这篇文章:
https://blog.csdn.net/q764424567/article/details/80407920

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章           查看所有文章
加:2021-11-15 16:10:45  更:2021-11-15 16:11:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 5:10:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码