विवश बनाम असंबंधित लेआउट

सिल्वरलाइट में लेआउट हमेशा दो मोडों में से एक में होता है, या तो विवश है, या असंबंधित है। एक संकुचित लेआउट एक है, जहां एक कंटेनर चौड़ाई या ऊंचाई लगाता है। उदाहरण के लिए, वेब ब्राउज़र, आमतौर पर सीएसएस के साथ, हमेशा सिल्वरलाइट प्लग-इन के समग्र आयामों को निर्धारित करता है।

कुछ महत्वपूर्ण विशेषताएं हैं -

  • शीर्ष-स्तरीय तत्वों का लेआउट क्षैतिज और लंबवत दोनों तरह से विवश है। यह जो भी लेआउट का उत्पादन करता है, उसे हमेशा उन परिणामों के साथ समाप्त होना चाहिए जो ब्राउज़र द्वारा लगाए गए आकार के हैं।

  • कुछ तत्व खत्म हो जाते हैं Unconstrainedलेआउट, जिसका अर्थ है कि तत्व अपने स्वयं के आकार का चयन करने के लिए स्वतंत्र हैं। उदाहरण के लिए, एक ऊर्ध्वाधर के अंदर के तत्वStackPanel लंबवत रूप से असंवैधानिक हैं।

  • StackPanel उन्हें उतनी ही ऊंचाई देगा, जितनी उन्हें आवश्यकता होगी। वास्तव में, यह पर्याप्त जगह न होने पर भी ऐसा करेगा। यह उन तत्वों को बताएगा जो उनके पास आवश्यक ऊंचाई है, और फिर कुछ भी फसल लें जो फिट नहीं है।

  • अधिकांश सिल्वरलाइट उपयोगकर्ता इंटरफ़ेस में इन दो लेआउट शैलियों का मिश्रण होता है। भले ही इसके अभिभावक अड़चनें पैदा करें या नहीं, कStackPanel हमेशा प्रदर्शन करेंगे Unconstrainedस्टैकिंग की दिशा में लेआउट। ग्रिड पंक्ति या स्तंभ के लिए भी यही सच है जब ऊंचाई या चौड़ाई निर्धारित की जाती हैAuto

मान लीजिए कि आपके पास एक तत्व है, जो एक कंटेनर के अंदर है जो एक निश्चित क्षैतिज चौड़ाई लगाता है। डिफ़ॉल्ट रूप से, आपके तत्व को स्थान भरने के लिए बढ़ाया जाएगा। यदि आप अलाइनमेंट को लेफ्ट, राइट, या सेंटर पर सेट करते हैं, तो यह बाधा को हटा देगा।

तत्व केवल उस चौड़ाई को लेगा जिसकी उसे जरूरत है। बेशक, आप एक निश्चित चौड़ाई या ऊंचाई के साथ एक बाधा का परिचय दे सकते हैं।

  • असंबंधित लेआउट को कभी-कभी कहा जाता है Size to Content, क्योंकि एक अप्रतिबंधित तत्व का आकार आमतौर पर इसकी सामग्री द्वारा निर्धारित किया जाता है।

  • सिल्वरलाइट लेआउट में सामग्री का आकार एक महत्वपूर्ण विचार है। यह वह है जो लेआउट को स्वयं को जो भी जानकारी प्रदर्शित की जा रही है, उसके अनुकूल बनाने में सक्षम बनाता है।

अनु क्रमांक। नियंत्रण और विवरण
1 GridSplitter

बाधाएं आपके डिज़ाइन में युक्त ब्राउज़र, या निश्चित आयामों से आ सकती हैं। हालांकि, कभी-कभी उपयोगकर्ता को बाधाएं डालने देने के लिए यह उपयोगी होता है।

2 ScrollViewer

उपलब्ध जगह में फिट होने से अधिक जानकारी प्रदर्शित करने के लिए कुछ उपयोगकर्ता इंटरफ़ेस को समाप्त करने की आवश्यकता होती है। इसका एक सामान्य समाधान एक स्क्रॉल करने योग्य क्षेत्र प्रदान करना है। स्क्रॉललाइट के साथ सिल्वरलाइट इसे बहुत आसान बनाता है।

3 बॉर्डर

उपयोगकर्ता इंटरफ़ेस को बाहर रखने के लिए एक और उपयोगी तत्व बॉर्डर है।

फ़ुल स्क्रीन मोड

सिल्वरलाइट प्लग-इन पूरी स्क्रीन को संभालने में सक्षम है। एक ऐसी संपत्ति है जिसे आप पूर्ण स्क्रीन मोड में जाने के लिए एक सहायक वर्ग पर सेट कर सकते हैं। हालाँकि, सुरक्षा उद्देश्यों के लिए कुछ अड़चनें हैं। किसी वेबसाइट को इच्छा के अनुसार स्क्रीन पर ले जाने से रोकने के लिए, और कुछ बुराई करने के लिए, जैसे कि उपयोगकर्ता के पासवर्ड के लिए संकेत मांगना।

पूर्ण स्क्रीन मोड में प्रवेश करने के लिए, आपको एप्लिकेशन ऑब्जेक्ट से Host.Content प्रॉपर्टी को होल्ड करना होगा, और इसके IsFullScreen प्रॉपर्टी को सही पर सेट करना होगा।

आइए हम एक सरल उदाहरण पर नजर डालते हैं जो संपत्ति को दर्शाता है, इसलिए यह पूर्ण स्क्रीन और सामान्य के बीच आगे और पीछे फ्लिप करेगा।

<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>

यहां C # में एक कोड है जो पूर्ण स्क्रीन से सामान्य स्थिति में लौटने की शुरुआत करता है। आप यह पता लगा सकते हैं कि ऐसा कब होता हैHost.Content वस्तुओं FullScreenChanged प्रतिस्पर्धा।

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; 
      } 
		
   } 
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

जब उपयोगकर्ता क्लिक करता है Go Full Screen बटन है, तो यह पूर्ण स्क्रीन मोड में बदल जाएगा।

ध्यान दें कि बटन का पाठ बदल गया है। यह अब कहता हैReturn to Normal। यदि आप इसे फिर से क्लिक करते हैं या हिट एस्केप करते हैं, तो यह पूर्ण स्क्रीन मोड से वापस फ्लिप हो जाएगा।