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

相关推荐
jump_jump17 小时前
基于 Squoosh WASM 的浏览器端图片转换库
前端·javascript·性能优化
小二·20 小时前
前端监控体系完全指南:从错误捕获到用户行为分析(Vue 3 + Sentry + Web Vitals)
前端·vue.js·sentry
阿珊和她的猫1 天前
`require` 与 `import` 的区别剖析
前端·webpack
谎言西西里1 天前
零基础 Coze + 前端 Vue3 边玩边开发:宠物冰球运动员生成器
前端·coze
努力的小郑1 天前
2025年度总结:当我在 Cursor 里敲下 Tab 的那一刻,我知道时代变了
前端·后端·ai编程
GIS之路1 天前
GDAL 实现数据空间查询
前端
OEC小胖胖1 天前
01|从 Monorepo 到发布产物:React 仓库全景与构建链路
前端·react.js·前端框架
2501_944711431 天前
构建 React Todo 应用:组件通信与状态管理的最佳实践
前端·javascript·react.js
困惑阿三1 天前
2025 前端技术全景图:从“夯”到“拉”排行榜
前端·javascript·程序人生·react.js·vue·学习方法
苏瞳儿1 天前
vue2与vue3的区别
前端·javascript·vue.js