WPF - शैलियाँ
.NET फ्रेमवर्क एक आवेदन की उपस्थिति को निजीकृत और अनुकूलित करने के लिए कई रणनीतियां प्रदान करता है। शैलियाँ हमें किसी वस्तु के कुछ गुणों को सेट करने और एक समान दिखने के लिए कई वस्तुओं में इन विशिष्ट सेटिंग्स का पुन: उपयोग करने की सुविधा प्रदान करती हैं।
शैलियों में, आप किसी ऑब्जेक्ट के केवल मौजूदा गुण जैसे कि ऊँचाई, चौड़ाई, फ़ॉन्ट आकार, आदि सेट कर सकते हैं।
नियंत्रण के केवल डिफ़ॉल्ट व्यवहार को निर्दिष्ट किया जा सकता है।
एक ही शैली में कई गुण जोड़े जा सकते हैं।
स्टाइल्स का उपयोग एक समान रूप या नियंत्रणों को दिखाने के लिए किया जाता है। किसी दिए गए प्रकार के सभी नियंत्रणों के लिए एक उपस्थिति लागू करने और आवेदन को सरल बनाने के लिए निहित शैलियों का उपयोग किया जाता है। तीन बटन की कल्पना करें, उन सभी को समान, समान चौड़ाई और ऊंचाई, एक ही फ़ॉन्ट आकार, एक ही अग्रभूमि रंग आदि देखना होगा। हम उन सभी गुणों को बटन तत्वों पर स्वयं सेट कर सकते हैं और यह अभी भी सभी बटन के लिए काफी ठीक है। निम्नलिखित आरेख पर एक नज़र डालें।
लेकिन एक वास्तविक जीवन के अनुप्रयोगों में, आपके पास आमतौर पर इनमें से बहुत अधिक होंगे जो बिल्कुल समान दिखने की आवश्यकता है। और निश्चित रूप से केवल बटन ही नहीं, आप आमतौर पर अपने टेक्स्ट ब्लॉक, टेक्स्ट बॉक्स और कॉम्बो बॉक्स आदि को अपने आवेदन में देखना चाहेंगे। निश्चित रूप से, इसे प्राप्त करने का एक बेहतर तरीका होना चाहिए और इसे इस रूप में जाना जाता हैstyling। आप एक शैली को एक से अधिक तत्वों के लिए संपत्ति मानों के एक सेट को लागू करने के लिए एक सुविधाजनक तरीका के रूप में सोच सकते हैं। निम्नलिखित आरेख पर एक नज़र डालें।
उदाहरण
आइए इस अवधारणा को समझने के लिए एक सरल उदाहरण लेते हैं। एक नया WPF प्रोजेक्ट बनाकर शुरू करें।
टूलबॉक्स से डिज़ाइन विंडो में तीन बटन खींचें।
निम्नलिखित XAML कोड तीन बटन बनाता है और उन्हें कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFStyle.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: WPFStyle"
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 | आवेदन स्तर ऐप स्तर पर एक शैली को परिभाषित करना इसे पूरे एप्लिकेशन के दौरान सुलभ बना सकता है। आइए एक ही उदाहरण लेते हैं, लेकिन यहां, हम एप्लिकेशन में शैलियों को ऐप्लीकेशल फ़ाइल में डाल देंगे ताकि इसे पूरे एप्लिकेशन तक पहुंच योग्य बनाया जा सके। |