XAML - त्वरित गाइड

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

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

  • यह मुख्य रूप से GUIs को डिजाइन करने के लिए उपयोग किया जाता है।

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

XAML का उपयोग विभिन्न प्लेटफार्मों जैसे WPF (विंडोज प्रेजेंटेशन फाउंडेशन), सिल्वरलाइट, मोबाइल डेवलपमेंट और विंडोज स्टोर ऐप में किया जा सकता है। इसका उपयोग विभिन्न .Net फ्रेमवर्क और CLR (सामान्य भाषा रनटाइम) संस्करणों में किया जा सकता है।

XAML कैसे काम करता है

एक्सएएमएल ए है declarative भाषा इस अर्थ में इसे परिभाषित करती है WHAT तथा HOWआप करना चाहते हैं। XAML प्रोसेसर के लिए जिम्मेदार हैHOWपता लगाने के लिए हिस्सा। आइए निम्नलिखित स्कीमा पर एक नज़र डालें। यह चीजों के XAML पक्ष को पूरा करता है -

आंकड़ा निम्नलिखित क्रियाओं को दिखाता है -

  • XAML फ़ाइल की व्याख्या एक प्लेटफॉर्म-विशिष्ट XAML प्रोसेसर द्वारा की जाती है।

  • XAML प्रोसेसर XAML को यूआई तत्व का वर्णन करने वाले आंतरिक कोड में बदल देता है।

  • आंतरिक कोड और C # कोड को आंशिक वर्ग परिभाषाओं के माध्यम से एक साथ जोड़ा जाता है और फिर .NET कंपाइलर ऐप बनाता है।

XAML के लाभ

जीयूआई डिजाइन के साथ हम सभी की सबसे लंबी समस्याओं में से एक XAML का उपयोग करके हल किया जा सकता है। इसका उपयोग विंडोज फॉर्म अनुप्रयोगों में यूआई तत्वों को डिजाइन करने के लिए किया जा सकता है।

पहले के GUI फ्रेमवर्क में, कोई वास्तविक अलगाव नहीं था कि कोई एप्लिकेशन कैसा दिखता है और यह कैसे व्यवहार करता है। GUI और इसके व्यवहार दोनों को एक ही भाषा में बनाया गया था, जैसे C # या VB.net, जिसे UI और इसके साथ जुड़े व्यवहार दोनों को लागू करने के लिए डेवलपर से अधिक प्रयास की आवश्यकता होगी।

XAML के साथ, डिजाइनर कोड से व्यवहार को अलग करना बहुत आसान है। इसलिए, एक्सएएमएल प्रोग्रामर और डिजाइनर समानांतर में काम कर सकते हैं। XAML कोड पढ़ना और समझना बहुत आसान है।

Microsoft XAML के लिए दो महत्वपूर्ण उपकरण प्रदान करता है -

  • दृश्य स्टूडियो
  • अभिव्यक्ति मिश्रण

वर्तमान में, दोनों उपकरण XAML बना सकते हैं, लेकिन तथ्य यह है कि विज़ुअल स्टूडियो डेवलपर्स द्वारा अधिक उपयोग किया जाता है, जबकि अभिव्यक्ति ब्लेंड अभी भी डिजाइनरों द्वारा अधिक बार उपयोग किया जाता है।

Microsoft विजुअल स्टूडियो का एक निःशुल्क संस्करण प्रदान करता है जिसे डाउनलोड किया जा सकता है https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx

Note- इस ट्यूटोरियल के लिए, हम ज्यादातर WPF प्रोजेक्ट्स और विंडोज स्टोर ऐप का उपयोग करेंगे। लेकिन विजुअल स्टूडियो का मुफ्त संस्करण विंडोज स्टोर ऐप का समर्थन नहीं करता है। तो उस उद्देश्य के लिए, आपको विजुअल स्टूडियो के लाइसेंस प्राप्त संस्करण की आवश्यकता होगी।

इंस्टालेशन

अपने सिस्टम पर Visual Studio स्थापित करने के लिए नीचे दिए गए चरणों का पालन करें -

  • फ़ाइलों को डाउनलोड करने के बाद, इंस्टॉलर चलाएं। निम्नलिखित संवाद बॉक्स प्रदर्शित किया जाएगा।

  • इंस्टॉल बटन पर क्लिक करें और यह इंस्टॉलेशन प्रक्रिया शुरू कर देगा।

  • एक बार इंस्टॉलेशन प्रक्रिया सफलतापूर्वक पूरी हो जाने के बाद, आपको निम्न स्क्रीन दिखाई देगी।

  • इस संवाद बॉक्स को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।

  • अब स्टार्ट मेनू से विजुअल स्टूडियो खोलें जो निम्नलिखित डायलॉग बॉक्स दिखाएगा। पहली बार कुछ समय लगेगा, केवल तैयारी के लिए।

एक बार जब सब हो जाता है, तो आप विजुअल स्टूडियो की मुख्य विंडो देखेंगे।

कार्यान्वयन के लिए पहला कदम

आइए हम एक सरल कार्यान्वयन के साथ शुरू करते हैं। नीचे दिए गए चरणों का पालन करें -

  • फ़ाइल → नया → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।

  • निम्नलिखित संवाद बॉक्स प्रदर्शित किया जाएगा -

  • टेम्प्लेट के तहत, विज़ुअल C # चुनें और WPF एप्लिकेशन चुनें। प्रोजेक्ट को एक नाम दें और OK बटन पर क्लिक करें।

  • Mainwindow.xaml फ़ाइल में, निम्न XAML टैग डिफ़ॉल्ट रूप से लिखे गए हैं। आप इन सभी टैग को बाद में इस ट्यूटोरियल में समझेंगे।

<Window x:Class = "FirstStepDemo.MainWindow"
   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" 
   xmlns:local = "clr-namespace:FirstStepDemo" 
   mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604"> 
	
   <Grid> 
         
   </Grid> 
</Window>

डिफ़ॉल्ट रूप से, एक ग्रिड पृष्ठ के बाद पहले तत्व के रूप में सेट किया जाता है।

चलो ग्रिड तत्व के तहत एक बटन और एक टेक्स्ट ब्लॉक जोड़ें। यह कहा जाता हैobject element syntax, एक बाएं कोण कोष्ठक के नाम के बाद जिसे हम तत्काल करना चाहते हैं, उदाहरण के लिए एक बटन, फिर एक सामग्री संपत्ति को परिभाषित करें। कंटेंट को सौंपे गए स्ट्रिंग को बटन पर प्रदर्शित किया जाएगा। अब बटन की ऊँचाई और चौड़ाई क्रमशः 30 और 50 निर्धारित करें। इसी तरह टेक्स्ट ब्लॉक के गुणों को इनिशियलाइज़ करें।

अब डिज़ाइन विंडो को देखें। आपको एक बटन देखने को मिलेगा। अब इस XAML कोड को निष्पादित करने के लिए F5 दबाएँ।

<Window x:Class = "FirstStepDemo.MainWindow" 
   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" 
   xmlns:local = "clr-namespace:FirstStepDemo" 
   mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604"> 
	
   <Grid> 
      <Button Content = "First Button" Height = "30" Width = "80"/> 
      <TextBlock Text = "Congratulations you have successfully build your first app" 
         Height = "30" Margin = "162,180,122,109"/> 
   </Grid> 
	
</Window>

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

बधाई हो! आपने अपना पहला बटन डिज़ाइन किया है।

XAML अनुप्रयोगों को मैक पर भी विकसित किया जा सकता है। Mac पर, XAML को iOS और Android एप्लिकेशन के रूप में उपयोग किया जा सकता है। मैक पर पर्यावरण की स्थापना के लिए, www.xamarin.com पर जाएं । उत्पादों पर क्लिक करें और Xamarin प्लेटफ़ॉर्म चुनें। Xamarin स्टूडियो डाउनलोड करें और इसे स्थापित करें। यह आपको विभिन्न प्लेटफार्मों के लिए एप्लिकेशन विकसित करने की अनुमति देगा।

एक्सएएमएल - सी # सिंटैक्स

इस अध्याय में, आप XAML एप्लिकेशन लिखने के लिए बुनियादी 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 फ़ाइल में देख सकते हैं, विभिन्न प्रकार के टैग और तत्व हैं। निम्न तालिका संक्षेप में सभी तत्वों का वर्णन करती है।

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

<Window

यह मूल का प्रारंभिक वस्तु तत्व या कंटेनर है।

2

x:Class="Resources.MainWindow"

यह आंशिक वर्ग घोषणा है जो मार्कअप को आंशिक वर्ग कोड से परिभाषित करता है जो इसमें परिभाषित है।

3

xmlns

WPF क्लाइंट / फ्रेमवर्क के लिए डिफ़ॉल्ट XAML नामस्थान को मैप करें

4

xmlns:x

XAML भाषा के लिए XAML नामस्थान जो इसे x: उपसर्ग में मैप करता है

5

>

जड़ के वस्तु तत्व का अंत।

6

<Grid>

</Grid>

खाली ग्रिड ऑब्जेक्ट के टैग को शुरू करना और बंद करना।

7

</Window>

वस्तु तत्व को बंद करना

वस्तु तत्व के लिए सिंटेक्स नियम

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 Orientation = "Horizontal"> 
   <TextBlock Text = "Hello"/> 
</StackPanel>

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

XAML UI तत्वों को डिज़ाइन करने का एक और सरल और आसान तरीका है। XAML के साथ, यह आप पर है कि आप XAML में वस्तुओं को घोषित करना चाहते हैं या कोड का उपयोग करके उन्हें घोषित करना चाहते हैं।

आइए एक सरल उदाहरण लेते हैं कि XAML में कैसे लिखें -

<Window x:Class = "XAMLVsCode.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"> 
	
   <StackPanel> 
      <TextBlock Text = "Welcome to XAML Tutorial" Height = "20" Width = "200" Margin = "5"/>
      <Button Content = "Ok" Height = "20" Width = "60" Margin = "5"/> 
   </StackPanel> 
	
</Window>

इस उदाहरण में, हमने एक बटन और एक टेक्स्ट ब्लॉक के साथ एक स्टैक पैनल बनाया है और बटन और टेक्स्ट ब्लॉक के कुछ गुणों को परिभाषित किया है जैसे कि ऊँचाई, चौड़ाई और मार्जिन। जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

अब उसी कोड को देखें जो C # में लिखा गया है।

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

namespace XAMLVsCode { 
   /// <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 TextBlock 
         TextBlock textBlock = new TextBlock(); 
         textBlock.Text = "Welcome to XAML Tutorial"; 
         textBlock.Height = 20;
         textBlock.Width = 200; 
         textBlock.Margin = new Thickness(5); 
         stackPanel.Children.Add(textBlock);  
			
         // Create the Button 
         Button button = new Button(); 
         button.Content = "OK"; 
         button.Height = 20; 
         button.Width = 50; 
         button.Margin = new Thickness(20); 
         stackPanel.Children.Add(button); 
      } 
   }
}

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

अब आप देख सकते हैं कि XAML का उपयोग करना और समझना कितना सरल है।

