WPF - Ikhtisar XAML

Salah satu hal pertama yang akan Anda temui saat bekerja dengan WPF adalah XAML. XAML adalah singkatan dari Extensible Application Markup Language. Ini adalah bahasa sederhana dan deklaratif berdasarkan XML.

  • Di XAML, sangat mudah untuk membuat, menginisialisasi, dan menyetel properti objek dengan relasi hierarkis.

  • Ini terutama digunakan untuk mendesain GUI, namun dapat digunakan untuk tujuan lain juga, misalnya, untuk mendeklarasikan alur kerja di Workflow Foundation.

Sintaks Dasar

Saat Anda membuat proyek WPF baru, Anda akan menemukan beberapa kode XAML secara default di MainWindow.xaml seperti yang ditunjukkan di bawah ini.

<Window x:Class = "Resources.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   Title = "MainWindow" Height = "350" Width = "525"> 
	
   <Grid> 
         
   </Grid> 
	
</Window>

File XAML di atas berisi berbagai jenis informasi. Tabel berikut menjelaskan secara singkat peran setiap informasi.

Informasi Deskripsi
<Jendela Ini adalah elemen objek pembuka atau wadah dari root.
x: Class = "Resources.MainWindow" Ini adalah deklarasi kelas parsial yang menghubungkan markup ke kode kelas parsial yang ditentukan di belakang.
xmlns = "http://schemas.microsoft.com/win fx / 2006 / xaml / presentasi" Memetakan namespace XAML default untuk klien / kerangka WPF
xmlns: x = "http://schemas.microsoft.com/w infx / 2006 / xaml" Namespace XAML untuk bahasa XAML yang memetakannya ke awalan x:
> Akhir elemen objek dari root

<Grid>

</Grid>

Ini memulai dan menutup tag dari objek grid kosong.
</Window> Menutup elemen objek

Aturan sintaks untuk XAML hampir mirip dengan XML. Jika Anda melihat dokumen XAML, maka Anda akan melihat bahwa itu sebenarnya adalah file XML yang valid, tetapi file XML belum tentu merupakan file XAML. Karena di XML nilai atribut harus berupa string sedangkan di XAML bisa berupa objek yang berbeda yang dikenal dengan sintaks elemen Property.

  • Sintaks elemen Objek dimulai dengan tanda kurung siku kiri (<) diikuti dengan nama objek, misalnya Tombol.

  • Tentukan beberapa Properti dan atribut elemen objek itu.

  • Elemen Objek harus ditutup dengan garis miring (/) diikuti segera dengan tanda kurung siku (>).

Contoh objek sederhana tanpa elemen anak

<Button/>

Contoh elemen objek dengan beberapa atribut

<Button Content = "Click Me" Height = "30" Width = "60" />

Contoh sintaks alternatif memang mendefinisikan properti (sintaks elemen properti)

<Button> 
   <Button.Content>Click Me</Button.Content> 
   <Button.Height>30</Button.Height> 
   <Button.Width>60</Button.Width> 
</Button>

Contoh Objek dengan Elemen Anak: StackPanel berisi Textblock sebagai elemen anak

<StackPanel Orientation = "Horizontal"> 
   <TextBlock Text = "Hello"/> 
</StackPanel>

Mengapa XAML di WPF

XAML bukan hanya fitur WPF yang paling banyak dikenal, tetapi juga salah satu fitur yang paling disalahpahami. Jika Anda memiliki eksposur ke WPF, maka Anda pasti pernah mendengar tentang XAML; tetapi perhatikan dua fakta yang kurang diketahui berikut tentang XAML -

  • WPF tidak membutuhkan XAML
  • XAML tidak membutuhkan WPF

Mereka sebenarnya adalah bagian-bagian teknologi yang dapat dipisahkan. Untuk memahami bagaimana itu bisa terjadi, mari kita lihat contoh sederhana di mana tombol dibuat dengan beberapa properti di XAML.

<Window x:Class = "WPFXAMLOverview.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"> 
	
   <StackPanel> 
      <Button x:Name = "button" Content = "Click Me" HorizontalAlignment = "Left"  
         Margin = "150" VerticalAlignment = "Top" Width = "75" /> 
   </StackPanel> 
	
</Window>

Jika Anda memilih untuk tidak menggunakan XAML di WPF, Anda juga bisa mendapatkan hasil GUI yang sama dengan bahasa prosedural. Mari kita lihat contoh yang sama, tapi kali ini, kita akan membuat tombol di C #.

using System.Windows; 
using System.Windows.Controls;  

namespace WPFXAMLOverview { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window { 
	
      public MainWindow() { 
         InitializeComponent(); 
			
         // Create the StackPanel 
         StackPanel stackPanel = new StackPanel(); 
         this.Content = stackPanel; 
			
         // Create the Button 
         Button button = new Button();
         button.Content = "Click Me"; 
         button.HorizontalAlignment = HorizontalAlignment.Left; 
         button.Margin = new Thickness(150); 
         button.VerticalAlignment = VerticalAlignment.Top; 
         button.Width = 75; 
         stackPanel.Children.Add(button);  
      } 
   } 
}

Saat Anda mengkompilasi dan mengeksekusi kode XAML atau kode C #, Anda akan melihat output yang sama seperti yang ditunjukkan di bawah ini.

Dari contoh di atas, jelas bahwa apa yang dapat Anda lakukan di XAML untuk membuat, menginisialisasi, dan mengatur properti objek, tugas yang sama juga dapat dilakukan dengan menggunakan kode.

  • XAML hanyalah cara sederhana dan mudah untuk mendesain elemen UI.

  • Dengan XAML, tidak berarti bahwa yang dapat Anda lakukan untuk mendesain elemen UI adalah satu-satunya cara. Anda dapat mendeklarasikan objek di XAML atau mendefinisikannya menggunakan kode.

  • XAML bersifat opsional, tetapi meskipun demikian, XAML adalah inti dari desain WPF.

  • Tujuan XAML adalah untuk memungkinkan desainer visual membuat elemen antarmuka pengguna secara langsung.

  • WPF bertujuan untuk memungkinkan pengendalian semua aspek visual antarmuka pengguna dari mark-up.