Pengembangan Windows 10 - Kontrol XAML
XAML Singkatan dari Extensible Application Markup Language. Ini adalah kerangka kerja Antarmuka Pengguna dan menawarkan pustaka kontrol ekstensif yang mendukung pengembangan UI untuk Windows. Beberapa dari mereka memiliki representasi visual seperti Button, Textbox dan TextBlock dll; sementara kontrol lain digunakan sebagai wadah untuk kontrol atau konten lain, seperti gambar dll. Semua kontrol XAML diwarisi dari“System.Windows.Controls.Control”.
XAML Emerging Story
XAML digunakan di banyak platform Microsoft penting seperti Windows Presentation Foundation (WPF), Silverlight dan sekarang, aplikasi Windows. Sekarang, Microsoft Office 2016 juga merupakan keluarga aplikasi UWP. XAML adalah Platform yang kaya, yang menyediakan fitur dan kontrol yang sangat keren yang dapat digunakan dalam aplikasi UWP.
Hierarki kontrol pewarisan lengkap ditampilkan di bawah ini.
Kontrol Tata Letak
Tata Letak Kontrol sangat penting dan kritis untuk kegunaan aplikasi. Ini digunakan untuk mengatur sekelompok elemen GUI di aplikasi Anda. Ada beberapa hal penting yang perlu dipertimbangkan saat memilih panel tata letak -
- Posisi elemen anak.
- Ukuran elemen anak.
- Layering elemen anak yang tumpang tindih di atas satu sama lain.
Daftar Layout Controls diberikan di bawah -
S.No. | Kontrol & Deskripsi |
---|---|
1 | StackPanel StackPaneladalah panel tata letak yang sederhana dan berguna di XAML. Pada panel stack, elemen anak dapat diatur dalam satu baris baik secara horizontal maupun vertikal berdasarkan properti orientasi. |
2 | WrapPanel Di WrapPanel, elemen turunan diposisikan dalam urutan berurutan dari kiri ke kanan atau dari atas ke bawah berdasarkan properti orientasi. Satu-satunya perbedaan antara StackPanel dan WrapPanel adalah ia tidak menumpuk semua elemen turunan ke dalam satu baris tetapi membungkus elemen yang tersisa ke baris lain jika tidak ada ruang tersisa. |
3 | DockPanel DockPanelmendefinisikan area untuk mengatur elemen anak relatif satu sama lain, baik secara horizontal atau vertikal. Dengan DockPanel Anda dapat dengan mudah memasang elemen turunan ke atas, bawah, kanan, kiri, dan tengah dengan properti Dock. Dengan LastChildFill properti, elemen turunan terakhir mengisi ruang yang tersisa terlepas dari nilai dok lainnya saat disetel untuk elemen itu. |
4 | Canvas Canvasadalah panel tata letak dasar tempat elemen anak dapat diposisikan secara eksplisit menggunakan koordinat yang relatif terhadap sisi mana pun seperti kiri, kanan, atas, dan bawah. Biasanya Canvas digunakan untuk elemen grafis 2D (seperti Ellipse, Rectangle, dll.) Tetapi tidak untuk elemen UI karena menentukan koordinat absolut akan menimbulkan masalah saat mengubah ukuran, melokalkan, atau menskalakan aplikasi XAML. |
5 | Grid Gridmenyediakan area yang fleksibel, yang terdiri dari baris dan kolom. Di Grid, elemen anak dapat diatur dalam bentuk tabel. Elemen dapat ditambahkan ke baris dan kolom tertentu dengan menggunakanGrid.Row dan Grid.Column properti. |
6 | SplitView SplitViewmewakili wadah dengan dua tampilan; satu tampilan untuk konten utama dan tampilan lain yang biasanya digunakan untuk perintah navigasi. |
7 | RelativePanel RelativePanel mendefinisikan area di mana Anda dapat memposisikan dan menyelaraskan objek anak dalam kaitannya satu sama lain atau panel induk. |
8 | ViewBox ViewBox mendefinisikan dekorator konten yang dapat memperluas dan menskalakan satu anak untuk mengisi ruang yang tersedia. |
9 | FlipView FlipView merepresentasikan kontrol item yang menampilkan satu item pada satu waktu, dan memungkinkan perilaku "membalik" untuk melintasi koleksi itemnya. |
10 | GridView GridView adalah kontrol yang menampilkan kumpulan item dalam baris dan kolom dan dapat digulir secara horizontal. |
Kontrol UI
Berikut adalah daftar Kontrol UI, yang dapat dilihat oleh pengguna akhir.
S.No. | Kontrol & Deskripsi UI |
---|---|
1 | Button Kontrol yang merespons masukan pengguna |
2 | Calendar Merepresentasikan kontrol yang memungkinkan pengguna untuk memilih tanggal dengan menggunakan tampilan kalender visual. |
3 | CheckBox Kontrol yang dapat dipilih atau dihapus pengguna. |
4 | ComboBox Daftar drop-down item, pengguna dapat memilih dari. |
5 | ContextMenu Mendapat atau menyetel elemen menu konteks yang harus muncul setiap kali menu konteks diminta melalui antarmuka pengguna (UI) dari dalam elemen ini. |
6 | DataGrid Merepresentasikan kontrol yang menampilkan data dalam kisi yang dapat disesuaikan. |
7 | DatePicker Kontrol yang memungkinkan pengguna memilih tanggal. |
8 | Dialogs Sebuah aplikasi juga dapat menampilkan jendela tambahan untuk dilakukan pengguna untuk mengumpulkan atau menampilkan informasi penting. |
9 | Flyout Merepresentasikan kontrol yang menampilkan UI ringan yang berupa informasi, atau memerlukan interaksi pengguna. Tidak seperti dialog, Flyout dapat dihilangkan dengan mengklik atau mengetuk di luarnya, menekan tombol kembali perangkat, atau menekan tombol 'Esc'. |
10 | Image Kontrol yang menampilkan gambar. |
11 | ListBox Kontrol yang menampilkan daftar item sebaris yang dapat dipilih pengguna. |
12 | Menus Merepresentasikan kontrol menu Windows yang memungkinkan Anda mengatur secara hierarki elemen yang terkait dengan perintah dan penangan kejadian. |
13 | MenuFlyout Merepresentasikan flyout yang menampilkan menu perintah. |
14 | PasswordBox Kontrol untuk memasukkan kata sandi. |
15 | Popup Menampilkan konten di atas konten yang ada, dalam batas-batas jendela aplikasi. |
16 | ProgressBar Kontrol yang menunjukkan kemajuan dengan menampilkan bilah. |
17 | ProgressRing Kontrol yang menunjukkan kemajuan tak tentu dengan menampilkan cincin. |
18 | RadioButton Kontrol yang memungkinkan pengguna untuk memilih satu opsi dari sekelompok opsi. |
19 | RichEditBox Kontrol yang memungkinkan pengguna mengedit dokumen teks kaya dengan konten seperti teks yang diformat, hyperlink, dan gambar. |
20 | ScrollViewer Kontrol wadah yang memungkinkan pengguna menggeser dan memperbesar kontennya. |
21 | SearchBox Kontrol yang memungkinkan pengguna memasukkan kueri penelusuran. |
22 | Slider Kontrol yang memungkinkan pengguna memilih dari berbagai nilai dengan menggerakkan kontrol Thumb di sepanjang trek. |
23 | TextBlock Kontrol yang menampilkan teks. |
24 | TimePicker Kontrol yang memungkinkan pengguna menetapkan nilai waktu. |
25 | ToggleButton Tombol yang dapat diubah antara 2 status. |
26 | ToolTip Jendela pop-up yang menampilkan informasi untuk suatu elemen. |
27 | Window Jendela root yang menyediakan opsi minimalkan / maksimalkan, bilah judul, tombol batas dan tutup. |
Diberikan di bawah ini adalah contoh, yang berisi berbagai jenis kontrol dalam a SplitView. Dalam file XAML, kontrol berbeda dibuat dengan beberapa properti dan acara.
<Page
x:Class = "UWPControlsDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPControlsDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel Margin = "20">
<StackPanel Orientation = "Horizontal">
<ToggleButton x:Name = "HamburgerButton" FontFamily = "Segoe MDL2 Assets"
Content = "" Checked = "HandleCheck" Unchecked = "HandleUnchecked"
HorizontalAlignment = "Center"/>
<AppBarButton Icon = "Like" />
<AppBarButton Icon = "Dislike" />
<AppBarSeparator/>
<AppBarButton Icon = "Accept" />
<AppBarButton Icon = "Add" />
</StackPanel>
<SplitView x:Name = "splitView" DisplayMode = "Inline"
OpenPaneLength = "296">
<SplitView.Pane>
<StackPanel>
<TextBlock Text = "SplitView Pane" FontSize = "36"
VerticalAlignment = "Center" HorizontalAlignment = "Center"
Margin = "10"/>
<Button Content = "Options" Margin = "10">
<Button.Flyout>
<MenuFlyout>
<MenuFlyoutItem Text = "Reset"/>
<MenuFlyoutSeparator/>
<MenuFlyoutItem Text = "Repeat"/>
<MenuFlyoutItem Text = "Shuffle"/>
</MenuFlyout>
</Button.Flyout>
</Button>
</StackPanel>
</SplitView.Pane>
<StackPanel>
<TextBlock Text = "SplitView Content" FontSize = "36"
VerticalAlignment = "Center" HorizontalAlignment = "Center"
Margin = "10"/>
<Border BorderThickness = "3" BorderBrush = "Red" Margin = "5">
<StackPanel Orientation = "Horizontal">
<TextBlock Text = "Hyperlink example" Margin = "5"/>
<HyperlinkButton Content = "www.microsoft.com"
NavigateUri = "http://www.microsoft.com"/>
</StackPanel>
</Border>
<RelativePanel BorderBrush = "Red" BorderThickness = "2"
CornerRadius = "10" Padding = "12" Margin = "5">
<TextBlock x:Name = "txt" Text = "Relative Panel example"
RelativePanel.AlignLeftWithPanel = "True"
Margin = "5,0,0,0"/>
<TextBox x:Name = "textBox1" RelativePanel.RightOf = "btn"
Margin = "5,0,0,0"/>
<Button x:Name = "btn" Content = "Name"
RelativePanel.RightOf = "txt" Margin = "5,0,0,0"/>
</RelativePanel>
<FlipView Height = "400" Margin = "10" Width = "400">
<Image Source = "Images/DSC_0104.JPG"/>
<Image Source = "Images/DSC_0080.JPG"/>
<Image Source = "Images/DSC_0076.JPG"/>
<Image Source = "Images/thGTF7BWGW.jpg"/>
</FlipView>
</StackPanel>
</SplitView>
</StackPanel>
</Grid>
</Page>
Diberikan di bawah ini adalah Events implementasi di C #.
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Media;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPControlsDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void HandleCheck(object sender, RoutedEventArgs e) {
splitView.IsPaneOpen = true;
}
private void HandleUnchecked(object sender, RoutedEventArgs e) {
splitView.IsPaneOpen = false;
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut -
Saat Anda mengklik tombol hamburger di sisi kiri atas, itu akan membuka / menutup SplitView panel.
Dalam SplitView Panel, Anda dapat melihat Flyout, MenuFlyout dan FlipView kontrol.
Dalam SplitView Konten, Anda dapat melihat Hyperlink, Relative Panel, ViewBox, dan tombol lain serta kontrol kotak teks.