Freigeben über


ContentElement.CaptureMouse Methode

Definition

Versucht, die Mausaufzeichnung für dieses Element zu erzwingen.

public:
 virtual bool CaptureMouse();
public bool CaptureMouse ();
abstract member CaptureMouse : unit -> bool
override this.CaptureMouse : unit -> bool
Public Function CaptureMouse () As Boolean

Gibt zurück

true, wenn die Maus erfolgreich aufgezeichnet wird, andernfalls false.

Implementiert

Beispiele

Im folgenden Beispiel wird die Maus erfasst oder die Aufnahme freigegeben, je nachdem, ob die Maus bereits vom Element erfasst wurde. Beachten Sie, dass in diesem Beispiel das prospektive Erfassungszielelement in die IInputElement -Schnittstelle umgewandelt wird und daher zunächst die IInputElement.CaptureMouse -Methode aufgerufen wird. Das Umwandeln in IInputElement ist eine Technik, die nützlich ist, wenn Sie nicht sicher sind, ob das Element, das Sie die Maus erfassen möchten, ein UIElement oder ein ContentElementist. Die Schnittstellenumwandlung und der Aufruf der Schnittstellenmethode rufen dann intern die entsprechende typspezifische CaptureMouse-Implementierung auf, ohne dass eine Testumwandlung in oder UIElement erforderlich ContentElementist. Dieselbe Umwandlungstechnik funktioniert für andere Member, die IInputElement für instance viele eingabebezogene Ereignisse und andere eingabebezogene Methoden definieren.

private void CaptureMouseCommandExecuted(object sender, ExecutedRoutedEventArgs e)
{
  MessageBox.Show("Mouse Command");
  IInputElement target = Mouse.DirectlyOver;

  target = target as Control;
  if (target != null)
  {
    if (!target.IsMouseCaptured)
    {
      Mouse.Capture(target);
    } else {
      Mouse.Capture(null);
    }
  }
}
Private Sub CaptureMouseCommandExecuted(ByVal sender As Object, ByVal e As ExecutedRoutedEventArgs)
  MessageBox.Show("Mouse Command")
  Dim target As IInputElement = Mouse.DirectlyOver

  target = TryCast(target, Control)
  If target IsNot Nothing Then
    If Not target.IsMouseCaptured Then
      Mouse.Capture(target)
    Else
      Mouse.Capture(Nothing)
    End If
  End If
End Sub

Hinweise

Um erfasst zu werden, muss ein Element aktiviert sein. Überprüfen Sie, ob IsEnabledtrue Sie vor dem Aufrufen CaptureMousevon .

Wenn der Aufruf CaptureMouse zurückgibt true, IsMouseCaptured ist auch true.

Wenn der Aufruf CaptureMouse zurückgibt true, werden die GotMouseCapture Ereignisse und IsMouseCapturedChanged ausgelöst, wobei RoutedEventArgs.Source in den Ereignisdaten als das Element gemeldet wird, in dem die CaptureMouse Methode aufgerufen wird. Wenn Sie die Erfassung erzwingen, können Sie vorhandene Aufzeichnungen beeinträchtigen , insbesondere bei Aufzeichnungen, die sich auf das Ziehen und Ablegen mit der Maus beziehen.

Um die Mauserfassung von allen Elementen zu löschen, rufen Sie Mouse.Capture mit dem element angegebenen Parameter als nullauf.

Gilt für:

Weitere Informationen