Unity VR 开发教程 OpenXR+XR Interaction Toolkit 番外(一)用 Grip 键, Trigger 键和摇杆控制手部动画

此教程相关的详细教案,文档,思维导图和工程文件会分享在 Spatial XR 社区。这是一个高质量 XR 开发者社区,博主目前在内担任 XR 开发的讲师。该社区提供专人答疑、完整进阶教程、从零到一项目孵化保姆服务(包含产品上架App lab)、投资|融资对接、工程文件下载等服务。

社区链接:
SpatialXR社区:完整课程、项目下载、项目孵化宣发、答疑、投融资、专属圈子

在这里插入图片描述


在大部分 VR 游戏中,手部的动画通常是由手柄的三个按键来控制的。比如 Grip 键控制中指、无名指、小拇指的弯曲,Trigger 键控制食指的弯曲,触摸摇杆控制大拇指的弯曲。

这个教程,我将介绍如何利用这三个按键的输入来控制手部动画。原理和我之前写的一篇教程“Unity VR 开发教程 OpenXR+XR Interaction Toolkit (二) 手部动画”是类似的,只不过 Animation Controller 和相关脚本会有一些变化。

项目源码(持续更新):https://github.com/YY-nb/Unity_XRInteractionToolkit2.3.2_Demo (场景位于 Asset/Scene/Extra/01.Hand(New),脚本位于 Asset/Scripts/Extra/01.Hand(New),手部模型和相应的动画位于 Asset/Oculus Hands 中。

效果图:

在这里插入图片描述


📕制作手部动画

在我之前写的手部动画教程中,我创建了两种手部动画(握拳和捏合),分别由手柄的 Grip 键和 Trigger 键来控制。这篇教程我们将创建三种手部动画,用 Grip 键控制中指、无名指、小拇指的弯曲,Trigger 键控制食指的弯曲,触摸摇杆控制大拇指的弯曲。创建动画的原理是类似的,我们需要用 Unity 的 Animation 窗口来录制关键帧,制作手势的动画。我们可以直接点击 Hirerarchy 窗口中的手部模型,然后点击 Unity 编辑器菜单栏上方的 Window -> Animation -> Animation 打开 Animation 窗口:

在这里插入图片描述

在这里插入图片描述

然后就可以在 Animation 窗口中录制动画了,简单来说就是在关键帧中修改需要弯曲的手指的 Transform,我这边是已经有现成的动画了,如果小伙伴们想制作自己的手部动画,可以去搜索 Animation 录制的相关教程,这里就不作详细介绍了。

按下 Grip 键的动画:

在这里插入图片描述

按下 Trigger 键的动画:

在这里插入图片描述

触摸摇杆的动画:

在这里插入图片描述

需要特别注意的是:

  1. 左右手都要准备相应的动画,我这边就是要准备 3×2=6 个动画
  2. 在一个手部动画中,如果有手指是不需要弯曲的,就不要在 Animation 窗口中添加它的 Transform。比如我想制作 Trigger 动画,我只需要弯曲食指,所以在关键帧中需要对食指的 Transform 进行修改。而其他手指保持默认的状态,也就是说它们的 Transform 保持不变,那么我是不需要将这些手指的 Transform 添加到关键帧中的。因此在我的项目里,“按下 Trigger 键”的动画只有 Index (食指)的 Transform 被添加到了 Aniamtion 的 Property 中。这样是为了避免之后不同动画混合后产生的动画覆盖问题。

在这里插入图片描述

📕设置 Animation Controller

分别为左右手创建 Animation Controller,然后添加到手部模型的 Animator 组件中,我以左手为例:

在这里插入图片描述

Animation Controller:

在这里插入图片描述

我们需要点击 Layers 的 “+” 号,额外添加三个动画层,分别对应按下 Grip 键,按下 Trigger 键,触摸摇杆(为了实现我们的需求,Animation Controller 可以有很多中设置方式,我这里提供我的一种实现方式)

Base Layer 按照默认的就行,无需添加任何动画。重要的是新添加的三个动画层。

首先在 Parameters 中添加三个 Float 类型的参数:

在这里插入图片描述

然后我们将这三个动画层的权重设为 1,以 Grip Layer 为例:

在这里插入图片描述

接下来我们需要设置三个动画层的动画和状态连线。

Grip Layer:

在这里插入图片描述

首先创建一个空状态,然后创建一个 Blend Tree,将这两个状态进行连线。状态切换的条件如下(记得取消勾选 Has Exit Time):

在这里插入图片描述

在这里插入图片描述

然后我们看看这个 Blend Tree 长什么样:

在这里插入图片描述

