XAML - शैलियाँ

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 आवेदन स्तर

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