Gaze Interaction
Unity's XR Interaction Toolkit offers a Gaze Interaction system that enable users to interact with objects in VR using their eye gaze through XRGazeInteractor. This component handles gaze-based interaction. It casts a ray forward based on the user's eye pose (or head pose if eye tracking isn't available) and detects interactable objects.
The Ray interaction consists of:
- XR Gaze Interactor: XRGazeInteractor is the interactor used for interacting with Interactables via gaze. This is handled via ray casts that update the current set of valid targets for this interactor. This component is provided by Unity´s XR Interaction Toolkit. VIROO provides an already configured Gaze Interactor for the player.
- XR Simple Interactable: XRSimpleInteractable is the component with which XRGazeInteractor interacts.
- Viroo XR Simple Interactable: this component is in charge of configuring the way XRSimpleInteractable interacts with the interactors and also that the interaction events are triggered to all users in session through the network.
Warning
Gaze Interaction at runtime is disabled by default, to enable it, you must open the VIROO menu and activate it. The XR Gaze Interactor will run at the same time as other interactors.
Add a Gaze Interaction to a GameObject
To add a XR Gaze Interactor to an object you must:
- Set up the interactable object with the necessary components.
- Configure the events you want to handle.
Set up the Gaze Interactable object
This interactor will interacts with XR Simple Interactable that have enabled Allow Gaze Interaction.
- XR Simple Interactable: Unity´s XR Interaction Toolkit component.
- Collider: this GameObject or its children must have one or more colliders.
- Network Object: necessary to identify the GameObject by VIROO Networking.
- Viroo XR Simple Interactable: necessary to setup how XR Simple Interactable is interacted and to launch the events through the network.
XR Simple Interactable
This is a Unity´s XR Interaction Toolkit component and is the simplest version of an Interactable object. It's intended to be used as a way to respond to interaction events with no underlying interaction behavior. For more information please refer to the official documentation.
Collider
For XR Gaze Interactor to interact with XR Simple Interactable, it's necessary that there is at least one collider. The collider can be at the same level of the component or in one of its children and can not be of type Trigger.
Network Object
For network functions to work, interacting components need this component that uniquely identifies them across the network. It's important to make sure that their ObjectId identifier isn't repeated.
Viroo XR Simple Interactable
This VIROO component is necessary to setup how XR Simple Interactable is interacted and to launch the events through the Network.
The XR Simple Interactable component by default doesn't differentiate if it's being interacted by a XR Direct Interaction, XR Ray Interaction or a XR Gaze Interaction. That's why VIROO, through this component, provides a way to limit the way in which it interacts with this interactable. It configures it so that it can only be interacted by an interactor of one type and not by both.
| Field | Description | 
|---|---|
| Send Network Events | If this checkbox is checked the events triggered by the XRSimpleInteractable (HoverEnter, Activate…) will be networked, otherwise the events will be triggered only locally. | 
| Allow Direct Interaction | If this checkbox is checked it means that the associated interactable will interact with a Near-Far Interactor . | 
| Interact With Hands | In this field you can specify whether the interactable is hand-interactable (controllers and hand tracking). It has four possible values, None, Left, Right, Both. Allow Direct Interaction must be checked. | 
| Tag Filters | If you want the interactable to interact only with specific DirectInteractors, you can define tags for this purpose. For more information check the Custom Direct Interactors section in this page. Allow Direct Interaction must be checked. | 
| Allow Ray Interaction | If this checkbox is checked it means that the associated interactable will interact with a Near-Far Interactor remotely and XR Gaze Interactor. | 
| Allow Distance Select Interactor | Check this checkbox to allow interactable be selected remotely through a Near-Far Interactor remotely. It's commonly used to be able to grab objects from a distance. | 
The standard configuration for a Gaze Interaction is to have Allow Direct Interaction disabled and Allow Ray Interaction enabled.

You can configure the interactable so that it can only be interacted with by the XR Gaze Interactor. To do so, change the layer of the GameObject to Gaze.

Configuring the events
At this point you can use XRSimpleInteractable events to trigger logic when the Gaze Interaction happens. VIROO Interaction System ensures that XRSimpleInteractable events are propagated over the network to all users if Send Network Events is selected. With this, the events you subscribe will be called to all users in the VIROO Application.
If you want to use the VIROO Interaction System Actions and you are sending events through the network, you must use the LocalExecute functions (instead of Execute).
To add events to XRSimpleInteractable, expand the Interactable Events section. Here are the most common events that are used when performing Gaze Interaction.
| Event | Description | 
|---|---|
| Hover Entered | The event that's called when an Interactor begins hovering over this Interactable. | 
| Hover Exited | The event that's called when an Interactor ends hovering over this Interactable. | 
A complete list of all events, please refer to the official documentation.