WPF - Gaya

Kerangka .NET menyediakan beberapa strategi untuk mempersonalisasi dan menyesuaikan tampilan aplikasi. Gaya memberi kami fleksibilitas untuk menyetel beberapa properti suatu objek dan menggunakan kembali setelan khusus ini di beberapa objek untuk tampilan yang konsisten.

  • Dalam gaya, Anda hanya dapat menyetel properti objek yang sudah ada seperti Tinggi, Lebar, Ukuran font, dll.

  • Hanya perilaku default dari sebuah kontrol yang dapat ditentukan.

  • Beberapa properti dapat ditambahkan ke dalam satu gaya.

Gaya digunakan untuk memberikan tampilan atau tampilan yang seragam ke sekumpulan kontrol. Gaya implisit digunakan untuk menerapkan tampilan ke semua kontrol dari tipe tertentu dan menyederhanakan aplikasi. Bayangkan tiga tombol, semuanya harus terlihat sama, lebar dan tinggi sama, ukuran font sama, warna latar depan sama, dll. Kita bisa menyetel semua properti itu pada elemen tombol itu sendiri dan itu masih cukup oke untuk semua tombol. Perhatikan diagram berikut.

Namun dalam aplikasi kehidupan nyata, Anda biasanya akan memiliki lebih banyak lagi yang harus terlihat sama persis. Dan bukan hanya tombol saja, Anda biasanya ingin blok teks, kotak teks, dan kotak kombo, dll. Terlihat sama di seluruh aplikasi Anda. Pasti ada cara yang lebih baik untuk mencapai ini dan itu dikenal sebagaistyling. Anda dapat menganggap gaya sebagai cara mudah untuk menerapkan sekumpulan nilai properti ke lebih dari satu elemen. Perhatikan diagram berikut.

Contoh

Mari kita ambil contoh sederhana untuk memahami konsep ini. Mulailah dengan membuat proyek WPF baru.

  • Seret tiga tombol dari kotak alat ke jendela desain.

  • Kode XAML berikut membuat tiga tombol dan menginisialisasinya dengan beberapa properti.

<Window x:Class = "WPFStyle.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   xmlns:local = "clr-namespace: WPFStyle" 
   mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604"> 
	
   <StackPanel> 
      <Button Content = "Button1" Height = "30" Width = "80" 
         Foreground = "Blue" FontSize = "12" Margin = "10"/> 
      <Button Content = "Button2" Height = "30" Width = "80" 
         Foreground = "Blue" FontSize = "12" Margin = "10"/> 
      <Button Content = "Button3" Height = "30" Width = "80" 
         Foreground = "Blue" FontSize = "12" Margin = "10"/> 
   </StackPanel> 
	
</Window>

Ketika Anda melihat kode di atas, Anda akan melihat bahwa untuk semua tombol, tinggi, lebar, warna latar depan, ukuran font, dan properti margin adalah sama. Sekarang ketika kode di atas dikompilasi dan dijalankan, jendela berikut akan ditampilkan.

Sekarang mari kita lihat contoh yang sama, tapi kali ini, kita akan menggunakan style.

<Window x:Class = "XAMLStyle.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
   xmlns:local = "clr-namespace:XAMLStyle" 
   mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
	
   <Window.Resources> 
      <Style x:Key = "myButtonStyle" TargetType = "Button"> 
         <Setter Property = "Height" Value = "30" /> 
         <Setter Property = "Width" Value = "80" /> 
         <Setter Property = "Foreground" Value = "Blue" /> 
         <Setter Property = "FontSize" Value = "12" /> 
         <Setter Property = "Margin" Value = "10" /> 
      </Style> 
   </Window.Resources> 
	
   <StackPanel> 
      <Button Content = "Button1" Style = "{StaticResource myButtonStyle}" /> 
      <Button Content = "Button2" Style = "{StaticResource myButtonStyle}" /> 
      <Button Content = "Button3" Style="{StaticResource myButtonStyle}" /> 
   </StackPanel> 
	
</Window>

Gaya ditentukan dalam kamus sumber daya dan setiap gaya memiliki pengenal kunci unik dan jenis target. Di dalam <style> Anda dapat melihat bahwa beberapa tag penyetel ditentukan untuk setiap properti yang akan disertakan dalam gaya.

Dalam contoh di atas, semua properti umum dari setiap tombol sekarang ditentukan dalam gaya, lalu gaya ditetapkan ke setiap tombol dengan kunci unik dengan menyetel properti gaya melalui ekstensi markup StaticResource.

Ketika Anda mengkompilasi dan menjalankan kode di atas, ini akan menampilkan jendela berikut (keluaran yang sama).

Keuntungan melakukannya seperti ini segera terlihat, kita dapat menggunakan kembali gaya itu dimanapun dalam ruang lingkupnya; dan jika kita perlu mengubahnya, kita cukup mengubahnya sekali dalam definisi gaya alih-alih di setiap elemen.

Di tingkat apa gaya didefinisikan secara instan membatasi ruang lingkup gaya itu. Jadi cakupannya, yaitu di mana Anda dapat menggunakan gaya, bergantung pada tempat Anda mendefinisikannya. Gaya dapat ditentukan pada level berikut -

Sr Tidak Level & Deskripsi
1 Level Kontrol

Mendefinisikan gaya pada tingkat kontrol hanya dapat diterapkan ke kontrol tertentu. Diberikan di bawah ini adalah contoh level kontrol di mana tombol dan TextBlock memiliki gayanya sendiri.

2 Tingkat Tata Letak

Mendefinisikan gaya pada setiap tingkat tata letak akan membuatnya dapat diakses oleh tata letak tersebut dan elemen turunannya saja.

3 Level Jendela

Mendefinisikan gaya pada tingkat jendela dapat membuatnya dapat diakses oleh semua elemen pada jendela itu.

4 Tingkat Aplikasi

Mendefinisikan gaya pada level aplikasi dapat membuatnya dapat diakses di seluruh aplikasi. Mari kita ambil contoh yang sama, tetapi di sini, kita akan meletakkan gaya di file app.xaml agar dapat diakses di seluruh aplikasi.