WPF - XAML ओवरव्यू

WPF के साथ काम करते समय आपका सामना करने वाली पहली चीजों में से एक XAML है। XAML का मतलब एक्स्टेंसिबल एप्लिकेशन मार्कअप लैंग्वेज है। यह XML पर आधारित एक सरल और घोषित भाषा है।

  • XAML में, पदानुक्रमित संबंधों के साथ वस्तुओं के गुणों को बनाना, शुरू करना और सेट करना बहुत आसान है।

  • यह मुख्य रूप से GUIs को डिजाइन करने के लिए उपयोग किया जाता है, हालांकि इसका उपयोग अन्य उद्देश्यों के लिए भी किया जा सकता है, उदाहरण के लिए, वर्कफ़्लो फ़ाउंडेशन में वर्कफ़्लो घोषित करने के लिए।

बेसिक सिंटेक्स

जब आप अपना नया WPF प्रोजेक्ट बनाते हैं, तो आप नीचे दिखाए गए MainWindow.xaml में डिफ़ॉल्ट रूप से कुछ XAML कोड का सामना करेंगे।

<Window x:Class = "Resources.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   Title = "MainWindow" Height = "350" Width = "525"> 
	
   <Grid> 
         
   </Grid> 
	
</Window>

उपरोक्त XAML फ़ाइल में विभिन्न प्रकार की जानकारी है। निम्नलिखित तालिका संक्षेप में प्रत्येक जानकारी की भूमिका बताती है।

जानकारी विवरण
<विंडो यह मूल का प्रारंभिक वस्तु तत्व या कंटेनर है।
x: कक्षा = "संसाधन। मेनविन्दो" यह एक आंशिक वर्ग घोषणा है जो मार्कअप को आंशिक रूप से परिभाषित आंशिक वर्ग कोड से जोड़ता है।
xmlns = "http://schemas.microsoft.com/win fx / 2006 / xaml / प्रस्तुति" WPF क्लाइंट / फ्रेमवर्क के लिए डिफ़ॉल्ट XAML नामस्थान को मैप करें
xmlns: x = "http://schemas.microsoft.com/w infx / 2006 / xaml" XAML भाषा के लिए XAML नामस्थान जो इसे x: उपसर्ग में मैप करता है
> जड़ के वस्तु तत्व का अंत

<ग्रिड>

</ ग्रिड>

यह खाली ग्रिड ऑब्जेक्ट के टैग को शुरू और बंद कर रहा है।
</ विंडो> वस्तु तत्व को बंद करना

XAML के लिए वाक्यविन्यास नियम लगभग XML के समान है। यदि आप एक XAML दस्तावेज़ को देखते हैं, तो आप ध्यान देंगे कि यह वास्तव में एक वैध XML फ़ाइल है, लेकिन XML फ़ाइल आवश्यक रूप से XAML फ़ाइल नहीं है। ऐसा इसलिए है क्योंकि एक्सएमएल में एक्सएएमएल में विशेषताओं का मूल्य एक स्ट्रिंग होना चाहिए, यह एक अलग वस्तु हो सकती है जिसे संपत्ति तत्व सिंटैक्स के रूप में जाना जाता है।

  • ऑब्जेक्ट तत्व का सिंटैक्स एक बाएं कोण ब्रैकेट (<) से शुरू होता है, जिसके बाद ऑब्जेक्ट का नाम होता है, जैसे बटन।

  • उस वस्तु तत्व के कुछ गुणों और विशेषताओं को परिभाषित करें।

  • ऑब्जेक्ट तत्व को आगे की ओर स्लैश (/) द्वारा बंद किया जाना चाहिए, जिसके तुरंत बाद एक समकोण कोष्ठक (>) होगा।

बिना बाल तत्व वाली सरल वस्तु का उदाहरण

<Button/>

कुछ विशेषताओं के साथ वस्तु तत्व का उदाहरण

<Button Content = "Click Me" Height = "30" Width = "60" />

एक वैकल्पिक सिंटैक्स का उदाहरण गुणों को परिभाषित करता है (संपत्ति तत्व सिंटैक्स)

<Button> 
   <Button.Content>Click Me</Button.Content> 
   <Button.Height>30</Button.Height> 
   <Button.Width>60</Button.Width> 
</Button>

बाल तत्व के साथ वस्तु का उदाहरण: StackPanel में बाल तत्व के रूप में टेक्स्टब्लॉक है

<StackPanel Orientation = "Horizontal"> 
   <TextBlock Text = "Hello"/> 
</StackPanel>

WPF में XAML क्यों

एक्सएएमएल न केवल डब्ल्यूपीएफ की सबसे व्यापक रूप से जानी जाने वाली विशेषता है, बल्कि यह सबसे गलत तरीकों में से एक है। यदि आपके पास WPF के संपर्क में है, तो आपने XAML के बारे में सुना होगा; लेकिन XAML के बारे में निम्नलिखित दो ज्ञात तथ्यों पर ध्यान दें -

  • WPF को XAML की आवश्यकता नहीं है
  • XAML को WPF की आवश्यकता नहीं है

वे वास्तव में प्रौद्योगिकी के वियोज्य टुकड़े हैं। यह समझने के लिए कि यह कैसे हो सकता है, आइए एक साधारण उदाहरण देखें जिसमें एक बटन XAML में कुछ गुणों के साथ बनाया गया है।

<Window x:Class = "WPFXAMLOverview.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   Title = "MainWindow" Height = "350" Width = "604"> 
	
   <StackPanel> 
      <Button x:Name = "button" Content = "Click Me" HorizontalAlignment = "Left"  
         Margin = "150" VerticalAlignment = "Top" Width = "75" /> 
   </StackPanel> 
	
</Window>

यदि आप WPF में XAML का उपयोग नहीं करने का विकल्प चुनते हैं, तो आप प्रक्रियात्मक भाषा के साथ भी वही GUI परिणाम प्राप्त कर सकते हैं। आइए एक ही उदाहरण पर एक नज़र डालें, लेकिन इस बार, हम C # में एक बटन बनाएंगे।

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

namespace WPFXAMLOverview { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window { 
	
      public MainWindow() { 
         InitializeComponent(); 
			
         // Create the StackPanel 
         StackPanel stackPanel = new StackPanel(); 
         this.Content = stackPanel; 
			
         // Create the Button 
         Button button = new Button();
         button.Content = "Click Me"; 
         button.HorizontalAlignment = HorizontalAlignment.Left; 
         button.Margin = new Thickness(150); 
         button.VerticalAlignment = VerticalAlignment.Top; 
         button.Width = 75; 
         stackPanel.Children.Add(button);  
      } 
   } 
}

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

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

  • XAML UI तत्वों को डिज़ाइन करने का एक और सरल और आसान तरीका है।

  • XAML के साथ, इसका मतलब यह नहीं है कि यूआई तत्वों को डिजाइन करने के लिए आप क्या कर सकते हैं। आप XAML में ऑब्जेक्ट को घोषित कर सकते हैं या कोड का उपयोग करके उन्हें परिभाषित कर सकते हैं।

  • XAML वैकल्पिक है, लेकिन इसके बावजूद, यह WPF डिज़ाइन के केंद्र में है।

  • XAML का लक्ष्य दृश्य डिजाइनरों को सीधे उपयोगकर्ता इंटरफ़ेस तत्व बनाने में सक्षम करना है।

  • WPF का लक्ष्य उपयोगकर्ता इंटरफ़ेस के सभी दृश्य पहलुओं को मार्क-अप से नियंत्रित करना संभव बनाना है।