Tata Letak Dibatasi vs. Tidak Dibatasi

Tata letak di Silverlight selalu terjadi di salah satu dari dua mode, baik Dibatasi, atau Tidak dibatasi. Tata letak Constrained adalah salah satu, di mana penampung memberlakukan lebar atau tinggi. Misalnya, browser web, biasanya dengan CSS, selalu menentukan dimensi keseluruhan dari plugin Silverlight.

Beberapa fitur penting adalah -

  • Tata letak elemen tingkat atas dibatasi baik secara horizontal maupun vertikal. Apapun tata letak yang dihasilkannya, itu harus selalu berakhir dengan hasil yang ukurannya sesuai dengan browser.

  • Beberapa elemen berakhir dengan UnconstrainedLayout, artinya elemen bebas memilih ukurannya sendiri. Misalnya, elemen di dalam vertikalStackPanel tidak dibatasi secara vertikal.

  • StackPanel akan memberi mereka ketinggian sebanyak yang mereka butuhkan. Faktanya, ini akan melakukan ini meskipun tidak ada cukup ruang. Ini akan memberi tahu elemen bahwa mereka memiliki ketinggian yang mereka butuhkan, dan kemudian memotong apa pun yang tidak sesuai.

  • Kebanyakan antarmuka pengguna Silverlight berisi campuran dari dua gaya tata letak ini. Terlepas dari apakah induknya memberikan batasan atau tidak, aStackPanel akan selalu tampil UnconstrainedTata letak ke arah penumpukan. Hal yang sama berlaku untuk baris atau kolom Kisi ketika tinggi atau lebar diaturAuto.

Misalkan Anda memiliki elemen, yang berada di dalam wadah yang menerapkan lebar horizontal tetap. Secara default, elemen Anda akan direntangkan untuk mengisi ruang. Jika Anda mengatur perataan ke Kiri, Kanan, atau Tengah, itu akan menghilangkan batasan.

Elemen hanya akan mengambil lebar yang dibutuhkannya. Tentu saja, Anda bisa memasukkan batasan dengan lebar atau tinggi tetap.

  • Tata Letak Tak Terbatas terkadang dipanggil Size to Content, karena ukuran elemen yang tidak dibatasi biasanya ditentukan oleh isinya.

  • Size to Content adalah ide penting dalam tata letak Silverlight. Inilah yang memungkinkan tata letak menyesuaikan diri dengan informasi apa pun yang sedang ditampilkan.

No Sr Kontrol & Deskripsi
1 GridSplitter

Batasan dapat berasal dari browser yang memuat, atau dimensi tetap dalam desain Anda. Namun, terkadang ada gunanya membiarkan pengguna memaksakan batasan.

2 ScrollViewer

Beberapa antarmuka pengguna akhirnya perlu menampilkan lebih banyak informasi daripada yang akan muat di ruang yang tersedia. Salah satu solusi umum untuk ini adalah menyediakan wilayah yang dapat digulir. Silverlight membuat ini sangat mudah dengan ScrollViewer.

3 Berbatasan

Satu lagi elemen berguna yang perlu diingat saat menata antarmuka pengguna adalah Border.

Mode layar penuh

Plug-in Silverlight dapat mengambil alih seluruh layar. Ada properti yang bisa Anda atur di kelas helper untuk masuk ke mode layar penuh. Namun, ada beberapa kendala untuk tujuan keamanan. Untuk mencegah situs web mengambil alih layar sesuka hati, dan melakukan sesuatu yang jahat, seperti berpura-pura meminta kata sandi pengguna.

Untuk memasuki mode layar penuh, Anda perlu mendapatkan properti Host.Content dari objek aplikasi, dan menyetel properti IsFullScreen ke true.

Mari kita lihat contoh sederhana yang mengubah properti, jadi itu akan beralih antara layar penuh dan normal.

<UserControl x:Class = "FullScreenExample.MainPage" 
   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" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "400">
   
   <Border BorderBrush = "Gray" BorderThickness = "4" CornerRadius = "30" Padding = "20"> 
	
      <Border.Background> 
         <LinearGradientBrush StartPoint = "0,0" EndPoint = "0,1"> 
            <GradientStop Offset = "0" Color = "Wheat" /> 
            <GradientStop Offset = "1" Color = "BurlyWood" />
         </LinearGradientBrush> 
      </Border.Background> 
		
      <Grid x:Name = "LayoutRoot"> 
         <Button x:Name = "fullScreenButton" HorizontalAlignment = "Center" 
            VerticalAlignment = "Center" FontSize = "30" Width = "300" 
            Height = "100" Content = "Go Full Screen" Click = "Button_Click" /> 
      </Grid> 
		
   </Border> 
	
</UserControl>

Berikut adalah kode dalam C # yang memulai kembali dari layar penuh ke normal. Anda dapat mengetahui kapan ini terjadi dengan menangani fileHost.Content benda FullScreenChanged peristiwa.

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

namespace FullScreenExample { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent();  
         App.Current.Host.Content.FullScreenChanged += Content_FullScreenChanged; 
      }
	  
      void Content_FullScreenChanged(object sender, EventArgs e) { 
		
         if (Application.Current.Host.Content.IsFullScreen) { 
            fullScreenButton.Content = "Return to Normal"; 
         } else { 
            fullScreenButton.Content = "Go Full Screen";
         } 
      }
	  
      private void Button_Click(object sender, RoutedEventArgs e) { 
         var content = Application.Current.Host.Content; 
         content.IsFullScreen = !content.IsFullScreen; 
      } 
		
   } 
}

Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat output berikut.

Saat pengguna mengklik Go Full Screen tombol, maka itu akan beralih ke mode layar penuh.

Perhatikan bahwa teks tombol telah berubah. Sekarang tertulisReturn to Normal. Jika Anda mengkliknya lagi atau dengan menekan Escape, itu akan kembali keluar dari mode layar penuh.