इस अध्याय में, हम VB.Net में एक ही उदाहरण लिखेंगे ताकि जो लोग VB.Net से परिचित हैं, वे XAML के फायदों को भी समझ सकें।

आइए फिर से उसी उदाहरण पर एक नज़र डालते हैं जो XAML में लिखा गया है -

<Window x:Class = "XAMLVsCode.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> 
      <TextBlock Text = "Welcome to XAML Tutorial with VB.net" Height = "20" Width = "220" Margin = "5"/> 
      <Button Content = "Ok" Height = "20" Width = "60" Margin = "5"/> 
   </StackPanel> 
	
</Window>

इस उदाहरण में, हमने एक बटन और एक टेक्स्ट ब्लॉक के साथ एक स्टैक पैनल बनाया है और बटन के कुछ गुणों और टेक्स्ट ब्लॉक जैसे कि ऊँचाई, चौड़ाई और मार्जिन को परिभाषित किया है। जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

अब उसी कोड को देखें जो VB.Net में लिखा गया है -

Public Class MainWindow
   Private Sub Window_Loaded(sender As Object, e As RoutedEventArgs) 
      Dim panel As New StackPanel() 
      panel.Orientation = Orientation.Vertical 
      Me.Content = panel 
      Dim txtInput As New TextBlock 
		
      txtInput.Text = "Welcome to XAML Tutorial with VB.net" 
      txtInput.Width = 220 
      txtInput.Height = 20 
      txtInput.Margin = New Thickness(5) 
		
      panel.Children.Add(txtInput)  
      Dim btn As New Button()
		
      btn.Content = "Ok" 
      btn.Width = 60 
      btn.Height = 20 
      btn.Margin = New Thickness(5) 
		
      panel.Children.Add(btn)
   End Sub 
End Class

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आउटपुट बिल्कुल उसी प्रकार होता है जैसे XAML कोड का आउटपुट।

अब आप कल्पना कर सकते हैं कि VB.Net की तुलना में XAML के साथ काम करना कितना सरल है।

उपरोक्त उदाहरण में, हमने देखा है कि हम XAML में जो कर सकते हैं वह अन्य प्रक्रियात्मक भाषाओं जैसे C # और VB.Net में भी किया जा सकता है।

आइए एक और उदाहरण देखें जिसमें हम XAML और VB.Net दोनों का उपयोग करेंगे। हम XAML में एक GUI डिजाइन करेंगे और व्यवहार VB.Net में लागू किया जाएगा।

इस उदाहरण में, मुख्य विंडो में एक बटन जोड़ा जाता है। जब उपयोगकर्ता इस बटन पर क्लिक करता है, तो यह संदेश बॉक्स पर एक संदेश प्रदर्शित करता है। यहाँ XAML में कोड है जिसमें कुछ गुणों के साथ एक बटन ऑब्जेक्ट घोषित किया गया है।

<Window x:Class="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"> 
	
   <Grid> 
      <Button Name = "btn" HorizontalAlignment = "Center" Width = "60" Height = "30" Content = "Click Me" /> 
   </Grid> 
	
</Window>

VB.Net में, बटन क्लिक इवेंट (व्यवहार) कार्यान्वित किया जाता है। यह ईवेंट संदेशबॉक्स पर संदेश प्रदर्शित करता है।

Public Class MainWindow
   Private Sub btn_Click(sender As Object, e As RoutedEventArgs) Handles btn.Click 
      MessageBox.Show("Button is Clicked") 
   End Sub 
End Class

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित स्क्रीन प्रदर्शित करेगा -

अब उपरोक्त बटन पर क्लिक करें जो "मुझे क्लिक करें" कहे। यह निम्न संदेश प्रदर्शित करेगा -

यह अध्याय XAML अनुप्रयोगों के कुछ बुनियादी और महत्वपूर्ण निर्माण ब्लॉकों का वर्णन करेगा। यह बताएगा कि कैसे

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

वस्तुओं

XAML एक आम तौर पर घोषित भाषा है जो वस्तुओं को बना सकती है और उन्हें तुरंत भेज सकती है। यह एक्सएमएल पर आधारित वस्तुओं का वर्णन करने का एक और तरीका है, अर्थात, किन वस्तुओं को बनाने की आवश्यकता है और कार्यक्रम के निष्पादन से पहले उन्हें कैसे आरंभ किया जाना चाहिए। वस्तुएं हो सकती हैं

  • कंटेनर (स्टैक पैनल, डॉक पैनल)
  • UI तत्व / नियंत्रण (बटन, टेक्स्टबॉक्स, आदि)
  • संसाधन शब्दकोश

साधन

संसाधन आम तौर पर कुछ ऑब्जेक्ट से जुड़ी परिभाषाएं हैं जिन्हें आप सिर्फ एक बार से अधिक बार उपयोग करने का अनुमान लगाते हैं। यह नियंत्रणों के लिए या वर्तमान विंडो के लिए या संपूर्ण अनुप्रयोगों के लिए वैश्विक स्तर पर डेटा को संग्रहीत करने की क्षमता है।

शैलियों

XAML ढांचा एक आवेदन की उपस्थिति को निजीकृत और अनुकूलित करने के लिए कई रणनीतियां प्रदान करता है। शैलियाँ हमें किसी वस्तु के कुछ गुणों को सेट करने और एक समान दिखने के लिए कई वस्तुओं में इन विशिष्ट सेटिंग्स का पुन: उपयोग करने की सुविधा देती हैं।

  • शैलियों में, आप किसी ऑब्जेक्ट के केवल मौजूदा गुण जैसे कि ऊँचाई, चौड़ाई, फ़ॉन्ट आकार, आदि सेट कर सकते हैं।
  • केवल एक नियंत्रण का डिफ़ॉल्ट व्यवहार निर्दिष्ट किया जा सकता है।
  • एक शैली में कई गुण जोड़े जा सकते हैं।

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

टेम्पलेट्स

एक टेम्पलेट एक नियंत्रण के समग्र रूप और दृश्य उपस्थिति का वर्णन करता है। प्रत्येक नियंत्रण के लिए, इसके साथ एक डिफ़ॉल्ट टेम्पलेट जुड़ा होता है जो उस नियंत्रण को उपस्थिति देता है। XAML में, जब आप दृश्य व्यवहार और नियंत्रण की दृश्य उपस्थिति को अनुकूलित करना चाहते हैं, तो आप आसानी से अपने स्वयं के टेम्पलेट बना सकते हैं।

निम्नलिखित स्क्रीनशॉट में, दो बटन हैं, एक टेम्पलेट के साथ है और दूसरा डिफ़ॉल्ट बटन है।

अब जब आप माउस को बटन पर लहराते हैं, तो यह नीचे दिखाए गए अनुसार रंग बदलता है।

टेम्प्लेट के साथ, आप शैलियों की तुलना में नियंत्रण के अधिक हिस्सों तक पहुंच सकते हैं। आप एक नियंत्रण के मौजूदा और नए व्यवहार दोनों को निर्दिष्ट कर सकते हैं।

एनिमेशन और रूपांतरण

विंडोज रनटाइम के अंदर एनिमेशन और ट्रांसफॉर्मेशन आपके एक्सएएमएल एप्लिकेशन को अन्तरक्रियाशीलता और आंदोलन के निर्माण से बेहतर बना सकते हैं। आप Windows Runtime एनीमेशन लाइब्रेरी से एनिमेशन का उपयोग करके अपने XAML एप्लिकेशन में इंटरेक्टिव लुक और फील को आसानी से एकीकृत कर सकते हैं। एनिमेशन का उपयोग किया जाता है

  • उपयोगकर्ता इंटरफ़ेस बढ़ाने या इसे और अधिक आकर्षक बनाने के लिए।
  • एक बदलाव के लिए उपयोगकर्ता का ध्यान आकर्षित करने के लिए।

निम्नलिखित स्क्रीनशॉट में, आप एक वर्ग देख सकते हैं -

जब आप इस वर्गाकार पर माउस घुमाते हैं, तो यह नीचे दिखाए गए अनुसार सभी दिशाओं में खर्च करेगा।

XAML यूजर इंटरफेस फ्रेमवर्क एक व्यापक लाइब्रेरी ऑफ कंट्रोल प्रदान करता है जो विंडोज के लिए यूआई विकास का समर्थन करता है। उनमें से कुछ में एक दृश्य प्रतिनिधित्व है जैसे बटन, टेक्स्टबॉक्स, टेक्स्टब्लॉक, आदि; जबकि अन्य नियंत्रण कंटेनर के रूप में अन्य नियंत्रण या सामग्री के लिए उपयोग किए जाते हैं, उदाहरण के लिए, चित्र। सभी XAML नियंत्रण विरासत में मिले हैंSystem.Windows.Controls.Control

नियंत्रणों की पूर्ण विरासत पदानुक्रम इस प्रकार है -

यहां उन नियंत्रणों की सूची दी गई है, जिनकी चर्चा हम इस अध्याय में एक-एक करके करेंगे।

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

एक नियंत्रण जो उपयोगकर्ता इनपुट के प्रति प्रतिक्रिया करता है।

2 पंचांग

एक नियंत्रण का प्रतिनिधित्व करता है जो एक उपयोगकर्ता को एक दृश्य कैलेंडर डिस्प्ले का उपयोग करके एक तिथि का चयन करने में सक्षम बनाता है।

3 चेक बॉक्स

एक नियंत्रण जो उपयोगकर्ता का चयन या स्पष्ट कर सकता है।

4 सम्मिश्रण पटी

उन आइटमों की एक ड्रॉप-डाउन सूची, जिनसे कोई उपयोगकर्ता चयन कर सकता है।

5 संदर्भ की विकल्प - सूची

जब भी संदर्भ मेनू इस तत्व के भीतर से उपयोगकर्ता इंटरफ़ेस (UI) के माध्यम से अनुरोध किया जाता है, तो संदर्भ मेनू तत्व हो जाता है या दिखाई देता है।

6 डेटा ग्रिड

एक नियंत्रण का प्रतिनिधित्व करता है जो अनुकूलन ग्रिड में डेटा प्रदर्शित करता है।

7 खजूर बीनने वाला

एक नियंत्रण जो उपयोगकर्ता को एक तिथि का चयन करने देता है।

8 संवाद

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

9 जाली देखना

एक नियंत्रण जो पंक्तियों और स्तंभों में वस्तुओं का एक संग्रह प्रस्तुत करता है जो क्षैतिज रूप से स्क्रॉल कर सकते हैं।

10 छवि

एक नियंत्रण जो एक छवि प्रस्तुत करता है।

1 1 सूची बाक्स

एक नियंत्रण जो उन मदों की एक इनलाइन सूची प्रस्तुत करता है, जिसे उपयोगकर्ता चुन सकता है।

12 मेनू

एक Windows मेनू नियंत्रण का प्रतिनिधित्व करता है जो आपको कमांड और ईवेंट हैंडलर से जुड़े तत्वों को पदानुक्रमित करने में सक्षम बनाता है।

13 PasswordBox

पासवर्ड दर्ज करने के लिए एक नियंत्रण।

