当前位置: 首页 > news >正文

浅谈 Unity XR:从混战到统一,OpenXR 的演进与现实困境

一.引言

在 XR(扩展现实)技术日渐普及的今天,Unity 已成为开发 VR、AR 和 MR 应用的主流平台。然而在这个生态蓬勃发展的背后,XR 的接口标准也经历了混乱到统一的演进过程。从早期的厂商割据,到 Unity 的初步抽象,再到 OpenXR 的出现,一步步走向“写一次,到处运行”的理想。

二.什么是 XR?它和 VR、AR、MR 的关系?

XR 是“Extended Reality”(扩展现实)的缩写,是一个统称,涵盖了以下三类技术:

  • VR(Virtual Reality,虚拟现实):用户完全沉浸在一个虚构的 3D 虚拟世界中,比如使用 Oculus Rift、HTC Vive 体验的游戏或模拟场景。

  • AR(Augmented Reality,增强现实):将虚拟物体叠加到现实世界中,常用于手机、眼镜等设备,如 Google ARCore、Apple ARKit。

  • MR(Mixed Reality,混合现实):虚拟内容与现实世界实时交互并融合,强调更深层次的物理/空间理解,比如 Microsoft HoloLens。

XR 是对 VR、AR 和 MR 的总称,用来泛指所有这类“现实+虚拟”结合的技术。Unity 将这些技术整合进统一框架,统称为 XR 系统。


三.发展进程 

1. 各自为战的早期混乱

最初,XR 设备制造商如 Oculus(Meta)、HTC Vive、HoloLens、ARCore(Google)、ARKit(Apple)等各自推出了各自的 SDK。这些 SDK 各不兼容:

  • Meta 使用 Oculus SDK

  • HTC 使用 SteamVR / Vive SDK

  • Android 平台使用 ARCore

  • iOS 则使用 ARKit

这意味着开发者必须针对每个平台分别适配、编写交互逻辑,代码重复、维护困难、移植复杂。


2. Unity XR Plug-in Framework:初步统一

为了缓解上述问题,Unity 推出了 XR Plug-in Management 框架,试图规范 XR 插件的接入流程。Unity 将原本各家 SDK 封装为统一的 XR Plug-in 接口,比如:

  • Oculus XR Plugin

  • ARCore XR Plugin

  • Windows XR Plugin

  • Mock HMD Loader(虚拟测试设备)

配合 XR Interaction Toolkit 和 Input System,Unity 提供了一套可复用的开发范式,一定程度的屏蔽了各个厂商SDK的差异。但开发者仍需手动为不同平台切换插件,部分 API 也仍存在厂商差异。

 

笔者近期对接一个厂商的设备,导入了它家的SDK,因为厂商接入了  XR Plug-in Management 框架

所以我可以很方便的配置,只需要简单的勾选.但你可能感到疑问,为什么就这么几个选项,前面不是提到一大堆厂商吗?他们的SDK选项去哪了?请往下看!


3. OpenXR:由 Khronos Group 推出的统一标准

OpenXR 是由 Khronos Group(OpenGL/Vulkan 的制定者)主导的跨平台 XR 规范。目标是让所有 XR 平台和设备使用统一的接口标准。

其带来的好处是显而易见的:

  • 开发者使用一套 API(如 Unity 的 OpenXR 插件)

  • 所有支持 OpenXR 的设备可直接运行

  • 极大简化开发成本与平台迁移代价

如今主流厂商如 Meta、Pico、HTC、微软等均已提供 OpenXR Runtime 实现,并逐渐弃用自家旧 SDK。

你可能感到疑问:在OpenXR出现之前,Unity难道没有帮我们屏蔽各个厂商SDK的差异吗?

答案是:

在 OpenXR 出现之前,Unity 的 XR Plug-in Management 确实已经在做“屏蔽厂商 SDK 差异”的工作,但有以下几个重要特征:

Unity XR Plug-in Management 是一个 插件管理框架

它做的事情是:

  • 让你能通过 UI 面板方便切换 SDK(比如 Oculus XR Plugin、ARCore Plugin、Windows XR Plugin)

  • 提供统一的生命周期管理(初始化、启用、禁用 XR)

 但是,它并没有提供统一的运行时行为(比如不同 SDK 的输入系统、空间定位、手柄交互方式等行为仍不同)。

所以 Unity 后来推出了 XR Interaction Toolkit —— 真正统一开发接口

  • XR Plug-in Management 管插件生命周期(选谁、启谁)

  • XR Interaction Toolkit 管开发接口(开发者怎么写)

但这里的问题来了:

各家 SDK 的实现行为和支持范围仍有差异,即使你都使用 Toolkit,有些功能不同厂商支持也不同。

例如:

功能Oculus XR PluginARCore PluginWindows XR Plugin
手柄交互支持
头部追踪
手势识别
Haptic(触感)反馈

 总结:

Unity XR Plug-in Management + XR Interaction Toolkit = 半统一 

插件管理是统一的,但底层行为因 SDK 差异仍不一致

