Compartir a través de


InvokePattern.Invoke Método

Definición

Envía una solicitud para activar un control e iniciar su acción única e inequívoca.

public:
 void Invoke();
public void Invoke ();
member this.Invoke : unit -> unit
Public Sub Invoke ()

Excepciones

El elemento no admite el patrón de control InvokePattern, o está oculto o bloqueado.

El elemento no está habilitado. Se puede generar si un proveedor de UI Automation implementó su propio control de la propiedad IsEnabled.

Ejemplos

En el ejemplo siguiente, se obtiene un InvokePattern patrón de control de un control y se llama al Invoke método .

///--------------------------------------------------------------------
/// <summary>
/// Obtains an InvokePattern control pattern from a control
/// and calls the InvokePattern.Invoke() method on the control.
/// </summary>
/// <param name="targetControl">
/// The control of interest.
/// </param>
///--------------------------------------------------------------------
private void InvokeControl(AutomationElement targetControl)
{
    InvokePattern invokePattern = null;

    try
    {
        invokePattern =
            targetControl.GetCurrentPattern(InvokePattern.Pattern)
            as InvokePattern;
    }
    catch (ElementNotEnabledException)
    {
        // Object is not enabled
        return;
    }
    catch (InvalidOperationException)
    {
        // object doesn't support the InvokePattern control pattern
        return;
    }

    invokePattern.Invoke();
}
'''--------------------------------------------------------------------
''' <summary>
''' Obtains an InvokePattern control pattern from a control
''' and calls the InvokePattern.Invoke() method on the control.
''' </summary>
''' <param name="targetControl">
''' The control of interest.
''' </param>
'''--------------------------------------------------------------------
Private Sub InvokeControl(ByVal targetControl As AutomationElement) 
    Dim invokePattern As InvokePattern = Nothing
    
    Try
        invokePattern = _
        DirectCast(targetControl.GetCurrentPattern(invokePattern.Pattern), _
        InvokePattern)
    Catch e As ElementNotEnabledException
        ' Object is not enabled.
        Return
    Catch e As InvalidOperationException
        ' Object doesn't support the InvokePattern control pattern
        Return
    End Try
    
    invokePattern.Invoke()

End Sub

Comentarios

Las llamadas a Invoke deben devolverse inmediatamente sin bloquear. Sin embargo, este comportamiento depende completamente de la implementación del proveedor de Microsoft Automatización de la interfaz de usuario. En escenarios en los que la llamada Invoke provoca un problema de bloqueo (por ejemplo, un cuadro de diálogo modal), es posible que se requiera un subproceso auxiliar independiente para llamar al método .

Se aplica a

Consulte también