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.