WPF - त्वरित गाइड
WPF का मतलब विंडोज प्रेजेंटेशन फाउंडेशन है। यह विंडोज अनुप्रयोगों के निर्माण के लिए एक शक्तिशाली ढांचा है। यह ट्यूटोरियल उन विशेषताओं की व्याख्या करता है, जिन्हें आपको WPF अनुप्रयोगों के निर्माण के लिए समझने की आवश्यकता है और यह विंडोज अनुप्रयोगों में एक मौलिक परिवर्तन कैसे लाता है।
WPF को पहले .NET फ्रेमवर्क 3.0 संस्करण में पेश किया गया था, और फिर बाद में .NET फ्रेमवर्क संस्करणों में कई अन्य विशेषताएं जोड़ी गईं।
WPF आर्किटेक्चर
WPF से पहले, Microsoft द्वारा MFC और Windows रूपों के रूप में पेश किए जाने वाले अन्य यूजर इंटरफेस फ्रेमवर्क, User32 और GDI32 DLL के आसपास केवल रैपर थे, लेकिन WPF User32 का केवल न्यूनतम उपयोग करता है। इसलिए,
- WPF सिर्फ एक आवरण से अधिक है।
- यह .NET फ्रेमवर्क का एक हिस्सा है।
- इसमें प्रबंधित और अप्रबंधित कोड का मिश्रण है।
WPF आर्किटेक्चर के प्रमुख घटक नीचे दिए गए चित्र में दिखाए गए हैं। WPF का सबसे महत्वपूर्ण कोड हिस्सा हैं -
- प्रस्तुति की रूपरेखा
- प्रस्तुति कोर
- Milcore
presentation framework और यह presentation core प्रबंधित कोड में लिखा गया है। Milcore अप्रबंधित कोड का एक हिस्सा है जो डायरेक्टएक्स (प्रदर्शन और प्रतिपादन के लिए जिम्मेदार) के साथ तंग एकीकरण की अनुमति देता है। CLR मेमोरी फीचर्स, एरर हैंडलिंग आदि जैसे कई फीचर्स देकर डेवलपमेंट प्रोसेस को और अधिक प्रोडक्टिव बनाता है।
WPF - लाभ
पहले के GUI फ्रेमवर्क में, कोई वास्तविक जुदाई नहीं थी कि कोई एप्लिकेशन कैसा दिखता है और यह कैसे व्यवहार करता है। GUI और व्यवहार दोनों को एक ही भाषा में बनाया गया था, जैसे C # या VB.Net जिसे डेवलपर से अधिक प्रयास करने की आवश्यकता होगी ताकि वह UI और उसके साथ जुड़े व्यवहार को कार्यान्वित कर सके।
WPF में, UI तत्वों को XAML में डिज़ाइन किया गया है जबकि व्यवहार को प्रक्रियात्मक भाषाओं जैसे C # और VB.Net में लागू किया जा सकता है। इसलिए डिजाइनर कोड से व्यवहार को अलग करना बहुत आसान है।
XAML के साथ, प्रोग्रामर डिजाइनरों के साथ समानांतर में काम कर सकते हैं। एक जीयूआई और इसके व्यवहार के बीच अलगाव हमें शैलियों और टेम्पलेट्स का उपयोग करके नियंत्रण के रूप को आसानी से बदलने की अनुमति दे सकता है।
WPF - सुविधाएँ
WPF विंडोज एप्लिकेशन बनाने के लिए एक शक्तिशाली ढांचा है। यह कई बेहतरीन विशेषताओं का समर्थन करता है, जिनमें से कुछ नीचे सूचीबद्ध किए गए हैं -
फ़ीचर | विवरण |
---|---|
एक नियंत्रण के अंदर नियंत्रण | सामग्री के रूप में किसी अन्य नियंत्रण के अंदर एक नियंत्रण को परिभाषित करने की अनुमति देता है। |
अनिवार्य तथ्य | यूआई तत्वों और उपयोगकर्ता इंटरफ़ेस पर डेटा ऑब्जेक्ट के बीच डेटा को प्रदर्शित करने और बातचीत करने के लिए तंत्र। |
मीडिया सेवाएं | छवियों, ऑडियो और वीडियो जैसे आम मीडिया तत्वों के साथ उपयोगकर्ता इंटरफेस के निर्माण के लिए एक एकीकृत प्रणाली प्रदान करता है। |
टेम्पलेट्स | WPF में आप सीधे टेम्पलेट के साथ एक तत्व के रूप को परिभाषित कर सकते हैं |
एनिमेशन | उपयोगकर्ता इंटरफ़ेस पर सहभागिता और आंदोलन का निर्माण |
वैकल्पिक इनपुट | विंडोज 7 और इसके बाद के संस्करण पर मल्टी-टच इनपुट का समर्थन करता है। |
Direct3D | अधिक जटिल ग्राफिक्स और कस्टम थीम प्रदर्शित करने की अनुमति देता है |
Microsoft WPF अनुप्रयोग विकास के लिए दो महत्वपूर्ण उपकरण प्रदान करता है।
- दृश्य स्टूडियो
- अभिव्यक्ति मिश्रण
दोनों उपकरण WPF प्रोजेक्ट्स बना सकते हैं, लेकिन तथ्य यह है कि विज़ुअल स्टूडियो का उपयोग डेवलपर्स द्वारा अधिक किया जाता है, जबकि ब्लेंड डिजाइनरों द्वारा अधिक बार उपयोग किया जाता है। इस ट्यूटोरियल के लिए, हम ज्यादातर विजुअल स्टूडियो का उपयोग करेंगे।
इंस्टालेशन
Microsoft Visual Studio का एक निःशुल्क संस्करण प्रदान करता है जिसे VisualStudio से डाउनलोड किया जा सकता है ।
अपने सिस्टम पर WPF अनुप्रयोग विकास वातावरण सेट करने के लिए फ़ाइलों को डाउनलोड करें और नीचे दिए गए चरणों का पालन करें।
डाउनलोड पूरा होने के बाद, चलाएँ installer। निम्नलिखित संवाद प्रदर्शित किया जाएगा।
दबाएं Install बटन और यह स्थापना प्रक्रिया शुरू कर देगा।
एक बार स्थापना प्रक्रिया सफलतापूर्वक पूरी हो जाने के बाद, आपको निम्नलिखित संवाद बॉक्स देखने को मिलेगा।
इस संवाद बॉक्स को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।
अब स्टार्ट मेनू से विजुअल स्टूडियो खोलें जो निम्नलिखित डायलॉग बॉक्स को खोलेगा।
- एक बार जब सब हो जाता है, तो आप विजुअल स्टूडियो की मुख्य विंडो देखेंगे।
अब आप अपना पहला WPF एप्लिकेशन बनाने के लिए तैयार हैं।
इस अध्याय में, हम एक सरल हैलो वर्ल्ड डब्ल्यूपीएफ एप्लिकेशन विकसित करेंगे। तो चलिए नीचे दिए गए चरणों का पालन करके सरल कार्यान्वयन शुरू करते हैं।
- फ़ाइल> नया> प्रोजेक्ट मेनू विकल्प पर क्लिक करें।
- निम्नलिखित संवाद बॉक्स प्रदर्शित किया जाएगा।
टेम्प्लेट के तहत, विज़ुअल C # और मध्य पैनल में, WPF एप्लिकेशन चुनें।
प्रोजेक्ट को कोई नाम दें। प्रकारHelloWorld नाम फ़ील्ड में और ठीक बटन पर क्लिक करें।
डिफ़ॉल्ट रूप से, दो फ़ाइलें बनाई जाती हैं, एक है XAML फ़ाइल (mainwindow.xaml) और अन्य एक है CS फ़ाइल (mainwindow.cs)
Mainwindow.xaml पर, आपको दो उप-विंडो दिखाई देंगी, एक है design window और दूसरा एक है source (XAML) window।
WPF एप्लिकेशन में, आपके एप्लिकेशन के लिए UI डिज़ाइन करने के दो तरीके हैं। एक यूआई तत्वों को टूलबॉक्स से डिज़ाइन विंडो में बस खींचें और छोड़ना है। दूसरा तरीका यूआई तत्वों के लिए एक्सएएमएल टैग लिखकर अपने यूआई को डिजाइन करना है। विजुअल स्टूडियो XAML टैग्स को हैंडल करता है जब UI डिजाइनिंग के लिए ड्रैग एंड ड्रॉप फीचर का इस्तेमाल किया जाता है।
Mainwindow.xaml फ़ाइल में, निम्न XAML टैग डिफ़ॉल्ट रूप से लिखे गए हैं।
<Window x:Class = "HelloWorld.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>
</Grid>
</Window>
- डिफ़ॉल्ट रूप से, एक ग्रिड पृष्ठ के बाद पहले तत्व के रूप में सेट किया जाता है।
- आइए टूलबॉक्स पर जाएं और एक टेक्स्टब्लॉक को डिज़ाइन विंडो पर खींचें।
- आपको डिज़ाइन विंडो पर TextBlock दिखाई देगा।
जब आप स्रोत विंडो को देखते हैं, तो आप देखेंगे कि विज़ुअल स्टूडियो ने आपके लिए टेक्स्टब्लॉक का XAML कोड तैयार किया है।
चलिए TextBlock से Hello World में TextBlock के टेक्स्ट प्रॉपर्टी को XAML कोड में बदलते हैं।
<Window x:Class = "HelloWorld.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>
<TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"
Margin = "235,143,0,0" TextWrapping = "Wrap" Text = "Hello World!"
VerticalAlignment = "Top" Height = "44" Width = "102" />
</Grid>
</Window>
- अब, आप डिज़ाइन विंडो पर भी बदलाव देखेंगे।
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
बधाई हो! आपने अपना पहला WPF एप्लिकेशन डिज़ाइन और बनाया है।
WPF के साथ काम करने के दौरान आपके सामने आने वाली पहली चीजों में से एक XAML है। XAML का मतलब एक्स्टेंसिबल एप्लिकेशन मार्कअप लैंग्वेज है। यह XML पर आधारित एक सरल और घोषित भाषा है।
XAML में, पदानुक्रमित संबंधों के साथ वस्तुओं के गुणों को बनाना, शुरू करना और सेट करना बहुत आसान है।
यह मुख्य रूप से GUIs को डिजाइन करने के लिए उपयोग किया जाता है, हालांकि इसका उपयोग अन्य उद्देश्यों के लिए भी किया जा सकता है, उदाहरण के लिए, वर्कफ़्लो फ़ाउंडेशन में वर्कफ़्लो घोषित करने के लिए।
बेसिक सिंटेक्स
जब आप अपना नया WPF प्रोजेक्ट बनाते हैं, तो आप नीचे दिखाए गए MainWindow.xaml में डिफ़ॉल्ट रूप से कुछ XAML कोड का सामना करेंगे।
<Window x:Class = "Resources.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "525">
<Grid>
</Grid>
</Window>
उपरोक्त XAML फ़ाइल में विभिन्न प्रकार की जानकारी है। निम्न तालिका संक्षेप में प्रत्येक जानकारी की भूमिका बताती है।
जानकारी | विवरण |
---|---|
<विंडो | यह मूल का प्रारंभिक वस्तु तत्व या कंटेनर है। |
x: वर्ग = "संसाधन। मेनविन्दो" | यह एक आंशिक वर्ग घोषणा है जो मार्कअप को आंशिक रूप से परिभाषित आंशिक वर्ग कोड से जोड़ता है। |
xmlns = "http://schemas.microsoft.com/win fx / 2006 / xaml / प्रस्तुति" | WPF क्लाइंट / फ्रेमवर्क के लिए डिफ़ॉल्ट XAML नामस्थान को मैप करें |
xmlns: x = "http://schemas.microsoft.com/w infx / 2006 / xaml" | XAML भाषा के लिए XAML नामस्थान जो इसे x: उपसर्ग में मैप करता है |
> | जड़ के वस्तु तत्व का अंत |
<ग्रिड> </ ग्रिड> |
यह एक खाली ग्रिड ऑब्जेक्ट के टैग को शुरू करना और बंद करना है। |
</ विंडो> | वस्तु तत्व को बंद करना |
XAML के लिए वाक्यविन्यास नियम लगभग XML के समान है। यदि आप एक XAML दस्तावेज़ को देखते हैं, तो आप ध्यान देंगे कि यह वास्तव में एक वैध XML फ़ाइल है, लेकिन XML फ़ाइल आवश्यक रूप से XAML फ़ाइल नहीं है। ऐसा इसलिए है क्योंकि एक्सएमएल में एक्सएएमएल में विशेषताओं का मूल्य एक स्ट्रिंग होना चाहिए, यह एक अलग वस्तु हो सकती है जिसे संपत्ति तत्व सिंटैक्स के रूप में जाना जाता है।
ऑब्जेक्ट तत्व का सिंटैक्स बाएं कोण ब्रैकेट (<) के साथ शुरू होता है, जिसके बाद ऑब्जेक्ट का नाम होता है, जैसे बटन।
उस वस्तु तत्व के कुछ गुणों और विशेषताओं को परिभाषित करें।
ऑब्जेक्ट तत्व को आगे की ओर स्लैश (/) द्वारा बंद किया जाना चाहिए, जिसके तुरंत बाद एक समकोण कोष्ठक (>) होगा।
बिना बाल तत्व वाली सरल वस्तु का उदाहरण
<Button/>
कुछ विशेषताओं के साथ वस्तु तत्व का उदाहरण
<Button Content = "Click Me" Height = "30" Width = "60" />
एक वैकल्पिक सिंटैक्स का उदाहरण गुणों को परिभाषित करता है (संपत्ति तत्व सिंटैक्स)
<Button>
<Button.Content>Click Me</Button.Content>
<Button.Height>30</Button.Height>
<Button.Width>60</Button.Width>
</Button>
बाल तत्व के साथ वस्तु का उदाहरण: StackPanel में बाल तत्व के रूप में टेक्स्टब्लॉक है
<StackPanel Orientation = "Horizontal">
<TextBlock Text = "Hello"/>
</StackPanel>
WPF में XAML क्यों
एक्सएएमएल न केवल डब्ल्यूपीएफ की सबसे व्यापक रूप से ज्ञात विशेषता है, बल्कि यह सबसे गलतफहमी सुविधाओं में से एक है। यदि आपके पास WPF के संपर्क में है, तो आपने XAML के बारे में सुना होगा; लेकिन XAML के बारे में निम्नलिखित दो कम ज्ञात तथ्यों पर ध्यान दें -
- WPF को XAML की आवश्यकता नहीं है
- XAML को WPF की आवश्यकता नहीं है
वे वास्तव में प्रौद्योगिकी के वियोज्य टुकड़े हैं। यह समझने के लिए कि यह कैसे हो सकता है, आइए एक सरल उदाहरण देखें जिसमें XAML में कुछ गुणों के साथ एक बटन बनाया गया है।
<Window x:Class = "WPFXAMLOverview.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "604">
<StackPanel>
<Button x:Name = "button" Content = "Click Me" HorizontalAlignment = "Left"
Margin = "150" VerticalAlignment = "Top" Width = "75" />
</StackPanel>
</Window>
यदि आप WPF में XAML का उपयोग नहीं करने का विकल्प चुनते हैं, तो आप प्रक्रियात्मक भाषा के साथ भी वही GUI परिणाम प्राप्त कर सकते हैं। आइए एक ही उदाहरण पर एक नज़र डालें, लेकिन इस बार, हम C # में एक बटन बनाएंगे।
using System.Windows;
using System.Windows.Controls;
namespace WPFXAMLOverview {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
// Create the StackPanel
StackPanel stackPanel = new StackPanel();
this.Content = stackPanel;
// Create the Button
Button button = new Button();
button.Content = "Click Me";
button.HorizontalAlignment = HorizontalAlignment.Left;
button.Margin = new Thickness(150);
button.VerticalAlignment = VerticalAlignment.Top;
button.Width = 75;
stackPanel.Children.Add(button);
}
}
}
जब आप XAML कोड या C # कोड को संकलित करते हैं और निष्पादित करते हैं, तो आपको नीचे दिखाए गए अनुसार समान आउटपुट दिखाई देगा।
उपरोक्त उदाहरण से, यह स्पष्ट है कि आप वस्तुओं के गुणों को बनाने, शुरू करने और सेट करने के लिए एक्सएएमएल में क्या कर सकते हैं, वही कार्य कोड का उपयोग करके भी किया जा सकता है।
XAML UI तत्वों को डिज़ाइन करने का एक और सरल और आसान तरीका है।
XAML के साथ, इसका मतलब यह नहीं है कि यूआई तत्वों को डिजाइन करने के लिए आप क्या कर सकते हैं। आप या तो XAML में ऑब्जेक्ट घोषित कर सकते हैं या कोड का उपयोग करके उन्हें परिभाषित कर सकते हैं।
XAML वैकल्पिक है, लेकिन इसके बावजूद, यह WPF डिज़ाइन के केंद्र में है।
XAML का लक्ष्य दृश्य डिजाइनरों को सीधे उपयोगकर्ता इंटरफ़ेस तत्व बनाने में सक्षम करना है।
WPF का लक्ष्य है कि उपयोगकर्ता इंटरफ़ेस के सभी दृश्य पहलुओं को मार्क-अप से नियंत्रित करना संभव है।
कई प्रौद्योगिकियां हैं जहां तत्वों और घटकों को एक पेड़ की संरचना में आदेश दिया जाता है ताकि प्रोग्रामर ऑब्जेक्ट को आसानी से संभाल सकें और किसी एप्लिकेशन के व्यवहार को बदल सकें। विंडोज प्रेजेंटेशन फाउंडेशन (WPF) में वस्तुओं के रूप में एक व्यापक वृक्ष संरचना है। डब्ल्यूपीएफ में, दो तरीके हैं जो एक पूर्ण वस्तु पेड़ की अवधारणा है -
- तार्किक वृक्ष संरचना
- दृश्य ट्री संरचना
इन ट्री संरचनाओं की मदद से, आप आसानी से UI तत्वों के बीच संबंध बना सकते हैं और पहचान सकते हैं। अधिकतर, WPF डेवलपर्स और डिज़ाइनर या तो एप्लिकेशन बनाने के लिए प्रक्रियात्मक भाषा का उपयोग करते हैं या XAML में ऑब्जेक्ट ट्री संरचना को ध्यान में रखते हुए एप्लिकेशन के UI भाग को डिज़ाइन करते हैं।
तार्किक वृक्ष संरचना
WPF अनुप्रयोगों में, XAML में UI तत्वों की संरचना तार्किक वृक्ष संरचना का प्रतिनिधित्व करती है। XAML में, UI के मूल तत्व डेवलपर द्वारा घोषित किए जाते हैं। WPF में तार्किक पेड़ निम्नलिखित को परिभाषित करता है -
- निर्भरता गुण
- स्थिर और गतिशील संसाधन
- इसके नाम आदि पर तत्वों को बांधना।
आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें एक बटन और एक सूची बॉक्स बनाया जाता है।
<Window x:Class = "WPFElementsTree.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "604">
<StackPanel>
<Button x:Name = "button" Height = "30" Width = "70" Content = "OK" Margin = "20" />
<ListBox x:Name = "listBox" Height = "100" Width = "100" Margin = "20">
<ListBoxItem Content = "Item 1" />
<ListBoxItem Content = "Item 2" />
<ListBoxItem Content = "Item 3" />
</ListBox>
</StackPanel>
</Window>
यदि आप XAML कोड को देखते हैं, तो आप एक ट्री संरचना का निरीक्षण करेंगे, अर्थात रूट नोड विंडो है और रूट नोड के अंदर केवल एक बच्चा है, वह है स्टैकपैनल। लेकिन स्टैकपैनल में दो बाल तत्व, बटन और सूची बॉक्स शामिल हैं। सूची बॉक्स में तीन और बाल सूची बॉक्स आइटम हैं।
दृश्य ट्री संरचना
WPF में, दृश्य वृक्ष की अवधारणा दृश्य वस्तुओं की संरचना का वर्णन करती है, जैसा कि दृश्य बेस क्लास द्वारा दर्शाया गया है। यह सभी UI तत्वों को दर्शाता है जो आउटपुट स्क्रीन पर दिए गए हैं।
जब कोई प्रोग्रामर किसी विशेष नियंत्रण के लिए टेम्पलेट बनाना चाहता है, तो वह वास्तव में उस नियंत्रण के दृश्य ट्री को प्रस्तुत कर रहा है। दृश्य पेड़ उन लोगों के लिए भी बहुत उपयोगी है जो प्रदर्शन और अनुकूलन कारणों के लिए निचले स्तर के नियंत्रण को आकर्षित करना चाहते हैं।
WPF अनुप्रयोगों में, दृश्य वृक्ष का उपयोग किया जाता है -
- दृश्य वस्तुओं का प्रतिपादन।
- लेआउट का प्रतिपादन।
- रूट किए गए ईवेंट ज्यादातर विज़ुअल ट्री के साथ-साथ चलते हैं, न कि लॉजिकल ट्री के साथ।
उपरोक्त सरल अनुप्रयोग के दृश्य पेड़ को देखने के लिए जिसमें एक बटन और एक सूची बॉक्स है, चलो XAML कोड को संकलित और निष्पादित करते हैं और आपको निम्न विंडो दिखाई देगी।
जब एप्लिकेशन चल रहा होता है, तो आप लाइव विजुअल ट्री विंडो में रनिंग एप्लिकेशन के विजुअल ट्री को देख सकते हैं जो इस एप्लिकेशन की पूरी पदानुक्रम को दिखाता है, जैसा कि नीचे दिखाया गया है।
विज़ुअल ट्री आम तौर पर लॉजिकल ट्री का सुपरसेट होता है। आप यहाँ देख सकते हैं कि दृश्य पेड़ में सभी तार्किक तत्व भी मौजूद हैं। तो ये दो पेड़ वास्तव में यूआई बनाने वाली वस्तुओं के एक ही सेट के दो अलग-अलग दृश्य हैं।
लॉजिकल ट्री बहुत सारी डिटेल निकलता है जिससे आप यूजर इंटरफेस की मुख्य संरचना पर ध्यान केंद्रित कर सकते हैं और इसे प्रस्तुत करने के तरीके के विवरण को अनदेखा कर सकते हैं।
लॉजिकल ट्री वह है जो आप यूजर इंटरफेस की मूल संरचना बनाने के लिए उपयोग करते हैं।
यदि आप प्रेजेंटेशन पर ध्यान केंद्रित कर रहे हैं, तो विज़ुअल ट्री दिलचस्पी का होगा। उदाहरण के लिए, यदि आप किसी भी UI तत्व की उपस्थिति को अनुकूलित करना चाहते हैं, तो आपको विज़ुअल ट्री का उपयोग करना होगा।
डब्ल्यूपीएफ अनुप्रयोगों में, निर्भरता संपत्ति एक विशिष्ट प्रकार की संपत्ति है जो सीएलआर संपत्ति का विस्तार करती है। यह WPF संपत्ति प्रणाली में उपलब्ध विशिष्ट प्रकार्य का लाभ उठाता है।
एक वर्ग जो एक निर्भरता संपत्ति को परिभाषित करता है, को विरासत में प्राप्त होना चाहिए DependencyObjectकक्षा। UI नियंत्रण वर्ग के कई जो XAML में उपयोग किए जाते हैं, से प्राप्त होते हैंDependencyObject वर्ग और वे निर्भरता गुणों का समर्थन करते हैं, जैसे बटन वर्ग समर्थन करता है IsMouseOver निर्भरता गुण।
निम्नलिखित XAML कोड कुछ गुणों के साथ एक बटन बनाता है।
<Window x:Class = "WPFDependencyProperty.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "clr-namespace:WPFDependencyProperty"
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। जब माउस बटन के ऊपर होता है, तो यह बटन के अग्रभूमि रंग को बदल देगा। जब माउस बटन छोड़ता है, तो यह अपने मूल रंग में बदल जाता है।
क्यों हमें निर्भरता गुणों की आवश्यकता है
डिपेंडेंसी प्रॉपर्टी आपको हर तरह के लाभ देती है जब आप इसे अपने आवेदन में इस्तेमाल करते हैं। डिपेंडेंसी प्रॉपर्टी एक CLR प्रॉपर्टी को निम्नलिखित परिदृश्य में उपयोग कर सकती है -
- अगर आप स्टाइल सेट करना चाहते हैं
- यदि आप डेटा बाइंडिंग चाहते हैं
- यदि आप एक संसाधन (एक स्थिर या एक गतिशील संसाधन) के साथ सेट करना चाहते हैं
- यदि आप एनीमेशन का समर्थन करना चाहते हैं
असल में, डिपेंडेंसी प्रॉपर्टीज बहुत सी कार्यक्षमता प्रदान करती हैं जो आपको सीएलआर प्रॉपर्टी का उपयोग करके नहीं मिलेगी।
के बीच मुख्य अंतर dependency properties और दूसरा CLR properties नीचे सूचीबद्ध हैं -
सीएलआर गुण सीधे कक्षा के निजी सदस्य से पढ़ / लिख सकते हैं getter तथा setter। इसके विपरीत, निर्भरता गुण स्थानीय ऑब्जेक्ट में संग्रहीत नहीं हैं।
निर्भरता गुणों को कुंजी / मूल्य जोड़े के एक शब्दकोश में संग्रहीत किया जाता है जो डिपेंडेंसीओबजेक्ट क्लास द्वारा प्रदान किया जाता है। यह बहुत सी मेमोरी को भी बचाता है क्योंकि यह परिवर्तित होने पर संपत्ति को संग्रहीत करता है। यह XAML में भी बाध्य हो सकता है।
कस्टम निर्भरता गुण
.NET फ्रेमवर्क में, कस्टम निर्भरता गुणों को भी परिभाषित किया जा सकता है। C # में कस्टम निर्भरता गुण को परिभाषित करने के लिए नीचे दिए गए चरणों का पालन करें।
घोषणा करें और अपना पंजीकरण करें dependency property सिस्टम कॉल रजिस्टर के साथ।
प्रदान करना setter तथा getter संपत्ति के लिए।
परिभाषित करें a static handler जो विश्व स्तर पर होने वाले किसी भी परिवर्तन को संभाल लेगा
परिभाषित करें a instance handler जो उस विशेष उदाहरण में होने वाले किसी भी परिवर्तन को संभाल लेंगे।
निम्न C # कोड सेट करने के लिए एक निर्भरता गुण को परिभाषित करता है SetText उपयोगकर्ता नियंत्रण की संपत्ति।
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>
आइए इस एप्लिकेशन को चलाते हैं। आप तुरंत देख सकते हैं कि हमारे मेनविंडो में, उपयोगकर्ता नियंत्रण के लिए निर्भरता संपत्ति को एक पाठ के रूप में सफलतापूर्वक उपयोग किया गया है।
ए routed eventएक प्रकार की घटना है जो एक वस्तु के पेड़ में कई श्रोताओं पर हैंडलर्स को आमंत्रित कर सकती है बजाय कि इस घटना को उठाए हुए। यह मूल रूप से एक सीएलआर घटना है जो रूटेड इवेंट क्लास के एक उदाहरण द्वारा समर्थित है। यह WPF इवेंट सिस्टम के साथ पंजीकृत है। RoutedEvents की तीन मुख्य रूटिंग रणनीतियाँ हैं जो इस प्रकार हैं -
- प्रत्यक्ष घटना
- बबलिंग इवेंट
- सुरंग घटना
प्रत्यक्ष घटना
एक प्रत्यक्ष घटना विंडोज रूपों की घटनाओं के समान है जो उस तत्व द्वारा उठाए जाते हैं जिसमें घटना उत्पन्न होती है।
एक मानक सीएलआर घटना के विपरीत, प्रत्यक्ष रूटिंग इवेंट्स क्लास हैंडलिंग का समर्थन करते हैं और इन्हें आपके कस्टम नियंत्रण की शैली के भीतर इवेंट सेटर्स और इवेंट ट्रिगर में उपयोग किया जा सकता है।
प्रत्यक्ष घटना का एक अच्छा उदाहरण माउसइंटर इवेंट होगा।
बबलिंग इवेंट
एक बुदबुदाती घटना उस तत्व से शुरू होती है जहां घटना की उत्पत्ति होती है। फिर यह दृश्य पेड़ के दृश्य पेड़ में सबसे ऊपरी तत्व तक जाता है। इसलिए, WPF में, सबसे ऊपरी तत्व एक खिड़की है।
सुरंग घटना
तत्व ट्री रूट पर ईवेंट हैंडलर मंगाए जाते हैं और फिर ईवेंट दृश्य ट्री को सभी बच्चों के नोड्स तक ले जाता है जब तक कि वह उस तत्व तक नहीं पहुंच जाता है जिसमें घटना की उत्पत्ति हुई थी।
बुदबुदाती और सुरंग खोदने वाली घटना के बीच का अंतर यह है कि सुरंग बनाने वाली घटना हमेशा पूर्वावलोकन के साथ शुरू होगी।
एक WPF आवेदन में, घटनाओं को अक्सर एक सुरंग बनाने / बुदबुदाती जोड़ी के रूप में लागू किया जाता है। तो, आपके पास एक पूर्वावलोकन माउसडाउन और फिर एक माउसडाउन इवेंट होगा।
नीचे दिए गए रूटेड इवेंट का एक सरल उदाहरण है जिसमें कुछ गुणों और घटनाओं के साथ एक बटन और तीन टेक्स्ट ब्लॉक बनाए जाते हैं।
<Window x:Class = "WPFRoutedEvents.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "450" Width = "604" ButtonBase.Click = "Window_Click" >
<Grid>
<StackPanel Margin = "20" ButtonBase.Click = "StackPanel_Click">
<StackPanel Margin = "10">
<TextBlock Name = "txt1" FontSize = "18" Margin = "5" Text = "This is a TextBlock 1" />
<TextBlock Name = "txt2" FontSize = "18" Margin = "5" Text = "This is a TextBlock 2" />
<TextBlock Name = "txt3" FontSize = "18" Margin = "5" Text = "This is a TextBlock 3" />
</StackPanel>
<Button Margin = "10" Content = "Click me" Click = "Button_Click" Width = "80"/>
</StackPanel>
</Grid>
</Window>
यहां बटन, स्टैकपैनल और विंडो के लिए क्लिक इवेंट कार्यान्वयन के लिए सी # कोड है।
using System.Windows;
namespace WPFRoutedEvents {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void Button_Click(object sender, RoutedEventArgs e) {
txt1.Text = "Button is Clicked";
}
private void StackPanel_Click(object sender, RoutedEventArgs e) {
txt2.Text = "Click event is bubbled to Stack Panel";
}
private void Window_Click(object sender, RoutedEventArgs e) {
txt3.Text = "Click event is bubbled to Window";
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा -
जब आप बटन पर क्लिक करते हैं, तो टेक्स्ट ब्लॉक अपडेट हो जाएंगे, जैसा कि नीचे दिखाया गया है।
यदि आप किसी विशेष स्तर पर रूट किए गए ईवेंट को रोकना चाहते हैं, तो आपको e.Handled = true सेट करना होगा;
चलो बदलते हैं StackPanel_Click नीचे दिखाए अनुसार घटना -
private void StackPanel_Click(object sender, RoutedEventArgs e) {
txt2.Text = "Click event is bubbled to Stack Panel";
e.Handled = true;
}
जब आप बटन पर क्लिक करते हैं, तो आप देखेंगे कि क्लिक इवेंट को विंडो में रूट नहीं किया जाएगा और स्टैकपैन पर रुक जाएगा और 3 आरडी टेक्स्ट ब्लॉक अपडेट नहीं किया जाएगा।
कस्टम रूटेड ईवेंट
.NET फ्रेमवर्क में, कस्टम रूट की गई घटना को भी परिभाषित किया जा सकता है। C # में एक कस्टम रूट की गई घटना को परिभाषित करने के लिए आपको नीचे दिए गए चरणों का पालन करने की आवश्यकता है।
अपने कॉल किए गए ईवेंट को सिस्टम कॉल RegisterRoutedEvent के साथ घोषित और पंजीकृत करें।
रूटिंग रणनीति, अर्थात बबल, टनल, या डायरेक्ट को निर्दिष्ट करें।
इवेंट हैंडलर प्रदान करें।
आइए, कस्टम रूट की गई घटनाओं के बारे में अधिक समझने के लिए एक उदाहरण लें। नीचे दिए गए चरणों का पालन करें -
WPFCustomRoutedEvent के साथ एक नया WPF प्रोजेक्ट बनाएं
अपने समाधान पर राइट क्लिक करें और Add> New Item ... चुनें
निम्न संवाद खुल जाएगा, अब चयन करें Custom Control (WPF) और इसे नाम दें MyCustomControl।
दबाएं Add बटन और आप देखेंगे कि आपके समाधान में दो नई फाइलें (थीम्स / 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:WPFCustomRoutedEvent">
<Style TargetType = "{x:Type local:MyCustomControl}">
<Setter Property = "Margin" Value = "50"/>
<Setter Property = "Template">
<Setter.Value>
<ControlTemplate TargetType = "{x:Type local:MyCustomControl}">
<Border Background = "{TemplateBinding Background}"
BorderBrush = "{TemplateBinding BorderBrush}"
BorderThickness = "{TemplateBinding BorderThickness}">
<Button x:Name = "PART_Button" Content = "Click Me" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</ResourceDictionary>
नीचे दिए गए के लिए C # कोड है MyCustomControl class जो विरासत में मिला है Control class जिसमें कस्टम कंट्रोल के लिए एक कस्टम रूटेड ईवेंट क्लिक बनाया जाता है।
using System.Windows;
using System.Windows.Controls;
namespace WPFCustomRoutedEvent {
public class MyCustomControl : Control {
static MyCustomControl() {
DefaultStyleKeyProperty.OverrideMetadata(typeof(MyCustomControl),
new FrameworkPropertyMetadata(typeof(MyCustomControl)));
}
public override void OnApplyTemplate() {
base.OnApplyTemplate();
//demo purpose only, check for previous instances and remove the handler first
var button = GetTemplateChild("PART_Button") as Button;
if (button ! = null)
button.Click + = Button_Click;
}
void Button_Click(object sender, RoutedEventArgs e) {
RaiseClickEvent();
}
public static readonly RoutedEvent ClickEvent =
EventManager.RegisterRoutedEvent("Click", RoutingStrategy.Bubble,
typeof(RoutedEventHandler), typeof(MyCustomControl));
public event RoutedEventHandler Click {
add { AddHandler(ClickEvent, value); }
remove { RemoveHandler(ClickEvent, value); }
}
protected virtual void RaiseClickEvent() {
RoutedEventArgs args = new RoutedEventArgs(MyCustomControl.ClickEvent);
RaiseEvent(args);
}
}
}
यहाँ C # में कस्टम रूटेड ईवेंट कार्यान्वयन है जो उपयोगकर्ता द्वारा क्लिक करने पर एक संदेश बॉक्स प्रदर्शित करेगा।
using System.Windows;
namespace WPFCustomRoutedEvent {
// <summary>
// Interaction logic for MainWindow.xaml
// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void MyCustomControl_Click(object sender, RoutedEventArgs e) {
MessageBox.Show("It is the custom routed event of your custom control");
}
}
}
यहां रूट किए गए ईवेंट क्लिक के साथ कस्टम नियंत्रण जोड़ने के लिए MainWindow.xaml में कार्यान्वयन है।
<Window x:Class = "WPFCustomRoutedEvent.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "clr-namespace:WPFCustomRoutedEvent"
Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<local:MyCustomControl Click = "MyCustomControl_Click" />
</Grid>
</Window>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित विंडो का उत्पादन करेगा जिसमें एक कस्टम नियंत्रण होता है।
जब आप कस्टम नियंत्रण पर क्लिक करते हैं, तो यह निम्न संदेश का उत्पादन करेगा।
विंडोज प्रेजेंटेशन फाउंडेशन (डब्ल्यूपीएफ) डेवलपर्स को आसानी से यूआई आधारित अनुप्रयोगों को आसानी से बनाने और बनाने की अनुमति देता है।
अन्य UI फ्रेमवर्क में शास्त्रीय UI तत्व या नियंत्रण WPF अनुप्रयोगों में भी बढ़ाए जाते हैं।
सभी मानक WPF नियंत्रण टूलबॉक्स में पाए जा सकते हैं जो System.Windows.Controls का एक हिस्सा है।
ये नियंत्रण XAML मार्कअप भाषा में भी बनाए जा सकते हैं।
WPF नियंत्रणों की पूर्ण विरासत पदानुक्रम निम्नानुसार हैं -
निम्न तालिका में नियंत्रणों की एक सूची है, जिसके बारे में हम बाद के अध्यायों में चर्चा करेंगे।
अनु क्रमांक। | नियंत्रण और विवरण |
---|---|
1 | बटन एक नियंत्रण जो उपयोगकर्ता इनपुट के प्रति प्रतिक्रिया करता है |
2 | पंचांग एक नियंत्रण का प्रतिनिधित्व करता है जो एक उपयोगकर्ता को एक दृश्य कैलेंडर डिस्प्ले का उपयोग करके एक तिथि का चयन करने में सक्षम बनाता है। |
3 | चेक बॉक्स एक नियंत्रण जो उपयोगकर्ता का चयन या स्पष्ट कर सकता है। |
4 | सम्मिश्रण पटी उन आइटमों की एक ड्रॉप-डाउन सूची, जिनसे कोई उपयोगकर्ता चयन कर सकता है। |
5 | संदर्भ की विकल्प - सूची संदर्भ मेनू तत्व हो जाता है या सेट हो जाता है जो इस तत्व के भीतर उपयोगकर्ता इंटरफ़ेस (UI) के माध्यम से संदर्भ मेनू से अनुरोध किया जाता है। |
6 | डेटा ग्रिड एक नियंत्रण का प्रतिनिधित्व करता है जो अनुकूलन ग्रिड में डेटा प्रदर्शित करता है। |
7 | खजूर बीनने वाला एक नियंत्रण जो उपयोगकर्ता को एक तिथि का चयन करने देता है। |
8 | संवाद एक एप्लिकेशन भी उपयोगकर्ता को इकट्ठा करने या महत्वपूर्ण जानकारी प्रदर्शित करने में मदद करने के लिए अतिरिक्त विंडो प्रदर्शित कर सकता है। |
9 | जाली देखना एक नियंत्रण जो पंक्तियों और स्तंभों में वस्तुओं का एक संग्रह प्रस्तुत करता है जो क्षैतिज रूप से स्क्रॉल कर सकते हैं। |
10 | छवि एक नियंत्रण जो एक छवि प्रस्तुत करता है। |
1 1 | लेबल प्रपत्र पर पाठ प्रदर्शित करता है। पहुँच कुंजी के लिए समर्थन प्रदान करता है। |
12 | सूची बाक्स एक नियंत्रण जो उन मदों की एक इनलाइन सूची प्रस्तुत करता है, जिसे उपयोगकर्ता चुन सकता है। |
13 | मेनू एक Windows मेनू नियंत्रण का प्रतिनिधित्व करता है जो आपको कमांड और ईवेंट हैंडलर से जुड़े तत्वों को पदानुक्रमित करने में सक्षम बनाता है। |
14 | PasswordBox पासवर्ड दर्ज करने के लिए एक नियंत्रण। |
15 | पॉप अप एप्लिकेशन विंडो के सीमा के भीतर, मौजूदा सामग्री के शीर्ष पर सामग्री प्रदर्शित करता है। |
16 | प्रगति पट्टी एक नियंत्रण जो एक बार प्रदर्शित करके प्रगति को इंगित करता है। |
17 | रेडियो बटन एक नियंत्रण जो उपयोगकर्ता को विकल्पों के समूह से एकल विकल्प का चयन करने की अनुमति देता है। |
18 | ScrollViewer एक कंटेनर नियंत्रण जो उपयोगकर्ता को पैन और उसकी सामग्री को ज़ूम करने देता है। |
19 | स्लाइडर एक नियंत्रण जो उपयोगकर्ता को एक ट्रैक के साथ एक अंगूठे नियंत्रण को स्थानांतरित करके मूल्यों की एक श्रृंखला से चुनने देता है। |
20 | TextBlock एक नियंत्रण जो पाठ प्रदर्शित करता है। |
21 | टॉगल बटन एक बटन जिसे 2 राज्यों के बीच टॉगल किया जा सकता है। |
22 | टूलटिप एक पॉप-अप विंडो जो किसी तत्व के लिए जानकारी प्रदर्शित करती है। |
23 | खिड़की रूट विंडो जो न्यूनतम / अधिकतम विकल्प, टाइटल बार, बॉर्डर और क्लोज बटन प्रदान करती है |
24 | 3 पार्टी नियंत्रण अपने WPF अनुप्रयोगों में तीसरे पक्ष के नियंत्रण का उपयोग करें। |
हम उनके कार्यान्वयन के साथ एक-एक करके इन सभी नियंत्रणों पर चर्चा करेंगे।
अनुप्रयोग प्रयोज्य के लिए नियंत्रण का लेआउट बहुत महत्वपूर्ण और महत्वपूर्ण है। इसका उपयोग आपके एप्लिकेशन में GUI तत्वों के समूह को व्यवस्थित करने के लिए किया जाता है। लेआउट पैनल का चयन करते समय कुछ महत्वपूर्ण बातों पर विचार करना चाहिए -
- बाल तत्वों की स्थिति
- बाल तत्वों का आकार
- एक-दूसरे के ऊपर बाल तत्वों को ओवरलैप करना
नियंत्रण के फिक्स्ड पिक्सेल व्यवस्था तब काम नहीं करती है जब एप्लिकेशन को विभिन्न स्क्रीन रिज़ॉल्यूशन पर sed होना है। XAML GUI तत्वों को उचित तरीके से व्यवस्थित करने के लिए अंतर्निहित लेआउट पैनल का एक समृद्ध सेट प्रदान करता है। सबसे अधिक इस्तेमाल किए जाने वाले और लोकप्रिय लेआउट पैनल में से कुछ इस प्रकार हैं -
अनु क्रमांक। | पैनल और विवरण |
---|---|
1 | स्टैक पैनल स्टैक पैनल एक्सएएमएल में एक सरल और उपयोगी लेआउट पैनल है। स्टैक पैनल में, ओरिएंटेशन प्रॉपर्टी के आधार पर, बाल तत्वों को एक पंक्ति में, क्षैतिज या लंबवत रूप से व्यवस्थित किया जा सकता है। |
2 | लपेटें पैनल WrapPanel में, ओरिएंटेशन प्रॉपर्टी के आधार पर बाल तत्व बाएं से दाएं या ऊपर से नीचे तक अनुक्रमिक क्रम में स्थित होते हैं। |
3 | डॉक पैनल DockPanel एक क्षेत्र को परिभाषित करता है कि वे बाल तत्वों को एक दूसरे के सापेक्ष व्यवस्थित करते हैं, या तो क्षैतिज या लंबवत। DockPanel के साथ आप आसानी से ऊपर, नीचे, दाएं, बाएं और केंद्र का उपयोग करके बाल तत्वों को डॉक कर सकते हैंDock संपत्ति। |
4 | कैनवस पैनल कैनवस पैनल बुनियादी लेआउट पैनल है जिसमें बच्चे के तत्वों को स्पष्ट रूप से निर्देशांक का उपयोग करके तैनात किया जा सकता है जो कि सापेक्ष हैं Canvas किसी भी पक्ष जैसे कि बाएं, दाएं, ऊपर और नीचे। |
5 | ग्रिड पैनल ग्रिड पैनल एक लचीला क्षेत्र प्रदान करता है जिसमें पंक्तियाँ और स्तंभ होते हैं। एक ग्रिड में, बाल तत्वों को सारणीबद्ध रूप में व्यवस्थित किया जा सकता है। |
लेआउट के नेस्टिंग का अर्थ है किसी अन्य लेआउट के अंदर उपयोग लेआउट पैनल, जैसे ग्रिड के अंदर स्टैक पैनल को परिभाषित करना। इस अवधारणा को व्यापक रूप से एक अनुप्रयोग में कई लेआउट के फायदे लेने के लिए उपयोग किया जाता है। निम्नलिखित उदाहरण में, हम एक ग्रिड के अंदर स्टैक पैनल का उपयोग करेंगे।
आइए निम्नलिखित XAML कोड पर एक नज़र डालें।
<Window x:Class = "WPFNestingLayouts.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:WPFNestingLayouts"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Grid Background = "AntiqueWhite">
<Grid.RowDefinitions>
<RowDefinition Height = "*" />
<RowDefinition Height = "*" />
<RowDefinition Height = "*" />
<RowDefinition Height = "*" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "*" />
</Grid.ColumnDefinitions>
<Label Content = "Employee Info" FontSize = "15"
FontWeight = "Bold" Grid.Column = "0" Grid.Row = "0"/>
<StackPanel Grid.Column = "0" Grid.Row = "1" Orientation = "Horizontal">
<Label Content = "Name" VerticalAlignment = "Center" Width = "70"/>
<TextBox Name = "txtName" Text = "Muhammad Ali" VerticalAlignment = "Center"
Width = "200">
</TextBox>
</StackPanel>
<StackPanel Grid.Column = "0" Grid.Row = "2" Orientation = "Horizontal">
<Label Content = "ID" VerticalAlignment = "Center" Width = "70"/>
<TextBox Name = "txtCity" Text = "421" VerticalAlignment = "Center"
Width = "50">
</TextBox>
</StackPanel>
<StackPanel Grid.Column = "0" Grid.Row = "3" Orientation = "Horizontal">
<Label Content = "Age" VerticalAlignment = "Center" Width = "70"/>
<TextBox Name = "txtState" Text = "32" VerticalAlignment = "Center"
Width = "50"></TextBox>
</StackPanel>
<StackPanel Grid.Column = "0" Grid.Row = "4" Orientation = "Horizontal">
<Label Content = "Title" VerticalAlignment = "Center" Width = "70"/>
<TextBox Name = "txtCountry" Text = "Programmer" VerticalAlignment = "Center"
Width = "200"></TextBox>
</StackPanel>
</Grid>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा।
हम अनुशंसा करते हैं कि आप उपरोक्त उदाहरण कोड निष्पादित करें और अन्य घोंसले के शिकार की कोशिश करें।
विंडोज प्रेजेंटेशन फाउंडेशन (WPF) एक शक्तिशाली एपीआई प्रदान करता है जिसकी मदद से एप्लिकेशन विभिन्न उपकरणों जैसे माउस, कीबोर्ड और टच पैनल से इनपुट प्राप्त कर सकते हैं। इस अध्याय में, हम निम्नलिखित प्रकार के इनपुट पर चर्चा करेंगे, जिन्हें WPF अनुप्रयोगों में संभाला जा सकता है -
अनु क्रमांक। | इनपुट और विवरण |
---|---|
1 | चूहा माउस इनपुट के विभिन्न प्रकार होते हैं जैसे माउसडाउन, माउसइंटर, माउसलेव, आदि। |
2 | कीबोर्ड कीबोर्ड इनपुट कई प्रकार के होते हैं जैसे कीडाउन, की-यूपी, टेक्स्टइनपुट, आदि। |
3 | कॉन्टेक्स्टमेन्यू या रूटेडकमैंड्स RoutedCommands अधिक सिमेंटिक स्तर पर इनपुट हैंडलिंग को सक्षम करता है। ये वास्तव में सरल निर्देश हैं जैसे कि न्यू, ओपन, कॉपी, कट और सेव। |
4 | मल्टीटच विंडोज 7 और इसके उच्च संस्करणों में कई टचसेंसेटिव उपकरणों से इनपुट प्राप्त करने की क्षमता है। WPF एप्लिकेशन स्पर्श इनपुट को अन्य इनपुट के रूप में भी संभाल सकते हैं, जैसे कि माउस या कीबोर्ड, जब टच होता है तो घटनाओं को बढ़ाकर। |
कमांड लाइन तर्क एक ऐसा तंत्र है जहां एक उपयोगकर्ता WPF अनुप्रयोग के मापदंडों या मूल्यों के एक सेट को पारित कर सकता है जब इसे निष्पादित किया जाता है। उदाहरण के लिए, बाहर से किसी एप्लिकेशन को नियंत्रित करने के लिए ये तर्क बहुत महत्वपूर्ण हैं, यदि आप कमांड प्रॉम्प्ट से वर्ड डॉक्यूमेंट खोलना चाहते हैं, तो आप इस कमांड का उपयोग कर सकते हैं ”C:\> start winword word1.docx”और यह खुल जाएगा word1.docx दस्तावेज़।
कमांड लाइन तर्क स्टार्टअप कार्य में संभाला जाता है। निम्नलिखित एक सरल उदाहरण है जो दिखाता है कि WPF आवेदन में कमांड लाइन तर्क कैसे पारित करें। आइए नाम के साथ एक नया WPF एप्लिकेशन बनाएंWPFCommandLine।
टूलबॉक्स से डिज़ाइन विंडो में एक टेक्स्टबॉक्स खींचें।
इस उदाहरण में, हम कमांड लाइन पैरामीटर के रूप में हमारे आवेदन के लिए एक txt फ़ाइल पथ पास करेंगे।
कार्यक्रम txt फ़ाइल को पढ़ेगा और फिर पाठ बॉक्स पर सभी पाठ लिख देगा।
निम्न XAML कोड एक पाठ बॉक्स बनाता है और इसे कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFCommandLine.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:WPFCommandLine"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<Grid>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left"
Height = "180" Margin = "100" TextWrapping = "Wrap"
VerticalAlignment = "Top" Width = "300"/>
</Grid>
</Window>
- अब नीचे दिखाए अनुसार App.xaml फ़ाइल में स्टार्टअप घटना की सदस्यता लें।
<Application x:Class = "WPFCommandLine.App"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "clr-namespace:WPFCommandLine"
StartupUri = "MainWindow.xaml" Startup = "app_Startup">
<Application.Resources>
</Application.Resources>
</Application>
नीचे दिए गए App.xaml.cs में app_Startup घटना का कार्यान्वयन है जिसे कमांड लाइन तर्क मिलेगा।
using System.Windows;
namespace WPFCommandLine {
/// <summary>
/// Interaction logic for App.xaml
/// </summary>
public partial class App : Application {
public static string[] Args;
void app_Startup(object sender, StartupEventArgs e) {
// If no command line arguments were provided, don't process them
if (e.Args.Length == 0) return;
if (e.Args.Length > 0) {
Args = e.Args;
}
}
}
}
अब, मेनविंडो क्लास में, प्रोग्राम txt फाइल को खोलेगा और टेक्स्टबॉक्स पर सभी टेक्स्ट लिखेगा।
यदि कुछ त्रुटि पाई जाती है, तो प्रोग्राम टेक्स्टबॉक्स पर एक त्रुटि संदेश प्रदर्शित करेगा।
using System;
using System.IO;
using System.Windows;
namespace WPFCommandLine {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
String[] args = App.Args;
try {
// Open the text file using a stream reader.
using (StreamReader sr = new StreamReader(args[0])) {
// Read the stream to a string, and write
// the string to the text box
String line = sr.ReadToEnd();
textBox.AppendText(line.ToString());
textBox.AppendText("\n");
}
}
catch (Exception e) {
textBox.AppendText("The file could not be read:");
textBox.AppendText("\n");
textBox.AppendText(e.Message);
}
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह एक टेक्स्टबॉक्स के साथ एक खाली विंडो का उत्पादन करेगा क्योंकि इस प्रोग्राम को कमांड लाइन तर्क की आवश्यकता है। इसलिए Visual Studio कमांड लाइन के मापदंडों के साथ अपने एप्लिकेशन को निष्पादित करने का एक आसान तरीका प्रदान करता है।
समाधान एक्सप्लोरर में अपनी WPF परियोजना पर राइट क्लिक करें और गुणों का चयन करें, यह निम्न विंडो प्रदर्शित करेगा।
डिबग विकल्प का चयन करें और कमांड लाइन तर्क में फ़ाइल पथ लिखें।
Test.txt के साथ एक txt फ़ाइल बनाएँ और उस फ़ाइल में कुछ पाठ लिखें और इसे किसी भी स्थान पर सहेजें। इस स्थिति में, txt फ़ाइल "D:\" हार्ड ड्राइव।
अपनी परियोजना में परिवर्तन सहेजें और अब अपने आवेदन को संकलित करें और निष्पादित करें। आपको टेक्स्टबॉक्स में वह टेक्स्ट दिखाई देगा, जो प्रोग्राम Text.txt फाइल से पढ़ता है।
अब चलो कोशिश करते हैं और अपनी मशीन से फ़ाइल का नाम बदलते हैं Test.txt सेवा Test1.txt और अपने प्रोग्राम को फिर से निष्पादित करें, फिर आपको टेक्स्ट बॉक्स में वह त्रुटि संदेश दिखाई देगा।
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और अपने आवेदन को सफलतापूर्वक निष्पादित करने के लिए सभी चरणों का पालन करें।
डब्ल्यूपीएफ अनुप्रयोगों में डेटा बाइंडिंग एक तंत्र है जो विंडोज रनटाइम ऐप्स को डेटा के साथ प्रदर्शित करने और बातचीत करने का एक सरल और आसान तरीका प्रदान करता है। इस तंत्र में, डेटा के प्रबंधन को पूरी तरह से डेटा से अलग किया जाता है।
डेटा बाध्यकारी यूआई तत्वों और उपयोगकर्ता इंटरफ़ेस पर डेटा ऑब्जेक्ट के बीच डेटा के प्रवाह की अनुमति देता है। जब कोई बंधन स्थापित होता है और डेटा या आपका व्यवसाय मॉडल बदलता है, तो यह UI तत्वों के लिए स्वचालित रूप से अपडेट को दर्शाता है और इसके विपरीत। यह मानक डेटा स्रोत के लिए नहीं, बल्कि पृष्ठ पर किसी अन्य तत्व से भी बाँधना संभव है।
डेटा बाइंडिंग दो प्रकार की होती है - one-way data binding तथा two-way data binding।
वन-वे डेटा बाइंडिंग
एक-तरफ़ा बाइंडिंग में, डेटा अपने स्रोत से बंधा होता है (वह ऑब्जेक्ट जो डेटा को रखता है) अपने लक्ष्य पर (वह ऑब्जेक्ट जो डेटा प्रदर्शित करता है)
आइए एक-तरफ़ा डेटा बाइंडिंग को विस्तार से समझने के लिए एक सरल उदाहरण लेते हैं। सबसे पहले, नाम के साथ एक नया WPF प्रोजेक्ट बनाएंWPFDataBinding।
निम्नलिखित XAML कोड दो लेबल, दो टेक्स्टबॉक्स और एक बटन बनाता है और उन्हें कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFDataBinding.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:WPFDataBinding"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<Label Name = "nameLabel" Margin = "2">_Name:</Label>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode = OneWay}"/>
<Label Name = "ageLabel" Margin = "2" Grid.Row = "1">_Age:</Label>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "2"
Text = "{Binding Age, Mode = OneWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click="Button_Click" />
</StackPanel>
</Grid>
</Window>
दोनों टेक्स्टबॉक्स के टेक्स्ट गुण "नाम" और "एज" से बाँधते हैं जो कि व्यक्ति वर्ग के वर्ग चर हैं जो नीचे दिखाया गया है।
व्यक्ति वर्ग में, हमारे पास केवल दो चर हैं Name तथा Age, और इसके ऑब्जेक्ट को इनिशियलाइज़ किया जाता है MainWindow कक्षा।
XAML कोड में, हम एक संपत्ति के नाम और आयु के लिए बाध्य कर रहे हैं, लेकिन हमने यह नहीं चुना है कि वह संपत्ति किस वस्तु की है।
किसी वस्तु को असाइन करने का आसान तरीका है DataContext जिनके गुण हम निम्नलिखित C # कोड में बांध रहे हैं MainWindowconstructor।
using System.Windows;
namespace WPFDataBinding {
public partial class MainWindow : Window {
Person person = new Person { Name = "Salman", Age = 26 };
public MainWindow() {
InitializeComponent();
this.DataContext = person;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = person.Name + " is " + person.Age;
MessageBox.Show(message);
}
}
public class Person {
private string nameValue;
public string Name {
get { return nameValue; }
set { nameValue = value; }
}
private double ageValue;
public double Age {
get { return ageValue; }
set {
if (value != ageValue) {
ageValue = value;
}
}
}
}
}
आइए इस एप्लिकेशन को चलाएं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हमने उस व्यक्ति के नाम और आयु के बारे में सफलतापूर्वक बाध्य कर दिया है।
जब तुम दबाओगे Show बटन, यह संदेश बॉक्स पर नाम और आयु प्रदर्शित करेगा।
नाम और आयु को संवाद बॉक्स में बदलें।
यदि आप अब Show बटन पर क्लिक करते हैं, तो यह फिर से उसी संदेश को प्रदर्शित करेगा।
ऐसा इसलिए है क्योंकि डेटा बाइंडिंग मोड XAML कोड में वन-वे पर सेट है। अपडेट किए गए डेटा को दिखाने के लिए, आपको दो-तरफ़ा डेटा बाइंडिंग को समझना होगा।
टू-वे डेटा बाइंडिंग
दो-तरफ़ा बाइंडिंग में, उपयोगकर्ता डेटा को उपयोगकर्ता इंटरफ़ेस के माध्यम से संशोधित कर सकता है और उस डेटा को स्रोत में अपडेट कर सकता है। यदि उपयोगकर्ता देखने के दौरान स्रोत बदलता है, तो आप चाहते हैं कि दृश्य अपडेट किया जाए।
चलो एक ही उदाहरण लेते हैं लेकिन यहां, हम XAML कोड में वन वे टू टू वे से बाइंडिंग मोड को बदल देंगे।
<Window x:Class = "WPFDataBinding.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:WPFDataBinding"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<Label Name = "nameLabel" Margin = "2">_Name:</Label>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "2"
Text = "{Binding Name, Mode = TwoWay}"/>
<Label Name = "ageLabel" Margin = "2" Grid.Row = "1">_Age:</Label>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "2"
Text = "{Binding Age, Mode = TwoWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "_Show..." Click = "Button_Click" />
</StackPanel>
</Grid>
</Window>
चलिए इस एप्लिकेशन को फिर से चलाते हैं।
यह एक ही आउटपुट का उत्पादन करेगा -
आइए अब नाम और आयु मान बदलें -
यदि आप अब Show बटन पर क्लिक करते हैं, तो यह अपडेट किया हुआ संदेश प्रदर्शित करेगा।
हम अनुशंसा करते हैं कि आप अवधारणा की बेहतर समझ के लिए दोनों मामलों के साथ उपरोक्त कोड निष्पादित करें।
संसाधन आम तौर पर कुछ ऑब्जेक्ट से जुड़ी परिभाषाएं हैं जिन्हें आप सिर्फ एक बार से अधिक बार उपयोग करने का अनुमान लगाते हैं। यह नियंत्रणों के लिए या वर्तमान विंडो के लिए या संपूर्ण अनुप्रयोगों के लिए वैश्विक स्तर पर डेटा को संग्रहीत करने की क्षमता है।
किसी वस्तु को संसाधन के रूप में परिभाषित करने से हम उसे दूसरी जगह से एक्सेस कर सकते हैं। इसका मतलब यह है कि वस्तु का पुन: उपयोग किया जा सकता है। संसाधनों को संसाधन शब्दकोशों में परिभाषित किया गया है और किसी भी वस्तु को एक संसाधन के रूप में परिभाषित किया जा सकता है जो प्रभावी रूप से इसे साझा करने योग्य संपत्ति बनाता है। एक XAML संसाधन के लिए एक अद्वितीय कुंजी निर्दिष्ट है और उस कुंजी के साथ, इसे StaticResource मार्कअप एक्सटेंशन का उपयोग करके संदर्भित किया जा सकता है।
संसाधन दो प्रकार के हो सकते हैं -
- StaticResource
- DynamicResource
StaticResource एक ऑनटाइम लुकअप है, जबकि एक डायनेमिकResource डेटा बाइंडिंग की तरह काम करता है। यह याद रखता है कि एक संपत्ति एक विशेष संसाधन कुंजी के साथ जुड़ी हुई है। यदि उस कुंजी से जुड़ी वस्तु बदल जाती है, तो गतिशील संसाधन लक्ष्य संपत्ति को अद्यतन करेगा।
उदाहरण
यहाँ SolidColorBrush संसाधन के लिए एक सरल अनुप्रयोग है।
आइए नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPFResouces।
दो आयतें खींचें और उनके गुण सेट करें जैसा कि निम्नलिखित XAML कोड में दिखाया गया है।
<Window x:Class = "WPFResources.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:WPFResources"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<Window.Resources>
<SolidColorBrush x:Key = "brushResource" Color = "Blue" />
</Window.Resources>
<StackPanel>
<Rectangle Height = "50" Margin = "20" Fill = "{StaticResource brushResource}" />
<Rectangle Height = "50" Margin = "20" Fill = "{DynamicResource brushResource}" />
<Button x:Name = "changeResourceButton"
Content = "_Change Resource" Click = "changeResourceButton_Click" />
</StackPanel>
</Window>
उपरोक्त XAML कोड में, आप देख सकते हैं कि एक आयत में StaticResource है और दूसरे में DynamicResource है और brushResource का रंग बिस्क है।
जब आप कोड संकलित और निष्पादित करते हैं, तो यह निम्नलिखित MainWindow का उत्पादन करेगा।
जब आप "संसाधन बदलें" बटन पर क्लिक करते हैं, तो आप देखेंगे कि डायनामिक स्रोत के साथ आयत अपने रंग को लाल में बदल देगा।
संसाधन स्कोप
संसाधनों में परिभाषित किया गया है resource dictionaries, लेकिन कई जगह हैं जहां एक संसाधन शब्दकोश को परिभाषित किया जा सकता है। उपरोक्त उदाहरण में, विंडो / पृष्ठ स्तर पर एक संसाधन शब्दकोश परिभाषित किया गया है। किस शब्दकोश में एक संसाधन परिभाषित किया गया है, तुरंत उस संसाधन के दायरे को सीमित करता है। इसलिए गुंजाइश, यानी जहां आप संसाधन का उपयोग कर सकते हैं, इस पर निर्भर करता है कि आपने इसे कहां परिभाषित किया है।
एक ग्रिड के संसाधन शब्दकोश में संसाधन को परिभाषित करें और यह केवल उस ग्रिड और उसके बाल तत्वों द्वारा सुलभ है।
इसे एक विंडो / पृष्ठ पर परिभाषित करें और यह उस विंडो / पृष्ठ पर सभी तत्वों द्वारा सुलभ है।
एप्लिकेशन रूट App.xaml संसाधनों शब्दकोश में पाया जा सकता है। यह हमारे आवेदन की जड़ है, इसलिए यहाँ परिभाषित संसाधन पूरे आवेदन के लिए तैयार हैं।
जहां तक संसाधन के दायरे का सवाल है, सबसे अधिक अक्सर अनुप्रयोग स्तर, पृष्ठ स्तर, और एक विशिष्ट तत्व स्तर जैसे ग्रिड, स्टैकपैनल, आदि होते हैं।
उपरोक्त एप्लिकेशन के पास इसकी विंडो / पृष्ठ स्तर में संसाधन हैं।
संसाधन शब्दकोश
XAML ऐप में रिसोर्स डिक्शनरी का मतलब है कि रिसोर्स डिक्शनरी को अलग-अलग फाइलों में रखा गया है। लगभग सभी XAML ऐप में इसका पालन किया जाता है। अलग-अलग फ़ाइलों में संसाधनों को परिभाषित करने के निम्नलिखित फायदे हो सकते हैं -
संसाधन शब्दकोश और UI संबंधित कोड में परिभाषित संसाधनों के बीच अलगाव।
App.xaml जैसे एक अलग फ़ाइल में सभी संसाधनों को परिभाषित करने से उन्हें ऐप में उपलब्ध कराया जाएगा।
तो, हम एक अलग फ़ाइल में संसाधन शब्दकोश में अपने संसाधनों को कैसे परिभाषित करते हैं? खैर, यह बहुत आसान है, बस नीचे दिए गए चरणों का पालन करके विज़ुअल स्टूडियो के माध्यम से एक नया संसाधन शब्दकोश जोड़ें -
अपने समाधान में, एक नया फ़ोल्डर जोड़ें और इसे नाम दें ResourceDictionaries।
इस फ़ोल्डर पर राइट-क्लिक करें और ऐड सबमेनू आइटम से संसाधन शब्दकोश का चयन करें और इसे नाम दें DictionaryWithBrush.xaml
उदाहरण
आइए अब एक ही उदाहरण लेते हैं, लेकिन यहां, हम एप्लिकेशन स्तर में संसाधन शब्दकोश को परिभाषित करेंगे। MainWindow.xaml के लिए XAML कोड निम्नानुसार है -
<Window x:Class = "WPFResources.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:WPFResources"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<StackPanel>
<Rectangle Height = "50" Margin = "20" Fill = "{StaticResource brushResource}" />
<Rectangle Height = "50" Margin = "20" Fill = "{DynamicResource brushResource}" />
<Button x:Name = "changeResourceButton"
Content = "_Change Resource" Click = "changeResourceButton_Click" />
</StackPanel>
</Window>
यहाँ DictionaryWrBrush.xaml में कार्यान्वयन है -
<ResourceDictionary xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml">
<SolidColorBrush x:Key = "brushResource" Color = "Blue" />
</ResourceDictionary>
यहाँ app.xaml में कार्यान्वयन है -
<Application x:Class="WPFResources.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>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
जब आप चेंज रिसोर्स बटन पर क्लिक करते हैं, तो आयत इसका रंग बदलकर लाल कर देगा।
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और कुछ और संसाधनों का प्रयास करें (उदाहरण के लिए, पृष्ठभूमि का रंग)।
एक टेम्पलेट एक नियंत्रण के समग्र रूप और दृश्य उपस्थिति का वर्णन करता है। प्रत्येक नियंत्रण के लिए, इसके साथ एक डिफ़ॉल्ट टेम्पलेट जुड़ा हुआ है जो नियंत्रण को अपनी उपस्थिति देता है। WPF अनुप्रयोगों में, आप आसानी से अपने खुद के टेम्प्लेट बना सकते हैं जब आप दृश्य व्यवहार और नियंत्रण के दृश्य उपस्थिति को अनुकूलित करना चाहते हैं।
तर्क और टेम्पलेट के बीच कनेक्टिविटी डेटा बाइंडिंग द्वारा प्राप्त की जा सकती है। के बीच मुख्य अंतरstyles तथा templates नीचे सूचीबद्ध हैं -
शैलियाँ केवल उस नियंत्रण के डिफ़ॉल्ट गुणों के साथ आपके नियंत्रण की उपस्थिति को बदल सकती हैं।
टेम्प्लेट के साथ, आप शैलियों की तुलना में नियंत्रण के अधिक हिस्सों तक पहुंच सकते हैं। आप एक नियंत्रण के मौजूदा और नए व्यवहार दोनों को भी निर्दिष्ट कर सकते हैं।
दो प्रकार के टेम्प्लेट हैं जो सबसे अधिक उपयोग किए जाते हैं -
- नियंत्रण टेम्पलेट
- डेटा टेम्प्लेट
नियंत्रण टेम्पलेट
नियंत्रण टेम्पलेट नियंत्रण की दृश्य उपस्थिति को परिभाषित करता है। यूआई तत्वों के सभी प्रकार के रूप में अच्छी तरह से व्यवहार है, जैसे, बटन एक उपस्थिति और व्यवहार है। क्लिक इवेंट या माउस हॉवर ईवेंट वे व्यवहार हैं, जो एक क्लिक और होवर के जवाब में निकाल दिए जाते हैं और बटन का डिफ़ॉल्ट रूप भी होता है जिसे नियंत्रण टेम्पलेट द्वारा बदला जा सकता है।
उदाहरण
एक सरल उदाहरण लेते हैं। हम दो बटन बनाएंगे (एक टेम्पलेट के साथ है और दूसरा डिफ़ॉल्ट बटन है) और उन्हें कुछ गुणों के साथ प्रारंभ करें।
<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 प्रदर्शित करेगा।
जब आप कस्टम टेम्प्लेट के साथ माउस को बटन पर ले जाते हैं, तो यह नीचे दिखाए गए अनुसार अपना रंग बदल देगा।
डेटा टेम्प्लेट
डेटा टेम्प्लेट डेटा के संग्रह की उपस्थिति और संरचना को परिभाषित और निर्दिष्ट करता है। यह किसी भी यूआई तत्व पर डेटा की प्रस्तुति को प्रारूपित करने और परिभाषित करने के लिए लचीलापन प्रदान करता है। इसका उपयोग ज्यादातर डेटा संबंधित आइटम नियंत्रणों जैसे कि कॉम्बो बॉक्स, लिस्टबॉक्स आदि पर किया जाता है।
उदाहरण
चलो डेटा टेम्पलेट की अवधारणा को समझने के लिए एक सरल उदाहरण लेते हैं। नाम के साथ एक नया WPF प्रोजेक्ट बनाएंWPFDataTemplates।
निम्नलिखित XAML कोड में, हम लेबल और टेक्स्टबॉक्स को रखने के लिए संसाधन के रूप में एक डेटा टेम्पलेट बनाएंगे। डेटा प्रदर्शित करने के लिए एक बटन और एक सूची बॉक्स भी है।
<Window x:Class = "WPFDataTemplates.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:WPFDataTemplates"
xmlns:loc = "clr-namespace:WPFDataTemplates"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<Window.Resources>
<DataTemplate DataType = "{x:Type loc:Person}">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<Label Name = "nameLabel" Margin = "10"/>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "10"
Text = "{Binding Name}"/>
<Label Name = "ageLabel" Margin = "10" Grid.Row = "1"/>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "10"
Text = "{Binding Age}"/>
</Grid>
</DataTemplate>
</Window.Resources>
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<ListBox ItemsSource = "{Binding}" />
<StackPanel Grid.Row = "1" >
<Button Content = "_Show..." Click = "Button_Click" Width = "80" HorizontalAlignment = "Left" Margin = "10"/>
</StackPanel>
</Grid>
</Window>
यहाँ है implementation in C# जिसमें व्यक्ति वस्तुओं की एक सूची DataContext को सौंपी जाती है, व्यक्ति वर्ग का कार्यान्वयन और बटन क्लिक घटना।
using System.Collections.Generic;
using System.Windows;
namespace WPFDataTemplates {
public partial class MainWindow : Window {
Person src = new Person { Name = "Ali", Age = 27 };
List<Person> people = new List<Person>();
public MainWindow() {
InitializeComponent();
people.Add(src);
people.Add(new Person { Name = "Mike", Age = 62 });
people.Add(new Person { Name = "Brian", Age = 12 });
this.DataContext = people;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = src.Name + " is " + src.Age;
MessageBox.Show(message);
}
}
public class Person {
private string nameValue;
public string Name {
get { return nameValue; }
set { nameValue = value; }
}
private double ageValue;
public double Age {
get { return ageValue; }
set {
if (value != ageValue) {
ageValue = value;
}
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। इसमें एक सूची होती है और सूची बॉक्स के अंदर, प्रत्येक सूची बॉक्स आइटम में व्यक्ति वर्ग ऑब्जेक्ट डेटा होता है जो लेबल और टेक्स्ट बॉक्स पर प्रदर्शित होते हैं।
.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 | आवेदन स्तर ऐप स्तर पर एक शैली को परिभाषित करना इसे पूरे एप्लिकेशन के दौरान सुलभ बना सकता है। चलो एक ही उदाहरण लेते हैं, लेकिन यहां, हम एप्लिकेशन में शैलियों को ऐप्लीकेशल फ़ाइल में डाल देंगे ताकि इसे पूरे एप्लिकेशन तक पहुंच योग्य बनाया जा सके। |
एक ट्रिगर मूल रूप से आपको संपत्ति के मूल्यों को बदलने या किसी संपत्ति के मूल्य के आधार पर कार्रवाई करने में सक्षम बनाता है। तो, यह आपको गतिशील रूप से एक नया निर्माण किए बिना अपने नियंत्रण की उपस्थिति और / या व्यवहार को बदलने की अनुमति देता है।
किसी भी संपत्ति के मूल्य को बदलने के लिए ट्रिगर का उपयोग किया जाता है, जब कुछ शर्तों को संतुष्ट किया जाता है। ट्रिगर आमतौर पर एक शैली में या उस दस्तावेज़ के मूल में परिभाषित किए जाते हैं जो उस विशिष्ट नियंत्रण पर लागू होते हैं। ट्रिगर तीन प्रकार के होते हैं -
- संपत्ति ट्रिगर
- डेटा ट्रिगर
- इवेंट ट्रिगर
संपत्ति ट्रिगर
प्रॉपर्टी ट्रिगर्स में, जब एक प्रॉपर्टी में बदलाव होता है, तो यह प्रॉपर्टी में तत्काल या एनिमेटेड बदलाव लाएगा। उदाहरण के लिए, जब आप बटन पर माउस को घुमाते हैं, तो बटन के स्वरूप को बदलने के लिए आप गुण ट्रिगर का उपयोग कर सकते हैं।
निम्न उदाहरण कोड दिखाता है कि जब बटन पर माउस लहराता है तो बटन के अग्रभूमि रंग को कैसे बदलना है।
<Window x:Class = "WPFPropertyTriggers.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 = "WPFDataTrigger.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>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -
जब आप चेकबॉक्स पर टिक करते हैं, तो टेक्स्ट ब्लॉक अपने अग्रभूमि रंग को लाल रंग में बदल देगा।
इवेंट ट्रिगर
जब कोई विशिष्ट ईवेंट निकाल दिया जाता है, तो ईवेंट ट्रिगर कुछ क्रियाएं करता है। आमतौर पर इस तरह के DoubleAnumatio, ColorAnimation, आदि नियंत्रण पर कुछ एनीमेशन को पूरा करने के लिए इसका उपयोग किया जाता है। निम्नलिखित उदाहरण में, हम एक साधारण बटन बनाएंगे। जब क्लिक ईवेंट को निकाल दिया जाता है, तो यह बटन की चौड़ाई और ऊंचाई का विस्तार करेगा।
<Window x:Class = "WPFEventTrigger.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>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा -
बटन पर क्लिक करने पर, आप देखेंगे कि यह दोनों आयामों में विस्तार करना शुरू कर देगा।
हम अनुशंसा करते हैं कि आप उपरोक्त उदाहरणों को संकलित और निष्पादित करें और ट्रिगर्स को अन्य गुणों के साथ भी लागू करें।
यह कोड के एक टुकड़े में बग या दोषों की पहचान करने और उन्हें ठीक करने का एक व्यवस्थित तंत्र है, जो आपसे अपेक्षा के अनुरूप व्यवहार नहीं कर रहे हैं। एक जटिल एप्लिकेशन को डिबग करना जहां सबसिस्टम कसकर युग्मित हैं, यह इतना आसान नहीं है, क्योंकि एक सबसिस्टम में बग को ठीक करने से दूसरे सबसिस्टम में बग बन सकते हैं।
सी # में डिबगिंग
WPF अनुप्रयोगों में, प्रोग्रामर दो भाषाओं जैसे C # और XAML से निपटते हैं। यदि आप किसी प्रक्रियात्मक भाषा जैसे कि C # या C / C ++ में डिबगिंग से परिचित हैं और आप ब्रेक पॉइंट के उपयोग को भी जानते हैं, तो आप अपने एप्लिकेशन के C # भाग को आसानी से डीबग कर सकते हैं।
आइए एक सरल उदाहरण लेते हैं कि C # कोड डिबग कैसे करें। नाम के साथ एक नया WPF प्रोजेक्ट बनाएंWPFDebuggingDemo। टूलबॉक्स से चार लेबल, तीन टेक्स्टबॉक्स और एक बटन खींचें। निम्नलिखित XAML कोड पर एक नज़र डालें।
<Window x:Class = "WPFDebuggingDemo.Window1"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "Window1" Height = "400" Width = "604">
<Grid>
<TextBox Height = "23" Margin = "0,44,169,0" Name = "textBox1"
VerticalAlignment = "Top" HorizontalAlignment = "Right" Width = "120" />
<TextBox Height = "23" Margin = "0,99,169,0" Name = "textBox2"
VerticalAlignment = "Top" HorizontalAlignment = "Right" Width = "120" />
<TextBox HorizontalAlignment = "Right" Margin = "0,153,169,0"
Name = "textBox3" Width = "120" Height = "23" VerticalAlignment = "Top" />
<Label Height = "28" Margin = "117,42,0,0" Name = "label1"
VerticalAlignment = "Top" HorizontalAlignment = "Left" Width = "120">
Item 1</Label>
<Label Height = "28" HorizontalAlignment = "Left"
Margin = "117,99,0,0" Name = "label2" VerticalAlignment = "Top" Width = "120">
Item 2</Label>
<Label HorizontalAlignment = "Left" Margin = "117,153,0,181"
Name = "label3" Width = "120">Item 3</Label>
<Button Height = "23" HorizontalAlignment = "Right" Margin = "0,0,214,127"
Name = "button1" VerticalAlignment = "Bottom" Width = "75"
Click = "button1_Click">Total</Button>
<Label Height = "28" HorizontalAlignment = "Right"
Margin = "0,0,169,66" Name = "label4" VerticalAlignment = "Bottom" Width = "120"/>
</Grid>
</Window>
नीचे दिया गया C # कोड है जिसमें एक बटन क्लिक इवेंट लागू किया गया है।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
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 WPFDebuggingDemo {
/// <summary>
/// Interaction logic for Window1.xaml
/// </summary>
public partial class Window1 : Window {
public Window1() {
InitializeComponent();
}
private void button1_Click(object sender, RoutedEventArgs e) {
if (textBox1.Text.Length > 0 && textBox2.Text.Length > 0 && textBox2.Text.Length > 0) {
double total = Convert.ToDouble(textBox1.Text) +
Convert.ToDouble(textBox2.Text) + Convert.ToDouble(textBox3.Text);
label4.Content = total.ToString();
}
else {
MessageBox.Show("Enter the value in all field.");
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। अब टेक्स्टबॉक्स में मान दर्ज करें और कुल बटन दबाएं। टेक्स्टबॉक्स में दर्ज सभी मानों के योग के बाद आपको कुल मूल्य मिलेगा।
यदि आप वास्तविक मूल्यों के अलावा अन्य मूल्यों को दर्ज करने का प्रयास करते हैं, तो उपरोक्त एप्लिकेशन क्रैश हो जाएगा। समस्या को खोजने और हल करने के लिए (यह दुर्घटनाग्रस्त क्यों है), आप बटन क्लिक घटना में ब्रेक पॉइंट सम्मिलित कर सकते हैं।
नीचे दिए गए अनुसार आइटम 1 में "एबीसी" लिखें।
कुल बटन पर क्लिक करने पर, आप देखेंगे कि कार्यक्रम विराम बिंदु पर बंद हो जाता है
अब टेक्स्टबॉक्स 1 की ओर कर्सर को ले जाएं। टेक्स्ट और आप देखेंगे कि प्रोग्राम जोड़ने की कोशिश कर रहा है abc अन्य मानों के कारण जो प्रोग्राम क्रैश कर रहा है।
XAML में डिबगिंग
यदि आप XAML में एक ही तरह के डिबगिंग की उम्मीद कर रहे हैं, तो आपको यह जानकर आश्चर्य होगा कि XAML कोड को डीबग करना अभी तक संभव नहीं है जैसे किसी अन्य प्रक्रियात्मक भाषा कोड को डीबग करना। जब आप 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();
}
}
}
आइए इस एप्लिकेशन को चलाएं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम सफलतापूर्वक उस कर्मचारी के शीर्षक से बंध गए हैं लेकिन नाम बाध्य नहीं है।
नाम के साथ क्या हुआ, यह जांचने के लिए, आइए आउटपुट विंडो में देखें, जहां बहुत अधिक लॉग जेनरेट होता है।
एक त्रुटि खोजने के लिए आसान बस त्रुटि की खोज करना है और आपको निम्न त्रुटि मिलेगी जो कहती है "बाइंडिंगएक्सप्रेशन पथ त्रुटि: 'FirstName' गुण 'ऑब्जेक्ट' 'Employe" पर नहीं मिला
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 को फिर से नाम में बदलते हैं, तो आप वांछित आउटपुट देखेंगे।
XAML के लिए UI डिबगिंग टूल
रनवे पर XAML कोड का निरीक्षण करने के लिए विजुअल स्टूडियो 2015 के साथ XAML के लिए UI डिबगिंग टूल पेश किए गए थे। इन उपकरणों की मदद से, XAML कोड आपके चल रहे WPF एप्लिकेशन के विज़ुअल ट्री के रूप में प्रस्तुत किया गया है और पेड़ में विभिन्न UI तत्व गुण भी हैं। इन उपकरणों को सक्षम करने के लिए, नीचे दिए गए चरणों का पालन करें।
- टूल मेनू पर जाएं और टूल मेनू से विकल्प चुनें।
- यह निम्नलिखित डायलॉग बॉक्स खोलेगा।
- बाईं ओर आइटम डीबगिंग के अंतर्गत सामान्य विकल्प पर जाएं।
- हाइलाइट किए गए विकल्प पर टिक करें, अर्थात, "XAML के लिए UI डिबगिंग उपकरण सक्षम करें" और ठीक बटन पर क्लिक करें।
अब कोई भी 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 के किसी पुराने विकल्प का उपयोग कर रहे हैं, तो आप इस टूल का उपयोग नहीं कर सकते, हालाँकि एक और उपकरण है जिसे Visual Studio जैसे XAML Spy for Visual Studio के साथ एकीकृत किया जा सकता है। । आप इसे xamlspy से डाउनलोड कर सकते हैं
WPF एप्लिकेशन कस्टम नियंत्रण बनाने की अनुमति देता है जो सुविधा संपन्न और अनुकूलन नियंत्रण बनाने में बहुत आसान बनाता है। कस्टम नियंत्रण का उपयोग तब किया जाता है जब Microsoft द्वारा प्रदान किए गए सभी अंतर्निहित नियंत्रण आपके मानदंडों को पूरा नहीं कर रहे हैं या आप तृतीय-पक्ष नियंत्रण के लिए भुगतान नहीं करना चाहते हैं।
इस अध्याय में, आप सीखेंगे कि कस्टम नियंत्रण कैसे बनाया जाए। इससे पहले कि हम कस्टम नियंत्रण पर एक नज़र रखना शुरू करें, चलो पहले उपयोगकर्ता नियंत्रण पर एक नज़र डालें।
उपयोगकर्ता नियंत्रण
उपयोगकर्ता नियंत्रण विभिन्न अंतर्निहित नियंत्रणों को एक साथ इकट्ठा करने और उन्हें संयोजित करने और उन्हें पुन: उपयोग करने योग्य XAML में पैकेज करने का एक तरीका प्रदान करते हैं। उपयोगकर्ता नियंत्रण का उपयोग निम्नलिखित परिदृश्यों में किया जाता है -
यदि नियंत्रण में मौजूदा नियंत्रण होते हैं, तो, आप पहले से मौजूद नियंत्रणों में से कई का एकल नियंत्रण बना सकते हैं।
यदि नियंत्रण को थीमिंग के लिए समर्थन की आवश्यकता नहीं है। उपयोगकर्ता नियंत्रण जटिल अनुकूलन, नियंत्रण टेम्पलेट्स और शैली के लिए मुश्किल का समर्थन नहीं करते हैं।
यदि कोई डेवलपर कोड-पीछे मॉडल का उपयोग करके नियंत्रण लिखना पसंद करता है, जहां एक दृश्य और फिर घटना संचालकों के लिए एक सीधा कोड होता है।
आप अनुप्रयोगों पर अपना नियंत्रण साझा नहीं करेंगे।
उदाहरण
चलो उपयोगकर्ता नियंत्रण के एक उदाहरण पर जाएं और नीचे दिए गए चरणों का पालन करें।
एक नया WPF प्रोजेक्ट बनाएं और फिर अपने समाधान पर राइट-क्लिक करें और Add> New Item चुनें ...
निम्न विंडो खुल जाएगी। अब सेलेक्ट करेंUser Control (WPF) और इसे MyUserControl नाम दें।
ऐड बटन पर क्लिक करें और आप देखेंगे कि आपके समाधान में दो नई फाइलें (MyUserControl.xaml और MyUserControl.cs) जोड़ी जाएंगी।
यहां XAML कोड है जिसमें एक बटन और एक टेक्स्ट बॉक्स MyUserControl.xaml फ़ाइल में कुछ गुणों के साथ बनाया गया है।
<UserControl x:Class = "WPFUserControl.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" Click = "button_Click" />
</Grid>
</UserControl>
नीचे दिए गए पाठ बॉक्स के अपडेट के लिए MyUserControl.cs फ़ाइल में बटन क्लिक घटना के लिए C # कोड है।
using System;
using System.Windows;
using System.Windows.Controls;
namespace WPFUserControl {
/// <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:WPFUserControl"
Title = "MainWindow" Height = "350" Width = "525">
<Grid>
<control:MyUserControl/>
</Grid>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा।
"मुझे क्लिक करें" बटन पर क्लिक करने पर, आप देखेंगे कि टेक्स्टबॉक्स के अंदर का पाठ अपडेट किया गया है।
कस्टम नियंत्रण
एक कस्टम नियंत्रण एक वर्ग है जो अपनी शैली और टेम्पलेट प्रदान करता है जो सामान्य रूप से जेनेरिक.एक्सामल में परिभाषित होते हैं। कस्टम नियंत्रण का उपयोग निम्नलिखित परिदृश्यों में किया जाता है -
यदि नियंत्रण मौजूद नहीं है और आपको इसे स्क्रैच से बनाना होगा।
यदि आप अपने विशिष्ट परिदृश्य को फिट करने के लिए एक अतिरिक्त संपत्ति या एक अतिरिक्त कार्यक्षमता जोड़कर एक preexisting नियंत्रण के लिए कार्यक्षमता बढ़ाना या जोड़ना चाहते हैं।
यदि आपके नियंत्रणों को थीमिंग और स्टाइलिंग का समर्थन करने की आवश्यकता है।
यदि आप अनुप्रयोगों पर अपना नियंत्रण साझा करना चाहते हैं।
उदाहरण
आइए एक उदाहरण लें कि कस्टम नियंत्रण कैसे काम करता है। एक नया WPF प्रोजेक्ट बनाएं और फिर अपने समाधान पर राइट-क्लिक करें और Add> New Item चुनें ...
यह निम्न विंडो खोलेगा। अब सेलेक्ट करेंCustom Control (WPF) और इसे नाम दें MyCustomControl।
Add बटन पर क्लिक करें और आप देखेंगे कि आपके समाधान में दो नई फाइलें (Themes / 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:WPFCustomControls">
<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 WPFCustomControls {
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 WPFCustomControls {
/// <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 = "WPFCustomControls.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:control = "clr-namespace:WPFCustomControls"
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>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह एक कस्टम नियंत्रण के साथ निम्न विंडो का उत्पादन करेगा जो एक अनुकूलित बटन है।
अनुकूलित बटन पर क्लिक करने पर, आप देखेंगे कि टेक्स्ट ब्लॉक के अंदर का टेक्स्ट अपडेट हो गया है।
एक अपवाद किसी भी त्रुटि की स्थिति या एक अप्रत्याशित व्यवहार है जो एक कार्यक्रम के निष्पादन के दौरान सामने आता है। अपवाद कई कारणों से उठाए जा सकते हैं, उनमें से कुछ इस प्रकार हैं -
अपने कोड या कोड में दोष जिसे आप कॉल करते हैं (जैसे कि एक साझा लाइब्रेरी),
अनुपलब्ध ऑपरेटिंग सिस्टम संसाधन,
अनपेक्षित स्थितियाँ जो एक सामान्य भाषा रनटाइम का सामना करती हैं (जैसे कि कोड जिसे सत्यापित नहीं किया जा सकता)
वाक्य - विन्यास
अपवादों में प्रोग्राम के प्रवाह को एक भाग से दूसरे भाग में स्थानांतरित करने की क्षमता होती है। .NET फ्रेमवर्क में, अपवाद हैंडलिंग में निम्नलिखित चार कीवर्ड हैं -
try - इस ब्लॉक में, प्रोग्राम एक निश्चित स्थिति की पहचान करता है जो कुछ अपवाद उठाता है।
catch- कैच कीवर्ड अपवाद को पकड़ने का संकेत देता है। एtry ब्लॉक एक या अधिक के बाद है catch एक प्रोग्राम में जगह पर एक अपवाद हैंडलर के साथ एक अपवाद को पकड़ने के लिए ब्लॉक जहां आप समस्या को संभालना चाहते हैं।
finally- अंततः ब्लॉक का उपयोग दिए गए कथनों के सेट को निष्पादित करने के लिए किया जाता है, चाहे कोई अपवाद फेंका जाए या नहीं। उदाहरण के लिए, यदि आप कोई फ़ाइल खोलते हैं, तो उसे बंद कर दिया जाना चाहिए, चाहे कोई अपवाद उठाया गया हो या नहीं।
throw- जब कोई समस्या दिखाई देती है तो एक प्रोग्राम एक अपवाद को फेंक देता है। यह एक थ्रो कीवर्ड का उपयोग करके किया जाता है।
इन चार कीवर्ड का उपयोग करने का सिंटैक्स निम्नानुसार है -
try {
///This will still trigger the exception
}
catch (ExceptionClassName e) {
// error handling code
}
catch (ExceptionClassName e) {
// error handling code
}
catch (ExceptionClassName e) {
// error handling code
}
finally {
// statements to be executed
}
मल्टीपल कैच स्टेटमेंट का इस्तेमाल उन मामलों में किया जाता है, जहां एक ट्रायल ब्लॉक प्रोग्राम फ्लो की स्थिति के आधार पर एक से अधिक अपवाद उठा सकता है।
अनुक्रम
.NET फ्रेमवर्क में लगभग सभी अपवाद वर्ग प्रत्यक्ष या अप्रत्यक्ष रूप से अपवाद वर्ग से प्राप्त होते हैं। अपवाद वर्ग से प्राप्त सबसे महत्वपूर्ण अपवाद वर्ग हैं -
ApplicationException class- यह उन अपवादों का समर्थन करता है जो कार्यक्रमों द्वारा उत्पन्न होते हैं। जब डेवलपर अपवाद को परिभाषित करना चाहता है तो वर्ग को इस वर्ग से लिया जाना चाहिए।
SystemException class- यह सभी पूर्वनिर्धारित रनटाइम सिस्टम अपवादों के लिए आधार वर्ग है। निम्न पदानुक्रम रनटाइम द्वारा प्रदान किए गए मानक अपवादों को दर्शाता है।
निम्न तालिका रनटाइम द्वारा प्रदान किए गए मानक अपवादों और उन स्थितियों को सूचीबद्ध करती है जिनके तहत आपको एक व्युत्पन्न वर्ग बनाना चाहिए।
अपवाद प्रकार | आधार प्रकार | विवरण |
---|---|---|
Exception | वस्तु | सभी अपवादों के लिए बेस क्लास। |
SystemException | अपवाद | सभी रनटाइम जनरेट त्रुटियों के लिए बेस क्लास। |
IndexOutOfRangeException | SystemException | किसी क्रम को अनुचित तरीके से अनुक्रमित करने पर ही रनटाइम द्वारा फेंका जाता है। |
NullReferenceException | SystemException | रनटाइम द्वारा केवल तभी फेंका जाता है जब किसी अशक्त वस्तु को संदर्भित किया जाता है। |
AccessViolationException | SystemException | रनटाइम द्वारा केवल तभी फेंका जाता है जब अमान्य मेमोरी एक्सेस की जाती है। |
InvalidOperationException | SystemException | अमान्य अवस्था में होने पर विधियों द्वारा फेंकें। |
ArgumentException | SystemException | सभी तर्क अपवादों के लिए आधार वर्ग। |
ArgumentNullException | ArgumentException | उन तरीकों से फेंको जो एक तर्क को शून्य होने की अनुमति नहीं देते हैं। |
ArgumentOutOfRangeException | ArgumentException | उन तरीकों से फेंकें जो यह सत्यापित करते हैं कि तर्क एक सीमा में हैं। |
ExternalException | SystemException | अपवाद के लिए बेस क्लास जो रनटाइम के बाहर के वातावरण में होती है या लक्षित होती है। |
SEHException | बाहरी अपवाद | अपवाद Win32 संरचित अपवाद जानकारी को संभालने से संरचित। |
उदाहरण
आइए अवधारणा को बेहतर ढंग से समझने के लिए एक सरल उदाहरण लेते हैं। नाम के साथ एक नया WPF प्रोजेक्ट बनाकर शुरू करेंWPFExceptionHandling।
टूलबॉक्स से डिज़ाइन विंडो में एक टेक्स्टबॉक्स खींचें। निम्न XAML कोड एक पाठ बॉक्स बनाता है और इसे कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFExceptionHandling.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:WPFExceptionHandling"
mc:Ignorable = "d"
Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left"
Height = "241" Margin = "70,39,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Width = "453"/>
</Grid>
</Window>
यहाँ C # में अपवाद हैंडलिंग के साथ फ़ाइल रीडिंग है।
using System;
using System.IO;
using System.Windows;
namespace WPFExceptionHandling {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
ReadFile(0);
}
void ReadFile(int index) {
string path = @"D:\Test.txt";
StreamReader file = new StreamReader(path);
char[] buffer = new char[80];
try {
file.ReadBlock(buffer, index, buffer.Length);
string str = new string(buffer);
str.Trim();
textBox.Text = str;
}
catch (Exception e) {
MessageBox.Show("Error reading from "+ path + "\nMessage = "+ e.Message);
}
finally {
if (file != null) {
file.Close();
}
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा जिसमें पाठ बॉक्स के अंदर एक पाठ प्रदर्शित होता है।
जब कोई अपवाद उठाया जाता है या आप इसे मैन्युअल रूप से (निम्न कोड में) फेंक देते हैं, तो यह त्रुटि के साथ एक संदेश बॉक्स दिखाएगा।
using System;
using System.IO;
using System.Windows;
namespace WPFExceptionHandling {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
ReadFile(0);
}
void ReadFile(int index) {
string path = @"D:\Test.txt";
StreamReader file = new StreamReader(path);
char[] buffer = new char[80];
try {
file.ReadBlock(buffer, index, buffer.Length);
string str = new string(buffer);
throw new Exception();
str.Trim();
textBox.Text = str;
}
catch (Exception e) {
MessageBox.Show("Error reading from "+ path + "\nMessage = "+ e.Message);
}
finally {
if (file != null) {
file.Close();
}
}
}
}
}
जब उपरोक्त कोड निष्पादित करते समय एक अपवाद उठाया जाता है, तो यह निम्नलिखित संदेश प्रदर्शित करेगा।
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और इसकी विशेषताओं के साथ प्रयोग करें।
स्थानीयकरण विशिष्ट संस्कृतियों के लिए स्थानीयकृत संस्करणों में अनुप्रयोग संसाधनों का अनुवाद है जो अनुप्रयोग का समर्थन करता है।
जब आप अपना एप्लिकेशन विकसित करते हैं और आपका एप्लिकेशन केवल एक भाषा में उपलब्ध होता है, तो आप अपने ग्राहकों की संख्या और अपने व्यवसाय के आकार को सीमित कर रहे हैं। यदि आप अपने ग्राहक आधार को बढ़ाना चाहते हैं जो आपके व्यवसाय को भी बढ़ाएगा, तो आपका उत्पाद वैश्विक दर्शकों के लिए उपलब्ध और उपलब्ध होना चाहिए। प्रभावी लागतlocalization आपके उत्पाद को अधिक ग्राहकों तक पहुंचाने के लिए सबसे अच्छे और सबसे किफायती तरीकों में से एक है।
WPF में, स्थानीय अनुप्रयोग बनाना आसान है resxफ़ाइल जो स्थानीयकरण के लिए सबसे सरल समाधान है। आइए यह समझने के लिए एक सरल उदाहरण लें कि यह कैसे काम करता है -
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPFLocalization।
आपके समाधान एक्सप्लोरर में, आपको Properties फ़ोल्डर के अंतर्गत Resources.resx फ़ाइल दिखाई देगी।
आंतरिक से सार्वजनिक तक पहुंच संशोधक को बदलें ताकि यह XAML फ़ाइल में सुलभ हो सके।
अब निम्नलिखित स्ट्रिंग का नाम और मान जोड़ें जो हम अपने आवेदन में उपयोग करेंगे।
Resources.enx.resx और Resources.ru-RU.resx नामों के साथ Resources.resx फ़ाइल की दो प्रतियां बनाएँ। ये भाषा और देश / क्षेत्र के नाम के लिए विशिष्ट नामकरण कर रहे हैं, और यह राष्ट्रीय भाषा समर्थन (एनएलएस) एपीआई के नाम पर पाया जा सकता है (https://msdn.microsoft.com/en-us/goglobal/bb896001.aspx ) पृष्ठ।
संसाधन.ru-RU.resx के मूल्यों को रूसी शब्दों में बदलें, जैसा कि नीचे दिखाया गया है।
आइए डिज़ाइन विंडो पर जाएं और तीन टेक्स्टबॉक्स, तीन लेबल और तीन बटन खींचें।
XAML फ़ाइल में, पहले स्थानीय संसाधनों का उपयोग करने के लिए नामस्थान घोषणा को जोड़ें xmlns: p = "clr-namespace: WPFLocalization.Properties"
सभी नियंत्रणों के गुणों को नीचे दिखाए अनुसार सेट करें। इस उदाहरण में, हम XAML फ़ाइल में लेबल, बटन और विंडो के शीर्षक की सामग्री के लिए हार्डकोड स्ट्रिंग्स का उपयोग नहीं करेंगे। हम उन स्ट्रिंग्स का उपयोग करेंगे जो * .resx फ़ाइलों में परिभाषित हैं। उदाहरण के लिए, खिड़की के शीर्षक के लिए, हम शीर्षक स्ट्रिंग का उपयोग करते हैं जो * .resx फ़ाइल में इस तरह परिभाषित है "शीर्षक =" {x: Static p: Resources.Title} ""
यहाँ XAML फ़ाइल है जिसमें विभिन्न गुणों के साथ नियंत्रण बनाए और बनाए गए हैं।
<Window x:Class = "WPFLocalization.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "clr-namespace:WPFLocalization"
xmlns:p = "clr-namespace:WPFLocalization.Properties"
Title = "{x:Static p:Resources.Title}" Height = "350" Width = "604">
<Grid>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left" Height = "23"
Margin = "128,45,0,0" TextWrapping = "Wrap" VerticalAlignment = "Top" Width = "304"/>
<Label x:Name = "label" Content = "{x:Static p:Resources.Name}"
HorizontalAlignment = "Left" Margin = "52,45,0,0" VerticalAlignment = "Top" Width = "86"/>
<TextBox x:Name = "textBox1" HorizontalAlignment = "Left" Height = "23"
Margin = "128,102,0,0" TextWrapping = "Wrap" VerticalAlignment = "Top" Width = "304"/>
<Label x:Name = "label1" Content = "{x:Static p:Resources.Address}"
HorizontalAlignment = "Left" Margin = "52,102,0,0" VerticalAlignment = "Top" Width = "86"/>
<TextBox x:Name = "textBox2" HorizontalAlignment = "Left" Height = "23"
Margin = "128,157,0,0" TextWrapping = "Wrap" VerticalAlignment = "Top" Width = "80"/>
<Label x:Name = "label2" Content = "{x:Static p:Resources.Age}"
HorizontalAlignment = "Left" Margin = "52,157,0,0" VerticalAlignment = "Top" Width = "86"/>
<Button x:Name = "button" Content = "{x:Static p:Resources.OK_Button}"
HorizontalAlignment = "Left" Margin = "163,241,0,0" VerticalAlignment = "Top" Width = "75"/>
<Button x:Name = "button1" Content = "{x:Static p:Resources.Cancel_Button}"
HorizontalAlignment = "Left" Margin = "282,241,0,0" VerticalAlignment = "Top" Width = "75"/>
<Button x:Name = "button2" Content = "{x:Static p:Resources.Help_Button}"
HorizontalAlignment = "Left" Margin = "392,241,0,0" VerticalAlignment = "Top" Width = "75"/>
</Grid>
</Window>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी जिसमें विभिन्न नियंत्रण शामिल हैं।
डिफ़ॉल्ट रूप से, प्रोग्राम डिफ़ॉल्ट Resources.resx का उपयोग करता है। यदि आप रूसी भाषा में पाठ दिखाना चाहते हैं जो Resources.ru-RU.resx फाइल में परिभाषित हैं, तो आपको प्रोग्राम को App.xaml फ़ाइल में शुरू होने पर स्पष्ट रूप से सेट करना होगा जैसा कि नीचे दिखाया गया है।
using System.Windows;
namespace WPFLocalization {
/// <summary>
/// Interaction logic for App.xaml
/// </summary>
public partial class App : Application {
App() {
System.Threading.Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo("ru-RU");
//System.Threading.Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo("en");
}
}
}
जब आप अपना एप्लिकेशन चलाते हैं, तो आपको रूसी भाषा में सभी पाठ दिखाई देंगे।
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और अन्य संस्कृतियों के लिए भी रेक्स फाइल बनाएं।
WPF में, एक इंटरैक्शन दिखाता है कि कैसे एक दृश्य उस दृश्य में स्थित नियंत्रणों के साथ सहभागिता करता है। सबसे आम तौर पर ज्ञात बातचीत दो प्रकार की होती है -
- Behaviors
- खींचें और छोड़ें
व्यवहार
व्यवहार को एक्सप्रेशन ब्लेंड 3 के साथ पेश किया गया था जो कार्यक्षमता के कुछ भाग को पुन: प्रयोज्य घटक में बदल सकता है। अतिरिक्त व्यवहार जोड़ने के लिए, आप इन घटकों को नियंत्रण में संलग्न कर सकते हैं। व्यवहार जटिल उपयोगकर्ता इंटरैक्शन को आसानी से डिज़ाइन करने के लिए अधिक लचीलापन प्रदान करते हैं।
आइए एक सरल उदाहरण पर एक नज़र डालें जिसमें एक ControlStoryBoardAction व्यवहार नियंत्रणों से जुड़ा हुआ है।
WPFBehavior नाम के साथ एक नया WPF प्रोजेक्ट बनाएं।
निम्नलिखित XAML कोड दीर्घवृत्त की गति को नियंत्रित करने के लिए एक दीर्घवृत्त और दो बटन बनाता है।
<Window
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:WPFBehaviors"
xmlns:i = "http://schemas.microsoft.com/expression/2010/interactivity"
xmlns:ei = "http://schemas.microsoft.com/expression/2010/interactions"
x:Class = "WPFBehaviors.MainWindow"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Window.Resources>
<Storyboard x:Key = "Storyboard1" RepeatBehavior = "Forever" AutoReverse = "True">
<DoubleAnimationUsingKeyFrames Storyboard.TargetProperty =
"(UIElement.RenderTransform).(TransformGroup.Children )[3].(TranslateTransform.X)"
Storyboard.TargetName = "ellipse">
<EasingDoubleKeyFrame KeyTime = "0:0:1" Value = "301.524"/>
<EasingDoubleKeyFrame KeyTime = "0:0:2" Value = "2.909"/>
</DoubleAnimationUsingKeyFrames>
<DoubleAnimationUsingKeyFrames Storyboard.TargetProperty =
"(UIElement.RenderTransform).(TransformGroup.Children )[3].(TranslateTransform.Y)"
Storyboard.TargetName = "ellipse">
<EasingDoubleKeyFrame KeyTime = "0:0:1" Value = "-0.485"/>
<EasingDoubleKeyFrame KeyTime = "0:0:2" Value = "0"/>
</DoubleAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty = "(ContentControl.Content)"
Storyboard.TargetName = "button">
<DiscreteObjectKeyFrame KeyTime = "0" Value = "Play"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty = "(ContentControl.Content)"
Storyboard.TargetName = "button1">
<DiscreteObjectKeyFrame KeyTime = "0" Value = "Stop"/>
<DiscreteObjectKeyFrame KeyTime = "0:0:2" Value = "Stop"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</Window.Resources>
<Window.Triggers>
<EventTrigger RoutedEvent = "FrameworkElement.Loaded">
<BeginStoryboard Storyboard = "{StaticResource Storyboard1}"/>
</EventTrigger>
</Window.Triggers>
<Grid>
<Ellipse x:Name = "ellipse" Fill = "#FFAAAAC5" HorizontalAlignment = "Left"
Height = "50.901" Margin = "49.324,70.922,0,0" Stroke = "Black"
VerticalAlignment = "Top" Width = "73.684" RenderTransformOrigin = "0.5,0.5">
<Ellipse.RenderTransform>
<TransformGroup>
<ScaleTransform/>
<SkewTransform/>
<RotateTransform/>
<TranslateTransform/>
</TransformGroup>
</Ellipse.RenderTransform>
</Ellipse>
<Button x:Name = "button" Content = "Play" HorizontalAlignment = "Left" Height = "24.238"
Margin = "63.867,0,0,92.953" VerticalAlignment = "Bottom" Width = "74.654">
<i:Interaction.Triggers>
<i:EventTrigger EventName = "Click">
<ei:ControlStoryboardAction Storyboard = "{StaticResource Storyboard1}"/>
</i:EventTrigger>
</i:Interaction.Triggers>
</Button>
<Button x:Name = "button1" Content = "Stop" HorizontalAlignment = "Left" Height = "24.239"
Margin = "160.82,0,0,93.922" VerticalAlignment = "Bottom" Width = "75.138">
<i:Interaction.Triggers>
<i:EventTrigger EventName = "Click">
<ei:ControlStoryboardAction ControlStoryboardOption = "Stop"
Storyboard = "{StaticResource Storyboard1}"/>
</i:EventTrigger>
</i:Interaction.Triggers>
</Button>
</Grid>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा जिसमें एक दीर्घवृत्त और दो बटन होते हैं।
जब आप प्ले बटन दबाते हैं, तो यह बाएं से दाएं की ओर बढ़ना शुरू कर देगा और फिर अपने मूल स्थान पर वापस आ जाएगा। स्टॉप बटन आंदोलन को दीर्घवृत्त रोक देगा।
खींचें और छोड़ें
यूजर इंटरफेस पर ड्रैग एंड ड्रॉप, एप्लिकेशन की दक्षता और उत्पादकता को काफी बढ़ा सकता है। बहुत कम एप्लिकेशन हैं जिनमें ड्रैग और ड्रॉप फीचर का उपयोग किया जाता है क्योंकि लोगों को लगता है कि इसे लागू करना मुश्किल है। एक हद तक, ड्रैग एंड ड्रॉप फीचर को संभालना मुश्किल है, लेकिन डब्ल्यूपीएफ में, आप इसे आसानी से संभाल सकते हैं।
आइए यह समझने के लिए एक सरल उदाहरण लें कि यह कैसे काम करता है। हम एक एप्लिकेशन बनाएंगे जिसमें आप एक आयत से दूसरे में रंग को खींच और छोड़ सकते हैं।
WPFDragAndDrop नाम से एक नया WPF प्रोजेक्ट बनाएं।
पांच आयतों को डिज़ाइन विंडो में खींचें और निम्न XAML फ़ाइल में दिखाए गए गुणों को सेट करें।
<Window x:Class = "WPFDragAndDrop.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:WPFDragAndDrop"
mc:Ignorable = "d" Title = "MainWindow" Height = "402.551" Width = "604">
<Grid>
<Rectangle Name = "Target" Fill = "AliceBlue" HorizontalAlignment = "Left"
Height = "345" Margin = "10,10,0,0" Stroke = "Black"
VerticalAlignment = "Top" Width = "387" AllowDrop = "True" Drop = "Target_Drop"/>
<Rectangle Fill = "Beige" HorizontalAlignment = "Left" Height = "65"
Margin = "402,10,0,0" Stroke = "Black" VerticalAlignment = "Top"
Width = "184" MouseLeftButtonDown = "Rect_MLButtonDown"/>
<Rectangle Fill = "LightBlue" HorizontalAlignment = "Left" Height = "65"
Margin = "402,80,0,0" Stroke = "Black" VerticalAlignment = "Top"
Width = "184" MouseLeftButtonDown = "Rect_MLButtonDown"/>
<Rectangle Fill = "LightCoral" HorizontalAlignment = "Left" Height = "65"
Margin = "402,150,0,0" Stroke = "Black" VerticalAlignment = "Top"
Width = "184" MouseLeftButtonDown = "Rect_MLButtonDown"/>
<Rectangle Fill = "LightGray" HorizontalAlignment = "Left" Height = "65"
Margin = "402,220,0,0" Stroke = "Black" VerticalAlignment = "Top"
Width = "184" MouseLeftButtonDown = "Rect_MLButtonDown"/>
<Rectangle Fill = "OliveDrab" HorizontalAlignment = "Left" Height = "65"
Margin = "402,290,0,-7" Stroke = "Black" VerticalAlignment = "Top"
Width = "184" MouseLeftButtonDown = "Rect_MLButtonDown"/>
</Grid>
</Window>
पहला आयत लक्ष्य आयत है, इसलिए उपयोगकर्ता रंग को दूसरी आयत से लक्ष्य आयत तक खींच सकता है।
नीचे दिए गए घटनाओं को C # में ड्रैग एंड ड्रॉप के लिए लागू किया गया है।
using System.Windows;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Shapes;
namespace WPFDragAndDrop {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void Rect_MLButtonDown(object sender, MouseButtonEventArgs e) {
Rectangle rc = sender as Rectangle;
DataObject data = new DataObject(rc.Fill);
DragDrop.DoDragDrop(rc, data,DragDropEffects.Move);
}
private void Target_Drop(object sender, DragEventArgs e) {
SolidColorBrush scb = (SolidColorBrush)e.Data.GetData(typeof(SolidColorBrush));
Target.Fill = scb;
}
}
}
जब आप अपना एप्लिकेशन चलाते हैं, तो यह निम्न विंडो का उत्पादन करेगा।
यदि आप दाईं ओर आयत से रंग खींचते हैं और इसे बड़ी आयत पर बाईं ओर छोड़ते हैं, तो आपको तुरंत इसका प्रभाव दिखाई देगा।
चलो दाईं ओर से 4 वें को खींचें ।
आप देख सकते हैं कि लक्ष्य आयत का रंग बदल गया है। हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और इसकी विशेषताओं के साथ प्रयोग करें।
WPF 2 डी ग्राफिक्स की एक विस्तृत श्रृंखला प्रदान करता है जिसे आपके आवेदन की आवश्यकताओं के अनुसार बढ़ाया जा सकता है। WPF ड्राइंग और शेप ऑब्जेक्ट दोनों को सपोर्ट करता है जो कि ग्राफिकल कंटेंट को ड्रॉ करने के लिए उपयोग किया जाता है।
आकृतियाँ और आरेखण
आकार वर्ग फ्रेमवर्क वर्ग से लिया गया है, आकृति वस्तुओं का उपयोग पैनलों और अधिकांश नियंत्रणों के अंदर किया जा सकता है।
WPF कुछ मूल आकार की वस्तुएं प्रदान करता है, जो आकार वर्ग से प्राप्त होती हैं जैसे कि Ellipse, Line, Path, Polygon, Polyline और Rectangle।
दूसरी ओर, ड्राइंग ऑब्जेक्ट्स, फ्रेमवर्क क्लीयरिटी क्लास से नहीं निकलते हैं और एक हल्का-वजन कार्यान्वयन प्रदान करते हैं।
आकृति ऑब्जेक्ट की तुलना में आरेखण ऑब्जेक्ट सरल होते हैं। उनके पास बेहतर प्रदर्शन विशेषताएँ भी हैं।
उदाहरण
आइए विभिन्न आकारों की वस्तु का उपयोग करने के तरीके को समझने के लिए एक सरल उदाहरण लेते हैं।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPF2DGraphics।
निम्न कोड विभिन्न प्रकार के आकार बनाता है।
<Window x:Class = "WPF2DGraphics.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:WPF2DGraphics"
xmlns:PresentationOptions = "http://schemas.microsoft.com/winfx/2006/xaml/present ation/options"
mc:Ignorable = "PresentationOptions" Title = "MainWindow" Height = "400" Width = "604">
<StackPanel>
<Ellipse Width = "100" Height = "60" Name = "sample" Margin = "10">
<Ellipse.Fill>
<RadialGradientBrush>
<GradientStop Offset = "0" Color = "AliceBlue"/>
<GradientStop Offset = "1" Color = "Gray"/>
<GradientStop Offset = "2" Color = "Red"/>
</RadialGradientBrush>
</Ellipse.Fill>
</Ellipse>
<Path Stroke = "Red" StrokeThickness = "5" Data = "M 10,70 L 200,70"
Height = "42.085" Stretch = "Fill" Margin = "140.598,0,146.581,0" />
<Path Stroke = "BlueViolet" StrokeThickness = "5" Data = "M 20,100 A 100,56 42 1 0 200,10"
Height = "81.316" Stretch = "Fill" Margin = "236.325,0,211.396,0" />
<Path Fill = "LightCoral" Margin = "201.424,0,236.325,0"
Stretch = "Fill" Height = "124.929">
<Path.Data>
<PathGeometry>
<PathFigure StartPoint = "50,0" IsClosed = "True">
<LineSegment Point = "100,50"/>
<LineSegment Point = "50,100"/>
<LineSegment Point = "0,50"/>
</PathFigure>
</PathGeometry>
</Path.Data>
</Path>
</StackPanel>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह एक दीर्घवृत्त, एक सीधी रेखा, एक चाप और एक बहुभुज का उत्पादन करेगा।
उदाहरण
आइए एक और उदाहरण पर एक नज़र डालें जो दिखाता है कि ड्राइंग के साथ एक क्षेत्र को कैसे चित्रित किया जाए।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPF2DGraphics1।
निम्नलिखित XAML कोड दिखाता है कि छवि ड्राइंग के साथ अलग-अलग पेंट कैसे करें।
<Window x:Class = "WPF2DGraphics1.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:PresentationOptions = "http://schemas.microsoft.com/winfx/2006/xaml/present ation/options"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "PresentationOptions"
xmlns:local = "clr-namespace:WPF2DGraphics1" Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<Border BorderBrush = "Gray" BorderThickness = "1"
HorizontalAlignment = "Left" VerticalAlignment = "Top"
Margin = "20">
<Image Stretch = "None">
<Image.Source>
<DrawingImage PresentationOptions:Freeze = "True">
<DrawingImage.Drawing>
<DrawingGroup>
<ImageDrawing Rect = "300,100,300,180" ImageSource = "Images\DSC_0104.JPG"/>
<ImageDrawing Rect = "0,100,250,100" ImageSource = "Images\DSC_0104.JPG"/>
<ImageDrawing Rect = "150,0,25,25" ImageSource = "Images\DSC_0104.JPG"/>
<ImageDrawing Rect = "0,0,75,75" ImageSource = "Images\DSC_0104.JPG"/>
</DrawingGroup>
</DrawingImage.Drawing>
</DrawingImage>
</Image.Source>
</Image>
</Border>
</Grid>
</Window>
जब आप अपना एप्लिकेशन चलाते हैं, तो यह निम्न आउटपुट का उत्पादन करेगा -
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और अधिक 2D आकार और आरेखण का प्रयास करें।
विंडोज प्रेजेंटेशन फाउंडेशन (WPF) आपके एप्लिकेशन की आवश्यकता के अनुसार 3D ग्राफिक्स को आकर्षित करने, बदलने और एनिमेट करने के लिए एक कार्यक्षमता प्रदान करता है। यह पूर्ण प्रवाह 3D गेम विकास का समर्थन नहीं करता है, लेकिन कुछ स्तर तक, आप 3D ग्राफिक्स बना सकते हैं।
2 डी और 3 डी ग्राफिक्स के संयोजन से, आप समृद्ध नियंत्रण भी बना सकते हैं, डेटा के जटिल चित्र प्रदान कर सकते हैं या किसी एप्लिकेशन के इंटरफ़ेस के उपयोगकर्ता अनुभव को बढ़ा सकते हैं। Viewport3D तत्व हमारे WPF एप्लिकेशन में एक 3D मॉडल होस्ट करता है।
उदाहरण
आइए 3 डी ग्राफिक्स का उपयोग करने के तरीके को समझने के लिए एक सरल उदाहरण लें।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPF3DGraphics।
निम्न XAML कोड दिखाता है कि 3D ज्यामिति का उपयोग करके 2 डी ऑब्जेक्ट कैसे बनाया जाए।
<Window x:Class = "WPF3DGraphics.MainWindow"
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:local = "clr-namespace:WPF3DGraphics"
mc:Ignorable = "d" Title = "MainWindow" Height = "500" Width = "604">
<Grid>
<Viewport3D>
<Viewport3D.Camera>
<PerspectiveCamera Position = "2,0,10" LookDirection = "0.2,0.4,-1"
FieldOfView = "65" UpDirection = "0,1,0" />
</Viewport3D.Camera>
<ModelVisual3D>
<ModelVisual3D.Content>
<Model3DGroup>
<AmbientLight Color = "Bisque" />
<GeometryModel3D>
<GeometryModel3D.Geometry>
<MeshGeometry3D Positions = "0,0,0 0,8,0 10,0,0 8,8,0"
Normals = "0,0,1 0,0,1 0,0,1 0,0,1" TriangleIndices = "0,2,1 1,2,3"/>
</GeometryModel3D.Geometry>
<GeometryModel3D.Material>
<DiffuseMaterial Brush = "Bisque" />
</GeometryModel3D.Material>
</GeometryModel3D>
</Model3DGroup>
</ModelVisual3D.Content>
</ModelVisual3D>
</Viewport3D>
</Grid>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह 3 डी में 2 डी ऑब्जेक्ट का उत्पादन करेगा।
उदाहरण
आइए एक और उदाहरण देखें जो एक 3 डी ऑब्जेक्ट दिखाता है।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPF3DGraphics1
निम्नलिखित XAML कोड एक 3D ऑब्जेक्ट और एक स्लाइडर बनाता है। स्लाइडर की मदद से आप इस 3D ऑब्जेक्ट को घुमा सकते हैं।
<Window x:Class = "WPF3DGraphics1.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:WPF3DGraphics1"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<Grid>
<Viewport3D Name="viewport3D1">
<Viewport3D.Camera>
<PerspectiveCamera x:Name = "camMain" Position = "6 5 4" LookDirection = "-6 -5 -4">
</PerspectiveCamera>
</Viewport3D.Camera>
<ModelVisual3D>
<ModelVisual3D.Content>
<DirectionalLight x:Name = "dirLightMain" Direction = "-1,-1,-1">
</DirectionalLight>
</ModelVisual3D.Content>
</ModelVisual3D>
<ModelVisual3D x:Name = "MyModel">
<ModelVisual3D.Content>
<GeometryModel3D>
<GeometryModel3D.Geometry>
<MeshGeometry3D x:Name = "meshMain"
Positions = "0 0 0 1 0 0 0 1 0 1 1 0 0 0 1 1 0 1 0 1 1 0 1 1"
TriangleIndices = "2 3 1 3 1 0 7 1 3 7 5 1 6 5 7 6 4 5 6 2 0
2 0 4 2 7 3 2 6 7 0 1 5 0 5 4">
</MeshGeometry3D>
</GeometryModel3D.Geometry>
<GeometryModel3D.Material>
<DiffuseMaterial x:Name = "matDiffuseMain">
<DiffuseMaterial.Brush>
<SolidColorBrush Color = "Bisque"/>
</DiffuseMaterial.Brush>
</DiffuseMaterial>
</GeometryModel3D.Material>
</GeometryModel3D>
</ModelVisual3D.Content>
<ModelVisual3D.Transform>
<RotateTransform3D>
<RotateTransform3D.Rotation>
<AxisAngleRotation3D x:Name = "rotate" Axis = "1 2 1"/>
</RotateTransform3D.Rotation>
</RotateTransform3D>
</ModelVisual3D.Transform>
</ModelVisual3D>
</Viewport3D>
<Slider Height = "23" HorizontalAlignment = "Left"
Margin = "145,271,0,0" Name = "slider1"
VerticalAlignment = "Top" Width = "269"
Maximum = "360"
Value = "{Binding ElementName = rotate, Path=Angle}" />
</Grid>
</Window>
जब आप अपना एप्लिकेशन चलाते हैं, तो यह आपकी विंडो पर 3D ऑब्जेक्ट और स्लाइडर का उत्पादन करेगा।
जब आप स्लाइडर को स्लाइड करते हैं, तो आपकी विंडो पर ऑब्जेक्ट भी घूम जाएगा।
हम अनुशंसा करते हैं कि आप उपरोक्त कोड निष्पादित करें और अधिक 3 डी ज्यामिति का प्रयास करें।
WPF एप्लिकेशन वीडियो और ऑडियो का उपयोग करके समर्थन करते हैं MediaElement। यह आपको ऑडियो और वीडियो को एक एप्लिकेशन में एकीकृत करने की अनुमति देता है। MediaElement वर्ग छवि वर्ग के समान कार्य करता है। आप इसे मीडिया में इंगित करते हैं और इसे प्रस्तुत करते हैं। मुख्य अंतर यह है कि यह एक चलती छवि होगी, लेकिन यदि आप इसे उस फ़ाइल की ओर इंगित करते हैं जिसमें केवल ऑडियो और कोई वीडियो नहीं है जैसे कि एमपी 3, तो यह स्क्रीन पर कुछ भी दिखाए बिना इसे चलाएगा।
WPF मशीन विन्यास के आधार पर सभी प्रकार के वीडियो / ऑडियो प्रारूप का समर्थन करता है। यदि कोई मीडिया फ़ाइल मीडिया प्लेयर खेलती है, तो यह उसी मशीन पर WPF में भी काम करेगी।
उदाहरण
आइए एक उदाहरण लें कि अपने एप्लिकेशन में मल्टीमीडिया को कैसे एकीकृत किया जाए।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPFMultimedia।
निम्नलिखित XAML कोड एक मीडिया तत्व और तीन बटन बनाता है, और उन्हें कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFMultimedia.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:WPFMultimedia"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<StackPanel HorizontalAlignment = "Center" VerticalAlignment = "Center">
<MediaElement Name = "myMedia" Source = "D:\MicrosoftMVA.mp4"
LoadedBehavior = "Manual" Width = "591" Height = "274" />
<StackPanel Orientation = "Horizontal" Margin = "0,10,0,0">
<Button Content = "Play" Margin = "0,0,10,0" Padding = "5" Click = "mediaPlay" />
<Button Content = "Pause" Margin = "0,0,10,0" Padding = "5" Click = "mediaPause" />
<Button x:Name = "muteButt" Content = "Mute" Padding = "5" Click = "mediaMute" />
</StackPanel>
</StackPanel>
</Grid>
</Window>
यहाँ विभिन्न बटन के लिए C # में क्लिक इवेंट कार्यान्वयन है।
using System;
using System.Windows;
namespace WPFMultimedia {
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
myMedia.Volume = 100;
myMedia.Play();
}
void mediaPlay(Object sender, EventArgs e) {
myMedia.Play();
}
void mediaPause(Object sender, EventArgs e) {
myMedia.Pause();
}
void mediaMute(Object sender, EventArgs e) {
if (myMedia.Volume == 100) {
myMedia.Volume = 0;
muteButt.Content = "Listen";
}
else {
myMedia.Volume = 100;
muteButt.Content = "Mute";
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। आप वीडियो चला सकते हैं और तीन बटन के साथ इसके प्लेबैक को नियंत्रित कर सकते हैं।
बटन के साथ आप वीडियो को रोक सकते हैं, म्यूट कर सकते हैं और खेल सकते हैं।
भाषण सिंथेसाइज़र
WPF में टेक्स्ट को भाषण में बदलने की विशेषताएं हैं। यह API System.Speech नामस्थान में शामिल है।SpeechSynthesizer कक्षा पाठ को बोले गए शब्दों में बदल देती है।
उदाहरण
आइए एक साधारण उदाहरण देखें।
नाम के साथ एक नया WPF प्रोजेक्ट बनाएं WPFTextToSpeech।
हमें संदर्भ के रूप में जोड़ने के लिए System.Speech असेंबली की आवश्यकता होगी SpeechSynthesizer काम करने के लिए क्लास।
संदर्भ पर राइट क्लिक करें और संदर्भ जोड़ें का चयन करें।
संदर्भ प्रबंधक संवाद खुल जाएगा। अब System.Speech चेक बॉक्स को चेक करें
ओके बटन पर क्लिक करें। आप अपने संदर्भ में System.Speech असेंबली देख सकते हैं।
अब टूलबॉक्स से एक बटन और एक टेक्स्टबॉक्स को डिज़ाइन विंडो में खींचें।
निम्नलिखित XAML कोड एक बटन और एक टेक्स्टबॉक्स बनाता है, और उन्हें कुछ गुणों के साथ आरंभ करता है।
<Window x:Class = "WPFTextToSpeech.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:WPFTextToSpeech"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<Button x:Name = "button" Content = "Speak"
HorizontalAlignment = "Left" Margin = "218,176,0,0"
VerticalAlignment = "Top" Width = "75"/>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left"
Height = "23" Margin = "60,104,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Width = "418"/>
</Grid>
</Window>
यहां C # में सरल कार्यान्वयन है जो टेक्स्ट बॉक्स के अंदर पाठ को बोले गए शब्दों में बदल देगा।
using System.Speech.Synthesis;
using System.Windows;
namespace WPFTextToSpeech {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void button_Click(object sender, RoutedEventArgs e) {
if (textBox.Text != "") {
SpeechSynthesizer speechSynthesizer = new SpeechSynthesizer();
speechSynthesizer.Speak(textBox.Text);
}
else {
MessageBox.Show("Write some thing in the textbox!");
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। अब, टेक्स्ट बॉक्स के अंदर हैलो वर्ल्ड टाइप करें और स्पीक बटन पर क्लिक करें।
यह ध्वनि "हैलो वर्ल्ड" का उत्पादन करेगा। यदि आप टेक्स्टबॉक्स में कुछ भी टाइप नहीं करते हैं, तो यह निम्न संदेश को फ्लैश करेगा।
हम अनुशंसा करते हैं कि आप उपरोक्त उदाहरणों को निष्पादित करें।