ContentElement.CaptureMouse Methode
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
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 null
auf.