Navegación compatible con los ojos en MRTK: MRTK2

MRTK

Imagine está leyendo información en una pizarra y cuando llega al final del texto mostrado, el texto se desplaza automáticamente para mostrar más contenido. O bien, puedes acercar con fluidez dónde estás mirando. El mapa también ajusta automáticamente el contenido para mantener las cosas de interés dentro del campo de vista. Otra aplicación interesante es la observación sin manos de hologramas 3D al traer automáticamente las partes del holograma que está mirando al frente. Estos son algunos de los ejemplos que se describen en esta página en el contexto de la navegación compatible con los ojos.

En las descripciones siguientes se supone que ya está familiarizado con cómo configurar el seguimiento ocular en la escena de MRTK y con los conceptos básicos de acceso a los datos de seguimiento ocular en MRTK Unity. Los ejemplos descritos a continuación forman parte de la EyeTrackingDemo-03-Navigation escena (Assets/MRTK/Examples/Demos/EyeTracking/Scenes/EyeTrackingDemo-03-Navigation).

Resumen: Desplazamiento automático del texto, movimiento panorámico compatible con la mirada con los ojos y zoom de un mapa virtual, giro 3D dirigido por manos libres.

Desplazamiento automático

El desplazamiento automático permite al usuario desplazarse por textos sin levantar un dedo. Simplemente continúe leyendo y el texto se desplazará automáticamente hacia arriba o hacia abajo en función de dónde esté buscando el usuario. Puede empezar desde el ejemplo proporcionado en EyeTrackingDemo-03-Navigation (Assets/MRTK/Examples/Demos/EyeTracking/Scenes). En este ejemplo se usa un componente TextMesh para permitir cargar y dar formato a texto nuevo de forma flexible. Para habilitar el desplazamiento automático, basta con agregar los dos scripts siguientes al componente colisionador del cuadro de texto:

ScrollRectTransf

Para desplazarse por un TextMesh o, por lo general, un componente RectTransform , puede usar el script ScrollRectTransf . Si desea desplazarse por una textura en lugar de rectTransform, use ScrollTexture en lugar de ScrollRectTransf. A continuación, los parámetros de ScrollRectTransf que están disponibles en el Editor de Unity se explican con más detalle:

Parámetros Descripción
LimitPanning Si está habilitado, detendrá el contenido desplazable en su límite.
RectTransfToNavigate Referencia a RectTransform en la que desplazarse.
RefToViewport Referencia al rectTransform primario del contenido desplazable para determinar el desplazamiento y el límite correctos.
AutoGazeScrollIsActive Si está habilitado, el texto se desplazará automáticamente si el usuario examina una región activa (por ejemplo, la parte superior e inferior del panel de desplazamiento si la velocidad de desplazamiento vertical no es cero).
ScrollSpeed_x Si se establece en un valor distinto a cero, se habilitará el desplazamiento horizontal. Los valores negativos significan un cambio en la dirección del desplazamiento: de izquierda a derecha frente a derecha a izquierda.
ScrollSpeed_y Si se establece en un valor distinto a cero, se habilitará el desplazamiento vertical. Los valores negativos significan un cambio en la dirección del desplazamiento: arriba a abajo frente a hacia arriba.
MinDistFromCenterForAutoScroll Distancia mínima normalizada en x e y desde el centro del cuadro de acierto del destino (0, 0) para desplazarse. Por lo tanto, los valores deben oscilar entre 0 (desplazamiento siempre) y 0,5 (sin desplazamiento).
UseSkimProofing Si está habilitado, evita movimientos repentinos de desplazamiento cuando se miran rápidamente. Sin embargo, esto puede hacer que el desplazamiento se sienta menos dinámico. Se puede ajustar con el valor SkimProofUpdateSpeed .
SkimProofUpdateSpeed Cuanto menor sea el valor, más lento se acelerará el desplazamiento después de esquiar. Valor recomendado: 5.

Eye-supported scroll setup in Unity

EyeTrackingTarget

Adjuntar el componente EyeTrackingTarget permite controlar de forma flexible los eventos relacionados con la mirada ocular. En el ejemplo de desplazamiento se muestra el texto de desplazamiento que se inicia cuando el usuario examina el panel y se detiene cuando el usuario está mirando hacia fuera de él. Eye-supported scroll setup in Unity: EyeTrackingTarget

Panorámica y zoom compatibles con la mirada

Quién no ha usado un mapa virtual antes de buscar su hogar o explorar lugares completamente nuevos? El seguimiento ocular le permite profundizar directamente en las partes que le interesan y una vez acercado, puede seguir sin problemas el curso de una calle para explorar su vecindario! Esto no solo es útil para explorar mapas geográficos, sino también para consultar detalles en fotografías, visualizaciones de datos o incluso imágenes médicas transmitidas en vivo. ¡Para usar esta funcionalidad en la aplicación es fácil! Para el contenido representado en una textura (por ejemplo, una foto, datos transmitidos), basta con agregar el script PanZoomTexture . Para rectTransform , use PanZoomRectTransf. Extender la funcionalidad De desplazamiento automático , básicamente se habilita para desplazarse vertical y horizontalmente al mismo tiempo y ampliar el contenido justo alrededor del punto de enfoque actual del usuario.

