Metal samples
The Apple visionOS XR Plugin provides two samples that demonstrate how to set up a Metal scene for the visionOS platform. One sample uses the Built-in Rendering Pipeline and the other uses the Universal Rendering Pipeline (URP). The samples are otherwise the same.
The Metal samples use the following, additional packages:
- XR Interaction Toolkit: The XR Interaction Toolkit package is a high-level, component-based, interaction system for creating VR, MR, and AR experiences.
- XR Hands: The XR Hands package provides access to hand tracking data from ARKit on visionOS.
The XR Interaction Toolkit is required by the sample scenes, but the XR Hands package is optional. You can find instructions on how to install these packages at the links above.
Scene elements
The ARSession and ARInputManager components must exist in all Metal and Hybrid scenes on visionOS. These components are required because the visionOS platform provides head and hand tracking data through Apple's ARKit. These components can be on any GameObject in your scene, but only one of each should be present. In the Metal Sample scene, the components are on the GameObject named "AR Session." In addition to head and hand tracking data, ARKit on visionOS provides world meshes, planes, and image markers tracked by the device. With visionOS 2.0 we support object tracking and environment probes as well.
Note
On visionOS, Apple ARKit features are implemented by the Apple visionOS XR Plugin package (com.unity.xr.visionos). You do not need the Apple ARKit package (com.unity.xr.arkit), which implements ARKit features for iOS.
The XR Origin collection of GameObjects and components serves as the center of tracking space. It includes the camera that renders the scene from the user's point of view. Any GameObjects whose position is controlled by tracking data, including the main camera, hand representations, meshes, planes, and the like, must be children of the Camera Offset GameObject within the XR Origin hierarchy. (If you place such objects elsewhere in the scene hierarchy, tracked objects won't be positioned correctly relative to the user.)
The Anchor Placer GameObject has a sample script that places an ARAnchor in the scene using the VisionOSSpatialPointer.
The XRI GameObject is the parent of a set of GameObjects that use the XR Interaction Toolkit, These include:
- XR Interaction Manager: contains the manager component that manages interactions.
- Grab Interactable Left and Right: a pair of example objects to serve as interactable objects.
- Ray Interactor: contains the interactor components that let the user interact with the UI and the left and right grab interactables. The ray cast used for this interactor is controlled by the position and orientation of the VisionOSSpatialPointer.
- Ray Origin: visualizes the ray projected by the Ray Interactor using a TrackedPoseDriver set up to track the VisionOSSpatialPointer.
The Sample Canvas provides an example UI with a few controls that alter the behavior of a particle system and a button to clear any anchors the user has placed. The components used for the UI are the same as you might use in any Unity project, with the exception of the Tracked Device Graphic Raycaster component from the XR Interaction Toolkit. This component implements a custom GraphicRaycaster for tracked devices.
The Event System GameObject the standard EventSystem component that handles UI events in a scene and the XRUIInputModule component that adapts XR input to the Event System. Refer to UI interaction setup XR Interaction Toolkit manual for more information about configuring UI interaction in XR.
Important
Do not use the Standalone Input Module or Input System UI Input Module components in an XR scene. These other UI Input Modules are not compatible with the XR input and might cause undesired or unexpected behavior. Only use a single, XR UI Input Module to handle UI interactions.