Unity XR Interaction Toolkit(二)手柄交互

avatar
作者
猴君
阅读量:0

目录

一、结构配置

二、交互事件

1、事件设置

2、绑定设置

3、组合按键输入

4、事件挂载

三、代码响应

1、事件回调

2、数值获取


注意,本文的Toolkit版本在2.2以上,低版本没有样例和部分api,更新方法在第一张环境配置内

打开Package Manager,在右侧面板中点开Sample列表,导入Starter Assets。

一、结构配置

Starter Assets->Prefabs->Complete XR Origin Set Up

这是一个官方案例给出了完整的交互预制件,集拾取,交互,传送等功能

(没找到的话一定是未来版本删除了这个东西,肯定会有替代品,问题不大)

Input Action Manager:输入管理

InteractionManager:抓取交互管理

EventSystem:UI交互管理

XR Origin

->XR Origin

->Sanp Turn Provider (Action-based):快速转身功能

->Locomotion System:移动传送管理

->Teleportation Provider:传送功能

->Continuous Turn Provider:连续转身功能

->Dynamic Move Provider:持续移动功能

->Two-Handed Grab Move Provider:双手移动旋转功能

Left Hand

->Action Based Controller Manager:碰撞抓取、射线抓取与射线传送之间的切换管理

->XR Controller (Action-based):同步手柄控制器的位移和角度,绑定响应控制器的事件

Direct Interactor:碰撞抓取

Ray Interactor:射线抓取

->XR Ray Interactor:射线交互器

->Line Renderer:绘制射线组件

->XR Interactor Line Visual:射线组件设置组件,会覆盖Line Renderer参数

->Sorting Group:排序组

Teleport Interactor:射线传送交互器

->XR Ray Interactor:射线交互器,在这里可以设置射线的样式

->Line Renderer:绘制射线组件

->XR Interactor Line Visual:射线组件设置组件,会覆盖Line Renderer参数

->Sorting Group:排序组

->XR Controller (Action-bassed):响应传送开始事件,只绑定Select Action和Select Action Value即可

二、交互事件

Starter Assets->XRI Default Input Actions

官方给出的默认XR输入事件

Toolkit的输入事件由Input System负责,更改手柄按键全在这里修改

这是一个新版的输入系统,可以通过配置文件(右键->Create->Input Actions),组合按键输入事件,响应这个事件可以完成逻辑编辑

优点在于可以统一更改输入事件,比如抓取功能想从侧键改为扳机键,只需要改配置文件就可以,不用在代码中一个挨着一个的更改

如上图所示

  • 最左面黄色标头的是事件类别,拿出XRI LeftHand Interaction来说,子项都是交互的事件,XRI LeftHand Locomotion都是移动传送事件
  • 中间的绿色标头都是相应的事件,一个事件可以绑定多个输入,比如抓取事件Select,侧键可以绑定,扳机键也可以绑定,图中的抓取事件绑定了一个trigger(扳机键)和一个空输入
  • 右侧是事件的响应方式,图中是一个Button类型的Antion Type,触发时会响应一次并且无参数

1、事件设置

开发过程中,有各种各样的需求,Input System都可以实现,首先,我们需要设定好要添加的事件

Action Type

Add Binding:是单一值,简单又单纯

Add Positive\Negative Binding:一个正负值,类似于轴

Add Binding With One Modifier:一个组合按键,两个按键联按,手柄上摇杆前推并按下可以这么实现。其中Binding是主要值,Modifier只起到修饰作用

Add Binding With Two Modifier:两个组合按键,可以三键联按

一个Action有三种类型

Value:可以输入参数值,比如扳机键按下的力度,连续输入,需要区分值类型,有数字,向量,Pose等

Button:触发一次的函数,无参

PassThrough:和Value 一样,Value只会响应一个设备,而这会响应所有设备(类似于鼠标和手柄)

Ineractions

选完类型Type后,下方的Ineractions,它可以给输入添加条件(长按、双击等),图中添加一个Hold条件

Processors

值处理,可以反转值,限制值等

2、绑定设置

注意:Action Type不同,绑定的Path也不同,一个2d向量的绑定不能响应Button类型

这里设置绑定选项了,图中是一个2d的向量轴,意思是传送射线激活(Teleport Select)会通过一个2d向量(Primary2DAxis)设置

左手手柄只能设置左值,图中是[LeftHand XR Controller]

点击右侧的Path,来设置响应这个事件的路径

这里有很多选项,新手并不好选,因为部分值看起来很多很杂乱,这里有一个可以debug当前设备输入的工具,可以根据数值变化绑定路径Window->Analysis->XR Interaction Debugger,需要勾选Input Devices选项,同时这里也可以查看正在交互的物体和交互器

3、组合按键输入

上文说过了组合按键,这回来实际应用一下,我的设备是HTC Vive,手柄不是摇杆而是追踪板,当想要实现追踪板按下前端传送的时候,就需要组合输入了

首先这是一个Value类型事件,值类型为二位向量

添加一个修饰,需求是追踪板前端,这个输入就需要判定扇形区域(Sector)为North前端

组合按键是trackpadclicked,这样一个手柄事件就完成了

使用这个组合事件放在TeleportActivate下,将在摇杆/圆盘抬起时触发

而TeleportSelect是摇杆/圆盘按下时触发,主要用于开启手柄射线

4、事件挂载

官方案例中给出的预制件已经挂载好了事件,如果想要把刚才做好的事件替换掉,只需要根据名字挨个替换就好了

三、代码响应

1、事件回调

两种回调函数方式,分别为:

// 被动获取值,事件响应  //  [SerializeField] InputActionReference m_InputActionReference;  void Start(){     InputAction inputAction = m_InputActionReference.action;     inputAction.performed += Callback; }  void Callback(InputAction.CallbackContext obj){     var value = obj.ReadValue<int>(); }    //  [SerializeField] InputActionProperty m_InputActionProerty;  void Start(){     InputAction inputAction = m_InputActionProerty.action;     inputAction.performed += Callback; }  void Callback(InputAction.CallbackContext obj){     var value = obj.ReadValue<int>(); }

2、数值获取

// 在Update中主动获取值 void Update(){     InputAction action = m_InputActionProperty.action;     float value = action.ReadValue<Vector2>(); }

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!