Share via


Compatibilidad de UI Automation para el tipo de control Button

Nota

Esta documentación está dirigida a los desarrolladores de .NET Framework que quieran usar las clases de automatización de la interfaz de usuario administradas definidas en el espacio de nombres System.Windows.Automation. Para ver la información más reciente acerca de la automatización de la interfaz de usuario, consulte Windows Automation API: automatización de la interfaz de usuario.

Este tema proporciona información sobre la compatibilidad de UI Automation con el tipo de control de botón. En UI Automation, un tipo de control es un conjunto de condiciones que un control debe cumplir para poder usar la propiedad ControlTypeProperty. Las condiciones incluyen directrices específicas para la estructura de árbol de Automatización de la interfaz de usuario, los valores de propiedad de Automatización de la interfaz de usuario, los patrones de control y los eventos de automatización de la interfaz de usuario.

Un botón es un objeto con el que un usuario interactúa para realizar una acción, como por ejemplo los botones Aceptar y Cancelar de un cuadro de diálogo. El control de botón es un control simple de exponer porque se asigna a un único comando que el usuario quiere realizar.

Las siguientes secciones definen la estructura de árbol de automatización de UI Automation, las propiedades, los patrones de control y los eventos para el tipo de control de botón. Los requisitos de UI Automation se aplican a todos los controles de botón de número, ya sea Windows Presentation Foundation (WPF), Win32 o Windows Forms.

Estructura de árbol de Automatización de la interfaz de usuario necesaria

La siguiente tabla muestra la vista de control y la vista de contenido del árbol de UI Automation que pertenece a los controles de botón y describe lo que puede contener cada vista. Para más información sobre el árbol de UI Automation,consulte Introducción al árbol de Automatización de la interfaz de usuario.

Vista de control Vista de contenido
Botón

- Image (0 o más)
- Texto (0 o más)
Botón

Propiedades de Automatización de la interfaz de usuario necesarias

En la siguiente tabla se enumeran las propiedades UI Automation que tienen un valor o una definición que son especialmente relevantes para los controles que implementan el tipo de control Button (como los controles de botón). Para más información sobre las propiedades de automatización de la interfaz de usuario, consulte Propiedades de automatización de la interfaz de usuario para clientes.

Propiedad de automatización de interfaz de usuario Valor Notas
AcceleratorKeyProperty Vea las notas. El control Button normalmente debe admitir una tecla de aceleración para permitir que los usuarios finales realicen la acción que representa rápidamente desde el teclado.
AutomationIdProperty Vea las notas. El valor de esta propiedad debe ser único en todos los controles de una aplicación.
BoundingRectangleProperty Vea las notas. El rectángulo exterior que contiene el control completo.
ClickablePointProperty Vea las notas. Se admite si hay un rectángulo delimitador. Si no todos los puntos que se encuentran dentro del rectángulo delimitador son seleccionables, y realiza pruebas de aciertos especializadas, invalide y ofrezca un punto en el que hacer clic.
ControlTypeProperty Botón Este valor es el mismo para todos los marcos de trabajo de la interfaz de usuario.
HelpTextProperty Vea las notas. El texto de ayuda puede indicar cuál será el resultado final de la activación del botón. Suele ser el mismo tipo de información que se presenta mediante un elemento de información sobre herramientas.
IsContentElementProperty True El control Button siempre debe ser contenido.
IsControlElementProperty True El control Button siempre debe ser un control.
IsKeyboardFocusableProperty Vea las notas. Si el control puede recibir el foco del teclado, debe admitir esta propiedad.
LabeledByProperty Null Los controles de botón se etiquetan automáticamente con su contenido.
LocalizedControlTypeProperty "botón" Cadena localizada que corresponde al tipo de control Button.
NameProperty Vea las notas. El nombre del control de botón es el texto que se utiliza para etiquetarlo. Cada vez que se utiliza una imagen para etiquetar un botón, debe proporcionar texto alternativo para la propiedad Name del botón.

Patrones de control de Automatización de la interfaz de usuario necesarios

La siguiente tabla enumera los patrones de control de UI Automation que deben soportar todos los controles de botón. Para más información sobre los patrones de control, vea UI Automation Control Patterns Overview.

Patrón de control Soporte técnico Notas
IInvokeProvider Vea las notas. Todos los botones deben admitir el patrón de control Invoke o el patrón de control Toggle. Invoke se admite cuando el botón ejecuta un comando a petición del usuario. Este comando se asigna a una única operación, como cortar, copiar, pegar o eliminar.
IToggleProvider Vea las notas. Todos los botones deben admitir el patrón de control Invoke o el patrón de control Toggle. Toggle se admite si el botón puede pasar cíclicamente por una serie de hasta tres estados. Normalmente, se considera como un conmutador de encendido y apagado para características específicas.
IExpandCollapseProvider Vea las notas. Cuando un botón se hospeda como elemento secundario de un botón de expansión, el botón secundario puede admitir el patrón ExpandCollapse en lugar de Invoke o Toggle. El patrón ExpandCollapse se puede usar para abrir o cerrar un menú u otra subestructura asociada con el elemento de botón.

Eventos de Automatización de la interfaz de usuario necesarios

La siguiente tabla enumera los eventos de UI Automation que deben ser soportados por todos los controles de botón. Para más información sobre los eventos, vea UI Automation Events Overview.

Evento de Automatización de la interfaz de usuario Soporte técnico Notas
AutomationFocusChangedEvent Obligatorio None
Evento cambiado por propiedadBoundingRectangleProperty . Obligatorio None
Evento cambiado por propiedadIsOffscreenProperty . Obligatorio None
Evento cambiado por propiedadIsEnabledProperty . Obligatorio None
Evento cambiado por propiedadNameProperty . Obligatorio None
StructureChangedEvent Obligatorio None
InvokedEvent Depende Si el control admite el patrón de control Invoke, debe admitir este evento.
Evento cambiado por propiedadToggleStateProperty . Depende Si el control admite el patrón de control Toggle, debe admitir este evento.

Consulte también