विंडोज 10 देव - एक्सएएमएल प्रदर्शन

एप्लिकेशन का प्रदर्शन जैसे कि आपका एप्लिकेशन स्टार्टअप पर कितनी जल्दी दिखाई देता है या अगली सामग्री आदि दिखाने के लिए नेविगेट करता है आदि बहुत महत्वपूर्ण है।

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

उदाहरण के लिए, आपके अनुप्रयोगों में, कुछ चीजें हैं, जो आप दिखाना चाहते हैं जब पृष्ठ लोड होता है और फिर बाद में इसकी आवश्यकता नहीं होती है। यह भी संभव है कि स्टार्टअप में आपको लोड किए जाने वाले सभी UI तत्वों की आवश्यकता न हो।

विंडोज 10 ऐप में, XAML में कुछ नई सुविधाएँ जोड़ी गई हैं, जिससे XAML के प्रदर्शन में सुधार हुआ है।

किसी भी यूनिवर्सल विंडोज एप्लिकेशन के प्रदर्शन में निम्नलिखित तकनीकों द्वारा सुधार किया जा सकता है;

  • प्रगतिशील प्रतिपादन
  • आस्थगित लोड हो रहा है

प्रगतिशील प्रतिपादन

विंडोज 10 में, XAML में दो नए और बहुत अच्छे फीचर्स पेश किए गए हैं। वे हैं -

एक्स: बाइंड

यह बाध्यकारी के लिए उपयोग किए जाने वाले XAML में पेश किया गया एक नया वाक्यविन्यास है, जो लगभग उसी तरह काम करता है जैसे कि Binding वाक्य रचना करता है। x:Bindदो प्रमुख अंतर हैं; यह संकलन-समय सिंटैक्स सत्यापन और बेहतर प्रदर्शन प्रदान करता है।

एक्स: चरण

यह डेटा टेम्प्लेट के भीतर XAML नियंत्रण के प्रतिपादन को प्राथमिकता देने की क्षमता प्रदान करता है। प्रत्येक UI तत्व में केवल एक चरण निर्दिष्ट हो सकता है। यदि हां, तो यह तत्व पर सभी बाइंडिंग के लिए लागू होगा। यदि कोई चरण निर्दिष्ट नहीं है, तो चरण 0 मान लिया गया है।

यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) अनुप्रयोगों में, ये दो नई विशेषताएं प्रदर्शन में सुधार प्रदान करती हैं। इसका उपयोग मौजूदा विंडोज 8.x एप्लिकेशन में किया जा सकता है जो विंडोज 10 पर माइग्रेट करता है।

नीचे दिए गए एक उदाहरण है जिसमें कर्मचारी वस्तुओं के साथ बंधे हैं GridView का उपयोग करके x:Bind कुंजी शब्द।

<Page 
   x:Class = "XAMLPhase.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:local = "using:XAMLPhase" 
   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}"> 
      <GridView Name = "Presidents" ItemsSource = "{Binding}" Height = "300" 
         Width = "400" Margin = "50"> 
			
         <GridView.ItemTemplate> 
            <DataTemplate x:DataType = "local:Employee"> 
				
               <StackPanel Orientation = "Horizontal" Margin = "2"> 
                  <TextBlock Text = "{x:Bind Name}" Width = "95" Margin = "2" /> 
                  <TextBlock Text = "{x:Bind Title}" Width = "95" Margin = "2"  
                     x:Phase = "1"/> 
               </StackPanel> 
					
            </DataTemplate> 
         </GridView.ItemTemplate>
			
      </GridView> 
		
   </Grid> 
	
</Page>

उपरोक्त XAML कोड में, x:Phase = "1"शीर्षक के साथ परिभाषित किया गया है। इसलिए, पहले चरण में,Name प्रस्तुत किया जाएगा और फिर Title प्रदान किया जाएगा।

नीचे दिया गया है Employee class C # में कार्यान्वयन।

using System.Collections.ObjectModel; 
using System.ComponentModel; 
using System.Runtime.CompilerServices; 
using Windows.UI.Xaml.Controls;
  
// The Blank Page item template is documented at
   http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409 
	
namespace XAMLPhase {

   /// <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(); 
         DataContext = Employee.GetEmployees(); 
      } 
   } 
	
   public class Employee : INotifyPropertyChanged {
      private string name; 
		
      public string Name {
         get { return name; } 
			
         set {
            name = value; 
            RaiseProperChanged(); 
         } 
      } 
		
      private string title; 
		
      public string Title {
         get { return title; }
			
         set {
            title = value; 
            RaiseProperChanged(); 
         } 
      }
		
      public static Employee GetEmployee() {
       
         var emp = new Employee() {
            Name = "Waqas", 
            Title = "Software Engineer" 
         };  
			
         return emp; 
      } 
		
      public event PropertyChangedEventHandler PropertyChanged;
		
      private void RaiseProperChanged( 
         [CallerMemberName] string caller = "") {
			
         if (PropertyChanged != null) {
            PropertyChanged(this, new PropertyChangedEventArgs(caller)); 
         } 
			
      } 
		
      public static ObservableCollection<Employee> GetEmployees() {
         var employees = new ObservableCollection<Employee>(); 
			
         employees.Add(new Employee() { Name = "Ali", Title = "Developer" }); 
         employees.Add(new Employee() { Name = "Ahmed", Title = "Programmer" }); 
         employees.Add(new Employee() { Name = "Amjad", Title = "Desiner" }); 
         employees.Add(new Employee() { Name = "Waqas", Title = "Programmer" }); 
         employees.Add(new Employee() { Name = "Bilal", Title = "Engineer" }); 
         employees.Add(new Employee() { Name = "Waqar", Title = "Manager" }); 
			
         return employees; 
      } 
		
   }
	
}