14 पॉप अप

एप्लिकेशन विंडो के सीमा के भीतर, मौजूदा सामग्री के शीर्ष पर सामग्री प्रदर्शित करता है।

15 प्रगति पट्टी

एक नियंत्रण जो एक बार प्रदर्शित करके प्रगति को इंगित करता है।

16 ProgressRing

एक नियंत्रण जो एक अंगूठी प्रदर्शित करके अनिश्चित प्रगति को इंगित करता है।

17 रेडियो बटन

एक नियंत्रण जो उपयोगकर्ता को विकल्पों के समूह से एकल विकल्प का चयन करने की अनुमति देता है।

18 RichEditBox

एक नियंत्रण जो उपयोगकर्ता को फ़ॉर्मेट किए गए पाठ, हाइपरलिंक और छवियों जैसी सामग्री के साथ समृद्ध पाठ दस्तावेज़ों को संपादित करने देता है।

19 ScrollViewer

एक कंटेनर नियंत्रण जो उपयोगकर्ता को पैन और उसकी सामग्री को ज़ूम करने देता है।

20 खोज बॉक्स

एक नियंत्रण जो उपयोगकर्ता को खोज क्वेरी दर्ज करने देता है।

21 स्लाइडर

एक नियंत्रण जो उपयोगकर्ता को एक ट्रैक के साथ एक अंगूठे नियंत्रण को स्थानांतरित करके मूल्यों की एक श्रृंखला से चुनने देता है।

22 TextBlock

एक नियंत्रण जो पाठ प्रदर्शित करता है।

23 timepicker

एक नियंत्रण जो उपयोगकर्ता को एक समय मान सेट करने देता है।

24 टॉगल बटन

एक बटन जिसे 2 राज्यों के बीच टॉगल किया जा सकता है।

25 टूलटिप

एक पॉप-अप विंडो जो किसी तत्व के लिए जानकारी प्रदर्शित करती है।

26 खिड़की

रूट विंडो जो न्यूनतम / अधिकतम विकल्प, टाइटल बार, बॉर्डर और क्लोज बटन प्रदान करती है।

इस अध्याय में हम कार्यान्वयन के साथ इन सभी नियंत्रणों पर चर्चा करेंगे।

अनुप्रयोग प्रयोज्य के लिए नियंत्रण का लेआउट बहुत महत्वपूर्ण और महत्वपूर्ण है। अपने आवेदन में GUI तत्वों के समूह की व्यवस्था करना आवश्यक है। लेआउट पैनल का चयन करते समय विचार करने के लिए कुछ महत्वपूर्ण बिंदु हैं;

  • बाल तत्वों की स्थिति।
  • बाल तत्वों का आकार।
  • एक-दूसरे के ऊपर बाल तत्वों को ओवरलैप करना।

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

अनु क्रमांक पैनल और विवरण
1 StackPanel

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

2 WrapPanel

WrapPanel में, बाल तत्व ओरिएंटेशन प्रॉपर्टी के आधार पर बाएं से दाएं या ऊपर से नीचे तक अनुक्रमिक क्रम में स्थित होते हैं।

3 DockPanel

DockPanel एक क्षेत्र को परिभाषित करता है कि वे बाल तत्वों को एक दूसरे के सापेक्ष व्यवस्थित करते हैं, या तो क्षैतिज या लंबवत। DockPanel के साथ, आप आसानी से डॉक प्रॉपर्टी के साथ बाल तत्वों को टॉप, बॉटम, राइट, लेफ्ट और सेंटर में डॉक कर सकते हैं।

4 CanvasPanel

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

5 GridPanel

ग्रिड पैनल एक लचीला क्षेत्र प्रदान करता है जिसमें पंक्तियाँ और स्तंभ होते हैं। एक ग्रिड में, बाल तत्वों को एक सारणीबद्ध रूप में व्यवस्थित किया जा सकता है।

XAML में घटनाओं की सामान्य अवधारणा अन्य लोकप्रिय प्रोग्रामिंग भाषाओं जैसे .NET और C ++ की घटनाओं के समान है। एक्सएएमएल में, सभी नियंत्रण कुछ घटनाओं को उजागर करते हैं ताकि उन्हें विशिष्ट उद्देश्यों के लिए सब्सक्राइब किया जा सके।

जब भी कोई घटना होती है, तो आवेदन को अधिसूचित किया जाएगा और कार्यक्रम उन पर प्रतिक्रिया कर सकता है, जैसे, किसी संवाद को बंद करने के लिए बंद बटन का उपयोग किया जाता है।

कई प्रकार की घटनाएँ होती हैं जिन्हें उस एप्लिकेशन की आवश्यकता के आधार पर किसी एप्लिकेशन के विभिन्न व्यवहारों के लिए सब्सक्राइब किया जा सकता है, लेकिन सबसे अधिक उपयोग की जाने वाली घटनाएं ऐसी हैं जो माउस और कीबोर्ड से संबंधित हैं, जैसे,

  • Click
  • MouseDown
  • MouseEnter
  • MouseLeave
  • MouseUp
  • KeyDown
  • KeyUp

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

आइए एक बटन क्लिक घटना के सरल उदाहरण पर एक नज़र डालते हैं। नीचे दिए गए बटन नियंत्रण के लिए XAML कार्यान्वयन है जो कुछ गुणों और एक क्लिक इवेंट (क्लिक = "ओनक्लिक") के साथ बनाया और शुरू किया गया है।

<Window x:Class = "XAMLEventHandling.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"> 
	
   <Grid> 
      <Button x:Name = "button1" Content = "Click" Click = "OnClick" 
         Width = "150" Height = "30" HorizontalAlignment = "Center" /> 
   </Grid>
   
</Window>

जब भी इस बटन पर क्लिक किया जाता है, यह एक आग लगा देगा OnClickईवेंट और आप क्लिक के जवाब के रूप में किसी भी प्रकार का व्यवहार जोड़ सकते हैं। आइए ऑनक्लिक ईवेंट कार्यान्वयन पर एक नज़र डालें जो इस बटन को क्लिक करने पर एक संदेश दिखाएगा।

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

namespace XAMLEventHandling {
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
      }
      private void OnClick(object sender, RoutedEventArgs e) { 
         MessageBox.Show("Button is clicked!"); 
      } 
   }
}

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

जब आप बटन पर क्लिक करते हैं, तो क्लिक (ऑनक्लिक) ईवेंट को निकाल दिया जाएगा और निम्नलिखित संदेश प्रदर्शित होगा।

अब आइए थोड़ा सा जटिल उदाहरण देखें जहां कई घटनाओं को नियंत्रित किया जाता है।

उदाहरण

निम्नलिखित उदाहरण में ContextMenu के साथ एक टेक्स्टबॉक्स है जो टेक्स्टबॉक्स के भीतर पाठ को हेरफेर करता है।

निम्न XAML कोड एक टेक्स्टबॉक्स, एक ContextMenu, और MenuItems बनाता है जिसमें कुछ गुण और घटनाएँ जैसे कि जाँच, अनियंत्रित और क्लिक होती हैं।

<Window x:Class = "XAMLContextMenu.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"> 
	
   <Grid> 
      <TextBox Name = "textBox1" TextWrapping = "Wrap" Margin = "10" Grid.Row = "7"> 
         Hi, this is XAML tutorial. 
         <TextBox.ContextMenu>
         
            <ContextMenu>
               <MenuItem Header = "_Bold" IsCheckable = "True" 
                  Checked = "Bold_Checked" Unchecked = "Bold_Unchecked" /> 
               <MenuItem Header = "_Italic" IsCheckable = "True" 
                  Checked = "Italic_Checked" Unchecked = "Italic_Unchecked" /> 
               <Separator /> 
               <MenuItem Header = "Increase Font Size" Click = "IncreaseFont_Click" />
               <MenuItem Header = "_Decrease Font Size" Click = "DecreaseFont_Click" /> 
            </ContextMenu> 
				
         </TextBox.ContextMenu>
      </TextBox>
   </Grid> 
	
</Window>

यहाँ विभिन्न घटनाओं के लिए C # में कार्यान्वयन है जो किसी भी आइटम को चेक किए जाने, अनियंत्रित या क्लिक किए जाने पर निकाल दिया जाएगा।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Data;  

namespace XAMLContextMenu { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary>
	
   public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
      }
      private void Bold_Checked(object sender, RoutedEventArgs e) { 
         textBox1.FontWeight = FontWeights.Bold; 
      }
      private void Bold_Unchecked(object sender, RoutedEventArgs e) { 
         textBox1.FontWeight = FontWeights.Normal; 
      }
      private void Italic_Checked(object sender, RoutedEventArgs e) { 
         textBox1.FontStyle = FontStyles.Italic; 
      }
      private void Italic_Unchecked(object sender, RoutedEventArgs e) { 
         textBox1.FontStyle = FontStyles.Normal; 
      }
      private void IncreaseFont_Click(object sender, RoutedEventArgs e) { 
         if (textBox1.FontSize < 18) { 
            textBox1.FontSize += 2; 
         } 
      }
      private void DecreaseFont_Click(object sender, RoutedEventArgs e) { 
         if (textBox1.FontSize > 10) { 
            textBox1.FontSize -= 2; 
         } 
      }
   }
}

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

हम आपको उपरोक्त उदाहरण कोड निष्पादित करने और कुछ अन्य घटनाओं के साथ प्रयोग करने की सलाह देते हैं।

आयोजन

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

Checked

जब एक टॉगलबटन की जाँच की जाती है तो आग लग जाती है। (टॉगलबटन से विरासत में मिला)

2

Click

तब होता है जब एक बटन नियंत्रण क्लिक किया जाता है। (ButtonBase से निहित)

3

ContextMenuClosing

तत्व पर किसी भी संदर्भ मेनू से ठीक पहले होता है। (फ्रेमवर्क से इंहेरिट किया गया।)

4

ContextMenuOpening

तब होता है जब तत्व पर कोई संदर्भ मेनू खोला जाता है। (फ्रेमवर्क से इंहेरिट किया गया।)

5

DataContextChanged

तब होता है जब FrameworkElement.ataContext की संपत्ति का मान बदलता है। (फ्रेमवर्क से आच्छादित)

6

DragEnter

तब होता है जब इनपुट सिस्टम इस तत्व के साथ एक अंतर्निहित ड्रैग इवेंट को लक्ष्य के रूप में रिपोर्ट करता है। (UIElement से निहित)।

7

DragLeave

तब होता है जब इनपुट सिस्टम मूल के रूप में इस तत्व के साथ एक अंतर्निहित खींचें घटना की रिपोर्ट करता है। (UIElement से निहित)

8

DragOver

तब होता है जब इनपुट सिस्टम संभावित ड्रॉप लक्ष्य के रूप में इस तत्व के साथ एक अंतर्निहित ड्रैग घटना की रिपोर्ट करता है। (UIElement से निहित)

9

DragStarting

तब होता है जब एक ड्रैग ऑपरेशन शुरू किया जाता है। (UIElement से निहित)

10

DropCompleted

