Unity 人物方向旋转详细讲解

news2024/9/28 7:18:59

Unity 人物方向旋转详细讲解

  • 人物的旋转有很多种
  • 一、在介绍之前我们需要理解Unity的向量也就是Vector3
  • 二、下面我们创建两个小球f1,f2
    • 左边的为f2 右边的为f1
  • 三、我们将小球坐标用白色直线画出来,两个小球之间用黑色线画出来,两个小球的向量用黄线表示
    • 接下来我们需要做的就是创建一个物体将物体旋转到黄线的方向
    • 因为旋转不需要考虑向量的大小与坐标的y值所以这里我把黄线改为单位向量并将y改为0配置如下所示
    • 所以旋转时,这根白线的单位向量就是我们物体的朝向方向
    • 此时运行场景无论该物体的旋转是多少都无所谓最后都会缓慢的转向白线的方向

人物的旋转有很多种

这里介绍旋转使用四元数的方法

Quaternion.LookRotation(Vector3 dir);
Quaternion.Lerp(Quaternion a, Quaternion b, float t);

一、在介绍之前我们需要理解Unity的向量也就是Vector3

首先我们创建一个Unity的脚本,将坐标系用Unity画出来如下

图中白球的位置为0,0,0坐标的原点
在这里插入图片描述
代码如下:

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

[ExecuteInEditMode]
public class DirTest : MonoBehaviour {
	
	// Update is called once per frame
	void Update () {
        for (int i = 0; i < 10; i++)
        {
            for (int j = 0; j < 10; j++)
            {
                Debug.DrawLine(new Vector3 (0, i, j), new Vector3 (10, i, j), Color.red);
                Debug.DrawLine(new Vector3 (i, j, 0), new Vector3 (i, j, 10), Color.blue);
                Debug.DrawLine(new Vector3 (i, 0, j), new Vector3 (i, 10, j), Color.green);
            }
        }
    }
}

二、下面我们创建两个小球f1,f2

左边的为f2 右边的为f1

在这里插入图片描述

三、我们将小球坐标用白色直线画出来,两个小球之间用黑色线画出来,两个小球的向量用黄线表示

脚本中添加两个Transform p1 ,p2

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

[ExecuteInEditMode]
public class DirTest : MonoBehaviour {

    /// <summary>
    /// 
    /// </summary>
    public Transform p1;

    /// <summary>
    /// 
    /// </summary>
    public Transform p2;
    
	// Update is called once per frame
	void Update () {
        for (int i = 0; i < 10; i++)
        {
            for (int j = 0; j < 10; j++)
            {
                Debug.DrawLine(new Vector3 (0, i, j), new Vector3 (10, i, j), Color.red);
                Debug.DrawLine(new Vector3 (i, j, 0), new Vector3 (i, j, 10), Color.blue);
                Debug.DrawLine(new Vector3 (i, 0, j), new Vector3 (i, 10, j), Color.green);
            }
        }

        Debug.DrawLine(Vector3.zero, p1.position);
        Debug.DrawLine(Vector3.zero, p2.position);
        Debug.DrawLine(p1.position,p2.position, Color.black);

        Vector3 dir = p1.position - p2.position;
        Debug.DrawLine(Vector3.zero,dir, Color.black);

        Debug.DrawLine(Vector3.zero,dir, Color.yellow);
    }
}

效果如下:

这里我们发现黑线和黄线的方向大小都是一致的只是位置不同而已
在这里插入图片描述

接下来我们需要做的就是创建一个物体将物体旋转到黄线的方向

这个黄线是有方向的:(0,0,0)到黄线的末端就是向量的方向

因为旋转不需要考虑向量的大小与坐标的y值所以这里我把黄线改为单位向量并将y改为0配置如下所示

在这里插入图片描述

所以旋转时,这根白线的单位向量就是我们物体的朝向方向

创建旋转的物体
在这里插入图片描述

代码如下:

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

[ExecuteInEditMode]
public class DirTest : MonoBehaviour {

    /// <summary>
    /// 
    /// </summary>
    public Transform p1;

    /// <summary>
    /// 
    /// </summary>
    public Transform p2;

    /// <summary>
    /// 物体
    /// </summary>
    public Transform p3;
	