Parámetros Descripción
LimitPanning Si está habilitado, detendrá el contenido desplazable en su límite.
HandZoomEnabledOnStartup Indica si los gestos de mano se habilitan automáticamente para realizar un gesto de zoom. Es posible que desee deshabilitarlo al principio para evitar desencadenar accidentalmente acciones de zoom.
RendererOfTextureToBeNavigated Representador al que se hace referencia de la textura que se va a navegar.
Zoom_Acceleration Aceleración de zoom que define la inclinación de la asignación de funciones de velocidad logística.
Zoom_SpeedMax Velocidad máxima de zoom.
Zoom_MinScale Escala mínima de la textura para acercar: por ejemplo, 0,5f (mitad del tamaño original).
Zoom_MaxScale Escala máxima de la textura para alejar: por ejemplo, 1f (el tamaño original) o 2,0f (doble el tamaño original).
Zoom_TimeInSecToZoom Zoom con tiempo: una vez desencadenado, se realizará un zoom durante el período de tiempo determinado en segundos.
Zoom_Gesture Tipo de gesto de mano que se va a usar para acercar o alejar.
--- ---
Pan_AutoScrollIsActive Si está habilitado, el texto se desplazará automáticamente si el usuario examina una región activa (por ejemplo, la parte superior e inferior del panel de desplazamiento si la velocidad de desplazamiento vertical no es cero).
Pan_Speed_x Si se establece en un valor distinto a cero, se habilitará el desplazamiento horizontal. Los valores negativos significan un cambio en la dirección del desplazamiento: de izquierda a derecha frente a derecha a izquierda.
Pan_Speed_y Si se establece en un valor distinto a cero, se habilitará el desplazamiento vertical. Los valores negativos significan un cambio en la dirección del desplazamiento: arriba a abajo frente a hacia arriba.
Pan_MinDistFromCenter Distancia mínima normalizada en x e y desde el centro del cuadro de acierto del destino (0, 0) para desplazarse. Por lo tanto, los valores deben oscilar entre 0 (desplazamiento siempre) y 0,5 (sin desplazamiento).
UseSkimProofing Si está habilitado, evita movimientos repentinos de desplazamiento cuando se miran rápidamente. Sin embargo, esto puede hacer que el desplazamiento se sienta menos dinámico. Se puede ajustar con el valor SkimProofUpdateSpeed .
SkimProofUpdateSpeed Cuanto menor sea el valor, más lento se acelerará el desplazamiento después de esquiar. Valor recomendado: 5.

Eye-supported pan and zoom setup in Unity

Rotación 3D basada en la atención

Imagine mirar un objeto 3D y las partes que desea ver más estrechamente giran hacia usted - como si el sistema leyese tu mente y sepas girar el elemento hacia ti! Esa es la idea de rotaciones 3D basadas en la atención que permiten investigar todo el lado de un holograma sin levantar un dedo. Para habilitar este comportamiento, basta con agregar el script OnLookAtRotateByEyeGaze a la parte de GameObject con un componente Colisionador . Puede ajustar varios parámetros que se enumeran a continuación para limitar la rapidez y en qué direcciones se activará el holograma.

Como puede imaginar, tener este comportamiento activo en todo momento puede volverse muy distraído en una escena llena de gente. Este es el motivo por el que es posible que quiera empezar con este comportamiento deshabilitado y, a continuación, habilitarlo rápidamente mediante comandos de voz. Como alternativa, hemos agregado un ejemplo en EyeTrackingDemo-03-Navigation (Assets/MRTK/Examples/Demos/EyeTracking/Scenes) para usar TargetMoveToCamera para el que puede seleccionar un destino centrado y vuela delante de usted, simplemente diga "Ven a mí".

Una vez en el modo cercano, el modo de rotación automática se habilita automáticamente. En ese modo, puedes observarlo desde todos los lados simplemente inclinando hacia atrás y mirandolo, caminando por él o llegando a agarrarlo y girarlo con tu mano. Al descartar el destino (mira pellizcar & o decir "Volver atrás"), volverá a su ubicación original y dejará de reaccionar a ti desde lejos.

Parámetros Descripción
SpeedX Velocidad de rotación horizontal.
Rápida Velocidad de rotación vertical.
InverseX Para inverso de la dirección de rotación horizontal.
Inversa Para inverso de la dirección de rotación vertical.
RotationThreshInDegrees Si el ángulo entre 'Gaze to Target' y 'Cámara to Target' es menor que este valor, no haga nada. Esto es para evitar pequeñas rotaciones jittery.
MinRotX Ángulo de rotación horizontal mínimo. Esto es para limitar la rotación en diferentes direcciones.
MaxRotX Ángulo de rotación horizontal máximo. Esto es para limitar la rotación en diferentes direcciones.
MinRoty Ángulo de rotación vertical mínimo para limitar el giro alrededor del eje x.
MaxRotY Ángulo máximo de rotación vertical para limitar el giro alrededor del eje y.

Eye-supported 3D rotation setup in Unity

En resumen, los scripts anteriores le permitirán empezar a usar la mirada ocular para diversas tareas de navegación de entrada, como textos de desplazamiento, zoom y texturas de movimiento panorámico, así como la rotación de hologramas 3D.

Consulta también


De vuelta a "Seguimiento ocular en MixedRealityToolkit"