जब ऊपर दिए गए कोड को निष्पादित किया जाता है, तो आप निम्न विंडो देखेंगे।

X:Phase साथ में x:Bind रेंडर करने के लिए उपयोग किया जाता है ListView तथा GridView आइटम वृद्धिशील रूप से और पैनिंग अनुभव में सुधार करते हैं।

आस्थगित लोड हो रहा है

डिफर्ड लोडिंग एक तकनीक है, जिसका उपयोग किसी एप्लिकेशन के स्टार्टअप पर XAML UI तत्वों की संख्या को कम करके स्टार्टअप लोडिंग समय को कम करने के लिए किया जा सकता है। यदि आपके एप्लिकेशन में 30 UI तत्व हैं और उपयोगकर्ता को स्टार्टअप में इन सभी तत्वों की आवश्यकता नहीं है, तो उन सभी तत्वों, जिनकी आवश्यकता नहीं है, कुछ लोडिंग समय को हटाकर बचा सकते हैं।

x:DeferLoadStrategy = "Lazy" एक तत्व और उसके बच्चों के निर्माण में देरी करता है, जो स्टार्टअप समय को कम करता है लेकिन यह स्मृति उपयोग को थोड़ा बढ़ा देता है।

आस्थगित तत्व कॉलिंग द्वारा महसूस / बनाया जा सकता है FindName नाम के साथ जो तत्व पर परिभाषित किया गया था।

एक बार एक आस्थगित तत्व बनने के बाद, कई चीजें घटित होंगी -

  • तत्व पर लोड की गई घटना को उठाया जाएगा।

  • तत्व पर किसी भी बाइंडिंग का मूल्यांकन किया जाएगा।

  • यदि आवेदन स्थगित तत्व (नों) की संपत्ति पर संपत्ति परिवर्तन सूचनाएं प्राप्त करने के लिए पंजीकृत है, तो अधिसूचना को उठाया जाएगा।

नीचे दिया गया एक उदाहरण है जिसमें x:DeferLoadStrategy = "Lazy" का उपयोग ग्रिड के लिए किया जाता है जिसमें चार टेक्स्ट ब्लॉक होते हैं और जब तक आप इसे लोड नहीं करते, तब तक यह आपके एप्लिकेशन के स्टार्टअप पर लोड नहीं होगा।

<Page 
   x:Class = "UWPDeferredLoading.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPDeferredLoading" 
   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}"> 
      <Grid x:Name = "DeferredGrid" x:DeferLoadStrategy = "Lazy" Margin = "50"> 
         <Grid.RowDefinitions> 
            <RowDefinition Height = "Auto" /> 
            <RowDefinition Height = "Auto" /> 
         </Grid.RowDefinitions> 
			
         <Grid.ColumnDefinitions> 
            <ColumnDefinition Width = "Auto" /> 
            <ColumnDefinition Width = "Auto" /> 
         </Grid.ColumnDefinitions>
			
         <TextBlock Height = "100" Width = "100" Text = "TextBlock 1" Margin = "0,0,4,4" /> 
			
         <TextBlock Height = "100" Width = "100" Text = "TextBlock 2" 
            Grid.Column = "1" Margin = "4,0,0,4" /> 
				
         <TextBlock Height = "100" Width = "100" Text = "TextBlock 3" 
            Grid.Row = "1" Margin = "0,4,4,0" /> 
				
         <TextBlock Height = "100" Width = "100" Text = "TextBlock 4" 
            Grid.Row = "1" Grid.Column = "1" Margin = "4,4,0,0" /> 
      </Grid> 
		
      <Button x:Name = "RealizeElements" Content = "Show Elements"  
         Click = "RealizeElements_Click" Margin = "50"/> 
			
   </Grid>   
	
</Page>

निम्नलिखित कार्यक्रम क्लिक इवेंट कार्यान्वयन है, जिसमें एप्लिकेशन मुख्य पृष्ठ पर ग्रिड लोड किया जाता है।

using Windows.UI.Xaml; 
using Windows.UI.Xaml.Controls; 
 
// The Blank Page item template is documented at
   http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409  
	
namespace UWPDeferredLoading {

   /// <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 RealizeElements_Click(object sender, RoutedEventArgs e) {
         this.FindName("DeferredGrid"); // This will realize the deferred grid 
      } 
		
   } 
	
}

जब ऊपर दिए गए कोड को संकलित और निष्पादित किया गया है, तो आपको केवल एक बटन दिखाई देगा। Textblocks स्टार्टअप पर लोड नहीं हैं।

अब जब आप क्लिक करेंगे Show Elements बटन, यह टेक्स्ट ब्लॉक को लोड करेगा, जो आपके एप्लिकेशन के स्टार्टअप प्रदर्शन को बेहतर करेगा।