WPF - Pohon Elemen
Ada banyak teknologi dimana elemen dan komponen disusun dalam struktur pohon sehingga pemrogram dapat dengan mudah menangani objek dan mengubah perilaku aplikasi. Windows Presentation Foundation (WPF) memiliki struktur pohon yang komprehensif dalam bentuk objek. Di WPF, ada dua cara agar pohon objek lengkap dikonseptualisasikan -
- Struktur Pohon Logis
- Struktur Pohon Visual
Dengan bantuan struktur pohon ini, Anda dapat dengan mudah membuat dan mengidentifikasi hubungan antar elemen UI. Sebagian besar, pengembang dan desainer WPF menggunakan bahasa prosedural untuk membuat aplikasi atau merancang bagian UI aplikasi di XAML dengan mengingat struktur pohon objek.
Struktur Pohon Logis
Dalam aplikasi WPF, struktur elemen UI di XAML mewakili struktur pohon logis. Di XAML, elemen dasar UI dideklarasikan oleh pengembang. Pohon logis di WPF mendefinisikan yang berikut -
- Properti ketergantungan
- Sumber daya statis dan dinamis
- Mengikat elemen pada namanya dll.
Mari kita lihat contoh berikut di mana tombol dan kotak daftar dibuat.
<Window x:Class = "WPFElementsTree.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" Height = "30" Width = "70" Content = "OK" Margin = "20" />
<ListBox x:Name = "listBox" Height = "100" Width = "100" Margin = "20">
<ListBoxItem Content = "Item 1" />
<ListBoxItem Content = "Item 2" />
<ListBoxItem Content = "Item 3" />
</ListBox>
</StackPanel>
</Window>
Jika Anda melihat kode XAML, Anda akan melihat sebuah struktur pohon, yaitu node root adalah Window dan di dalam node root hanya ada satu anak, yaitu StackPanel. Tapi StackPanel berisi dua elemen anak, tombol dan kotak daftar. Kotak daftar memiliki tiga item kotak daftar anak lagi.
Struktur Pohon Visual
Dalam WPF, konsep pohon visual menggambarkan struktur objek visual, seperti yang direpresentasikan oleh Visual Base Class. Ini menandakan semua elemen UI yang dirender ke layar keluaran.
Ketika seorang programmer ingin membuat template untuk kontrol tertentu, dia sebenarnya sedang merender pohon visual dari kontrol itu. Pohon visual juga sangat berguna bagi mereka yang ingin menggambar kontrol tingkat yang lebih rendah untuk alasan kinerja dan pengoptimalan.
Dalam aplikasi WPF, pohon visual digunakan untuk -
- Merender objek visual.
- Merender tata letak.
- Peristiwa yang diarahkan sebagian besar berjalan di sepanjang pohon visual, bukan pohon logis.
Untuk melihat pohon visual dari aplikasi sederhana di atas yang berisi tombol dan kotak daftar, mari kita kompilasi dan jalankan kode XAML dan Anda akan melihat jendela berikut.
Saat aplikasi berjalan, Anda dapat melihat pohon visual dari aplikasi yang sedang berjalan di jendela Live Visual Tree yang menunjukkan hierarki lengkap aplikasi ini, seperti yang ditunjukkan di bawah ini.
Pohon visual biasanya merupakan superset dari pohon logika. Anda dapat melihat di sini bahwa semua elemen logika juga ada di pohon visual. Jadi kedua pohon ini sebenarnya hanyalah dua tampilan berbeda dari kumpulan objek yang sama yang menyusun UI.
Pohon logis meninggalkan banyak detail yang memungkinkan Anda untuk fokus pada struktur inti antarmuka pengguna dan mengabaikan detail persis bagaimana itu disajikan.
Pohon logis adalah apa yang Anda gunakan untuk membuat struktur dasar antarmuka pengguna.
Pohon visual akan menarik jika Anda berfokus pada presentasi. Misalnya, jika Anda ingin menyesuaikan tampilan elemen UI apa pun, Anda perlu menggunakan pohon visual.