XAML - Gestion des événements
Le concept général des événements en XAML est similaire aux événements dans d'autres langages de programmation courants tels que .NET et C ++. En XAML, tous les contrôles exposent certains événements afin qu'ils puissent être abonnés à des fins spécifiques.
Chaque fois qu'un événement a lieu, l'application sera notifiée et le programme pourra y réagir, par exemple, des boutons de fermeture sont utilisés pour fermer une boîte de dialogue.
Il existe de nombreux types d'événements qui peuvent être souscrits pour différents comportements d'une application en fonction des exigences de cette application, mais les événements les plus couramment utilisés sont ceux qui sont liés à la souris et au clavier tels que,
- Click
- MouseDown
- MouseEnter
- MouseLeave
- MouseUp
- KeyDown
- KeyUp
Dans ce chapitre, nous utiliserons certains des événements de base et les plus couramment utilisés pour comprendre comment un événement d'un contrôle spécifique peut être lié au code derrière où le comportement sera implémenté en fonction de ce que l'utilisateur veut faire lorsqu'un événement spécifique se produit.
Jetons un coup d'œil à un exemple simple d'événement de clic sur un bouton. Vous trouverez ci-dessous l'implémentation XAML pour le contrôle Button qui est créé et initialisé avec certaines propriétés et un événement Click (Click = "OnClick").
<Window x:Class = "XAMLEventHandling.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 x:Name = "button1" Content = "Click" Click = "OnClick"
Width = "150" Height = "30" HorizontalAlignment = "Center" />
</Grid>
</Window>
Chaque fois que ce bouton est cliqué, il déclenche un OnClicket vous pouvez ajouter n'importe quel type de comportement en réponse au Click. Jetons un coup d'œil à l'implémentation de l'événement OnClick qui affichera un message lorsque vous cliquerez sur ce bouton.
using System;
using System.Windows;
using System.Windows.Controls;
namespace XAMLEventHandling {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void OnClick(object sender, RoutedEventArgs e) {
MessageBox.Show("Button is clicked!");
}
}
}
Lorsque vous compilez et exécutez le code ci-dessus, il produira la sortie suivante -
Lorsque vous cliquez sur le bouton, l'événement Click (OnClick) est déclenché et le message suivant s'affiche.
Voyons maintenant un exemple un peu complexe où plusieurs événements sont gérés.
Exemple
L'exemple suivant contient une zone de texte avec ContextMenu qui manipule le texte dans la zone de texte.
Le code XAML suivant crée un TextBox, un ContextMenu et MenuItems avec certaines propriétés et événements tels que Checked, Unchecked et Click.
<Window x:Class = "XAMLContextMenu.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>
<TextBox Name = "textBox1" TextWrapping = "Wrap" Margin = "10" Grid.Row = "7">
Hi, this is XAML tutorial.
<TextBox.ContextMenu>
<ContextMenu>
<MenuItem Header = "_Bold" IsCheckable = "True"
Checked = "Bold_Checked" Unchecked = "Bold_Unchecked" />
<MenuItem Header = "_Italic" IsCheckable = "True"
Checked = "Italic_Checked" Unchecked = "Italic_Unchecked" />
<Separator />
<MenuItem Header = "Increase Font Size" Click = "IncreaseFont_Click" />
<MenuItem Header = "_Decrease Font Size" Click = "DecreaseFont_Click" />
</ContextMenu>
</TextBox.ContextMenu>
</TextBox>
</Grid>
</Window>
Voici l'implémentation en C # pour les différents événements qui seront déclenchés à chaque fois qu'un élément de menu est coché, décoché ou cliqué.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
namespace XAMLContextMenu {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void Bold_Checked(object sender, RoutedEventArgs e) {
textBox1.FontWeight = FontWeights.Bold;
}
private void Bold_Unchecked(object sender, RoutedEventArgs e) {
textBox1.FontWeight = FontWeights.Normal;
}
private void Italic_Checked(object sender, RoutedEventArgs e) {
textBox1.FontStyle = FontStyles.Italic;
}
private void Italic_Unchecked(object sender, RoutedEventArgs e) {
textBox1.FontStyle = FontStyles.Normal;
}
private void IncreaseFont_Click(object sender, RoutedEventArgs e) {
if (textBox1.FontSize < 18) {
textBox1.FontSize += 2;
}
}
private void DecreaseFont_Click(object sender, RoutedEventArgs e) {
if (textBox1.FontSize > 10) {
textBox1.FontSize -= 2;
}
}
}
}
Lorsque vous compilez et exécutez le code ci-dessus, il produira la sortie suivante -
Nous vous recommandons d'exécuter l'exemple de code ci-dessus et de tester d'autres événements.
Événements
N ° Sr. | Commandes et description |
---|---|
1 | Checked Se déclenche lorsqu'un ToggleButton est coché. (Hérité de ToggleButton) |
2 | Click Se produit lorsque l'utilisateur clique sur un contrôle bouton. (Hérité de ButtonBase) |
3 | ContextMenuClosing Se produit juste avant la fermeture d'un menu contextuel sur l'élément. (Hérité de FrameworkElement.) |
4 | ContextMenuOpening Se produit quand un menu contextuel sur l'élément est ouvert. (Hérité de FrameworkElement.) |
5 | DataContextChanged Se produit lorsque la valeur de la propriété FrameworkElement.DataContext change. (Hérité de FrameworkElement) |
6 | DragEnter Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible. (Hérité de UIElement). |
sept | DragLeave Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme origine. (Hérité de UIElement) |
8 | DragOver Se produit lorsque le système d'entrée signale un événement de glissement sous-jacent avec cet élément comme cible de dépôt potentielle. (Hérité de UIElement) |
9 | DragStarting Se produit lorsqu'une opération de glissement est lancée. (Hérité de UIElement) |
dix | DropCompleted Se produit à la fin d'une opération de glisser-déposer. (Hérité de UIElement) |
11 | DropDownClosed Se produit lorsque la partie déroulante du ComboBox se ferme. |
12 | DropDownOpened Se produit lorsque la partie déroulante de ComboBox s'ouvre. |
13 | GotFocus Se produit lorsqu'un UIElement reçoit le focus. (Hérité de UIElement) |
14 | Holding Se produit lorsqu'une interaction Hold autrement non gérée se produit sur la zone de test de positionnement de cet élément. (Hérité de UIElement) |
15 | Intermediate Se déclenche lorsque l'état d'un ToggleButton passe à l'état indéterminé. (Hérité de ToggleButton) |
16 | IsEnabledChanged Se produit lorsque la propriété IsEnabled change. (Hérité de Control) |
17 | KeyDown Se produit lorsqu'une touche du clavier est enfoncée alors que UIElement a le focus. (Hérité de UIElement) |
18 | KeyUp Se produit lorsqu'une touche du clavier est relâchée alors que UIElement a le focus. (Hérité de UIElement) |
19 | LostFocus Se produit lorsqu'un UIElement perd le focus. (Hérité de UIElement) |
20 | ManipulationCompleted Se produit lorsqu'une manipulation sur le UIElement est terminée. (Hérité de UIElement) |
21 | ManipulationDelta Se produit lorsque le périphérique d'entrée change de position pendant une manipulation. (Hérité de UIElement) |
22 | ManipulationInertiaStarting Se produit lorsque le périphérique d'entrée perd le contact avec l'objet UIElement lors d'une manipulation et que l'inertie commence. (Hérité de UIElement) |
23 | ManipulationStarted Se produit lorsqu'un périphérique d'entrée commence une manipulation sur le UIElement. (Hérité de UIElement) |
24 | ManipulationStarting Se produit lorsque le processeur de manipulation est créé pour la première fois. (Hérité de UIElement) |
25 | SelectionChanged Se produit lorsque la sélection de texte a changé. |
26 | SizeChanged Se produit lorsque la propriété ActualHeight ou ActualWidth change de valeur sur un FrameworkElement. (Hérité de FrameworkElement) |
27 | Unchecked Se produit lorsqu'un ToggleButton n'est pas coché. (Hérité de ToggleButton) |
28 | ValueChanged Se produit lorsque la valeur de la plage change. (Hérité de RangeBase) |