Udostępnij za pośrednictwem


AutomationElement.GetCurrentPattern(AutomationPattern) Metoda

Definicja

Pobiera określony obiekt wzorca w tym AutomationElementobiekcie .

public:
 System::Object ^ GetCurrentPattern(System::Windows::Automation::AutomationPattern ^ pattern);
public object GetCurrentPattern (System.Windows.Automation.AutomationPattern pattern);
member this.GetCurrentPattern : System.Windows.Automation.AutomationPattern -> obj
Public Function GetCurrentPattern (pattern As AutomationPattern) As Object

Parametry

pattern
AutomationPattern

Identyfikator wzorca do pobrania.

Zwraca

Object

Obiekt wzorca, jeśli określony wzorzec jest obecnie obsługiwany przez AutomationElementobiekt .

Wyjątki

Wzorzec nie jest obsługiwany przez element .

Interfejs użytkownika dla obiektu AutomationElement już nie istnieje.

Przykłady

W poniższym przykładzie pokazano, jak za pomocą tej metody pobrać SelectionItemPatternelement , który jest następnie używany do wybierania elementu w polu listy.

/// <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();
    }
}
''' <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

Uwaga

W przypadku często powtarzanych zadań, takich jak ten w przykładzie, bardziej wydajne byłoby buforowanie wzorca i używanie metody GetCachedPattern.

Uwagi

GetCurrentPattern Pobiera określony wzorzec na podstawie jego dostępności w momencie wywołania.

W przypadku niektórych form interfejsu użytkownika ta metoda spowoduje narzut na wydajność między procesami. Aplikacje mogą skoncentrować obciążenie przez buforowanie wzorców, a następnie pobieranie ich przy użyciu polecenia GetCachedPattern.

Dotyczy

Zobacz też