Organizar controles en aplicaciones de lienzo accesibles
Los controles de una aplicación deben estar organizados para ayudar a los usuarios del lector de pantalla a recorrerlos secuencialmente. Un orden lógico también reduce la confusión para los usuarios del teclado y les ayuda a ser más productivos.
Nombre de pantalla significativo
Cuando se carga una pantalla, los lectores de pantalla dirán su nombre. Elija un nombre significativo para orientar a los usuarios.
Puede cambiar el nombre de la pantalla en el árbol de controles o el panel de propiedades en Power Apps Studio. Seleccione la pantalla y, a continuación seleccione para cambiar el nombre de la pantalla.
El primer elemento de una pantalla es su nombre. Está oculto visualmente y solo pueden acceder a él los usuarios del lector de pantalla.
Cuando se carga una pantalla nueva, Power Apps enfoca el nombre de la pantalla. Si utiliza SetFocus inmediatamente al cargar la pantalla, no se leerá el nombre de la pantalla. Considere la posibilidad de crear un título visible y convertirlo en una región activa para anunciar el cambio de contexto.
Orden de controles lógico
Los usuarios del lector de pantalla pueden recorrer el contenido secuencialmente. El orden está determinado por la posición de los controles, comenzando de arriba a abajo, y de izquierda a derecha. El tamaño del control no importa, solo importan los valores de sus propiedades X e Y.
En este ejemplo, A aparece primero en la secuencia, ya que está más cerca de la parte superior. B y C tienen la misma posición vertical, pero como B está más cerca de la izquierda y, por tanto, aparece antes que C. En último lugar aparece D, ya que está más lejos de la parte superior.
Nota
- En el modo de Vista previa, al editar una aplicación el orden de los controles no se actualiza por razones de rendimiento. El orden será correcto cuando se publique y ejecute la aplicación.
- El orden de controles no es el mismo que se muestra en la vista de árbol de controles en Power Apps Studio. La vista de árbol ordena los controles según el momento en que se agregaron a la aplicación. No afecta el orden de los controles cuando se ejecuta la aplicación.
- Cuando el valor de un control X o Y se establece en una expresión, el orden de control no se actualiza cuando cambia el resultado de la expresión. El orden se calcula y se fija cuando se guarda la aplicación, utilizando el estado inicial de la aplicación para evaluar las expresiones.
- Si está cambiando su posición porque otros controles están ocultos o mostrados, puede usar contenedores de diseño automático para administrar X e Y para usted.
- También puede colocar todos los controles de forma lógica independientemente de los valores de expresión. Por ejemplo, si el control A siempre debe estar debajo del control B y B puede estar oculto a veces, establezca Y de A en
If(B.Visible, B.Y + B.Height, B.Y + 1)
. La suma de 1 asegura que A esté siempre debajo de B, incluso si B está oculto.
Controles agrupados
El orden predeterminado es adecuado para contenido aislado, pero no para contenido agrupado. Considere dos iconos, lado a lado, dibujados con controles de Rectángulo. Cada icono tiene un título. Debajo del título hay dos botones apilados verticalmente: A y B para el primer icono, y C y D para el segundo.
El orden predeterminado va de arriba abajo y de izquierda a derecha. Por lo tanto, el orden de los controles es:
- Rectángulo izquierdo
- Rectángulo derecho
- Título izquierdo
- Título derecho
- A
- C
- B
- D
Esta estructura no refleja que A y B están juntos y, de manera similar, que C y D están juntos.
Use Contenedores para agrupar contenido relacionado. Todos los controles de un Contenedor aparecerán juntos en una secuencia. Dentro de un contenedor, los controles se ordenan con la misma regla: de arriba a abajo, y de izquierda a derecha.
Si se reemplazan los Rectángulos del ejemplo anterior con los Contenedores, el orden de los controles pasa a ser lógico para los usuarios del lector de pantalla:
- Contenedor izquierdo
- Título izquierdo
- A
- B
- Contenedor derecho
- Título derecho
- C
- D
Todos los controles de una Tarjeta de formulario y una Galería se agrupan automáticamente, por lo que no es necesario utilizar un Contenedor. Sin embargo, si hubiera subgrupos, deberá usar Contenedores para ellos.
En este ejemplo, una fila de Galería tiene una miniatura y dos fragmentos de texto a la izquierda. A la derecha hay dos botones. Desde una perspectiva visual y lógica, hay que agrupar los dos conjuntos de controles. Esto garantiza que los usuarios del lector de pantalla encontrarán el grupo de la izquierda antes que el de la derecha.
Orden lógico de navegación del teclado
La navegación por teclado es un aspecto importante de cualquier aplicación. Para muchos usuarios, usar el teclado es más eficiente que usar una pantalla táctil o el mouse. El orden de navegación debe:
- Seguir el flujo visual de los controles.
- Seguir un orden intuitivo hasta "Z" y luego hacia abajo hasta "Z" o hacia abajo en sentido inverso y hasta llegar al otro extremo en sentido inverso.
- Solo tiene una tabulación en los controles que son interactivos.
AcceptsFocus especifica si se puede acceder a los controles mediante el teclado. Para los controles clásicos, la propiedad equivalente es TabIndex.
El orden de navegación sigue el orden de control: de izquierda a derecha, luego de arriba a abajo, en patrón de "Z". Puedes personalizarlo de la misma manera que con la orden de control. Por ejemplo, los controles en Contenedores, Formulario Tarjetas y Galerías se agrupan automáticamente. La tecla Tab navegará por todos los elementos dentro del contenedor antes de pasar al siguiente control fuera del contenedor.
Si el orden de navegación es inesperado, debe comprobar primero si la estructura de la aplicación es lógica.
Nota
Cuando los controles se mueven dinámicamente en la pantalla, por ejemplo, al cambiar su valor X o Y según una Power Fx expresión, el orden de navegación no se actualizará.
Solución alternativa para la secuencia de pestañas personalizada
Para situaciones excepcionales en las que el orden de navegación del teclado debería ser diferente del orden visual, puede colocar los controles de contenedor cuidadosamente para tener el mismo efecto.
En el siguiente ejemplo, el botón A está encima del botón B. El orden natural de navegación por pestañas es A, luego B.
Para invertir el orden de navegación de pestañas, coloque B en un control Contenedor. Establezca el valor Y del Contenedor para que esté por encima de A. La estructura de la aplicación ahora tiene el Contenedor (y B) antes de A. Por lo tanto, el orden de navegación de pestañas es B, luego A.
Con esta técnica, los usuarios de la pantalla Lector también encontrarán B antes que A cuando naveguen sin la tecla Tab.
Índices de pestañas personalizados (función retirada)
Los índices de pestañas personalizados son aquellos que son mayores que cero. Ya no reciben soporte. Todos los valores de TabIndex mayores que cero se tratarán como cero.
Los índices de pestañas personalizados casi siempre son un signo de un mal diseño. Hay mejores alternativas, como crear una estructura de aplicación adecuada o usar SetFocus para cambiar de enfoque.
Algunos problemas con los índices de pestañas personalizados:
Accesibilidad
Es un problema grave de accesibilidad tener índices de pestañas personalizados. Pantalla Lector Los usuarios navegan por una aplicación usando su estructura lógica. Los índices de pestañas personalizados ignoran esa estructura. Desde la pantalla Lector los usuarios también pueden navegar usando la tecla Tab, se confundirán cuando obtengan un orden diferente de otros métodos de navegación.
Facilidad de uso
Los usuarios pueden confundirse cuando parece que se omiten algunos elementos. Pueden desorientarse cuando el foco se mueve en un orden impredecible. Esto es aún más problemático para los usuarios con discapacidades cognitivas.
Mantenimiento
Los creadores de aplicaciones tienen que actualizar manualmente el TabIndex de múltiples controles cada vez que se inserta uno nuevo. Es fácil perderse una actualización o hacer un pedido incorrecto.
Rendimiento
Para admitir índices de pestañas personalizados, el sistema Power Apps tiene que examinar todos los controles en la página y calcular el orden apropiado. Este cálculo es un proceso intensivo. Controles de contenedores como Galería tienen reglas complicadas sobre cómo TabIndex funciona para controles de niños. El sistema mapea el TabIndex deseado del creador de la aplicación a un valor diferente para obedecer estas reglas. Por eso, incluso si TabIndex se establece en cero para todos los controles, el tabindex
HTML real será un número positivo.
Integración con otros componentes
Los índices de pestañas personalizados solo funcionan con controles integrados. Controles que no están integrados en el sistema de índice de pestañas de Power Apps tendrá un orden de navegación inesperado. Esto puede ser un problema para componentes del código. Los desarrolladores de estos componentes deben realizar un seguimiento de los elementos interactivos y establecer un índice de pestañas en ellos. Es posible que utilicen bibliotecas de terceros, que es posible que ni siquiera proporcionen una forma de personalizar los índices de las pestañas. Por otro lado, cuando todos los índices de pestañas son 0 o -1, no hay necesidad de involucrar el sistema de índice de pestañas de Power Apps. Cualquier componente de terceros incrustado en la aplicación obtendrá automáticamente la secuencia de pestañas correcta.
En la otra dirección, cuando las aplicaciones de lienzo están incrustadas en otra página web, los índices de pestañas personalizados no funcionan. Por ejemplo, en las páginas personalizadas. Power Apps no puede controlar los elementos fuera de la aplicación de lienzo, por lo que el orden general de navegación de pestañas será ilógico.
Pasos siguientes
Colores accesibles en Power Apps
Consulte también
- Creación de aplicaciones accesibles
- Mostrar u ocultar contenido de tecnologías de asistencia en aplicaciones de lienzo
- Anuncio de cambios dinámicos con regiones activas para aplicaciones de lienzo
- Usar el Comprobador de accesibilidad
- Limitaciones de accesibilidad en aplicaciones de lienzo
- Propiedades de accesibilidad