Obtener patrones de control de UI Automation admitidos
Nota |
---|
Esta documentación está dirigida a desarrolladores de .NET Framework que desean usar las clases administradas de UI Automation definidas en el espacio de nombres System.Windows.Automation.Para obtener información actualizada sobre UI Automation, vea Windows Automation API: UI Automation. |
En este tema se muestra cómo recuperar objetos patrón de control de elementos de UI Automation.
Obtener todos los patrones de control
Obtenga el elemento AutomationElement en cuyos patrones de control está interesado.
Llame a GetSupportedPatterns para obtener todos los patrones de control del elemento.
Precaución |
---|
Se recomienda encarecidamente que los clientes no utilicen GetSupportedPatterns.El rendimiento puede verse afectado de modo muy negativo, porque este método llama internamente a GetCurrentPattern para cada patrón de control existente.Si es posible, los clientes deben llamar a GetCurrentPattern para los patrones clave que le interesen. |
Obtener un patrón de control concreto
Obtenga el elemento AutomationElement en cuyos patrones de control está interesado.
Llame a GetCurrentPattern o a TryGetCurrentPattern para solicitar un patrón concreto. Estos métodos son similares, pero si no se encuentra el patrón, GetCurrentPattern inicia una excepción y TryGetCurrentPattern devuelve false.
Ejemplo
En el ejemplo siguiente se recupera un elemento AutomationElement para un elemento de lista y se obtiene el patrón de control SelectionItemPattern de ese elemento.
''' <summary>
''' Sets the focus to a list and selects a string item in that list.
''' </summary>
''' <param name="listElement">The list element.</param>
''' <param name="itemText">The text to select.</param>
''' <remarks>
''' This deselects any currently selected items. To add the item to the current selection
''' in a multiselect list, use AddToSelection instead of Select.
''' </remarks>
Public Sub SelectListItem(ByVal listElement As AutomationElement, ByVal itemText As String)
If listElement Is Nothing OrElse itemText = "" Then
Throw New ArgumentException("Argument cannot be null or empty.")
End If
listElement.SetFocus()
Dim cond As New PropertyCondition(AutomationElement.NameProperty, itemText, PropertyConditionFlags.IgnoreCase)
Dim elementItem As AutomationElement = listElement.FindFirst(TreeScope.Children, cond)
If Not (elementItem Is Nothing) Then
Dim pattern As SelectionItemPattern
Try
pattern = DirectCast(elementItem.GetCurrentPattern(SelectionItemPattern.Pattern), _
SelectionItemPattern)
Catch ex As InvalidOperationException
Console.WriteLine(ex.Message) ' Most likely "Pattern not supported."
Return
End Try
pattern.Select()
End If
End Sub 'SelectListItem
/// <summary>
/// Sets the focus to a list and selects a string item in that list.
/// </summary>
/// <param name="listElement">The list element.</param>
/// <param name="itemText">The text to select.</param>
/// <remarks>
/// This deselects any currently selected items. To add the item to the current selection
/// in a multiselect list, use AddToSelection instead of Select.
/// </remarks>
public void SelectListItem(AutomationElement listElement, String itemText)
{
if ((listElement == null) || (itemText == ""))
{
throw new ArgumentException("Argument cannot be null or empty.");
}
listElement.SetFocus();
Condition cond = new PropertyCondition(
AutomationElement.NameProperty, itemText, PropertyConditionFlags.IgnoreCase);
AutomationElement elementItem = listElement.FindFirst(TreeScope.Children, cond);
if (elementItem != null)
{
SelectionItemPattern pattern;
try
{
pattern = elementItem.GetCurrentPattern(SelectionItemPattern.Pattern) as SelectionItemPattern;
}
catch (InvalidOperationException ex)
{
Console.WriteLine(ex.Message); // Most likely "Pattern not supported."
return;
}
pattern.Select();
}
}