Auf Englisch lesen

Freigeben über


ContentElement.CaptureMouse Methode

Definition

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

C#
public bool CaptureMouse();

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.

C#
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);
    }
  }
}

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:

Produkt Versionen
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Weitere Informationen