Unity之【使用Blend-Tree】

2023-05-16

Blended-Tree

  • 材料准备
  • 创建Animator
  • 创建Controller
  • 配置混合树
  • 脚本代码
  • 效果演示

材料准备

  1. 人物模型和动画

    直接去Unity素材库里找,动画可以找可以自己录制

  2. Unity编辑器

创建Animator

  1. 步骤

    Inspector -> Add Component -> Animator
    Animator

  2. 主要包含Controller和Avatar

    Controller 是动画控制器,接下去着重讲解
    Avatar控制人物的关节等,这里可以为空,想了解可以看官方文档

创建Controller

  1. 新建Animator Controller

    点击鼠标右键,Create-> Animator Controller在这里插入图片描述

  2. 将创建出来的Animator Controller拖动到Animator的Controller框框中
  3. 打开创建出来的 Animator Controller

    刚开始只有箭头所示的三个状态,另外两个是自己加的
    在这里插入图片描述

  4. 点击左上角导航栏的Parameters,添加三个float参数

    在这里插入图片描述

  5. 在Base Layer界面中添加两个State:Idle和Run
    (其中Idle不需要混合树,设置为Empty,Run需要混合,设置成From New Blend Tree)

    在这里插入图片描述

  6. 设置状态转换

    这里不细讲了,不懂就去翻文档把
    简言之,就是Idle和Run的互相转换条件
    (1)Idle - > Run的条件:
    在这里插入图片描述
    (2)Run -> Idle的条件:
    在这里插入图片描述

配置混合树

  1. 双击刚刚创建的混合树Run
  2. 点击Blend Tree,选择Blend Type 为 2D Simple Directional ,Parameters两个参数指定为Horizontal 和 Vertical
  3. 并在右侧Inspector(点+,选择motion),添加要混合的移动动画

    (我这里是前后左右移动)在这里插入图片描述

  4. 点击图中的蓝色方块,调整对应动画到上下左右对称的位置

    如上图所示

  5. 拖动上图的红色圆心,可以在Inspactor下方看到玩家移动混合的效果

    在这里插入图片描述


至此,混合树界面部分创建完成,接下去为人物添加动画,通过键盘控制人物移动,并观看混合效果。


脚本代码

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

/// <summary>
/// 
/// </summary>
public class PlayerMove : MonoBehaviour
{
    public float speed = 3;
    public Animator moveAnimator;

    private void Awake()
    {
        moveAnimator = GetComponent<Animator>();
    }
    private void Update()
    {
        playerMove();
    }

    private void playerMove()
    {
        Vector3 movement = getMovement() * speed * Time.deltaTime;
        float hor = getHorizontal();
        float ver = getVertical();
        moveAnimator.SetFloat("Horizontal", hor);
        moveAnimator.SetFloat("Vertical", ver);
        float moveValue = movement.sqrMagnitude;
        moveAnimator.SetFloat("Movement", moveValue);
        this.transform.position += movement;
    }

    private float getHorizontal()
    {
        float hor = Input.GetAxis("Horizontal");
        return hor;
    }

    private float getVertical()
    {
        float ver = Input.GetAxis("Vertical");
        return ver;
    }

    private Vector3 getMovement()
    {
        float hor = getHorizontal();
        float ver = getVertical();
        Vector3 movement = Vector3.forward * ver + Vector3.right * hor;
        // 做成单位向量,后面使用自定义的speed可以精确控制移动速度
        movement.Normalize();
        return movement;
    }
}

