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 挂在子物体上。

相关推荐
打小就很皮...11 分钟前
Tesseract.js OCR 中文识别
前端·react.js·ocr
wuhen_n33 分钟前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon1 小时前
理解vue中的ref
前端·javascript·vue.js
落霞的思绪2 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q2 小时前
CSS 笔记2 (属性)
前端·css·笔记
Anastasiozzzz2 小时前
LeetCode Hot100 295. 数据流的中位数 MedianFinder
java·服务器·前端
Exquisite.3 小时前
Nginx
服务器·前端·nginx
打小就很皮...3 小时前
dnd-kit 实现表格拖拽排序
前端·react.js·表格拖拽·dnd-kit
Ulyanov3 小时前
从静态到沉浸:打造惊艳的Web技术发展历程3D时间轴
前端·javascript·html5·gui开发
打小就很皮...4 小时前
React 19 + Vite 6 + SWC 构建优化实践
前端·react.js·vite·swc