एक ड्रैग-एंड-ड्रॉप ऑपरेशन समाप्त होने पर होता है। (UIElement से निहित)

1 1

DropDownClosed

तब होता है जब कॉम्बो बॉक्स का ड्रॉप-डाउन भाग बंद हो जाता है।

12

DropDownOpened

तब होता है जब कॉम्बो बॉक्स का ड्रॉप-डाउन भाग खुलता है।

13

GotFocus

तब होता है जब एक UIElement फोकस प्राप्त करता है। (UIElement से निहित)

14

Holding

तब होता है जब इस तत्व के हिट परीक्षण क्षेत्र पर अन्यथा अखंडित होल्ड इंटरैक्शन होता है। (UIElement से निहित)

15

Intermediate

आग जब टॉगलबटन की स्थिति अनिश्चित स्थिति में बदल जाती है। (टॉगलबटन से विरासत में मिला)

16

IsEnabledChanged

तब होता है जब अक्षम संपत्ति बदल जाती है। (नियंत्रण से विरासत में मिला)

17

KeyDown

तब होता है जब एक कीबोर्ड कुंजी दबाया जाता है जबकि UIElement फोकस होता है। (UIElement से निहित)

18

KeyUp

तब होता है जब एक कीबोर्ड कुंजी जारी की जाती है जबकि UIElement फोकस होता है। (UIElement से निहित)

19

LostFocus

तब होता है जब एक UIElement फोकस खो देता है। (UIElement से निहित)

20

ManipulationCompleted

तब होता है जब UIElement पर एक हेरफेर पूरा हो गया है। (UIElement से निहित)

21

ManipulationDelta

तब होता है जब इनपुट डिवाइस हेरफेर के दौरान स्थिति बदलता है। (UIElement से निहित)

22

ManipulationInertiaStarting

तब होता है जब इनपुट डिवाइस एक हेरफेर के दौरान UIElement ऑब्जेक्ट के साथ संपर्क खो देता है और जड़ता शुरू होती है। (UIElement से निहित)

23

ManipulationStarted

तब होता है जब एक इनपुट डिवाइस UIElement पर एक हेरफेर शुरू करता है। (UIElement से निहित)

24

ManipulationStarting

तब होता है जब हेरफेर प्रोसेसर पहली बार बनाया जाता है। (UIElement से निहित)

25

SelectionChanged

तब होता है जब पाठ चयन बदल गया है।

26

SizeChanged

तब होता है जब या तो हाइटहाइट या एक्चुअलविदथ प्रॉपर्टी फ्रेमवर्क पर वैल्यू में बदलाव करता है। (फ्रेमवर्क से आच्छादित)

27

Unchecked

तब होता है जब एक टॉगलबटन अनियंत्रित होता है। (टॉगलबटन से विरासत में मिला)

28

ValueChanged

तब होता है जब सीमा मूल्य बदल जाता है। (रेंजबेस से विहित)

डेटा बाइंडिंग XAML अनुप्रयोगों में एक तंत्र है जो डेटा को प्रदर्शित करने और बातचीत करने के लिए आंशिक कक्षाओं का उपयोग करके विंडोज रनटाइम ऐप्स के लिए एक सरल और आसान तरीका प्रदान करता है। डेटा का प्रबंधन इस तंत्र में डेटा प्रदर्शित करने के तरीके से पूरी तरह से अलग है।

डेटा बाध्यकारी यूआई तत्वों और उपयोगकर्ता इंटरफ़ेस पर डेटा ऑब्जेक्ट के बीच डेटा के प्रवाह की अनुमति देता है। जब कोई बाइंडिंग स्थापित की जाती है और डेटा या आपका व्यवसाय मॉडल बदल जाता है, तो यह UI तत्वों के लिए स्वचालित रूप से अपडेट को प्रतिबिंबित करेगा और इसके विपरीत। यह मानक डेटा स्रोत के लिए नहीं, बल्कि पृष्ठ पर किसी अन्य तत्व के लिए बाध्य करना भी संभव है। डेटा बाइंडिंग दो प्रकार की हो सकती है -

  • एकतरफा डेटा बाइंडिंग
  • दो-तरफ़ा डेटा बाइंडिंग

वन-वे डेटा बाइंडिंग

एक-तरफ़ा बाइंडिंग में, डेटा अपने स्रोत (जो ऑब्जेक्ट डेटा को रखता है) से उसके लक्ष्य से जुड़ा होता है (वह ऑब्जेक्ट जो डेटा प्रदर्शित करता है)।

आइए एक-तरफ़ा डेटा बाइंडिंग के सरल उदाहरण पर एक नज़र डालते हैं। निम्नलिखित XAML कोड कुछ गुणों के साथ चार टेक्स्ट ब्लॉक बनाता है।

<Window x:Class = "DataBindingOneWay.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"> 
	
   <Grid>
      <StackPanel Name = "Display">
         <StackPanel Orientation = "Horizontal" Margin = "50, 50, 0, 0"> 
            <TextBlock Text = "Name: " Margin = "10" Width = "100" /> 
            <TextBlock Margin = "10" Width = "100" Text = "{Binding Name}" />
         </StackPanel> 
		
         <StackPanel Orientation = "Horizontal" Margin = "50,0,50,0"> 
            <TextBlock Text = "Title: " Margin = "10" Width = "100" /> 
            <TextBlock Margin = "10" Width = "100" Text = "{Binding Title}" /> 
         </StackPanel>
      </StackPanel>
   </Grid> 
	
</Window>

दो टेक्स्ट ब्लॉक की टेक्स्ट प्रॉपर्टीज़ "नाम" और "टाइटल" स्टेटिकली सेट की जाती हैं, जबकि अन्य दो टेक्स्ट ब्लॉक टेक्स्ट प्रॉपर्टीज़ "नाम" और "टाइटल" से बँधे होते हैं, जो एम्प्लॉई क्लास के क्लास वेरिएबल होते हैं, जो नीचे दिखाया गया है।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
 
namespace DataBindingOneWay {
   public class Employee {
      public string Name { get; set; } 
      public string Title { get; set; }  
		
      public static Employee GetEmployee() {
         var emp = new Employee() { 
            Name = "Ali Ahmed", Title = "Developer" 
         }; 
         return emp; 
      }
   }
}

इस वर्ग में, हमारे पास केवल दो चर हैं, Name तथा Title, और एक स्टैटिक तरीका है जिसमें कर्मचारी ऑब्जेक्ट को इनिशियलाइज़ किया जाता है जो उस कर्मचारी ऑब्जेक्ट को वापस करेगा। इसलिए हम एक संपत्ति, नाम और शीर्षक के लिए बाध्य हैं, लेकिन हमने यह नहीं चुना है कि वह संपत्ति किस वस्तु की है। सबसे आसान तरीका है DataContext के लिए एक वस्तु निर्दिष्ट करना जिसके गुण हम निम्नलिखित C # कोड में बाँध रहे हैं -

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

namespace DataBindingOneWay { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
         DataContext = Employee.GetEmployee(); 
      } 
   }
}

आइए इस एप्लिकेशन को चलाएं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम उस कर्मचारी वस्तु के नाम और शीर्षक से सफलतापूर्वक बंध गए हैं।

टू-वे डेटा बाइंडिंग

दो-तरफ़ा बाइंडिंग में, उपयोगकर्ता डेटा को उपयोगकर्ता इंटरफ़ेस के माध्यम से संशोधित कर सकता है और उस डेटा को स्रोत में अपडेट कर सकता है। यदि उपयोगकर्ता देखने के दौरान स्रोत बदलता है, तो आप दृश्य को अपडेट करना चाहेंगे।

उदाहरण

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

<Window x:Class = "XAMLTestBinding.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>
      <ComboBox Name = "comboBox"  Margin = "50" Width = "100"> 
         <ComboBoxItem Content = "Green" /> 
         <ComboBoxItem Content = "Yellow" IsSelected = "True" /> 
         <ComboBoxItem Content = "Orange" /> 
      </ComboBox>
		
      <TextBox  Name = "textBox" Margin = "50" 
         Width = "100" Height = "23" VerticalAlignment = "Top" 
         Text  = "{Binding ElementName = comboBox, Path = SelectedItem.Content, 
         Mode = TwoWay, UpdateSourceTrigger = PropertyChanged}" 
         Background = "{Binding ElementName = comboBox, Path = SelectedItem.Content}"> 
      </TextBox>
   </StackPanel> 
	
</Window>

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

इसी तरह, जब उपयोगकर्ता टेक्स्टबॉक्स में एक वैध रंग नाम टाइप करता है, तो कॉम्बोक्स और टेक्स्टबॉक्स पृष्ठभूमि रंग भी अपडेट किया जाएगा।

XAML अनुप्रयोगों में, मार्कअप एक्सटेंशन एक ऐसा तरीका / तकनीक है जो एक मूल्य प्राप्त करने के लिए है जो न तो एक विशिष्ट XAML ऑब्जेक्ट है और न ही एक आदिम प्रकार है। मार्कअप एक्सटेंशन को घुंघराले ब्रेसिज़ को खोलने और बंद करने से परिभाषित किया जा सकता है और उस घुंघराले ब्रेसिज़ के अंदर मार्कअप एक्सटेंशन के दायरे को परिभाषित किया जाता है।

डेटा बाइंडिंग और स्थिर संसाधन मार्कअप एक्सटेंशन हैं। में कुछ पूर्वनिर्धारित XAML मार्कअप एक्सटेंशन हैंSystem.xaml जिसका उपयोग किया जा सकता है।

आइए एक सरल उदाहरण देखें जहां StaticResources मार्कअप एक्सटेंशन का उपयोग किया जाता है जो एक पूर्वनिर्धारित एक्सएएमएल मार्कअप एक्सटेंशन है।

निम्नलिखित XAML कोड कुछ गुणों के साथ दो पाठ ब्लॉक बनाता है और उनके अग्रभूमि में परिभाषित किया गया है Window.Resources

<Window x:Class = "XAMLStaticResourcesMarkupExtension.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"> 
	
   <Window.Resources> 
      <SolidColorBrush Color = "Blue" x:Key = "myBrush"></SolidColorBrush> 
   </Window.Resources> 
	
   <Grid> 
      <StackPanel Orientation = "Vertical"> 
         <TextBlock Foreground = "{StaticResource myBrush}" Text = "First Name" 
            Width = "100" Margin = "10" /> 
         <TextBlock Foreground = "{StaticResource myBrush}" Text = "Last Name" 
            Width = "100" Margin = "10" /> 
      </StackPanel> 
   </Grid> 
	
</Window>

में Window.Resources, आप देख सकते हैं x:Key उपयोग किया जाता है जो विशिष्ट रूप से एक संसाधन शब्दकोश में एक संसाधन की पहचान करने के लिए XAML परिभाषित शब्दकोश में बनाए गए और संदर्भित तत्वों की विशिष्ट पहचान करता है।

जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित MainWindow का उत्पादन करेगा। आप नीले अग्रभूमि रंग के साथ दो पाठ ब्लॉक देख सकते हैं।