	// Update is called once per frame
	void Update () {
        for (int i = 0; i < 10; i++)
        {
            for (int j = 0; j < 10; j++)
            {
                Debug.DrawLine(new Vector3 (0, i, j), new Vector3 (10, i, j), Color.red);
                Debug.DrawLine(new Vector3 (i, j, 0), new Vector3 (i, j, 10), Color.blue);
                Debug.DrawLine(new Vector3 (i, 0, j), new Vector3 (i, 10, j), Color.green);
            }
        }

        Debug.DrawLine(Vector3.zero, p1.position);
        Debug.DrawLine(Vector3.zero, p2.position);
        Debug.DrawLine(p1.position,p2.position, Color.black);

        Vector3 dir = p1.position - p2.position;
        dir.y = 0;
        Debug.DrawLine(Vector3.zero,dir, Color.black);
        Debug.DrawLine(Vector3.zero,dir, Color.yellow);
        Debug.DrawLine(Vector3.zero,dir.normalized, Color.white);


        p3.rotation = Quaternion.Lerp(p3.rotation,Quaternion.LookRotation(dir.normalized),Time.deltaTime * 3f);
    }
}

此时运行场景无论该物体的旋转是多少都无所谓最后都会缓慢的转向白线的方向

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1334086.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软信天成:选择和部署主数据管理(MDM)的十大关键要求(下)

上期我们分享了软信天成&#xff1a;选择和部署主数据管理&#xff08;MDM&#xff09;的十大关键要求&#xff08;上&#xff09;&#xff0c;这期将继续为大家分享余下五大关键要求。 上期关键内容回顾&#xff08;前五大关键要求&#xff09; 在单一MDM系统内为多个业务数据…

哪个超声波清洗机好?适合洗眼镜超声波清洗机有哪些?

随着科技的进步&#xff0c;超声波清洗机已经成为了家居清洁的必备神器。尤其是对于眼镜、珠宝、饰品等需要深度清洁的小物件&#xff0c;超声波清洗机更是不可或缺。眼镜店最经常看见超声波清洗机的身影&#xff0c;可以很好帮我们清洗眼镜同时有些比较好的超声波清洗机还会带…

java实现广度优先搜索算法

广度优先搜索算法&#xff08;BFS&#xff09;是一种用于图遍历的算法。它从图的某个节点开始&#xff0c;依次访问其所有邻接节点&#xff0c;再依次访问邻接节点的邻接节点&#xff0c;以此类推&#xff0c;直到遍历完所有节点。 BFS使用队列数据结构来实现遍历过程。具体步…

Odoo16 实用功能之在Form视图的各个部位加入按钮

目录 1、 如何在form视图中的头部加上按钮 2、如何在form视图中的身体加上按钮 3、如何在notebook标签中加入按钮 1、 如何在form视图中的头部加上按钮 以CRM中的渠道form视图为例子介绍&#xff08;实现红框中的效果&#xff09; 直接在<header>标签里加入按钮即可 …

042、序列模型

之——从时序中获取信息 目录 之——从时序中获取信息 杂谈 正文 1.建模 2.方案A-马尔科夫假设 3.方案B-潜变量模型 4.简单实现 杂谈 很多连续的数据都是有前后的时间相关性的&#xff0c;并不是每一个单独的数据是随机出现的。在时序中会蕴含一些空间结构的变化信息、…

简洁高效的 NLP 入门指南: 200 行实现 Bert 文本分类 (Pytorch 代码纯享版)

简洁高效的 NLP 入门指南: 200 行实现 Bert 文本分类 Pytorch 版 概述NLP 的不同任务Bert 概述MLM 任务 (Masked Language Modeling)TokenizeMLM 的工作原理为什么使用 MLM NSP 任务 (Next Sentence Prediction)NSP 任务的工作原理NSP 任务栗子NSP 任务的调整和局限性 安装和环…

赛宁综合安全验证评估,筑牢关基网络安全屏障

在国际复杂态势和数字经济发展的驱动下&#xff0c;关键信息基础设施&#xff08;以下简称&#xff1a;关基&#xff09;的安全运营逐步走向实战化、体系化和常态化。验证评估作为安全运营的试金石&#xff0c;已成为实现动态防御、主动防御的有力手段。如何通过体系化验证评估…

Ps2022版DR5插件扩展窗口不展示及未正确签署等问题修复

前言 最近在安装DR5的时候遇到了一些报错问题&#xff0c;翻看了几篇文章找了一些实质性的方案&#xff0c;亲测有效&#xff0c;有同样问题的小伙伴自己对号入座哈。 窗口扩展不显示问题 问题 很多人第一次安装DR5时会发现这个【窗口-扩展】是灰色的&#xff0c;且没有DR5…