效果演示

  1. 后退 + 左移
    在这里插入图片描述
  2. 右移 + 前进
    在这里插入图片描述
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Unity之【使用Blend-Tree】 的相关文章

  • D3.js 在径向树中的元素之间添加链接(分层边缘捆绑元素)

    几个月前 我尝试过使用 d3 js 将分层边缘捆绑和径向 Reingold Tilford 树结合起来 https stackoverflow com questions 39150514 d3 js combining hierarchi
  • cytoscape:改变第二轴出租车分支的长度

    I want to create a tree with different branch lengths looking like this Is there a possibility of assigning a length to
  • 在Python中生成字典树中的所有叶到根路径

    我有一个 非标准 形式的字典树 如下所示 tree 0 A B C D E F 叶节点被定义为字典键值对 其中值是空字典 我想将所有叶到根路径提取为列表列表 如下所示 paths C B A 0 E D 0 F D 0 如果有帮助的话 也可
  • 静止搜索性能

    这是一个双重问题 我组装了一个简单的国际象棋引擎 它执行 Alpha Beta 搜索 最后执行静止搜索 静止搜索正在影响性能 问题是 这是可以接受的性能影响吗 如果不是 那么应该采取什么措施来解决这个问题 下图给出了性能影响 请注意 这些统
  • C++ 中的动态树

    我想制作一棵树 每个节点都可以有一些子节点 但我不知道它们的数量 树必须在小内存中使用 无额外数据 以每个节点的恒定时间进行编码 我认为我将创建具有值和子属性 值是 int 子属性是堆栈 的类 Tree 以及指向该树中每个节点的指针数组 我
  • 复合颜色:iPhone 上的 CALayer 和混合模式

    我正在尝试在 iPhone 上使用核心图像 我可以使用石英合成颜色来绘制 uiview 但我想将每个组件分成CALayer UIview消耗较多资源 所以我有一个白色蒙版 我想用它来过滤背景位图 并且我想尝试不同的混合模式 不幸的是 这些图
  • Tidyverse 重复跟踪父 ID 直到祖先的方法

    来自 Rebrickable 的主题数据集 https rebrickable com downloads 包括每个主题的 ID 及其父 ID 此处已重命名列 可能会递归 ID 可能有祖父母 曾祖父母等 这是一个遵循父链 City gt A
  • 可折叠树示例中的 d3.js v4 古怪链接转换

    如果您玩下面的可折叠树 您会发现当您到达树的末尾并展开和折叠节点时 这些线正在做一些古怪的事情 我不完全确定是什么驱动了这种行为 或者我的重写是否的在此输入链接描述 https bl ocks org mbostock 4339083完全没
  • 获取图表中走过的最长路线

    我有一组相互连接的节点 我有以下节点网络 这里0是起点 我想遍历尽可能多的节点 并且一个节点只遍历一次 另外 在从 0 到目标节点的旅程中 我只想有一个奇数编号的节点 如 1 3 5 7 现在我需要找出从起始位置 0 开始可以行驶的最长路线
  • 创建二叉树的时间复杂度

    我正在尝试从提供的源创建一棵树 要添加到树中的 2 个节点 以及应添加这 2 个新闻节点的节点 为了找到该节点在树中的位置 我使用了中序遍历 该遍历的时间复杂度为 O n 因此 如果要在树中添加 n 个节点 则创建整个树的时间复杂度为 O
  • 二叉搜索树是平衡的吗?

    这已经讨论过了here https stackoverflow com questions 742844 how to determine if binary tree is balanced 但我在下面有一个实现 线程中从未讨论过 pub
  • 二叉树实现C++

    二叉树插入 include stdafx h include
  • 知识树中的段错误

    我正在用 c 实现一个可以从文件中读取的知识树 我的 newStr 函数出现段错误 我无法用这个问题测试我的其余代码 我对 c 没有太多经验 任何帮助将不胜感激 我的 c 文件 包括 包括 include 动物 h 包括 包括 return
  • 如何使用KDTrees实现最近邻搜索?

    所以 我正在实施一个KD Tree http en wikipedia org wiki Kd tree进行最近邻搜索 我已经构建了树部分 但我认为我没有完全理解搜索部分 关于遍历树来搜索邻居 维基百科文章如下 Starting with
  • 如何使用 XSLT 从平面 XML 列表构建树?

    我使用极简 MVC 框架 其中PHP控制器手上的DOM模型 to the XSLT 视图 c f okapi http okapi liip ch 为了构建导航树 我在 MYSQL 中使用了嵌套集 这样 我最终得到一个如下所示的模型 XML
  • 我该如何实现这个折叠功能呢?

    给出了两种数据类型 颜色 和 植物 data Color Red Pink White Blue Purple Green Yellow deriving Show Eq data Plant Leaf Blossom Color Stal
  • 使用 Java 进行树可视化 [关闭]

    Closed 此问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 我正在寻找一个库来生成图形或树 例如组织图表 该库应该能够从该图中生成纯图像 有谁知道一个好的 希望开源
  • 如何展平解析树并存储在字符串中以进行进一步的字符串操作 python nltk

    我正在尝试从树结构中获取扁平树 如下所示 我想将整个树放在一个字符串中 就像没有检测到坏树错误一样 S NP SBJ NP DT The JJ high JJ seven day PP IN of NP DT the CD 400 NNS
  • 使用redis进行树形数据结构

    我需要为基于树的键值开发一个缓存系统 与Windows注册表编辑器非常相似 其中缓存键是字符串 表示树中到值的路径 可以是原始类型 int string bool double 等 或子树本身 例如 key root x y z w val
  • 应用对数来导航树

    我曾经知道一种使用对数从树的一片叶子移动到树的下一个 有序 叶子的方法 我认为它涉及获取 当前 叶子的位置值 排名 并将其用作从根向下到新目标叶子的新遍历的种子 一直使用对数函数测试来确定是否沿着右或左节点向下到达叶子 我已经不记得如何运用

随机推荐