XAML में, कस्टम मार्कअप एक्सटेंशन को MarkupExtension क्लास को इनहेरिट करके और ProvValue मेथड को ओवरराइड करके भी परिभाषित किया जा सकता है जो MarkupExtension क्लास में एक अमूर्त विधि है।

चलो कस्टम मार्कअप एक्सटेंशन के एक सरल उदाहरण पर एक नज़र डालते हैं।

<Window x:Class = "XAMLMarkupExtension.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:my = "clr-namespace:XAMLMarkupExtension" 
   Title = "MainWindow" Height = "350" Width = "525"> 
	
   <Grid> 
      <Button Content = "{my:MyMarkupExtension FirstStr = Markup, SecondStr = Extension}" 
         Width = "200" Height = "20" /> 
   </Grid> 
	
</Window>

उपरोक्त XAML कोड में, कुछ गुणों के साथ एक बटन बनाया जाता है और सामग्री मान के लिए एक कस्टम मार्कअप एक्सटेंशन होता है (my:MyMarkupExtension) दो मूल्यों "मार्कअप" और "एक्सटेंशन" के साथ उपयोग किया गया है जो क्रमशः FirstStr और SecondStr को सौंपा गया है।

दरअसल, MyMarkupExtensionएक ऐसा वर्ग है जो MarkupExtensionC # कार्यान्वयन के नीचे से दिखाया गया है। इस वर्ग में दो स्ट्रिंग चर, FirstStr और SecondStr होते हैं, जिन्हें संक्षिप्त किया जाता है और उस स्ट्रिंग को ProvValue विधि से एक बटन की सामग्री पर लौटा दिया जाता है।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;
 
using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Data; 
using System.Windows.Documents; 
using System.Windows.Input; 
using System.Windows.Markup; 
using System.Windows.Media; 
using System.Windows.Media.Imaging; 
using System.Windows.Navigation; 
using System.Windows.Shapes;  

namespace XAMLMarkupExtension { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window { 
      public MainWindow() { 
         InitializeComponent(); 
      } 
   }
   public class MyMarkupExtension : MarkupExtension { 
      public MyMarkupExtension() { } 
      public String FirstStr { get; set; } 
      public String SecondStr { get; set; }  
		
      public override object ProvideValue(IServiceProvider serviceProvider) { 
        return FirstStr + " " + SecondStr; 
      } 
   }
}

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

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

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

<Window x:Class = "XAMLDependencyProperty.MainWindow"
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:local = "clr-namespace:XAMLDependencyProperty"
   Title = "MainWindow" Height = "350" Width = "604">
	
   <Grid>
      <Button Height = "40" Width = "175" Margin = "10" Content = "Dependency Property">
         <Button.Style>
            <Style TargetType = "{x:Type Button}">
               <Style.Triggers> 
                  <Trigger Property = "IsMouseOver" Value = "True">
                     <Setter Property = "Foreground" Value = "Red" />
                  </Trigger>
               </Style.Triggers>
            </Style>
         </Button.Style>
      </Button>
   </Grid>
   
</Window>

X: XAML में टाइप मार्कअप एक्सटेंशन में टाइप # (C #) की तरह की कार्यक्षमता है। इसका उपयोग तब किया जाता है जब विशेषताएँ निर्दिष्ट की जाती हैं जो ऑब्जेक्ट का प्रकार लेती हैं जैसे कि <Style TargetType = "{x: Type Button}">

जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित MainWindow का उत्पादन करेगा। जब माउस बटन के ऊपर होता है, तो यह बटन के अग्रभूमि रंग को बदल देगा। जब माउस बटन छोड़ता है, तो यह वापस अपने मूल रंग में बदल जाएगा।

निर्भरता गुण और अन्य सीएलआर गुणों के बीच मुख्य अंतर हैं -

  • सीएलआर गुण सीधे कक्षा के निजी सदस्य से पढ़ / लिख सकते हैं getter तथा setter। निर्भरता गुणों के मामले में, यह एक स्थानीय वस्तु में संग्रहीत नहीं है।

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

  • यह बहुत सी मेमोरी को भी बचाता है क्योंकि यह परिवर्तित होने पर संपत्ति को संग्रहीत करता है।

  • यह XAML में भी बाध्य हो सकता है।

.NET फ्रेमवर्क में, कस्टम निर्भरता गुणों को भी परिभाषित किया जा सकता है। यहाँ C # में कस्टम डिपेंडेंसी प्रॉपर्टी को परिभाषित करने के चरण दिए गए हैं।

  • सिस्टम कॉल रजिस्टर के साथ अपनी निर्भरता संपत्ति की घोषणा और पंजीकरण करें।

  • संपत्ति के लिए सेटर और गेट्टर प्रदान करें।

  • विश्व स्तर पर होने वाले किसी भी बदलाव को संभालने के लिए एक स्थिर हैंडलर को परिभाषित करें।

  • उस विशेष उदाहरण के लिए होने वाले किसी भी परिवर्तन को संभालने के लिए एक उदाहरण हैंडलर को परिभाषित करें।

नीचे दिए गए कोड # निर्भरता संपत्ति के लिए कोड है जो उपयोगकर्ता नियंत्रण के सेटटेक्स्ट संपत्ति सेट करने के लिए परिभाषित किया गया है।

using System; 
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace WpfApplication3 {
   /// <summary> 
      /// Interaction logic for UserControl1.xaml 
   /// </summary> 
	
   public partial class UserControl1 : UserControl {
      public UserControl1() {
         InitializeComponent();
      }
      public static readonly DependencyProperty
         SetTextProperty = DependencyProperty.Register("SetText", typeof(string), 
         typeof(UserControl1), new PropertyMetadata("", 
         new PropertyChangedCallback(OnSetTextChanged)));
      public string SetText {
         get {return(string) GetValue(SetTextProperty); }
         set {SetValue(SetTextProperty, value);}
      }
      private static void OnSetTextChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) {
         UserControl1 UserControl1Control = d as UserControl1;
         UserControl1Control.OnSetTextChanged(e);
      }
      private void OnSetTextChanged(DependencyPropertyChangedEventArgs e) {
         tbTest.Text = e.NewValue.ToString();
      }
   }
}

यहां XAML फ़ाइल है जिसमें TextBlock को उपयोगकर्ता नियंत्रण के रूप में परिभाषित किया गया है और पाठ संपत्ति को SetText निर्भरता संपत्ति द्वारा इसे सौंपा जाएगा।

निम्नलिखित XAML कोड अपनी SetText निर्भरता संपत्ति और कुछ अन्य गुणों को शुरू करने के साथ एक उपयोगकर्ता नियंत्रण बनाता है।

<Window x:Class = "WpfApplication3.MainWindow"
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:views = "clr-namespace:WpfApplication3" 
   Title = "MainWindow" Height = "350" Width = "604">
	
   <Grid>
      <views:UserControl1 SetText = "Hellow World" />
   </Grid>
	
</Window>

आइए इस एप्लिकेशन को चलाएं और आप हमारे मेनविंडो में तुरंत देख सकते हैं कि उपयोगकर्ता नियंत्रण के लिए निर्भरता संपत्ति को पाठ के रूप में सफलतापूर्वक उपयोग किया गया है।

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

किसी वस्तु को संसाधन के रूप में परिभाषित करने से हम उसे दूसरी जगह से एक्सेस कर सकते हैं। इसलिए, यह पुन: प्रयोज्य की अनुमति देता है। संसाधनों को संसाधन शब्दकोशों में परिभाषित किया गया है और किसी भी वस्तु को एक संसाधन के रूप में परिभाषित किया जा सकता है जो प्रभावी रूप से इसे साझा करने योग्य संपत्ति बनाता है। XAML संसाधन के लिए एक अद्वितीय कुंजी निर्दिष्ट है और उस कुंजी के साथ, इसे StaticResource मार्कअप एक्सटेंशन का उपयोग करके संदर्भित किया जा सकता है।

आइए एक सरल उदाहरण पर फिर से नज़र डालते हैं जिसमें कुछ गुणों के साथ दो टेक्स्ट ब्लॉक बनाए गए हैं और उनके अग्रभूमि रंग को परिभाषित किया गया है Window.Resources

<Window x:Class = "XAMLResources.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"> 
	
   <Window.Resources> 
      <SolidColorBrush Color = "Blue" x:Key = "myBrush"></SolidColorBrush> 
   </Window.Resources>  
	
   <StackPanel Orientation = "Vertical"> 
      <TextBlock Foreground = "{StaticResource myBrush}" 
         Text = "First Name" Width = "100" Margin = "10" /> 
      <TextBlock Foreground = "{StaticResource myBrush}" 
         Text = "Last Name" Width = "100" Margin = "10" /> 
   </StackPanel> 
	
</Window>

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित MainWindow का उत्पादन करेगा। आप नीले अग्रभूमि रंग के साथ दो पाठ ब्लॉक देख सकते हैं। संसाधन का लाभ यह है कि यदि कई पाठ खंड हैं और आप उनकी पृष्ठभूमि का रंग बदलना चाहते हैं, तो आपको संसाधन शब्दकोश में इसे बदलने की आवश्यकता होगी।

संसाधन स्कोप

संसाधनों को संसाधन शब्दकोशों में परिभाषित किया गया है, लेकिन कई स्थान हैं जहां संसाधन शब्दकोश को परिभाषित किया जा सकता है। उपरोक्त उदाहरण में, विंडो / पृष्ठ स्तर पर एक संसाधन शब्दकोश परिभाषित किया गया है। किस शब्दकोश में एक संसाधन परिभाषित किया गया है, तुरंत उस संसाधन के दायरे को सीमित करता है। इसलिए गुंजाइश, यानी जहां आप संसाधन का उपयोग कर सकते हैं, इस पर निर्भर करता है कि आपने इसे कहां परिभाषित किया है।

  • एक ग्रिड के संसाधन शब्दकोश में संसाधन को परिभाषित करें और यह केवल उस ग्रिड और उसके बाल तत्वों द्वारा सुलभ है।

  • इसे एक विंडो / पृष्ठ पर परिभाषित करें और यह उस विंडो / पृष्ठ पर सभी तत्वों द्वारा सुलभ है।

  • App रूट को App.xaml संसाधनों के शब्दकोश में पाया जा सकता है। यह हमारे आवेदन की जड़ है, इसलिए यहां परिभाषित संसाधन पूर्ण आवेदन के लिए तैयार हैं।

जहां तक ​​संसाधन के दायरे का सवाल है, सबसे अधिक अक्सर अनुप्रयोग स्तर, पृष्ठ स्तर, और एक विशिष्ट तत्व स्तर जैसे ग्रिड, स्टैकपैनल, आदि होते हैं।

संसाधन शब्दकोश

XAML एप्लिकेशन में संसाधन शब्दकोश अलग फ़ाइलों में संसाधन शब्दकोशों का अर्थ है। लगभग सभी XAML ऐप में इसका पालन किया जाता है। अलग-अलग फ़ाइलों में संसाधनों को परिभाषित करने के निम्नलिखित फायदे हो सकते हैं -

  • संसाधन शब्दकोश और UI संबंधित कोड में परिभाषित संसाधनों के बीच अलगाव।

  • App.xaml जैसे एक अलग फ़ाइल में सभी संसाधनों को परिभाषित करने से उन्हें ऐप में उपलब्ध कराया जाएगा।