需要开发者写一些分平台逻辑,兼容差异(例如 if UNITY_ANDROID && !UNITY_EDITOR

OpenXR的强大:

特点之前(XR Plug-in + Toolkit)OpenXR 之后
插件切换手动切换插件统一一个插件
行为统一(如交互/输入)存在差异底层行为统一
可扩展性(比如手势系统)SDK 限制通过 OpenXR extension
厂商适配多套插件一套 OpenXR runtime

前面提到的我对接的哪家厂商就没实现OpenXR,所以我就不可避免的使用他家特有的API,导致我的代码实现不了一次编写到处运行.

这也回答了刚才的问题:多家厂商的SDK都被统一到OpenXR的选项上了

这需要我们引入OpenXR的包,因为我没引入这个包,所以刚才的截图没有该选项,但是为什么PC下面就有这个选项呢?这其实是一个快捷的预安装选项,勾选之后会自动帮我引入OpenXR的包,引入了包安卓下面也会出现OpenXR选项. 

但要注意的是:

虽然 OpenXR 实现了跨厂商 XR 接口的统一,但这并不意味着从此完全脱离厂商 SDK。在许多情况下,厂商会通过 OpenXR 提供基础功能支持,而将高级特性、运行时驱动、扩展能力保留在自己的 SDK 中。因此,即使使用 Unity 的 OpenXR Plugin,我们在开发中仍有可能需要引入厂商的支持插件,例如 HTC 设备需依赖 SteamVR 插件完成设备连接与功能调用。

IOS似乎拒绝加入OpenXR,还需要引入额外的包.


4. Unity + OpenXR:开发者视角

Unity 对 OpenXR 的支持主要通过以下几个官方包实现:

  • OpenXR Plugin:用于注册和管理底层 OpenXR runtime

  • XR Plug-in Management:用于选择 XR 后端(OpenXR、Oculus 等)

  • XR Interaction Toolkit:提供统一的交互行为(抓取、指向、按钮等)

如果所用设备支持 OpenXR,开发者只需勾选 OpenXR,使用 XR Interaction Toolkit 就可实现大部分 XR 功能,无需关注厂商差异。


5. 未完全统一的现实:平台与厂商的落差

尽管 OpenXR 是趋势,但现实中并非所有平台与厂商都已完成迁移:

  • Android 平台 仍常见 ARCore 与 Oculus 插件选项

  • iOS 平台 完全不支持 OpenXR,只能继续使用 ARKit

  • 部分中小厂商(如 RhinoX Pro) 提供自研 SDK,虽声称遵循 Unity XR Plug-in 接口,但未实现 OpenXR Runtime,仍需调用其自定义 API

这导致在某些项目中仍不可避免地混用官方与厂商 API。

就比如这家厂商还没完全迁移到OpenXR,所以就遗留了这个选项.


6. OpenXR 并非银弹:平台差异仍存在

尽管 OpenXR 统一了设备差异,但平台差异(如 Android vs Windows)仍需开发者关注:

  • UI 呈现、资源管理、文件路径等仍不一致

  • AR 支持(如环境理解)目前未被 OpenXR 完全覆盖

  • 性能调优策略、渲染管线等也需平台自适应

也就是说,OpenXR 是“统一设备行为”的手段,但不是“统一 一切平台差异”的解决方案。


7. 实践建议

  • 使用支持 OpenXR 的设备时,优先使用 Unity 官方的 OpenXR 插件和 XR Interaction Toolkit

  • 如果设备未支持 OpenXR,需根据厂商文档使用其 SDK,放弃 XR Toolkit 的部分功能

  • 针对多平台部署,需做好平台判断与抽象封装

  • 持续关注厂商 SDK 和 Unity 的更新节奏,掌握第一手迁移时机

仅个人理解,欢迎指正

相关文章:

  • ContextData() 在 pysnmp 中的作用详解
  • 榕壹云家政系统:基于Spring Boot与UniApp的智能家政服务解决方案
  • Go 语言的基础数据类型
  • 论文笔记:GTG: Generalizable Trajectory Generation Model for Urban Mobility.
  • 从UI前端到数字孪生:构建数据驱动的智能生态系统
  • 路由器压测实战:从负载均衡到DDoS防御,5步定位性能瓶颈(附脚本工具包)
  • vue 工具函数 useInfiniteScroll实现数据懒加载
  • Vue3 跨组件通信完整方案对比总结
  • 什么是状态机?状态机入门
  • Eureka 和 Feign(二)
  • 重新编译一个不支持 AVX、AVX2的 TensorFlow 1.15的python3.7的安装包
  • Spring Boot 管理系统项目解读
  • Android Studio 中使用 C++ 连接 OpenCV
  • Android studio打包生成jar包文件
  • Spring Cloud使用Eureka调用接口,超时设置(二)
  • Python爬取豆瓣短评并生成词云分析
  • 21 大刷题平台开启编程王者之路
  • Macbook如何关闭掉端口
  • 【WPF】WPF ComboBox 数据驱动不刷新?SelectedItem 与 SelectedIndex 解析!
  • 2025年SYN-CC混合攻击防御实战:某金融平台抵御800Gbps双重风暴实录
  • 连云港做网站制作首选公司/灰色行业推广平台网站
  • 餐饮加盟培训网站建设/十种营销方式
  • 白银市城县建设局网站/用模板快速建站
  • 东莞清溪镇做网站公司/百度竞价培训
  • 做app推广上哪些网站吗/郑州专业seo推荐
  • 甜点网站里的新闻资讯怎么做/谷歌seo查询