VR全景对普通人的生活有哪些好处?

许多普通人对VR全景还全然没有概念&#xff0c;这是因为VR全景虽然一直在快速发展&#xff0c;但目前为止也不过几年而已&#xff0c;但这发展的几年同样为我们普通人的生活带来了切实的改变和便利。VR全景技术为人们带来了沉浸感和真实感的体验&#xff0c;让我们感受到迥异于…

由浅入深,一文掌握NGINX知识文集

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

17.仿简道云公式函数实战-数学函数-ABS

1. ABS函数 ABS 函数可用于返回数字的绝对值 2. 函数用法 ABS(number) 3. 函数示例 如&#xff0c;ABS(-12)和ABS(12)的返回结果均为 12。 4. 代码实战 首先我们在function包下创建math包&#xff0c;在math包下创建AbsFunction类&#xff0c;代码如下&#xff1a; pac…

vue 使用 html2canvas 截取图片保存

vue 使用 html2canvas 截取图片保存 好久没有写博文了&#xff0c;写够了&#xff0c;没啥想写的了&#xff0c;这个号算是废了&#xff0c;哎&#xff0c;气人啊&#xff01;越来越胖&#xff0c;越来越懒了。 html2canvas 简介 html2canvas是一个JavaScript库&#xff0c;它…

MATLAB学习笔记(一)求解三阶微分方程

一、求解三阶微分方程 对于多变量三阶微分方程求解问题&#xff0c;这里介绍一种求解方法。 例题如下&#xff1a; 对于以上方程&#xff0c;给定边界条件&#xff0c;&#xff0c;&#xff0c;&#xff0c;&#xff0c;。求解和的表达式。 二、解题步骤 &#xff08;1&…

Python办公自动化Day2-openpyxl

目录 文章声明⭐⭐⭐让我们开始今天的学习吧&#xff01;常规操作添加数据遍历所有单元格数据合并/取消合并单元格添加/删除行与列移动指定范围单元格 文章声明⭐⭐⭐ 该文章为我&#xff08;有编程语言基础&#xff0c;非编程小白&#xff09;的 Python办公自动化自学笔记知识…

毫米波RIS研究测试方案:一站式助力工程师探索高频通信未来

方案介绍 在当前科技高速发展的时代&#xff0c;毫米波通信技术因其高数据传输速率和大容量的潜力而备受瞩目。其中&#xff0c;可重构智能表面&#xff08;RIS&#xff09;作为一项创新技术&#xff0c;正在为毫米波通信系统的设计和优化带来新的可能性。为了应对这一领域的研…

SQL Server的权限设置

实验环境&#xff08;实验案例一&#xff09; 某公司部署了 SQL Server 2016用来存储网站数据&#xff0c;由系统管理员进行维护.在bdon数据库中 已创建了class表。 需求描述 赋予用户zhangsan在bdqn数据库中创建表的权限和对class表查询和更新数据的权限。

持续集成交付CICD:Jira 发布流水线

目录 一、实验 1.环境 2.GitLab 查看项目 3.Jira 远程触发 Jenkins 实现合并 GitLab 分支 4.K8S master节点操作 5.Jira 发布流水线 一、实验 1.环境 &#xff08;1&#xff09;主机 表1 主机 主机架构版本IP备注master1K8S master节点1.20.6192.168.204.180 jenkins…

java八股 mysql优化

数据库篇-01-MySQL篇-课程介绍_哔哩哔哩_bilibili 1.定位慢查询 2.分析优化慢查询 3.索引概念及结构 3.1 红黑树&#xff08;一种自平衡的二叉排序树&#xff09; 节点可以自动平衡保证log2 n的查找复杂度. 但因为是二叉树&#xff0c;数据多了层数还会多。 所以找一个多叉树 3…

HarmonyOS 组件隔代双向数据通信Provide与Consume

今天 我们说一个场景 我们可以编写代码如下 Entry Component struct Index {State name:string "小猫猫";build() {Row() {Column() {Text(this.name)Button("改个name").onClick(() > {this.name this.name "小猫猫"?"小狗狗&quo…

whistle网络监控 fiddler的开源替代

github源码&#xff1a;https://github.com/avwo/whistle 官网说明&#xff1a;http://wproxy.org/whistle/ windows/mac一键安装 先安装nodejs 然后运行命令 npm i -g whistle && w2 start --init启动 w2 start停止 w2 stop注意停止后要手动关闭代理服务器设置 w…