तो, हम एक अलग फ़ाइल में संसाधन शब्दकोश में अपने संसाधनों को कैसे परिभाषित कर सकते हैं? ठीक है, यह बहुत आसान है, बस विज़ुअल स्टूडियो के माध्यम से निम्नलिखित चरणों में एक नया संसाधन शब्दकोश जोड़ें -

  • अपने समाधान में, एक नया फ़ोल्डर जोड़ें और इसे नाम दें ResourceDictionaries

  • इस फ़ोल्डर पर राइट-क्लिक करें और ऐड सबमेनू आइटम से संसाधन शब्दकोश का चयन करें और इसे नाम दें DictionaryWithBrush.xaml

चलो एक ही आवेदन पर एक नज़र है; बस संसाधन शब्दकोश अब App स्तर में परिभाषित किया गया है।

यहाँ MainWindow.xaml के लिए XAML कोड है।

<Window x:Class = "XAMLResources.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 Orientation = "Vertical"> 
      <TextBlock Foreground = "{StaticResource myBrush}" Text = "First Name" 
         Width = "100" Margin = "10" /> 
      <TextBlock Foreground = "{StaticResource myBrush}" Text = "Last Name" 
         Width = "100" Margin = "10"/> 
   </StackPanel> 
	
</Window>

यहाँ DictionaryWrBrush.xaml में कार्यान्वयन है -

<ResourceDictionary 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"> 
	
   <SolidColorBrush Color = "Blue" x:Key = "myBrush"></SolidColorBrush> 
	
</ResourceDictionary>

यहाँ app.xaml में कार्यान्वयन है -

<Application x:Class = "XAMLResources.App" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   StartupUri = "MainWindow.xaml"> 
	
   <Application.Resources> 
      <ResourceDictionary Source = " XAMLResources\ResourceDictionaries\DictionaryWithBrush.xaml" /> 
   </Application.Resources> 
	
</Application>

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

हम आपको उपरोक्त कोड निष्पादित करने और कुछ और संसाधनों जैसे पृष्ठभूमि रंग, आदि के साथ प्रयोग करने की सलाह देते हैं।

एक टेम्पलेट एक नियंत्रण के समग्र रूप और दृश्य उपस्थिति का वर्णन करता है। प्रत्येक नियंत्रण के लिए, इसके साथ एक डिफ़ॉल्ट टेम्पलेट जुड़ा होता है जो उस नियंत्रण को उपस्थिति देता है।

XAML में, जब आप दृश्य व्यवहार और नियंत्रण की दृश्य उपस्थिति को अनुकूलित करना चाहते हैं, तो आप आसानी से अपने स्वयं के टेम्पलेट बना सकते हैं। तर्क और टेम्पलेट के बीच कनेक्टिविटी डेटा बाइंडिंग द्वारा प्राप्त की जा सकती है।

शैलियों और टेम्पलेट्स के बीच मुख्य अंतर हैं -

  • शैलियाँ केवल उस नियंत्रण के डिफ़ॉल्ट गुणों के साथ आपके नियंत्रण की उपस्थिति को बदल सकती हैं।

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

दो प्रकार के टेम्पलेट हैं जो सबसे अधिक उपयोग किए जाते हैं।

  • नियंत्रण टेम्पलेट
  • डेटा टेम्प्लेट

नियंत्रण टेम्पलेट

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

आइए एक बार फिर एक सरल उदाहरण देखें जिसमें कुछ गुणों के साथ दो बटन बनाए गए हैं। एक साथ हैtemplate और दूसरे के साथ है default बटन।

<Window x:Class = "TemplateDemo.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"> 
	
   <Window.Resources>
      <ControlTemplate x:Key = "ButtonTemplate" TargetType = "Button">
         <Grid>
            <Ellipse x:Name = "ButtonEllipse" Height = "100" Width = "150" >
               <Ellipse.Fill> 
                  <LinearGradientBrush StartPoint = "0,0.2" EndPoint = "0.2,1.4"> 
                     <GradientStop Offset = "0" Color = "Red"/>
                     <GradientStop Offset = "1" Color = "Orange"/>
                  </LinearGradientBrush> 
               </Ellipse.Fill>
            </Ellipse>
            <ContentPresenter Content = "{TemplateBinding Content}"
               HorizontalAlignment = "Center" VerticalAlignment = "Center" />
         </Grid>
         <ControlTemplate.Triggers> 
            <Trigger Property = "IsMouseOver" Value = "True">
               <Setter TargetName = "ButtonEllipse" Property = "Fill" >
                  <Setter.Value> 
                     <LinearGradientBrush StartPoint = "0,0.2" EndPoint="0.2,1.4"> 
                        <GradientStop Offset = "0" Color = "YellowGreen"/>
                        <GradientStop Offset = "1" Color = "Gold"/>
                     </LinearGradientBrush> 
                  </Setter.Value> 
               </Setter>
            </Trigger> 
				
            <Trigger Property = "IsPressed" Value = "True"> 
               <Setter Property = "RenderTransform"> 
                  <Setter.Value> 
                     <ScaleTransform ScaleX = "0.8" ScaleY = "0.8" CenterX = "0" CenterY = "0" /> 
                  </Setter.Value> 
               </Setter> 
					
               <Setter Property = "RenderTransformOrigin" Value = "0.5,0.5" /> 
            </Trigger>
         </ControlTemplate.Triggers>
      </ControlTemplate> 
   </Window.Resources>
	
   <StackPanel> 
      <Button Content = "Round Button!" Template = "{StaticResource ButtonTemplate}" 
         Width = "150" Margin = "50" />
      <Button Content = "Default Button!" Height = "40" Width = "150" Margin = "5" /> 
   </StackPanel> 
	
</Window>

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित MainWindow का उत्पादन करेगा -

जब आप कस्टम टेम्प्लेट के साथ बटन पर माउस को घुमाते हैं, तो यह नीचे दिखाए अनुसार रंग भी बदलता है -

डेटा टेम्प्लेट

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

आइए डेटा टेम्पलेट के एक सरल उदाहरण पर एक नज़र डालते हैं। निम्न XAML कोड डेटा टेम्प्लेट और टेक्स्ट ब्लॉक के साथ एक कॉम्बोक्स बनाता है।

<Window x:Class = "XAMLDataTemplate.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"> 
	
   <Grid VerticalAlignment = "Top">
      <ComboBox Name = "Presidents" ItemsSource = "{Binding}" Height = "30" Width = "400"> 
         <ComboBox.ItemTemplate> 
            <DataTemplate>
               <StackPanel Orientation = "Horizontal" Margin = "2">
                  <TextBlock Text = "Name: " Width = "95" Background = "Aqua" Margin = "2" /> 
                  <TextBlock Text = "{Binding Name}" Width = "95" Background = "AliceBlue" Margin = "2" /> 
                  <TextBlock Text = "Title: " Width = "95" Background = "Aqua" Margin = "10,2,0,2" />
                  <TextBlock Text = "{Binding Title}" Width = "95" Background = "AliceBlue" Margin = "2" /> 
               </StackPanel>
            </DataTemplate>
         </ComboBox.ItemTemplate> 
      </ComboBox> 
   </Grid>
   
</Window>

यहाँ C # में कार्यान्वयन है जिसमें कर्मचारी ऑब्जेक्ट DataContext को सौंपा गया है -

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

namespace XAMLDataTemplate { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() {
         InitializeComponent(); 
         DataContext = Employee.GetEmployees(); 
      }
   }
}

यहाँ कर्मचारी वर्ग के लिए C # में कार्यान्वयन है -

using System; 
using System.Collections.Generic; 
using System.Collections.ObjectModel; 
using System.ComponentModel; 
using System.Linq; 
using System.Runtime.CompilerServices; 
using System.Text; 
using System.Threading.Tasks;

namespace XAMLDataTemplate { 
   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; 
      }
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा। इसमें एक कॉम्बोबॉक्स होता है और जब आप कॉम्बोबॉक्स पर क्लिक करते हैं, तो आप देखते हैं कि कर्मचारी वर्ग में बनाए गए डेटा के संग्रह को कॉम्बोक्स आइटम के रूप में सूचीबद्ध किया गया है।

हम आपको उपरोक्त कोड निष्पादित करने और इसके साथ प्रयोग करने की सलाह देते हैं।

XAML ढांचा एक आवेदन की उपस्थिति को निजीकृत और अनुकूलित करने के लिए कई रणनीतियां प्रदान करता है। शैलियाँ हमें किसी वस्तु के कुछ गुणों को सेट करने और एक समान दिखने के लिए कई वस्तुओं में इन विशिष्ट सेटिंग्स का पुन: उपयोग करने की सुविधा देती हैं।

  • शैलियों में, आप किसी ऑब्जेक्ट के केवल मौजूदा गुणों जैसे कि ऊँचाई, चौड़ाई और फ़ॉन्ट आकार सेट कर सकते हैं।

  • नियंत्रण का केवल डिफ़ॉल्ट व्यवहार निर्दिष्ट किया जा सकता है।

  • एक ही शैली में कई गुण जोड़े जा सकते हैं।

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

कल्पना करें कि हमारे पास तीन बटन हैं और उन सभी को एक जैसे दिखना है - एक ही चौड़ाई और ऊँचाई, एक ही फ़ॉन्ट आकार और एक ही अग्रभूमि रंग। हम उन सभी गुणों को बटन तत्वों पर स्वयं सेट कर सकते हैं और यह अभी भी सभी बटन के लिए काफी ठीक है जैसा कि निम्नलिखित चित्र में दिखाया गया है।

लेकिन एक वास्तविक जीवन ऐप में, आपके पास आम तौर पर इनमें से बहुत कुछ होगा जो बिल्कुल समान दिखने की आवश्यकता है। और न केवल बटन, आप अपने ऐप में समान दिखने के लिए आमतौर पर अपने टेक्स्ट ब्लॉक, टेक्स्ट बॉक्स और कॉम्बो बॉक्स आदि चाहते हैं। निश्चित रूप से इसे प्राप्त करने का एक बेहतर तरीका होना चाहिए - इसे इस रूप में जाना जाता हैstyling। आप निम्न आरेख में दिखाए गए अनुसार एक से अधिक तत्वों के लिए संपत्ति मानों के एक सेट को लागू करने के लिए एक सुविधाजनक तरीके के रूप में सोच सकते हैं।

आइए उदाहरण देखें जिसमें तीन बटन होते हैं जो कुछ गुणों के साथ XAML में बनाए जाते हैं।

<Window x:Class = "XAMLStyle.MainWindow" 
   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"
   xmlns:local = "clr-namespace:XAMLStyle" mc:Ignorable = "d" 
   Title = "MainWindow" Height = "350" Width = "604"> 
	
   <StackPanel> 
      <Button Content = "Button1" Height = "30" Width = "80" Foreground = "Blue" 
         FontSize = "12" Margin = "10"/>
      
      <Button Content = "Button2" Height = "30" Width = "80" Foreground = "Blue" 
         FontSize = "12" Margin = "10"/>
      
      <Button Content = "Button3" Height = "30" Width = "80" Foreground = "Blue" 
         FontSize = "12" Margin = "10"/> 
   </StackPanel> 
	
