Freigeben über


Gewusst wie: Ändern der Farbe eines Elements mithilfe von Fokusereignissen

Dieses Beispiel zeigt, wie Sie die Farbe eines Elements ändern, wenn es den Fokus erhält bzw. verliert, indem Sie die Ereignisse GotFocus und LostFocus verwenden.

Dieses Beispiel besteht aus einer Extensible Application Markup Language (XAML)-Datei und einer Code-Behind-Datei.

Beispiel

Der folgende XAML-Code erstellt die Benutzeroberfläche, die aus zwei Button-Objekten besteht, und fügt Ereignishandler für die Ereignisse GotFocus und LostFocus an die Button-Objekte an.

<StackPanel>
  <StackPanel.Resources>
    <Style TargetType="{x:Type Button}">
      <Setter Property="Height" Value="20"/>
      <Setter Property="Width" Value="250"/>
      <Setter Property="HorizontalAlignment" Value="Left"/>
    </Style>
  </StackPanel.Resources>
  <Button
      GotFocus="OnGotFocusHandler"
      LostFocus="OnLostFocusHandler">Click Or Tab To Give Keyboard Focus</Button>
  <Button
      GotFocus="OnGotFocusHandler"
      LostFocus="OnLostFocusHandler">Click Or Tab To Give Keyborad Focus</Button>
</StackPanel>

Der folgende Code-Behind erstellt die Ereignishandler GotFocus und LostFocus. Wenn Button den Tastaturfokus erhält, wird der Background von Button in die Farbe Rot geändert. Wenn Button den Tastaturfokus verliert, wird der Background von Button in die Farbe Weiß geändert.

Partial Public Class Window1
    Inherits Window

    Public Sub New()
        InitializeComponent()
    End Sub

    'raised when Button gains focus. Changes the color of the Button to red.
    Private Sub OnGotFocusHandler(ByVal sender As Object, ByVal e As RoutedEventArgs)
        Dim tb As Button = CType(e.Source, Button)
        tb.Background = Brushes.Red
    End Sub

    'raised when Button loses focus. Changes the color back to white.
    Private Sub OnLostFocusHandler(ByVal sender As Object, ByVal e As RoutedEventArgs)
        Dim tb As Button = CType(e.Source, Button)
        tb.Background = Brushes.White
    End Sub
End Class
public partial class Window1 : Window
{
    public Window1()
    {
        InitializeComponent();
    }

    // Raised when Button gains focus.
    // Changes the color of the Button to Red.
    private void OnGotFocusHandler(object sender, RoutedEventArgs e)
    {
        Button tb = e.Source as Button;
        tb.Background = Brushes.Red;
    }
    // Raised when Button losses focus. 
    // Changes the color of the Button back to white.
    private void OnLostFocusHandler(object sender, RoutedEventArgs e)
    {
        Button tb = e.Source as Button;
        tb.Background = Brushes.White;
    }
}

Siehe auch

Konzepte

Übersicht über die Eingabe