Comment : créer un effet de substitution à l'aide d'événements
Cet exemple montre comment modifier la couleur d'un élément lorsque le pointeur de la souris entre et sort de la zone occupée par l'élément.
Cet exemple comprend un fichier Extensible Application Markup Language (XAML) et un fichier code-behind.
Remarque |
---|
Cet exemple montre comment utiliser des événements, mais la méthode recommandée pour parvenir à ce même effet consiste à utiliser un Trigger dans un style.Pour plus d'informations, consultez Application d'un style et création de modèles. |
Exemple
Le XAML suivant crée l'interface utilisateur, qui se compose de Border autour d'un TextBlock et joint les gestionnaires d'événements MouseEnter et MouseLeave au Border.
<StackPanel>
<Border MouseEnter="OnMouseEnterHandler"
MouseLeave="OnMouseLeaveHandler"
Name="border1" Margin="10"
BorderThickness="1"
BorderBrush="Black"
VerticalAlignment="Center"
Width="300" Height="100">
<Label Margin="10" FontSize="14"
HorizontalAlignment="Center">Move Cursor Over Me</Label>
</Border>
</StackPanel>
Le code-behind suivant crée les gestionnaires d'événements MouseEnter et MouseLeave. Lorsque le pointeur de la souris entre dans le Border, l'arrière-plan du Border est modifié en rouge. Lorsque le pointeur de la souris quitte le Border, l'arrière-plan du Border repasse au blanc.
Partial Public Class Window1
Inherits Window
Public Sub New()
InitializeComponent()
End Sub
' raised when mouse cursor enters the are occupied by the element
Private Sub OnMouseEnterHandler(ByVal sender As Object, ByVal e As MouseEventArgs)
border1.Background = Brushes.Red
End Sub
' raised when mouse cursor leaves the are occupied by the element
Private Sub OnMouseLeaveHandler(ByVal sender As Object, ByVal e As MouseEventArgs)
border1.Background = Brushes.White
End Sub
End Class
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
// raised when mouse cursor enters the area occupied by the element
void OnMouseEnterHandler(object sender, MouseEventArgs e)
{
border1.Background = Brushes.Red;
}
// raised when mouse cursor leaves the area occupied by the element
void OnMouseLeaveHandler(object sender, MouseEventArgs e)
{
border1.Background = Brushes.White;
}
}