</Window>

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

अब हम उसी उदाहरण पर एक नज़र डालते हैं, लेकिन इस बार, हम इसका उपयोग करेंगे style

<Window x:Class = "XAMLStyle.MainWindow" 
   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"
   xmlns:local = "clr-namespace:XAMLStyle" mc:Ignorable = "d" 
   Title = "MainWindow" Height = "350" Width = "604">
	
   <Window.Resources> 
      <Style x:Key = "myButtonStyle" TargetType = "Button">
         <Setter Property = "Height" Value = "30"/> 
         <Setter Property = "Width" Value = "80"/> 
         <Setter Property = "Foreground" Value = "Blue"/> 
         <Setter Property = "FontSize" Value = "12"/> 
         <Setter Property = "Margin" Value = "10"/> 
      </Style>
   </Window.Resources> 
	
   <StackPanel> 
      <Button Content = "Button1" Style = "{StaticResource myButtonStyle}"/>
      <Button Content = "Button2" Style = "{StaticResource myButtonStyle}"/>
      <Button Content = "Button3" Style = "{StaticResource myButtonStyle}"/>
   </StackPanel>
	
</Window>

शैलियाँ संसाधन शब्दकोश में परिभाषित की गई हैं और प्रत्येक शैली में एक अद्वितीय कुंजी पहचानकर्ता और एक लक्ष्य प्रकार है। अंदर <शैली>, आप देख सकते हैं कि प्रत्येक संपत्ति के लिए कई सेटर टैग परिभाषित किए गए हैं जो शैली में शामिल होंगे।

उपर्युक्त उदाहरण में, प्रत्येक बटन के सभी सामान्य गुणों को अब शैली में परिभाषित किया गया है और फिर शैली को प्रत्येक बटन को StaticResource मार्कअप एक्सटेंशन के माध्यम से शैली गुण सेट करके असाइन किया गया है।

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

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

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

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

नियंत्रण स्तर पर एक शैली को परिभाषित करना केवल उस विशेष नियंत्रण पर लागू किया जा सकता है।

2 लेआउट स्तर

किसी भी लेआउट स्तर पर एक शैली को परिभाषित करना केवल उस लेआउट और उसके बाल तत्वों द्वारा ही सुलभ हो सकता है।

3 विंडो स्तर

एक खिड़की के स्तर पर एक शैली को परिभाषित करना उस खिड़की के सभी तत्वों द्वारा सुलभ हो सकता है।

4 आवेदन स्तर

ऐप स्तर पर एक शैली को परिभाषित करना इसे पूरे एप्लिकेशन में सुलभ बनाता है।

मूल रूप से, एक ट्रिगर आपको संपत्ति के मूल्यों को बदलने या किसी संपत्ति के मूल्य के आधार पर कार्रवाई करने में सक्षम बनाता है। इसलिए, यह मूल रूप से आपको एक नया बनाने के बिना गतिशील रूप से आपके नियंत्रण की उपस्थिति और / या व्यवहार को बदलने की अनुमति देता है।

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

  • संपत्ति ट्रिगर
  • डेटा ट्रिगर
  • इवेंट ट्रिगर

संपत्ति ट्रिगर

प्रॉपर्टी ट्रिगर्स में, जब एक प्रॉपर्टी में बदलाव होता है, तो यह प्रॉपर्टी में तत्काल या एनिमेटेड बदलाव लाएगा। उदाहरण के लिए, आप एक संपत्ति ट्रिगर का उपयोग कर सकते हैं यदि आप माउस के बटन के ऊपर होने पर बटन उपस्थिति को बदलना चाहते हैं।

उदाहरण

निम्नलिखित उदाहरण दर्शाता है कि जब माउस अपने क्षेत्र में प्रवेश करता है तो बटन के अग्रभूमि रंग को कैसे बदलना है।

<Window x:Class = "XAMLPropertyTriggers.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">
	
   <Window.Resources>
      <Style x:Key = "TriggerStyle" TargetType = "Button">
         <Setter Property = "Foreground" Value = "Blue" />
         <Style.Triggers>
            <Trigger Property = "IsMouseOver" Value = "True">
               <Setter Property = "Foreground" Value = "Green" />
            </Trigger> 
         </Style.Triggers>
      </Style>
   </Window.Resources>
	
   <Grid>
      <Button Width = "100" Height = "70" Style = "{StaticResource TriggerStyle}" 
         Content = "Trigger"/>
   </Grid>
	
</Window>

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

जब माउस बटन के क्षेत्र में प्रवेश करता है, तो अग्रभूमि का रंग हरे रंग में बदल जाएगा।

डेटा ट्रिगर

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

<Window x:Class = "XAMLDataTrigger.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "Data Trigger" Height = "350" Width = "604">
	
   <StackPanel HorizontalAlignment = "Center">
      <CheckBox x:Name = "redColorCheckBox" Content = "Set red as foreground color" Margin = "20"/>
		
      <TextBlock Name = "txtblock" VerticalAlignment = "Center" 
         Text = "Event Trigger" FontSize = "24" Margin = "20">
         <TextBlock.Style>
            <Style>
               <Style.Triggers>
                  <DataTrigger Binding = "{Binding ElementName = redColorCheckBox, Path = IsChecked}" 
                     Value = "true">
                     <Setter Property = "TextBlock.Foreground" Value = "Red"/>
                     <Setter Property = "TextBlock.Cursor" Value = "Hand" />
                  </DataTrigger>
               </Style.Triggers>
            </Style>
         </TextBlock.Style>
      </TextBlock>
   </StackPanel>
	
</Window>

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

जब चेकबॉक्स चेक किया जाता है, तो टेक्स्ट ब्लॉक का अग्रभूमि रंग लाल में बदल जाएगा।

इवेंट ट्रिगर

जब कोई विशिष्ट घटना निकाल दी जाती है, तो इवेंट ट्रिगर कुछ कार्रवाई करता है। इसका उपयोग आमतौर पर कुछ एनीमेशन को पूरा करने के लिए किया जाता है जैसे कि DoubleAnimation, ColorAnimation, आदि। निम्नलिखित कोड ब्लॉक एक साधारण बटन बनाता है। जब क्लिक ईवेंट को निकाल दिया जाता है, तो यह बटन की चौड़ाई और ऊंचाई का विस्तार करेगा।

<Window x:Class = "XAMLEventTrigger.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">
	
   <Grid>
      <Button Content = "Click Me" Width = "60" Height = "30">
         <Button.Triggers>
            <EventTrigger RoutedEvent = "Button.Click">
               <EventTrigger.Actions>
                  <BeginStoryboard>
                     <Storyboard>
                     
                        <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty = "Width" Duration = "0:0:4">
                           <LinearDoubleKeyFrame Value = "60" KeyTime = "0:0:0"/>
                           <LinearDoubleKeyFrame Value = "120" KeyTime = "0:0:1"/>
                           <LinearDoubleKeyFrame Value = "200" KeyTime = "0:0:2"/>
                           <LinearDoubleKeyFrame Value = "300" KeyTime = "0:0:3"/>
                        </DoubleAnimationUsingKeyFrames>
							
                        <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty = "Height" Duration = "0:0:4">
                           <LinearDoubleKeyFrame Value = "30" KeyTime = "0:0:0"/>
                           <LinearDoubleKeyFrame Value = "40" KeyTime = "0:0:1"/>
                           <LinearDoubleKeyFrame Value = "80" KeyTime = "0:0:2"/>
                           <LinearDoubleKeyFrame Value = "150" KeyTime = "0:0:3"/>
                        </DoubleAnimationUsingKeyFrames>
							
                     </Storyboard>
                  </BeginStoryboard>
               </EventTrigger.Actions>
            </EventTrigger>
         </Button.Triggers>
      </Button>
   </Grid>
</Window>

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

अब, बटन पर क्लिक करें और आप देखेंगे कि यह दोनों आयामों में विस्तार करना शुरू कर देगा।

यदि आप किसी प्रक्रियात्मक भाषा (जैसे C #, C / C ++ आदि) में डिबगिंग से परिचित हैं और आपको इसका उपयोग पता है breakऔर एक्सएएमएल में उसी तरह के डिबगिंग की उम्मीद कर रहे हैं, तो आपको यह जानकर आश्चर्य होगा कि एक्सएएमएल कोड को डीबग करना संभव नहीं है, जिस तरह से आप किसी अन्य प्रक्रियात्मक भाषा कोड को डीबग करते थे। XAML ऐप को डीबग करने का मतलब है कि त्रुटि खोजने की कोशिश करना;

  • डेटा बाइंडिंग में, आपका डेटा स्क्रीन पर दिखाई नहीं देता है और आपको पता नहीं है कि क्यों

  • या एक समस्या जटिल लेआउट से संबंधित है।

  • या लिस्टबॉक्स और कॉम्बो बॉक्स जैसे कुछ व्यापक टेम्पलेट्स के साथ मार्जिन रंग, ओवरले आदि में एक संरेखण मुद्दा या मुद्दे।

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

<Window x:Class = "DataBindingOneWay.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">
	
   <Grid>
      <StackPanel Name = "Display">
         <StackPanel Orientation = "Horizontal" Margin = "50, 50, 0, 0">
            <TextBlock Text = "Name: " Margin = "10" Width = "100"/>
            <TextBlock Margin = "10" Width = "100" Text = "{Binding FirstName}"/>
         </StackPanel>
			
         <StackPanel Orientation = "Horizontal" Margin = "50,0,50,0">
            <TextBlock Text = "Title: " Margin = "10" Width = "100"/>
            <TextBlock Margin = "10" Width="100" Text = "{Binding Title}" />
         </StackPanel>
      </StackPanel>
   </Grid>
	
</Window>

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

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;

namespace DataBindingOneWay {
   public class Employee {
      public string Name { get; set; } 
      public string Title { get; set; }
		
      public static Employee GetEmployee() {
         var emp = new Employee() {
            Name = "Ali Ahmed", 
            Title = "Developer"
         };
         return emp; 
      }
   }
}

यहाँ C # कोड में MainWindow क्लास का कार्यान्वयन है -

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

namespace DataBindingOneWay {
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() {
         InitializeComponent(); 
         DataContext = Employee.GetEmployee(); 
      }
   }
}

आइए इस एप्लिकेशन को चलाएं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम सफलतापूर्वक उस कर्मचारी के शीर्षक से बंध गए हैं लेकिन नाम बाध्य नहीं है।

नाम के साथ क्या हुआ, यह जांचने के लिए, आइए आउटपुट विंडो को देखें, जहां बहुत अधिक लॉग जेनरेट होता है।

एक त्रुटि खोजने का सबसे आसान तरीका है कि आप केवल त्रुटि की खोज करें और आपको नीचे उल्लिखित त्रुटि मिलेगी जो कहती है "बाइंडिंगप्रेशन पथ त्रुटि: 'फर्स्टनाम' संपत्ति 'ऑब्जेक्ट' 'एम्प्लोय" पर नहीं मिली

