Quest3 InteractionSDK 学习(二)

1.前言

如何在unity项目中显示出虚拟的双手,如何在unity中进行移动,本章将讲解,如何抓取,远程抓取物体。

2.正题

2.1导入虚拟的双手

Meta中的双手,主要是要导入 集成好了双手的预制体。OVRCameraRigInteraction就是带有虚拟双手的预制体。

2.2给3D物体添加交互

HandGrabInteraction:双手抓取的交互

RayGrabInteraction: 手柄抓取

DistanceHandGrabInteraction: 远程 双手抓取


实际操作的时候DistanceHandGrabInteraction发现 把3D物体丢出去后,3D物体又回到原来的位置。不仅如此 还无法响应重力、

去掉Time Out Snap Zone 脚本后,不仅仅不用返回到原本的位置; 还能响应重力

2.3 VR中实现传送和转向

传送和转向的 Interactor 已经被集成到 OVRCameraRigInteraction

现在只需要定义Interactable即可,如何定义呢?接下来一步一步演示

第一步:添加Empty object 将脚本都挂在空物体上,这样不管怎么变 只要这个Empty Object存在则会一直有传送和转向Interactable

添加传送和转向的 Interactable`的脚本

这个Surface 变量的含义是:Teleport Interactable组件中的surface对象通常指的是可以进行传送的目标表面或区域

正常情况下 你是无法将 地面对象 赋值给 这个Surface。

创建一个 Collider Surface 脚本 (还可以创建 Plane Surface 以及 NavMeshSurface)

将 Collider Surface 赋值给Teleport Interactable.并且 Collider Surface 可以将 地面 赋值给 Collider的变量。

经过上述操作已经完成跳转和转向。但是转向的UI 还需要一个脚本控制:Reticle Data Teleport


创建一个 Plane Surface 脚本 这个脚本是垂直于 地面的,所以要创建一个子物体,把 plane Surface 挂在子物体上。

相关推荐
OpenTiny社区4 分钟前
告别代码焦虑,单元测试让你代码自信力一路飙升!
前端·github
pe7er14 分钟前
HTTPS:本地开发绕不开的设置指南
前端
晨枫阳21 分钟前
前端VUE项目-day1
前端·javascript·vue.js
江山如画,佳人北望28 分钟前
SLAM 前端
前端
患得患失94933 分钟前
【前端】【Iconify图标库】【vben3】createIconifyIcon 实现图标组件的自动封装
前端
颜酱35 分钟前
抽离ant-design后台的公共查询设置
前端·javascript·ant design
用户95251151401551 小时前
js最简单的解密分析
前端
FogLetter1 小时前
深入浅出React-Router-Dom:从前端路由到SPA架构的华丽转身
前端·react.js
绅士玖1 小时前
JavaScript 设计模式之单例模式🚀
前端·javascript·设计模式
Dream耀1 小时前
useReducer:React界的"灭霸手套",一个dispatch搞定所有状态乱局
前端·javascript·react.js