我这里把 Blend Type 设为了 Direct,创建 Blend Tree 的目的是让手部动画有个平滑的过渡。Direct 直接混合可以直接将animator的参数映射到混合树动画的权重,也就是用参数精确控制混合的动画,而不是通过两个参数间接控制动画的混合。

然后将按下左手 Grip 键的动画添加到上图所示的 Motion 中

Trigger Layer:

原理和 Grip Layer 是一样的。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Thumb Layer:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

右手也是同理。


📕添加触摸摇杆的 Input Action

那么,程序要怎么知道我们触摸了手柄的摇杆呢?这里需要用到 Unity 的 Input System。XR Interaction Toolkit 提供了一个 Input Action Asset ,我们可以在里面配置各种输入和动作的映射关系。

在这里插入图片描述

我还是以左手为例,按下 Grip 键和按下 Trigger 键对应了 XRI LeftHand Interaction 中的 Select Value 和 Activate Value,选 Value 是因为按键会有个按下的程度,是个具体的值。

在这里插入图片描述

但是默认的 Action 并没有和“触摸摇杆”绑定的,所以我们需要手动配置。首先点击 Actions 旁的 “+” 号,添加一个 Action,我将它命名为 Thumb Value,然后将 Action Properties 中的 Action Type 改为 Value:

在这里插入图片描述

然后点击 Thumb Value 下的 Binding,设置 Binding 的 Path:

在这里插入图片描述

这个 Path 位于 XR Controller/XR Controller(Left Hand)/Optional Controls/thumbstick Touched

最后,别忘了保存我们新添加的 Action


📕代码部分

配置了 Action 后,我们需要用代码来判断 Action 是否被触发,然后根据从 Action 获取到的值来控制动画。

我们创建一个脚本,分别挂载到左手和右手的模型上。

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

public class NewAnimateHandController : MonoBehaviour
{
    public InputActionProperty triggerActionProperty;
    public InputActionProperty gripActionProperty;
    public InputActionProperty thumbActionProperty;
    private InputAction pinchAction;
    private InputAction gripAction;
    private InputAction thumbAction;
    private Animator animator;

    private string triggerName = "Trigger";
    private string gripName = "Grip";
    private string thumbName = "Thumb";

    void Start()
    {
        pinchAction = triggerActionProperty.action;
        gripAction = gripActionProperty.action;
        thumbAction = thumbActionProperty.action;
        animator = GetComponent<Animator>();
    }


    void Update()
    {
        float gripValue = gripAction.ReadValue<float>();
        animator.SetFloat(gripName, gripValue);

        float triggerValue = pinchAction.ReadValue<float>();
        animator.SetFloat(triggerName, triggerValue);
      
        float thumbValue = thumbAction.ReadValue<float>();
        animator.SetFloat(thumbName, thumbValue);
    }
}

然后在 Inspector 面板中添加 Action 的引用(以左手为例):

最终效果:

在这里插入图片描述

  • 10
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
UnityOpenXR XR Interaction ToolkitXRIT)是一个开源的工具包,用于处理虚拟现实和增强现实应用程序中的交互。在接入HTC Vive设备时,可能会遇到手柄无法使用的问题,以下是解决这个问题的步骤: 首,确保你已经安装了最新版本的UnityUnityXRIT插件。你可以从Unity的官方网站上下载并安装它们。 接下来,将HTC Vive设备连接到电脑,并确保它的驱动程序已正确安装,可以正常使用。 在Unity中,创建一个新的项目或打开现有项目。在项目视图中,导入XRIT插件,确保它已正确安装。 在Unity编辑器的窗口中,选择“Window”菜单,然后选择“Package Manager”。在Package Manager窗口中,搜索“XRIT”插件,并安装它。 安装完毕后,你可以在Unity编辑器的窗口中看到XRIT的工具栏和面板。 在XRIT面板中,选择“Add Input”按钮以添加新的输入设备。在下拉菜单中,选择HTC Vive手柄。这将使XRIT将Vive手柄的输入事件与Unity的输入系统进行关联。 确保Vive手柄已正确连接到电脑,并正常工作。在Unity编辑器的窗口中,选择“Play”按钮以启动项目的播放模式。 现在,你应该能够使用HTC Vive手柄进行交互了。可以测试一些基本的手柄输入,如按下按钮、移动手柄等,来确保它们在Unity中正常工作。 如果手柄仍然无法使用,可能存在其他问题,如驱动程序更新、Unity版本兼容性等。可以尝试更新驱动程序、检查Unity版本是否与XRIT插件兼容,或者在Unity的论坛或社区中寻求帮助。 总之,通过使用UnityOpenXR XR Interaction Toolkit,你应该能够解决HTC Vive手柄无法使用的问题,并实现在虚拟现实应用程序中与手柄进行交互的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YY-nb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值