System.Windows.Data Error: 40 : BindingExpression path error: 'FirstName'
   property not found on 'object' ''Employee' (HashCode = 11611730)'.
BindingExpression:Path = FirstName; 
DataItem = 'Employee' (HashCode = 11611730); target element is 'TextBlock' (Name = ''); 
target property is 'Text' (type 'String')

जो स्पष्ट रूप से इंगित करता है कि फर्स्टनाम कर्मचारी वर्ग का सदस्य नहीं है, इसलिए यह आपके आवेदन में इस प्रकार के मुद्दों को ठीक करने में मदद करता है।

जब आप बदलते हैं FirstName सेवा Name फिर से, आप वांछित आउटपुट देखेंगे।

XAML के लिए UI डिबगिंग टूल

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

  • Step 1 - टूल मेनू पर जाएं और टूल मेनू से विकल्प चुनें।

  • Step 2 - आपको निम्नलिखित डायलॉग बॉक्स देखने को मिलेगा।

  • Step 3 - बाईं ओर डिबगिंग आइटम के तहत सामान्य विकल्प पर जाएं।

  • Step 4 - हाइलाइट किए गए विकल्प की जाँच करें, अर्थात, "XAML के लिए UI डिबगिंग उपकरण सक्षम करें"

  • Step 5 - ओके बटन दबाएं।

अब कोई भी XAML एप्लिकेशन चलाएं या निम्नलिखित XAML कोड का उपयोग करें -

<Window x:Class = "XAMLTestBinding.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>
      <ComboBox Name = "comboBox" Margin = "50" Width = "100">
         <ComboBoxItem Content = "Green"/>
         <ComboBoxItem Content = "Yellow" IsSelected = "True"/>
         <ComboBoxItem Content = "Orange" />
      </ComboBox>
		
      <TextBox Name = "textBox" Margin = "50" Width = "100" 
         Height = "23" VerticalAlignment = "Top" Text = "{
         Binding ElementName = comboBox, Path = SelectedItem.Content, 
         Mode = TwoWay, UpdateSourceTrigger = PropertyChanged}" 
         Background = "{Binding ElementName = comboBox, Path = SelectedItem.Content}"> 
      </TextBox>
   </StackPanel>
	
</Window>

जब एप्लिकेशन निष्पादित होता है, तो यह लाइव विज़ुअल ट्री दिखाएगा जहां सभी तत्व एक पेड़ में दिखाए गए हैं।

यह लाइव विज़ुअल ट्री यूआई तत्वों को रखा गया है, यह समझने के लिए संपूर्ण लेआउट संरचना दिखाता है। लेकिन यह विकल्प केवल Visual Studio 2015 में उपलब्ध है। यदि आप Visual Studio के पुराने संस्करण का उपयोग कर रहे हैं, तो आप इस टूल का उपयोग नहीं कर सकते हैं; हालाँकि एक और उपकरण है जिसे विज़ुअल स्टूडियो के साथ एकीकृत किया जा सकता है जैसे विज़ुअल स्टूडियो के लिए XAML स्पाई। आप इससे डाउनलोड कर सकते हैंhttp://xamlspy.com/download। यदि आप Visual Studio के पुराने संस्करण का उपयोग कर रहे हैं तो हम आपको इस उपकरण को डाउनलोड करने की सलाह देते हैं।

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

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

उपयोगकर्ता नियंत्रण

उपयोगकर्ता नियंत्रण अलग-अलग निर्मित नियंत्रणों को एक साथ इकट्ठा करने और उन्हें फिर से उपयोग करने योग्य एक्सएएमएल में इकट्ठा करने और उन्हें संयोजित करने की एक तकनीक प्रदान करते हैं। उपयोगकर्ता नियंत्रण का उपयोग निम्नलिखित परिदृश्यों में किया जाता है -

  • यदि नियंत्रण में मौजूदा नियंत्रण होते हैं, तो, आप पहले से मौजूद नियंत्रणों में से कई का एकल नियंत्रण बना सकते हैं।

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

  • यदि कोई डेवलपर कोड-पीछे मॉडल का उपयोग करके नियंत्रण लिखना पसंद करता है, जहां एक दृश्य और फिर घटना संचालकों के लिए एक सीधा कोड लिखा जाता है।

  • आप अनुप्रयोगों पर अपना नियंत्रण साझा नहीं करेंगे।

चलो उपयोगकर्ता नियंत्रण का एक उदाहरण लेते हैं और नीचे दिए गए चरणों का पालन करते हैं -

  • Step 1 - एक नया WPF प्रोजेक्ट बनाएं और फिर अपने समाधान पर राइट-क्लिक करें और Add> New Item चुनें ...

  • Step 2 - निम्नलिखित संवाद खुल जाएगा, अब चयन करें User Control (WPF) और इसे नाम दें MyUserControl

  • Step 3 - ऐड बटन पर क्लिक करें और आप देखेंगे कि आपके समाधान में दो नई फाइलें (MyUserControl.xaml और MyUserControl.cs) जुड़ जाएंगी।

नीचे दिया गया XAML कोड है जिसमें एक बटन और एक टेक्स्टबॉक्स MyUserControl.xamag फ़ाइल में कुछ गुणों के साथ बनाया गया है।

<UserControl x:Class = "XAMLUserControl.MyUserControl" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
   mc:Ignorable = "d" d:DesignHeight = "300" d:DesignWidth = "300">
	
   <Grid>
      <TextBox Height = "23" HorizontalAlignment = "Left" 
         Margin = "80,49,0,0" Name = "txtBox" VerticalAlignment = "Top" Width = "200" />
      <Button Content = "Click Me" Height = "23" 
         HorizontalAlignment = "Left" Margin = "96,88,0,0" Name = "button" 
         VerticalAlignment = "Top" Width = "75" Click = "button_Click" />
   </Grid>
	
</UserControl>

नीचे दिए गए बटन पर क्लिक करने के लिए C # कोड MyUserControl.cs फ़ाइल में है जो पाठ बॉक्स को अपडेट करता है।

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

namespace XAMLUserControl {
   /// <summary> 
      /// Interaction logic for MyUserControl.xaml
   /// </summary> 
	
   public partial class MyUserControl : UserControl {
      public MyUserControl() {
         InitializeComponent(); 
      }
      private void button_Click(object sender, RoutedEventArgs e) { 
         txtBox.Text = "You have just clicked the button"; 
      } 
   }
}

उपयोगकर्ता नियंत्रण को जोड़ने के लिए यहाँ MainWindow.xaml में कार्यान्वयन है।

<Window x:Class = "XAMLUserControl.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:control = "clr-namespace:XAMLUserControl" 
   Title = "MainWindow" Height = "350" Width = "525">
	
   <Grid>
      <control:MyUserControl/>
   </Grid>
	
</Window>

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

अब "क्लिक मी" बटन पर क्लिक करें और आप देखेंगे कि टेक्स्टबॉक्स टेक्स्ट अपडेट हो गया है।

कस्टम नियंत्रण

एक कस्टम नियंत्रण एक वर्ग है जो अपनी शैली और टेम्पलेट प्रदान करता है जो सामान्य रूप से परिभाषित होते हैं generic.xaml। कस्टम नियंत्रण निम्नलिखित परिदृश्यों में उपयोग किए जाते हैं,

  • यदि नियंत्रण मौजूद नहीं है और आपको इसे स्क्रैच से बनाना होगा।

  • यदि आप अपने विशिष्ट परिदृश्य को फिट करने के लिए एक अतिरिक्त संपत्ति या एक अतिरिक्त कार्यक्षमता जोड़कर एक preexisting नियंत्रण के लिए कार्यक्षमता बढ़ाना या जोड़ना चाहते हैं।

  • यदि आपके नियंत्रणों को थीमिंग और स्टाइलिंग का समर्थन करने की आवश्यकता है।

  • यदि आप अनुप्रयोगों पर नियंत्रण साझा करना चाहते हैं।

चलो कस्टम नियंत्रण का एक उदाहरण लेते हैं और नीचे दिए गए चरणों का पालन करते हैं।

  • Step 1 - एक नया WPF प्रोजेक्ट बनाएं और फिर अपने समाधान पर राइट-क्लिक करें और Add> New Item चुनें ...

  • Step 2- निम्नलिखित डायलॉग बॉक्स खुलेगा। अब सेलेक्ट करेंCustom Control (WPF) और इसे नाम दें MyCustomControl

  • Step 3 - ऐड बटन पर क्लिक करें और आप देखेंगे कि आपके समाधान में दो नई फाइलें (थीम्स / Generic.xaml और MyCustomControl.cs) जोड़ी जाएंगी।

नीचे दिया गया XAML कोड है जिसमें Generic.xaml फ़ाइल में कस्टम नियंत्रण के लिए शैली सेट की गई है।

<ResourceDictionary 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:local = "clr-namespace:XAMLCustomControls">
	
   <Style TargetType = "{x:Type local:MyCustomControl}"
      BasedOn = "{StaticResource {x:Type Button}}"> 
      <Setter Property = "Background" Value = "LightSalmon"/>
      <Setter Property = "Foreground" Value = "Blue"/>
   </Style>
	
</ResourceDictionary>

नीचे दिए गए MyCustomControl वर्ग के लिए C # कोड है जो कि बटन वर्ग से और निर्माणकर्ता से विरासत में मिला है, यह मेटाडेटा को ओवरराइड करता है।

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

namespace XAMLCustomControls {
   public class MyCustomControl : Button {
      static MyCustomControl() {
         DefaultStyleKeyProperty.OverrideMetadata(typeof(MyCustomControl), 
            new FrameworkPropertyMetadata(typeof(MyCustomControl)));
      }
   }
}

नीचे दिया गया C # में कस्टम कंट्रोल क्लिक इवेंट इम्प्लीमेंटेशन है जो टेक्स्ट ब्लॉक के टेक्स्ट को अपडेट करता है।

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

namespace XAMLCustomControls {
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary> 
	
   public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
      }
      private void customControl_Click(object sender, RoutedEventArgs e) {
         txtBlock.Text = "You have just click your custom control"; 
      } 
   }
}

यहाँ कस्टम नियंत्रण और एक टेक्स्टब्लॉक को जोड़ने के लिए MainWindow.xaml में कार्यान्वयन है।

<Window x:Class = "XAMLCustomControls.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
   xmlns:control = "clr-namespace:XAMLCustomControls" Title = "MainWindow"
   Height = "350" Width = "604">
	
   <StackPanel>
      <control:MyCustomControl x:Name = "customControl" 
         Content = "Click Me" Width = "70" Margin = "10" Click = "customControl_Click"/>
      <TextBlock Name = "txtBlock" Width = "250" Height = "30"/>
   </StackPanel>
	
</Window>

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

अब कस्टमाइज्ड बटन पर क्लिक करें। आप देखेंगे कि टेक्स्ट ब्लॉक टेक्स्ट अपडेट हो गया है।