WPF - Déclencheurs
Un déclencheur vous permet essentiellement de modifier les valeurs de propriété ou d'effectuer des actions en fonction de la valeur d'une propriété. Ainsi, il vous permet de modifier dynamiquement l'apparence et / ou le comportement de votre contrôle sans avoir à en créer un nouveau.
Les déclencheurs sont utilisés pour modifier la valeur d'une propriété donnée, lorsque certaines conditions sont satisfaites. Les déclencheurs sont généralement définis dans un style ou à la racine d'un document qui sont appliqués à ce contrôle spécifique. Il existe trois types de déclencheurs -
- Déclencheurs de propriété
- Déclencheurs de données
- Déclencheurs d'événements
Déclencheurs de propriété
Dans les déclencheurs de propriété, lorsqu'une modification se produit dans une propriété, elle entraîne une modification immédiate ou animée d'une autre propriété. Par exemple, vous pouvez utiliser un déclencheur de propriété pour modifier l'apparence d'un bouton lorsque la souris survole le bouton.
L'exemple de code suivant montre comment modifier la couleur de premier plan d'un bouton lorsque la souris survole le bouton.
<Window x:Class = "WPFPropertyTriggers.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "604">
<Window.Resources>
<Style x:Key = "TriggerStyle" TargetType = "Button">
<Setter Property = "Foreground" Value = "Blue" />
<Style.Triggers>
<Trigger Property = "IsMouseOver" Value = "True">
<Setter Property = "Foreground" Value = "Green" />
</Trigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid>
<Button Width = "100" Height = "70"
Style = "{StaticResource TriggerStyle}" Content = "Trigger"/>
</Grid>
</Window>
Lorsque vous compilez et exécutez le code ci-dessus, il produira la fenêtre suivante -
Lorsque la souris survole le bouton, sa couleur de premier plan devient verte.
Déclencheurs de données
Un déclencheur de données effectue certaines actions lorsque les données liées remplissent certaines conditions. Jetons un coup d'œil au code XAML suivant dans lequel une case à cocher et un bloc de texte sont créés avec certaines propriétés. Lorsque la case est cochée, il changera sa couleur de premier plan en rouge.
<Window x:Class = "WPFDataTrigger.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "Data Trigger" Height = "350" Width = "604">
<StackPanel HorizontalAlignment = "Center">
<CheckBox x:Name = "redColorCheckBox"
Content = "Set red as foreground color" Margin = "20"/>
<TextBlock Name = "txtblock" VerticalAlignment = "Center"
Text = "Event Trigger" FontSize = "24" Margin = "20">
<TextBlock.Style>
<Style>
<Style.Triggers>
<DataTrigger Binding = "{Binding ElementName = redColorCheckBox, Path = IsChecked}"
Value = "true">
<Setter Property = "TextBlock.Foreground" Value = "Red"/>
<Setter Property = "TextBlock.Cursor" Value = "Hand" />
</DataTrigger>
</Style.Triggers>
</Style>
</TextBlock.Style>
</TextBlock>
</StackPanel>
</Window>
Lorsque le code ci-dessus est compilé et exécuté, il produira la sortie suivante -
Lorsque vous cochez la case, le bloc de texte change sa couleur de premier plan en rouge.
Déclencheurs d'événements
Un déclencheur d'événement exécute certaines actions lorsqu'un événement spécifique est déclenché. Il est généralement utilisé pour réaliser une animation sur un contrôle tel que DoubleAnumatio, ColorAnimation, etc. Dans l'exemple suivant, nous allons créer un bouton simple. Lorsque l'événement de clic est déclenché, il élargit la largeur et la hauteur du bouton.
<Window x:Class = "WPFEventTrigger.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<Button Content = "Click Me" Width = "60" Height = "30">
<Button.Triggers>
<EventTrigger RoutedEvent = "Button.Click">
<EventTrigger.Actions>
<BeginStoryboard>
<Storyboard>
<DoubleAnimationUsingKeyFrames Storyboard.TargetProperty =
"Width" Duration = "0:0:4">
<LinearDoubleKeyFrame Value = "60" KeyTime = "0:0:0"/>
<LinearDoubleKeyFrame Value = "120" KeyTime = "0:0:1"/>
<LinearDoubleKeyFrame Value = "200" KeyTime = "0:0:2"/>
<LinearDoubleKeyFrame Value = "300" KeyTime = "0:0:3"/>
</DoubleAnimationUsingKeyFrames>
<DoubleAnimationUsingKeyFrames Storyboard.TargetProperty = "Height"
Duration = "0:0:4">
<LinearDoubleKeyFrame Value = "30" KeyTime = "0:0:0"/>
<LinearDoubleKeyFrame Value = "40" KeyTime = "0:0:1"/>
<LinearDoubleKeyFrame Value = "80" KeyTime = "0:0:2"/>
<LinearDoubleKeyFrame Value = "150" KeyTime = "0:0:3"/>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</BeginStoryboard>
</EventTrigger.Actions>
</EventTrigger>
</Button.Triggers>
</Button>
</Grid>
</Window>
Lorsque vous compilez et exécutez le code ci-dessus, il produira la fenêtre suivante -
En cliquant sur le bouton, vous remarquerez qu'il commencera à se développer dans les deux dimensions.
Nous vous recommandons de compiler et d'exécuter les exemples ci-dessus et d'appliquer également les déclencheurs à d'autres propriétés.