Uitgebreide oogtracering in Unity
Ga als volgt te werk om toegang te krijgen tot de GitHub-opslagplaats voor het uitgebreide voorbeeld van oogtracering:
Uitgebreide ogentracering is een nieuwe functie in HoloLens 2. Het is een superset van de standaard oogtracering, die alleen gecombineerde oogkijkengegevens biedt. Uitgebreide ogentracering biedt ook individuele oogbooggegevens en maakt het mogelijk voor toepassingen om verschillende framesnelheden in te stellen voor de kijkgegevens, zoals 30, 60 en 90fps. Andere functies, zoals oogopenheid en oogopslag, worden op dit moment niet ondersteund door HoloLens 2.
Met de Extended Eye Tracking SDK kunnen toepassingen toegang krijgen tot gegevens en functies van uitgebreide oogtracering. Het kan worden gebruikt in combinatie met OpenXR-API's of verouderde WinRT-API's.
In dit artikel worden de manieren besproken waarop u de uitgebreide oogtracerings-SDK in Unity kunt gebruiken in combinatie met de Mixed Reality OpenXR-invoegtoepassing.
Instellen van het project
-
Stel het Unity-project in voor de ontwikkeling van HoloLens.
- Selecteer de functie Gaze-invoer
- Importeer de Mixed Reality OpenXR-invoegtoepassing uit het MRTK-functiehulpprogramma.
- Importeer het NuGet-pakket van de Eye Tracking SDK in uw Unity-project.
- Download en installeer het NuGetForUnity-pakket .
- Ga in de Unity-editor naar
NuGet
->Manage NuGet Packages
en zoek vervolgens naarMicrosoft.MixedReality.EyeTracking
- Klik op de knop Installeren om de nieuwste versie van het NuGet-pakket te importeren.
- Voeg de Unity-helperscripts toe.
- Voeg het
ExtendedEyeGazeDataProvider.cs
script hier toe aan uw Unity-project. - Maak een scène en koppel het
ExtendedEyeGazeDataProvider.cs
script vervolgens aan een GameObject.
- Voeg het
- Gebruik de functies van
ExtendedEyeGazeDataProvider.cs
en implementeer uw logica. - Bouwen en implementeren op HoloLens.
Functies van ExtendedEyeGazeDataProvider gebruiken
Notitie
Het ExtendedEyeGazeDataProvider
script is afhankelijk van sommige API's van de Mixed Reality OpenXR-invoegtoepassing om de coördinaten van de staargegevens te converteren. Het werkt niet als uw Unity-project gebruikmaakt van de afgeschafte Windows XR-invoegtoepassing of de verouderde ingebouwde XR in een oudere versie van Unity. Ga als volgt te werk om de uitgebreide oogtracering ook in deze scenario's te laten werken:
- Als u alleen toegang nodig hebt tot de instellingen voor de framesnelheid, is de Mixed Reality OpenXR-invoegtoepassing niet nodig en kunt u de
ExtendedEyeGazeDataProvider
wijzigen om alleen de logica voor de framesnelheid te behouden. - Als u nog steeds toegang nodig hebt tot gegevens van afzonderlijke ogenkijken, moet u WinRT-API's in Unity gebruiken. Raadpleeg de sectie 'Zie ook' voor meer informatie over het gebruik van de SDK voor uitgebreide ogentracering met WinRT-API's.
De ExtendedEyeGazeDataProvider
klasse verpakt de SDK-API's voor uitgebreide ogentracering. Het biedt functies om staren lezen in unity wereld ruimte of ten opzichte van de hoofdcamera.
Hier volgen codevoorbeelden die u kunt gebruiken ExtendedEyeGazeDataProvider
om de kijkgegevens op te halen.
ExtendedEyeGazeDataProvider extendedEyeGazeDataProvider;
void Update() {
timestamp = DateTime.Now;
var leftGazeReadingInWorldSpace = extendedEyeGazeDataProvider.GetWorldSpaceGazeReading(extendedEyeGazeDataProvider.GazeType.Left, timestamp);
var rightGazeReadingInWorldSpace = extendedEyeGazeDataProvider.GetWorldSpaceGazeReading(extendedEyeGazeDataProvider.GazeType.Right, timestamp);
var combinedGazeReadingInWorldSpace = extendedEyeGazeDataProvider.GetWorldSpaceGazeReading(extendedEyeGazeDataProvider.GazeType.Combined, timestamp);
var combinedGazeReadingInCameraSpace = extendedEyeGazeDataProvider.GetCameraSpaceGazeReading(extendedEyeGazeDataProvider.GazeType.Combined, timestamp);
}
Wanneer het ExtendedEyeGazeDataProvider
script wordt uitgevoerd, wordt de framesnelheid van gaze-gegevens ingesteld op de hoogste optie, die momenteel 90fps is.
API-verwijzing van extended eye tracking SDK
Afgezien van het gebruik van het ExtendedEyeGazeDataProvider
script, kunt u ook uw eigen script maken om de VOLGENDE SDK-API's rechtstreeks te gebruiken.
namespace Microsoft.MixedReality.EyeTracking
{
/// <summary>
/// Allow discovery of Eye Gaze Trackers connected to the system
/// This is the only class from the Extended Eye Tracking SDK that the application will instantiate,
/// other classes' instances will be returned by method calls or properties.
/// </summary>
public class EyeGazeTrackerWatcher
{
/// <summary>
/// Constructs an instance of the watcher
/// </summary>
public EyeGazeTrackerWatcher();
/// <summary>
/// Starts trackers enumeration.
/// </summary>
/// <returns>Task representing async action; completes when the initial enumeration is completed</returns>
public System.Threading.Tasks.Task StartAsync();
/// <summary>
/// Stop listening to trackers additions and removal
/// </summary>
public void Stop();
/// <summary>
/// Raised when an Eye Gaze tracker is connected
/// </summary>
public event System.EventHandler<EyeGazeTracker> EyeGazeTrackerAdded;
/// <summary>
/// Raised when an Eye Gaze tracker is disconnected
/// </summary>
public event System.EventHandler<EyeGazeTracker> EyeGazeTrackerRemoved;
}
/// <summary>
/// Represents an Eye Tracker device
/// </summary>
public class EyeGazeTracker
{
/// <summary>
/// True if Restricted mode is supported, which means the driver supports providing individual
/// eye gaze vector and frame rate
/// </summary>
public bool IsRestrictedModeSupported;
/// <summary>
/// True if Vergence Distance is supported by tracker
/// </summary>
public bool IsVergenceDistanceSupported;
/// <summary>
/// True if Eye Openness is supported by the driver
/// </summary>
public bool IsEyeOpennessSupported;
/// <summary>
/// True if individual gazes are supported
/// </summary>
public bool AreLeftAndRightGazesSupported;
/// <summary>
/// Get the supported target frame rates of the tracker
/// </summary>
public System.Collections.Generic.IReadOnlyList<EyeGazeTrackerFrameRate> SupportedTargetFrameRates;
/// <summary>
/// NodeId of the tracker, used to retrieve a SpatialLocator or SpatialGraphNode to locate the tracker in the scene
/// for the Perception API, use SpatialGraphInteropPreview.CreateLocatorForNode
/// for the Mixed Reality OpenXR API, use SpatialGraphNode.FromDynamicNodeId
/// </summary>
public Guid TrackerSpaceLocatorNodeId;
/// <summary>
/// Opens the tracker
/// </summary>
/// <param name="restrictedMode">True if restricted mode active</param>
/// <returns>Task representing async action; completes when the initial enumeration is completed</returns>
public System.Threading.Tasks.Task OpenAsync(bool restrictedMode);
/// <summary>
/// Closes the tracker
/// </summary>
public void Close();
/// <summary>
/// Changes the target frame rate of the tracker
/// </summary>
/// <param name="newFrameRate">Target frame rate</param>
public void SetTargetFrameRate(EyeGazeTrackerFrameRate newFrameRate);
/// <summary>
/// Try to get tracker state at a given timestamp
/// </summary>
/// <param name="timestamp">timestamp</param>
/// <returns>State if available, null otherwise</returns>
public EyeGazeTrackerReading TryGetReadingAtTimestamp(DateTime timestamp);
/// <summary>
/// Try to get tracker state at a system relative time
/// </summary>
/// <param name="time">time</param>
/// <returns>State if available, null otherwise</returns>
public EyeGazeTrackerReading TryGetReadingAtSystemRelativeTime(TimeSpan time);
/// <summary>
/// Try to get first first tracker state after a given timestamp
/// </summary>
/// <param name="timestamp">timestamp</param>
/// <returns>State if available, null otherwise</returns>
public EyeGazeTrackerReading TryGetReadingAfterTimestamp(DateTime timestamp);
/// <summary>
/// Try to get the first tracker state after a system relative time
/// </summary>
/// <param name="time">time</param>
/// <returns>State if available, null otherwise</returns>
public EyeGazeTrackerReading TryGetReadingAfterSystemRelativeTime(TimeSpan time);
}
/// <summary>
/// Represents a frame rate supported by an Eye Tracker
/// </summary>
public class EyeGazeTrackerFrameRate
{
/// <summary>
/// Frames per second of the frame rate
/// </summary>
public UInt32 FramesPerSecond;
}
/// <summary>
/// Snapshot of Gaze Tracker state
/// </summary>
public class EyeGazeTrackerReading
{
/// <summary>
/// Timestamp of state
/// </summary>
public DateTime Timestamp;
/// <summary>
/// Timestamp of state as system relative time
/// Its SystemRelativeTime.Ticks could provide the QPC time to locate tracker pose
/// </summary>
public TimeSpan SystemRelativeTime;
/// <summary>
/// Indicates of user calibration is valid
/// </summary>
public bool IsCalibrationValid;
/// <summary>
/// Tries to get a vector representing the combined gaze related to the tracker's node
/// </summary>
/// <param name="origin">Origin of the gaze vector</param>
/// <param name="direction">Direction of the gaze vector</param>
/// <returns></returns>
public bool TryGetCombinedEyeGazeInTrackerSpace(out System.Numerics.Vector3 origin, out System.Numerics.Vector3 direction);
/// <summary>
/// Tries to get a vector representing the left eye gaze related to the tracker's node
/// </summary>
/// <param name="origin">Origin of the gaze vector</param>
/// <param name="direction">Direction of the gaze vector</param>
/// <returns></returns>
public bool TryGetLeftEyeGazeInTrackerSpace(out System.Numerics.Vector3 origin, out System.Numerics.Vector3 direction);
/// <summary>
/// Tries to get a vector representing the right eye gaze related to the tracker's node position
/// </summary>
/// <param name="origin">Origin of the gaze vector</param>
/// <param name="direction">Direction of the gaze vector</param>
/// <returns></returns>
public bool TryGetRightEyeGazeInTrackerSpace(out System.Numerics.Vector3 origin, out System.Numerics.Vector3 direction);
/// <summary>
/// Tries to read vergence distance
/// </summary>
/// <param name="value">Vergence distance if available</param>
/// <returns>bool if value is valid</returns>
public bool TryGetVergenceDistance(out float value);
/// <summary>
/// Tries to get left Eye openness information
/// </summary>
/// <param name="value">Eye Openness if valid</param>
/// <returns>bool if value is valid</returns>
public bool TryGetLeftEyeOpenness(out float value);
/// <summary>
/// Tries to get right Eye openness information
/// </summary>
/// <param name="value">Eye openness if valid</param>
/// <returns>bool if value is valid</returns>
public bool TryGetRightEyeOpenness(out float value);
}
}