WPF - Pemicu

Pemicu pada dasarnya memungkinkan Anda untuk mengubah nilai properti atau mengambil tindakan berdasarkan nilai properti. Jadi, ini memungkinkan Anda untuk secara dinamis mengubah tampilan dan / atau perilaku kontrol Anda tanpa harus membuat yang baru.

Pemicu digunakan untuk mengubah nilai properti tertentu, saat kondisi tertentu terpenuhi. Pemicu biasanya ditentukan dalam gaya atau di root dokumen yang diterapkan ke kontrol khusus tersebut. Ada tiga jenis pemicu -

  • Pemicu Properti
  • Pemicu Data
  • Pemicu Peristiwa

Pemicu Properti

Di pemicu properti, ketika perubahan terjadi di satu properti, itu akan membawa perubahan langsung atau animasi di properti lain. Misalnya, Anda dapat menggunakan pemicu properti untuk mengubah tampilan tombol saat mouse mengarahkan kursor ke tombol.

Kode contoh berikut menunjukkan cara mengubah warna latar depan tombol saat mouse mengarahkan kursor ke tombol.

<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>

Ketika Anda mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan jendela berikut -

Saat mouse mengarahkan mouse ke atas tombol, warna latar depan akan berubah menjadi hijau.

Pemicu Data

Pemicu data melakukan beberapa tindakan saat data terikat memenuhi beberapa kondisi. Mari kita lihat kode XAML berikut di mana kotak centang dan blok teks dibuat dengan beberapa properti. Ketika kotak centang dicentang, itu akan mengubah warna latar depan menjadi merah.

<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>

Ketika kode di atas dikompilasi dan dijalankan, itu akan menghasilkan output berikut -

Saat Anda mencentang kotak, blok teks akan mengubah warna latar depan menjadi merah.

Pemicu Peristiwa

Pemicu peristiwa melakukan beberapa tindakan saat peristiwa tertentu diaktifkan. Biasanya digunakan untuk menyelesaikan beberapa animasi pada kontrol seperti DoubleAnumatio, ColorAnimation, dll. Dalam contoh berikut, kita akan membuat tombol sederhana. Saat peristiwa klik diaktifkan, ini akan memperluas lebar dan tinggi tombol.

<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>

Ketika Anda mengkompilasi dan menjalankan kode di atas, ini akan menghasilkan jendela berikut -

Setelah mengklik tombol, Anda akan melihat bahwa tombol tersebut akan mulai meluas di kedua dimensi.

Kami menyarankan Anda untuk mengompilasi dan menjalankan contoh di atas dan menerapkan pemicu ke properti lain juga.