विंडोज 10 विकास - त्वरित गाइड
यह ट्यूटोरियल उन लोगों के लिए बनाया गया है जो सीखना चाहते हैं कि विंडोज 10 एप्लिकेशन कैसे विकसित करें। इस ट्यूटोरियल में, हम सीखने जा रहे हैं -
- विंडोज 10 अनुप्रयोग विकास
- Microsoft द्वारा जारी नए OS के अपडेट
- अपडेट में डेवलपर्स के लिए नई सुविधाएँ
कई दिलचस्प ऐप परिदृश्य अब संभव हैं जो पहली रिलीज़ में हमारे लिए उपलब्ध नहीं थे। माइक्रोसॉफ्ट ने न केवल नए एपीआई जोड़े हैं, उन्होंने मौजूदा एपीआई को भी बढ़ाया है।
यूनिवर्सल विंडोज ऐप
एक यूनिवर्सल विंडोज ऐप को सबसे पहले विंडोज 8 में विंडोज रनटाइम के रूप में पेश किया गया था, जिसे यूनिवर्सल एप्लिकेशन प्लेटफॉर्म पर बनाया गया था।
अब, विंडोज 10 में, यूनिवर्सल एप्लिकेशन प्लेटफॉर्म का नाम बदलकर यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) कर दिया गया है। आप विंडोज स्टोर के लिए विंडोज 10 उपकरणों जैसे पीसी, टैबलेट, फोन, आदि को लक्षित करके आधुनिक और पूरी तरह से इमर्सिव ऐप्स का निर्माण कर सकते हैं।
विंडोज 10 में, आप आसानी से विंडोज 10 पर समर्थित सभी उपकरणों तक पहुंचने के लिए एप्लिकेशन विकसित कर सकते हैं -
- एक एपीआई सेट
- एक ऐप पैकेज
- और एक दुकान
यूनिवर्सल विंडोज प्लेटफॉर्म विभिन्न स्क्रीन आकार और विभिन्न इंटरैक्शन मॉडल जैसे टच पैड, माउस और कीबोर्ड, गेम कंट्रोलर या पेन का समर्थन करता है।
UWP ऐप्स के लक्षण
यहां यूनिवर्सल विंडोज ऐप्स की कुछ विशेषताएं हैं, जो इसे विंडोज 10 से बेहतर बनाती हैं।
आप डिवाइस परिवारों को लक्षित कर सकते हैं और विंडोज 8.1 की तरह ओएस नहीं।
ऐप्स का उपयोग करके पैक किया और वितरित किया जाता है .AppX पैकेजिंग प्रारूप, जो यह सुनिश्चित करता है कि आपके ऐप्स को तैनात और मूल रूप से अपडेट किया जा सके।
आप अपने आवेदन को विंडोज स्टोर में जमा कर सकते हैं और यह इसे सभी डिवाइस परिवारों, या केवल उन उपकरणों पर उपलब्ध कराएगा, जिन्हें आप चुनते हैं। आप आसानी से एक ही स्थान पर विंडोज उपकरणों के लिए अपने सभी एप्लिकेशन प्रबंधित कर सकते हैं।
आप अपने एप्लिकेशन की उपलब्धता को विशेष उपकरण परिवार तक सीमित कर सकते हैं।
यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) के मुख्य एपीआई सभी विंडोज डिवाइस परिवारों में समान हैं। तो आपका ऐप सभी विंडोज 10 डिवाइसों पर चल सकता है अगर यह केवल कोर एपीआई का उपयोग करता है।
एक्सटेंशन एसडीके की मदद से, आप विशेष उपकरणों के लिए अपने आवेदन को हल्का कर सकते हैं।
विकास विकल्प
यूनिवर्सल विंडोज एप्लिकेशन निम्न में से किसी भी भाषा में बनाए जा सकते हैं -
- XAML के साथ C # या विजुअल बेसिक
- HTML के साथ जावास्क्रिप्ट
- DirectX और / या XAML के साथ C ++
आप घटकों को एक भाषा में भी लिख सकते हैं और उनका उपयोग किसी अन्य भाषा में विकसित अनुप्रयोग में कर सकते हैं।
विंडोज रनटाइम (WinRT) एक प्लेटफॉर्म-सजातीय एप्लिकेशन आर्किटेक्चर है, जो C ++ / CX, C #, VB.NET और जावास्क्रिप्ट में विकास का समर्थन करता है। WinRT एप्लिकेशन मूल रूप से x86 और ARM आर्किटेक्चर दोनों का समर्थन करते हैं। कुछ महत्वपूर्ण विशेषताएं हैं।
इसे पहली बार सितंबर 2012 में विंडोज सर्वर 2012 में पेश किया गया था।
WinRT API जावास्क्रिप्ट, C #, विज़ुअल बेसिक और C ++ का उपयोग करके सभी मुख्य प्लेटफ़ॉर्म सुविधाओं तक पहुँच प्रदान करता है।
WinRT घटक कई भाषाओं और API जैसे देशी, प्रबंधित और स्क्रिप्टिंग भाषाओं का समर्थन करते हैं।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP)
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) पर एक यूनिवर्सल विंडोज ऐप बनाया गया है, जिसे पहली बार विंडोज 8 में विंडोज रनटाइम के रूप में पेश किया गया था। विंडोज 10 में, यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) पेश किया गया था, जो आगे विंडोज रनटाइम (WinRT) मॉडल को आगे बढ़ाता है।
विंडोज 8.1 में, WinRT, पहली बार, विंडोज फोन 8.1 अनुप्रयोगों और विंडोज 8.1 अनुप्रयोगों के बीच एक साझा कोडबेस का उपयोग करके विंडोज फोन और विंडोज एप्लिकेशन दोनों को लक्षित करने के लिए यूनिवर्सल विंडोज 8 एप्लिकेशन के बीच संरेखित किया गया था।
विंडोज 10 यूनिफाइड कोर, जिसे अब विंडोज कोर के रूप में जाना जाता है, एक ऐसे बिंदु पर पहुंच गया है, जहां अब, यूडब्ल्यूपी, विंडोज 10 पर चलने वाले प्रत्येक डिवाइस पर उपलब्ध एक सामान्य ऐप प्लेटफॉर्म प्रदान करता है।
UWP न केवल WinRT API को सभी डिवाइसेस के लिए सामान्य कह सकता है, बल्कि API (Win32 और .NET API सहित) जो डिवाइस परिवार के लिए विशिष्ट है कि ऐप चल रहा है।
विंडोज 10 द्वारा समर्थित उपकरण
विंडोज 8.1 और विंडोज फोन 8.1 ऐप एक ओएस को लक्षित करते हैं; या तो विंडोज या विंडोज फोन। विंडोज 10 एप्लिकेशन एक ओएस को लक्षित नहीं करते हैं लेकिन वे एक या अधिक डिवाइस परिवारों को लक्षित करते हैं।
डिवाइस परिवारों के पास अपने स्वयं के एपीआई भी होते हैं, जो उस विशेष उपकरण परिवार के लिए कार्यक्षमता जोड़ते हैं। आप एक डिवाइस परिवार के भीतर सभी उपकरणों को आसानी से निर्धारित कर सकते हैं, जिस पर आपके एप्लिकेशन इंस्टॉल किए जा सकते हैं और विंडोज स्टोर से चलाए जा सकते हैं। यहाँ उपकरण परिवार का पदानुक्रमित प्रतिनिधित्व है।
UWP के लाभ
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) डेवलपर्स के लिए मुट्ठी भर चीजें प्रदान करता है। वे हैं -
- सभी उपकरणों के लिए एक ऑपरेटिंग सिस्टम और एक एकीकृत कोर।
- हर परिवार में एप्लिकेशन चलाने के लिए वन ऐप प्लेटफ़ॉर्म।
- एक देव केंद्र आवेदन और डैशबोर्ड प्रस्तुत करने के लिए।
- सभी उपकरणों के लिए एक स्टोर।
UWP विकास के लिए सेटअप
विंडोज 10 के लिए अपने स्वयं के यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन बनाने के लिए निम्न चरणों का पालन करने की आवश्यकता है।
Windows 10 OS- UWP ऐप्स को विकसित करने के लिए विंडोज के नवीनतम संस्करण की आवश्यकता होती है। आप विंडोज 8.1 पर यूडब्ल्यूपी एप्लिकेशन भी विकसित कर सकते हैं लेकिन यूआई डिजाइनर विंडो के लिए कोई समर्थन नहीं है।
Windows 10 developer tools- विजुअल स्टूडियो 2015 में, आप अपने UWP ऐप्स को डिज़ाइन, कोड, टेस्ट और डीबग कर सकते हैं। आप मुफ्त Microsoft Visual Studio सामुदायिक 2015 से डाउनलोड और इंस्टॉल कर सकते हैंhttps://dev.windows.com/en-us/downloads
Enable development mode for Windows 10 -
के लिए जाओ Start > Settings।
चुनते हैं Update & security।
फिर सेलेक्ट करें "For developers"।
पर क्लिक करें Developer mode
UWP ऐप्स के लिए, उपकरणों पर अपने एप्लिकेशन का परीक्षण करना महत्वपूर्ण है।
Register as an app developer- आप एप्लिकेशन विकसित करना शुरू कर सकते हैं, लेकिन स्टोर में अपने एप्लिकेशन सबमिट करने के लिए, आपको एक डेवलपर खाते की आवश्यकता है। आप यहां अपना डेवलपर अकाउंट बना सकते हैंhttps://msdn.microsoft.com/enus/library/windows/apps/bg124287.aspx
उपरोक्त चरणों का पालन करने के बाद, आप अब एक यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन के विकास को शुरू करने के लिए तैयार हैं।
इस अध्याय में, हम अपना पहला सरल एप्लिकेशन बना रहे हैं "Hello world" यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) में एक्सएएमएल और सी # का उपयोग विंडोज 10. पर किया गया है। हम प्रदर्शित करेंगे कि विजुअल स्टूडियो में बनाए गए एकल यूडब्ल्यूपी एप्लिकेशन को किसी भी विंडोज 10 डिवाइस पर कैसे चलाया और चलाया जा सकता है।
नीचे दिए गए चरणों का पालन करके ऐप बनाना शुरू करें।
विजुअल स्टूडियो 2015 लॉन्च करें।
पर क्लिक करें File मेनू और चयन करें New > Project।
निम्नलिखित New Projectसंवाद विंडो प्रदर्शित की जाएगी। आप संवाद बॉक्स के बाएँ फलक पर विभिन्न प्रकार के टेम्पलेट देख सकते हैं।
बाएँ फलक में, आप ट्री दृश्य देख सकते हैं। चुनते हैंUniversal template से Templates > Visual C# > Windows।
केंद्र फलक से, का चयन करें Blank App (Universal Windows) टेम्पलेट
प्रोजेक्ट को नाम लिखकर दें UWPHelloWorld में Name field।
क्लिक OK एक नया UWP प्रोजेक्ट बनाने के लिए।
आप नई बनाई गई परियोजना को देख सकते हैं Solution Explorer।
यह एक खाली ऐप है लेकिन इसमें कई फाइलें हैं, जो किसी भी UWP एप्लिकेशन के लिए न्यूनतम आवश्यकता है।
MainPage.xaml तथा MainPage.xaml.cs जब आप अपने एप्लिकेशन को निष्पादित करते हैं तो चलाएं।
डिफ़ॉल्ट रूप से, MainPage.xaml फ़ाइल में निम्न जानकारी है।
<Page
x:Class = ”UWPHellowWorld.MainPage”
xmlns = ”http://schemas.microsoft.com/winfx/2006/xaml/presentation”
xmlns:x = ”http://schemas.microsoft.com/winfx/2006/xaml”
xmlns:local = ”using:UWPHellowWorld”
xmlns:d = ”http://schemas.microsoft.com/expression/blend/2008”
xmlns:mc = ”http://schemas.openxmlformats.org/markup-compatibility/2006”
mc:Ignorable = ”d”>
<Grid Background = ”{ThemeResource ApplicationPageBackgroundThemeBrush}”>
</Grid>
</Page>
नीचे दी गई डिफ़ॉल्ट जानकारी उपलब्ध है MainPage.xaml.cs।
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPHellowWorld {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage(){
this.InitializeComponent();
}
}
}
हमें कुछ टेक्स्ट ब्लॉक, एक टेक्स्टबॉक्स और एक बटन जोड़ें जैसा कि नीचे XAML कोड में दिखाया गया है।
<Page
x:Class = ”UWPHellowWorld.MainPage”
xmlns = ”http://schemas.microsoft.com/winfx/2006/xaml/presentation”
xmlns:x = ”http://schemas.microsoft.com/winfx/2006/xaml”
xmlns:local = ”using:UWPHellowWorld”
xmlns:d = ”http://schemas.microsoft.com/expression/blend/2008”
xmlns:mc = ”http://schemas.openxmlformats.org/markup-compatibility/2006”
mc:Ignorable = ”d”>
<Grid Background = ”{ThemeResource ApplicationPageBackgroundThemeBrush}”>
<StackPanel HorizontalAlignment = ”Center”>
<TextBlock Text = ”Hello, world!” Margin = ”20” Width = ”200”
HorizontalAlignment = ”Left”/>
<TextBlock Text = ”Write your name.” Margin = ”20” Width = ”200”
HorizontalAlignment = ”Left”/>
<TextBox x:Name = ”txtbox” Width = ”280” Margin = ”20”
HorizontalAlignment = ”Left”/>
<Button x:Name = ”button” Content = ”Click Me” Margin = ”20”
Click = ”button_Click”/>
<TextBlock x:Name = ”txtblock” HorizontalAlignment = ”Left”
Margin = ”20”/>
</StackPanel>
</Grid>
</Page>
- नीचे # C में क्लिक-इवेंट बटन दिया गया है।
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPHellowWorld {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void button_Click(object sender, RoutedEventArgs e) {
if (txtbox.Text != “”)
txtblock.Text = “Hello: “ + txtbox.Text;
else
txtblock.Text = “You have not write your name”;
}
}
}
UWP परियोजना में, device preview विकल्प पर उपलब्ध है Design Window, जिसकी मदद से आप लेआउट को आसानी से बदल सकते हैं, एक डिवाइस परिवार में सभी डिवाइसों के स्क्रीन आकार में फिट होने के लिए जिन्हें आप अपने एप्लिकेशन पर लक्षित कर रहे हैं।
आप अपने ऐप को स्थानीय मशीन, सिम्युलेटर या एमुलेटर पर या रिमोट डिवाइस पर चला सकते हैं। आप निम्न मेनू से लक्ष्य डिवाइस का चयन कर सकते हैं जैसा कि नीचे दिखाया गया है -
हम एक स्थानीय मशीन पर उपरोक्त कोड चलाते हैं और आपको निम्न विंडो दिखाई देगी। अब, टेक्स्ट बॉक्स में कोई भी नाम लिखें और बटन पर क्लिक करेंClick Me।
अब, यदि आप किसी एमुलेटर पर अपने ऐप का परीक्षण करना चाहते हैं, तो आप मेनू से एक विशेष एमुलेटर का चयन कर सकते हैं और अपने आवेदन को निष्पादित कर सकते हैं। आप निम्न एमुलेटर देखेंगे -
हम आपको विभिन्न उपकरणों के साथ उपरोक्त एप्लिकेशन को निष्पादित करने की सलाह देते हैं।
डेवलपर्स के लिए विंडोज स्टोर का लाभ यह है कि आप अपना एप्लिकेशन बेच सकते हैं। आप हर डिवाइस परिवार के लिए अपना एकल आवेदन जमा कर सकते हैं।
विंडोज 10 स्टोर वह जगह है जहां एप्लिकेशन सबमिट किए जाते हैं, ताकि उपयोगकर्ता आपके एप्लिकेशन को ढूंढ सके।
विंडोज 8 में, स्टोर केवल एप्लिकेशन तक ही सीमित था और Microsoft कई स्टोर यानी Xbox Music Store, Xbox Game Store आदि प्रदान करता है।
विंडोज 8 में, ये सभी अलग-अलग स्टोर थे लेकिन विंडोज 10 में इसे विंडोज स्टोर कहा जाता है। इसे एक तरह से डिज़ाइन किया गया है, जहाँ उपयोगकर्ता सभी विंडोज़ डिवाइसों के लिए एक ही स्थान पर कई तरह के ऐप, गेम्स, गाने, मूवी, सॉफ्टवेयर और सेवाएं पा सकते हैं।
मुद्रीकरण
मुद्रीकरण का अर्थ है अपने ऐप को डेस्कटॉप, मोबाइल, टैबलेट और अन्य उपकरणों पर बेचना। विभिन्न तरीके हैं जो आप कुछ पैसे कमाने के लिए विंडोज स्टोर पर अपने एप्लिकेशन और सेवाएं बेच सकते हैं।
आप निम्न विधियों में से किसी का चयन कर सकते हैं -
सबसे सरल तरीका है कि आप अपने ऐप को सशुल्क डाउनलोड विकल्पों के साथ स्टोर पर जमा करें।
ट्रेल्स विकल्प, जहां उपयोगकर्ता सीमित कार्यक्षमता के साथ खरीदने से पहले आपके आवेदन की कोशिश कर सकते हैं।
Microsoft विज्ञापन के साथ अपने ऐप्स में विज्ञापन जोड़ें।
Microsoft विज्ञापन
जब आप अपने एप्लिकेशन में विज्ञापन जोड़ते हैं और एक उपयोगकर्ता उस विशेष विज्ञापन पर क्लिक करता है, तो विज्ञापनदाता आपको पैसे देगा। Microsoft विज्ञापन डेवलपर्स को Microsoft विज्ञापन नेटवर्क से विज्ञापन प्राप्त करने की अनुमति देता है।
यूनिवर्सल विंडोज ऐप्स के लिए Microsoft विज्ञापन एसडीके विज़ुअल स्टूडियो 2015 द्वारा स्थापित पुस्तकालयों में शामिल है।
आप इसे visualstudiogallery से भी इंस्टॉल कर सकते हैं
अब, आप अपने ऐप्स में वीडियो और बैनर विज्ञापनों को आसानी से एकीकृत कर सकते हैं।
हमें XAML में एक साधारण उदाहरण पर एक नज़र डालते हैं, अपने उपयोग में एक बैनर विज्ञापन जोड़ने के लिए AdControl।
नाम के साथ एक नया यूनिवर्सल विंडोज खाली ऐप प्रोजेक्ट बनाएं UWPBannerAd।
में Solution Explorer, ठीक पर क्लिक करें References
चुनते हैं Add References, जो खुल जाएगा Reference Manager संवाद।
बाएँ फलक से, का चयन करें Extensions यूनिवर्सल विंडोज विकल्प के तहत और की जाँच करें Microsoft Advertising SDK for XAML।
क्लिक OK जारी रखने के लिए।
नीचे दिया गया XAML कोड है जिसमें AdControl कुछ गुणों के साथ जोड़ा जाता है।
<Page
x:Class = "UWPBannerAd.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPBannerAd"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:UI = "using:Microsoft.Advertising.WinRT.UI"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel HorizontalAlignment = "Center">
<UI:AdControl ApplicationId = "d25517cb-12d4-4699-8bdc-52040c712cab"
AdUnitId = "10043121" HorizontalAlignment = "Left" Height = "580"
VerticalAlignment = "Top" Width = "800"/>
</StackPanel>
</Grid>
</Page>
जब उपरोक्त कोड स्थानीय मशीन पर संकलित और निष्पादित किया जाता है, तो आप उस पर एमएसएन बैनर के साथ निम्न विंडो देखेंगे। जब आप इस बैनर पर क्लिक करते हैं, तो यह एमएसएन साइट खोल देगा।
आप एक भी जोड़ सकते हैं video bannerआपके आवेदन में। आइए एक और उदाहरण पर विचार करें जिसमें जबShow ad बटन पर क्लिक किया जाता है, यह Xbox One का वीडियो विज्ञापन चलाएगा।
नीचे दिया गया XAML कोड है जिसमें हम प्रदर्शित करते हैं कि कैसे कुछ गुणों और घटनाओं के साथ एक बटन जोड़ा जाता है।
<Page
x:Class = "UWPBannerAd.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPBannerAd"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:UI = "using:Microsoft.Advertising.WinRT.UI"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel HorizontalAlignment = "Center">
<Button x:Name = "showAd" Content = "Show Ad" HorizontalAlignment = "Left"
Margin = "138,296,0,0" VerticalAlignment = "Top" FontSize = "48"
Click = "showAd_Click"/>
</StackPanel>
</Grid>
</Page>
नीचे दिए गए C # में क्लिक इवेंट कार्यान्वयन है।
using Microsoft.Advertising.WinRT.UI;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPBannerAd {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
InterstitialAd videoAd = new InterstitialAd();
public MainPage() {
this.InitializeComponent();
}
private void showAd_Click(object sender, RoutedEventArgs e) {
var MyAppId = "d25517cb-12d4-4699-8bdc-52040c712cab";
var MyAdUnitId = "11388823";
videoAd.AdReady += videoAd_AdReady;
videoAd.RequestAd(AdType.Video, MyAppId, MyAdUnitId);
}
void videoAd_AdReady(object sender, object e){
if ((InterstitialAdState.Ready) == (videoAd.State)) {
videoAd.Show();
}
}
}
}
जब उपरोक्त कोड स्थानीय मशीन पर संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी, जिसमें ए Show Ad बटन।
अब, जब आप पर क्लिक करते हैं Show Ad बटन, यह आपके ऐप पर वीडियो चलाएगा।
XAML एक्स्टेंसिबल एप्लिकेशन मार्कअप लैंग्वेज के लिए खड़ा है। यह एक यूजर इंटरफेस फ्रेमवर्क है और यह विंडोज के लिए यूआई विकास का समर्थन करने वाले नियंत्रणों की एक विस्तृत लाइब्रेरी प्रदान करता है। उनमें से कुछ में एक दृश्य प्रतिनिधित्व है जैसे कि एक बटन, टेक्स्टबॉक्स और टेक्स्टब्लॉक आदि; जबकि अन्य नियंत्रणों का उपयोग अन्य नियंत्रणों या सामग्री के लिए कंटेनरों के रूप में किया जाता है, जैसे कि चित्र आदि। सभी XAML नियंत्रण विरासत में मिले हैं“System.Windows.Controls.Control”।
XAML उभरती कहानी
XAML का उपयोग कई महत्वपूर्ण Microsoft प्लेटफार्मों जैसे कि विंडोज प्रेजेंटेशन फाउंडेशन (WPF), सिल्वरलाइट और अब, विंडोज ऐप में किया जाता है। अब, Microsoft Office 2016 भी UWP ऐप्स का एक परिवार है। एक्सएएमएल एक समृद्ध प्लेटफ़ॉर्म है, जो यूडब्ल्यूपी अनुप्रयोगों में उपयोग किए जा सकने वाले बहुत अच्छे फीचर और नियंत्रण प्रदान करता है।
नियंत्रणों की पूर्ण विरासत पदानुक्रम नीचे दिखाया गया है।
लेआउट नियंत्रण
अनुप्रयोग प्रयोज्य के लिए नियंत्रण का लेआउट बहुत महत्वपूर्ण और महत्वपूर्ण है। इसका उपयोग आपके एप्लिकेशन में GUI तत्वों के समूह को व्यवस्थित करने के लिए किया जाता है। लेआउट पैनल का चयन करते समय कुछ महत्वपूर्ण बातें हैं -
- बाल तत्वों की स्थिति।
- बाल तत्वों का आकार।
- एक-दूसरे के ऊपर बाल तत्वों को ओवरलैप करना।
सूची Layout Controls नीचे दिया गया है -
क्र.सं. | नियंत्रण और विवरण |
---|---|
1 | StackPanel StackPanelXAML में एक सरल और उपयोगी लेआउट पैनल है। स्टैक पैनल में, बाल तत्वों को एक लाइन में क्षैतिज या लंबवत रूप से उन्मुखीकरण संपत्ति के आधार पर व्यवस्थित किया जा सकता है। |
2 | WrapPanel में WrapPanel, बाल तत्व अभिविन्यास संपत्ति के आधार पर बाएं से दाएं या ऊपर से नीचे तक अनुक्रमिक क्रम में तैनात होते हैं। StackPanel और WrapPanel के बीच एकमात्र अंतर यह है कि यह सभी बाल तत्वों को एक ही पंक्ति में नहीं रखता है, लेकिन यदि कोई स्थान नहीं बचा है तो यह शेष तत्वों को दूसरी पंक्ति में लपेटता है। |
3 | DockPanel DockPanelएक दूसरे के सापेक्ष बाल तत्वों को व्यवस्थित करने के लिए एक क्षेत्र को परिभाषित करता है, या तो क्षैतिज या लंबवत। DockPanel के साथ आप आसानी से डॉक प्रॉपर्टी के साथ बाल तत्वों को टॉप, बॉटम, राइट, लेफ्ट और सेंटर में डॉक कर सकते हैं। साथ में LastChildFill संपत्ति, अंतिम बाल तत्व उस तत्व के लिए निर्धारित किए जाने पर किसी अन्य डॉक मान की परवाह किए बिना शेष स्थान को भरता है। |
4 | Canvas Canvasबुनियादी लेआउट पैनल है जिसमें बाल तत्वों को स्पष्ट रूप से निर्देशांक का उपयोग करके तैनात किया जा सकता है जो किसी भी पक्ष जैसे कि बाएं, दाएं, ऊपर और नीचे के सापेक्ष हैं। आमतौर पर कैनवस का उपयोग 2D ग्राफिक तत्वों (जैसे कि एलीप, आयत आदि) के लिए किया जाता है, लेकिन UI तत्वों के लिए नहीं, क्योंकि निर्दिष्ट निर्देशांक एक XAML अनुप्रयोग में आकार बदलने, स्थानीयकरण या स्केलिंग करते समय परेशानी देते हैं। |
5 | Grid Gridएक लचीला क्षेत्र प्रदान करता है, जिसमें पंक्तियाँ और स्तंभ होते हैं। ग्रिड में, बाल तत्वों को एक सारणीबद्ध रूप में व्यवस्थित किया जा सकता है। तत्वों का उपयोग करके किसी भी विशिष्ट पंक्ति और स्तंभ में जोड़ा जा सकता हैGrid.Row तथा Grid.Column गुण। |
6 | SplitView SplitViewदो विचारों के साथ एक कंटेनर का प्रतिनिधित्व करता है; मुख्य सामग्री के लिए एक दृश्य और दूसरा दृश्य जो आमतौर पर नेविगेशन कमांड के लिए उपयोग किया जाता है। |
7 | RelativePanel RelativePanel एक ऐसे क्षेत्र को परिभाषित करता है जिसके भीतर आप एक दूसरे या माता-पिता के पैनल के संबंध में बाल वस्तुओं को स्थिति और संरेखित कर सकते हैं। |
8 | ViewBox ViewBox एक सामग्री डेकोरेटर को परिभाषित करता है जो उपलब्ध स्थान को भरने के लिए एकल बच्चे को खींच और स्केल कर सकता है। |
9 | FlipView FlipView एक आइटम के नियंत्रण का प्रतिनिधित्व करता है जो एक समय में एक आइटम प्रदर्शित करता है, और आइटम के अपने संग्रह को ट्रैवर्स करने के लिए "फ्लिप" व्यवहार को सक्षम करता है। |
10 | GridView GridView एक नियंत्रण है जो पंक्तियों और स्तंभों में वस्तुओं का संग्रह प्रस्तुत करता है और क्षैतिज रूप से स्क्रॉल किया जा सकता है। |
यूआई नियंत्रण
यहां UI नियंत्रणों की एक सूची दी गई है, जो अंतिम उपयोगकर्ताओं को दिखाई देते हैं।
क्र.सं. | UI नियंत्रण और विवरण |
---|---|
1 | Button एक नियंत्रण जो उपयोगकर्ता इनपुट के प्रति प्रतिक्रिया करता है |
2 | Calendar एक नियंत्रण का प्रतिनिधित्व करता है जो एक उपयोगकर्ता को एक दृश्य कैलेंडर डिस्प्ले का उपयोग करके एक तिथि का चयन करने में सक्षम बनाता है। |
3 | CheckBox एक नियंत्रण जो उपयोगकर्ता का चयन या स्पष्ट कर सकता है। |
4 | ComboBox आइटम की एक ड्रॉप-डाउन सूची, एक उपयोगकर्ता से चुन सकता है। |
5 | ContextMenu संदर्भ मेनू तत्व हो जाता है या सेट हो जाता है जो इस तत्व के भीतर उपयोगकर्ता इंटरफ़ेस (UI) के माध्यम से संदर्भ मेनू से अनुरोध किया जाता है। |
6 | DataGrid एक नियंत्रण का प्रतिनिधित्व करता है जो अनुकूलन ग्रिड में डेटा प्रदर्शित करता है। |
7 | DatePicker एक नियंत्रण जो उपयोगकर्ता को एक तिथि का चयन करने देता है। |
8 | Dialogs एक एप्लिकेशन उपयोगकर्ता को महत्वपूर्ण जानकारी एकत्र करने या प्रदर्शित करने के लिए अतिरिक्त विंडो भी प्रदर्शित कर सकता है। |
9 | Flyout एक नियंत्रण का प्रतिनिधित्व करता है जो हल्के UI को प्रदर्शित करता है जो या तो जानकारी है, या उपयोगकर्ता इंटरैक्शन की आवश्यकता है। एक संवाद के विपरीत, एक फ्लाईआउट को इसके बाहर क्लिक या टैप करके, डिवाइस के बैक बटन को दबाकर या 'Esc' कुंजी दबाकर हल्का खारिज किया जा सकता है। |
10 | Image एक नियंत्रण जो एक छवि प्रस्तुत करता है। |
1 1 | ListBox एक नियंत्रण जो उन मदों की एक इनलाइन सूची प्रस्तुत करता है, जिसे उपयोगकर्ता चुन सकता है। |
12 | Menus एक विंडोज़ मेनू नियंत्रण का प्रतिनिधित्व करता है जो आपको कमांड और ईवेंट हैंडलर से जुड़े तत्वों को पदानुक्रमित करने में सक्षम बनाता है। |
13 | MenuFlyout एक फ़्लायआउट का प्रतिनिधित्व करता है जो आदेशों का एक मेनू प्रदर्शित करता है। |
14 | PasswordBox पासवर्ड दर्ज करने के लिए एक नियंत्रण। |
15 | Popup एप्लिकेशन विंडो के सीमा के भीतर, मौजूदा सामग्री के शीर्ष पर सामग्री प्रदर्शित करता है। |
16 | ProgressBar एक नियंत्रण जो एक बार प्रदर्शित करके प्रगति को इंगित करता है। |
17 | ProgressRing एक नियंत्रण जो एक अंगूठी को प्रदर्शित करके अनिश्चित प्रगति को इंगित करता है। |
18 | RadioButton एक नियंत्रण जो उपयोगकर्ता को विकल्पों के समूह से एकल विकल्प का चयन करने की अनुमति देता है। |
19 | RichEditBox एक नियंत्रण जो उपयोगकर्ता को फ़ॉर्मेट किए गए पाठ, हाइपरलिंक और छवियों जैसी सामग्री के साथ समृद्ध पाठ दस्तावेज़ों को संपादित करने देता है। |
20 | ScrollViewer एक कंटेनर नियंत्रण जो उपयोगकर्ता को पैन और उसकी सामग्री को ज़ूम करने देता है। |
21 | SearchBox एक नियंत्रण जो उपयोगकर्ता को खोज क्वेरी दर्ज करने देता है। |
22 | Slider एक नियंत्रण जो उपयोगकर्ता को एक ट्रैक के साथ एक अंगूठे नियंत्रण को स्थानांतरित करके मूल्यों की एक श्रृंखला से चुनने देता है। |
23 | TextBlock एक नियंत्रण जो पाठ को प्रदर्शित करता है। |
24 | TimePicker एक नियंत्रण जो उपयोगकर्ता को एक समय मान सेट करने देता है। |
25 | ToggleButton एक बटन जिसे 2 राज्यों के बीच टॉगल किया जा सकता है। |
26 | ToolTip एक पॉप-अप विंडो जो किसी तत्व के लिए जानकारी प्रदर्शित करती है। |
27 | Window रूट विंडो जो न्यूनतम / अधिकतम विकल्प, टाइटल बार, बॉर्डर और क्लोज बटन प्रदान करती है। |
नीचे दिया गया एक उदाहरण है, जिसमें विभिन्न प्रकार के नियंत्रण शामिल हैं a SplitView। XAML फ़ाइल में, कुछ गुणों और घटनाओं के साथ अलग-अलग नियंत्रण बनाए जाते हैं।
<Page
x:Class = "UWPControlsDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPControlsDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel Margin = "20">
<StackPanel Orientation = "Horizontal">
<ToggleButton x:Name = "HamburgerButton" FontFamily = "Segoe MDL2 Assets"
Content = "" Checked = "HandleCheck" Unchecked = "HandleUnchecked"
HorizontalAlignment = "Center"/>
<AppBarButton Icon = "Like" />
<AppBarButton Icon = "Dislike" />
<AppBarSeparator/>
<AppBarButton Icon = "Accept" />
<AppBarButton Icon = "Add" />
</StackPanel>
<SplitView x:Name = "splitView" DisplayMode = "Inline"
OpenPaneLength = "296">
<SplitView.Pane>
<StackPanel>
<TextBlock Text = "SplitView Pane" FontSize = "36"
VerticalAlignment = "Center" HorizontalAlignment = "Center"
Margin = "10"/>
<Button Content = "Options" Margin = "10">
<Button.Flyout>
<MenuFlyout>
<MenuFlyoutItem Text = "Reset"/>
<MenuFlyoutSeparator/>
<MenuFlyoutItem Text = "Repeat"/>
<MenuFlyoutItem Text = "Shuffle"/>
</MenuFlyout>
</Button.Flyout>
</Button>
</StackPanel>
</SplitView.Pane>
<StackPanel>
<TextBlock Text = "SplitView Content" FontSize = "36"
VerticalAlignment = "Center" HorizontalAlignment = "Center"
Margin = "10"/>
<Border BorderThickness = "3" BorderBrush = "Red" Margin = "5">
<StackPanel Orientation = "Horizontal">
<TextBlock Text = "Hyperlink example" Margin = "5"/>
<HyperlinkButton Content = "www.microsoft.com"
NavigateUri = "http://www.microsoft.com"/>
</StackPanel>
</Border>
<RelativePanel BorderBrush = "Red" BorderThickness = "2"
CornerRadius = "10" Padding = "12" Margin = "5">
<TextBlock x:Name = "txt" Text = "Relative Panel example"
RelativePanel.AlignLeftWithPanel = "True"
Margin = "5,0,0,0"/>
<TextBox x:Name = "textBox1" RelativePanel.RightOf = "btn"
Margin = "5,0,0,0"/>
<Button x:Name = "btn" Content = "Name"
RelativePanel.RightOf = "txt" Margin = "5,0,0,0"/>
</RelativePanel>
<FlipView Height = "400" Margin = "10" Width = "400">
<Image Source = "Images/DSC_0104.JPG"/>
<Image Source = "Images/DSC_0080.JPG"/>
<Image Source = "Images/DSC_0076.JPG"/>
<Image Source = "Images/thGTF7BWGW.jpg"/>
</FlipView>
</StackPanel>
</SplitView>
</StackPanel>
</Grid>
</Page>
नीचे दिया गया है Events C # में कार्यान्वयन।
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Media;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPControlsDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void HandleCheck(object sender, RoutedEventArgs e) {
splitView.IsPaneOpen = true;
}
private void HandleUnchecked(object sender, RoutedEventArgs e) {
splitView.IsPaneOpen = false;
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी -
जब आप ऊपर बाईं ओर हैमबर्गर बटन पर क्लिक करेंगे, तो यह खुल जाएगा / बंद हो जाएगा SplitView फलक।
में SplitView फलक, आप देख सकते हैं Flyout, MenuFlyout तथा FlipView नियंत्रित करता है।
में SplitView सामग्री, आप हाइपरलिंक, रिलेटिव पैनल, व्यूबॉक्स और अन्य बटन और टेक्स्टबॉक्स नियंत्रण देख सकते हैं।
डेटा बाइंडिंग XAML एप्लिकेशन में एक तंत्र है, जो डेटा को प्रदर्शित करने और बातचीत करने के लिए आंशिक कक्षाओं का उपयोग करके विंडोज रनटाइम ऐप्स के लिए एक सरल और आसान तरीका प्रदान करता है। डेटा का प्रबंधन इस तंत्र में डेटा प्रदर्शित करने के तरीके से पूरी तरह से अलग है।
डेटा बाध्यकारी यूआई तत्वों और उपयोगकर्ता इंटरफ़ेस पर डेटा ऑब्जेक्ट के बीच डेटा के प्रवाह की अनुमति देता है। जब कोई बंधन स्थापित होता है और डेटा या आपका व्यवसाय मॉडल बदलता है, तो यह UI तत्वों के लिए स्वचालित रूप से अपडेट को दर्शाता है और इसके विपरीत। यह मानक डेटा स्रोत के लिए नहीं, बल्कि पृष्ठ पर किसी अन्य तत्व के लिए बाध्य करना भी संभव है। डेटा बाइंडिंग हो सकती है -
- एकतरफा डेटा बाइंडिंग
- दो-तरफ़ा डेटा बाइंडिंग
- तत्व बंधन
वन-वे डेटा बाइंडिंग
एक-तरफ़ा बाइंडिंग में, डेटा को उसके स्रोत (डेटा को रखने वाली वस्तु) से उसके लक्ष्य (डेटा प्रदर्शित करने वाली वस्तु) से बांधा जाता है।
आइए हम डेटा बाइंडिंग के एक तरीके का एक सरल उदाहरण देखें। नीचे दिया गया XAML कोड है जिसमें कुछ गुणों के साथ चार टेक्स्ट ब्लॉक बनाए गए हैं।
<Page
x:Class = "OneWayDataBinding.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:OneWayDataBinding"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel Name = "Display">
<StackPanel Orientation = "Horizontal" Margin = "50, 50, 0, 0">
<TextBlock Text = "Name: " Margin = "10" Width = "100"/>
<TextBlock Margin = "10" Width = "100" Text = "{Binding Name}"/>
</StackPanel>
<StackPanel Orientation = "Horizontal" Margin = "50,0,50,0">
<TextBlock Text = "Title: " Margin = "10" Width = "100"/>
<TextBlock Margin = "10" Width = "200" Text = "{Binding Title}" />
</StackPanel>
</StackPanel>
</Grid>
</Page>
दो टेक्स्ट ब्लॉक के टेक्स्ट गुण सेट किए गए हैं “Name” तथा “Title” वैधानिक रूप से, जबकि पाठ ब्लॉक के अन्य दो पाठ गुण "नाम" और "शीर्षक" से बंधे हैं, जो नीचे दिखाए गए अनुसार कर्मचारी वर्ग के वर्ग चर हैं।
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace OneWayDataBinding {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage(){
this.InitializeComponent();
DataContext = Employee.GetEmployee();
}
}
public class Employee {
public string Name { get; set; }
public string Title { get; set; }
public static Employee GetEmployee() {
var emp = new Employee() {
Name = "Waqar Ahmed",
Title = "Development Manager"
};
return emp;
}
}
}
में Employee class, हमारे पास चर हैं Name तथा Title और एक स्थिर विधि जिसमें employee objectआरंभिक है और उस कर्मचारी वस्तु को वापस करेगा इसलिए, हम संपत्ति, नाम और शीर्षक के लिए बाध्य हैं, लेकिन हमने अभी तक उस वस्तु का चयन नहीं किया है जिसके पास संपत्ति है। आसान तरीका यह है कि किसी वस्तु को कैसे निर्दिष्ट किया जाएDataContext, जिसके गुण हम में बाँध रहे हैं MainPage निर्माता।
जब आप इस एप्लिकेशन को चलाते हैं, तो आप तुरंत अपने में देख सकते हैं MainWindow आप उस कर्मचारी वस्तु के नाम और शीर्षक से सफलतापूर्वक बंधे हैं।
टू-वे डेटा बाइंडिंग
टू-वे बाइंडिंग में, उपयोगकर्ता यूजर इंटरफेस के माध्यम से डेटा को संशोधित करने में सक्षम है और उस डेटा को स्रोत में अपडेट किया गया है। उदाहरण के लिए, यदि उपयोगकर्ता देखने के दौरान स्रोत बदलता है, तो आप चाहते हैं कि दृश्य अपडेट किया जाए।
आइए हम नीचे दिए गए उदाहरण पर एक नज़र डालें जिसमें दो लेबल, दो टेक्स्ट बॉक्स और एक बटन कुछ गुणों और घटनाओं के साथ बनाए गए हैं।
<Page
x:Class = "TwoWayDataBinding.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:TwoWayDataBinding"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<TextBlock Name = "nameLabel" Margin = "200,20,0,0">Name:</TextBlock>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "10,20,0,0"
Text = "{Binding Name, Mode = TwoWay}"/>
<TextBlock Name = "ageLabel" Margin = "200,20,0,0"
Grid.Row = "1">Age:</TextBlock>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "10,20,0,0"
Text = "{Binding Age, Mode = TwoWay}"/>
<StackPanel Grid.Row = "2" Grid.ColumnSpan = "2">
<Button Content = "Display" Click = "Button_Click"
Margin = "200,20,0,0"/>
<TextBlock x:Name = "txtblock" Margin = "200,20,0,0"/>
</StackPanel>
</Grid>
</Page>
हम निम्नलिखित देख सकते हैं -
दोनों टेक्स्ट बॉक्स के टेक्स्ट गुण बाँधते हैं "Name" तथा "Age" के वर्ग चर हैं Person class जैसा की नीचे दिखाया गया।
में Person class, हमारे पास केवल दो चर हैं - नाम और आयु, और इसकी वस्तु को इसमें आरंभ किया गया है MainWindow कक्षा।
XAML कोड में, हम संपत्ति के लिए बाध्य हैं - Name तथा Age, लेकिन हमने उस वस्तु का चयन नहीं किया है जिसके पास संपत्ति है।
किसी वस्तु को असाइन करने का आसान तरीका है DataContext, जिनके गुण हम नीचे दिखाए गए अनुसार C # कोड में बांध रहे हैं MainWindowconstructor।
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace TwoWayDataBinding {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
Person person = new Person { Name = "Salman", Age = 26 };
public MainPage() {
this.InitializeComponent();
this.DataContext = person;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = person.Name + " is " + person.Age + " years old";
txtblock.Text = 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;
}
}
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी। दबाएंDisplay बटन।
आइए हम नाम और आयु को बदलते हैं और क्लिक करते हैं Display फिर से बटन।
आप उसे क्लिक बटन में देख सकते हैं ‘Display’डेटा दिखाने के लिए टेक्स्टबॉक्स के पाठ का उपयोग नहीं किया जाता है TextBlock लेकिन वर्ग चर का उपयोग किया जाता है।
मैं आपको बेहतर समझ के लिए दोनों मामलों के साथ उपरोक्त कोड निष्पादित करने की सलाह देता हूं।
तत्व बंधन
यह मानक डेटा स्रोत के लिए नहीं, बल्कि पृष्ठ पर किसी अन्य तत्व के लिए बाध्य करना भी संभव है। आइए हम एक एप्लिकेशन बनाएं जिसका नाम हैElementBindingजिसमें एक स्लाइडर और एक आयत बनाया जाता है और स्लाइडर के साथ, आयत की चौड़ाई और ऊँचाई बंधी होती है। नीचे XAML में कोड दिया गया है।
<Page
x:Class = "ElementBinding.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:ElementBinding"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel VerticalAlignment = "Center" HorizontalAlignment = "Center">
<Rectangle Height = "100" Width = "100" Fill = "SteelBlue"
RenderTransformOrigin = "0.5,0.5" Margin = "50">
<Rectangle.RenderTransform>
<CompositeTransform ScaleX = "{Binding Value, ElementName = MySlider}"
ScaleY = "{Binding Value, ElementName = MySlider}"/>
</Rectangle.RenderTransform>
</Rectangle>
<Slider Minimum = ".5" Maximum = "2.0" StepFrequency = ".1"
x:Name = "MySlider" />
</StackPanel>
</Grid>
</Page>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
स्लाइडर के साथ, आप नीचे दिखाए गए अनुसार आयत का आकार बदल सकते हैं।
एप्लिकेशन का प्रदर्शन जैसे कि आपका एप्लिकेशन स्टार्टअप पर कितनी जल्दी दिखाई देता है या अगली सामग्री आदि दिखाने के लिए नेविगेट करता है आदि बहुत महत्वपूर्ण है।
एक आवेदन के प्रदर्शन को कई चीजों से प्रभावित किया जा सकता है, जिसमें आपके आवेदन में आपके पास मौजूद सभी XAML कोड को पार्स करने के लिए XAML रेंडरिंग इंजन की क्षमता भी शामिल है। UI बनाने के लिए XAML एक बहुत ही शक्तिशाली उपकरण है, लेकिन यह नई तकनीकों का उपयोग करके अधिक मजबूत हो सकता है, जो अब विंडोज 10 अनुप्रयोगों में उपलब्ध हैं।
उदाहरण के लिए, आपके अनुप्रयोगों में, कुछ चीजें हैं, जिन्हें आप दिखाना चाहते हैं जब पृष्ठ लोड होता है और फिर बाद में इसकी आवश्यकता नहीं होती है। यह भी संभव है कि स्टार्टअप में आपको सभी यूआई तत्वों को लोड करने की आवश्यकता न हो।
विंडोज 10 ऐप में, XAML में कुछ नई सुविधाएँ जोड़ी गई हैं, जिससे XAML के प्रदर्शन में सुधार हुआ है।
किसी भी यूनिवर्सल विंडोज एप्लिकेशन के प्रदर्शन में निम्नलिखित तकनीकों द्वारा सुधार किया जा सकता है;
- प्रगतिशील प्रतिपादन
- आस्थगित लोड हो रहा है
प्रगतिशील प्रतिपादन
विंडोज 10 में, XAML में दो नए और बहुत अच्छे फीचर्स पेश किए गए हैं। वे हैं -
एक्स: बाइंड
यह बाध्यकारी के लिए उपयोग किए जाने वाले XAML में पेश किया गया एक नया वाक्यविन्यास है, जो लगभग उसी तरह काम करता है जैसे कि Binding वाक्य रचना करता है। x:Bindदो प्रमुख अंतर हैं; यह संकलन-समय सिंटैक्स सत्यापन और बेहतर प्रदर्शन प्रदान करता है।
एक्स: चरण
यह डेटा टेम्प्लेट के भीतर XAML नियंत्रण के प्रतिपादन को प्राथमिकता देने की क्षमता प्रदान करता है। प्रत्येक UI तत्व में केवल एक चरण निर्दिष्ट हो सकता है। यदि हां, तो यह तत्व पर सभी बाइंडिंग के लिए लागू होगा। यदि कोई चरण निर्दिष्ट नहीं है, तो चरण 0 मान लिया गया है।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) अनुप्रयोगों में, ये दो नई सुविधाएँ प्रदर्शन में सुधार प्रदान करती हैं। इसका उपयोग मौजूदा विंडोज 8.x एप्लिकेशन में किया जा सकता है जो विंडोज 10 पर माइग्रेट करता है।
नीचे दिया गया एक उदाहरण है जिसमें कर्मचारी वस्तुओं के साथ बंधे हैं GridView का उपयोग करके x:Bind कुंजी शब्द।
<Page
x:Class = "XAMLPhase.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:XAMLPhase"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<GridView Name = "Presidents" ItemsSource = "{Binding}" Height = "300"
Width = "400" Margin = "50">
<GridView.ItemTemplate>
<DataTemplate x:DataType = "local:Employee">
<StackPanel Orientation = "Horizontal" Margin = "2">
<TextBlock Text = "{x:Bind Name}" Width = "95" Margin = "2" />
<TextBlock Text = "{x:Bind Title}" Width = "95" Margin = "2"
x:Phase = "1"/>
</StackPanel>
</DataTemplate>
</GridView.ItemTemplate>
</GridView>
</Grid>
</Page>
उपरोक्त XAML कोड में, x:Phase = "1"शीर्षक के साथ परिभाषित किया गया है। इसलिए, पहले चरण में,Name प्रस्तुत किया जाएगा और फिर Title प्रदान किया जाएगा।
नीचे दिया गया है Employee class C # में कार्यान्वयन।
using System.Collections.ObjectModel;
using System.ComponentModel;
using System.Runtime.CompilerServices;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace XAMLPhase {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
DataContext = Employee.GetEmployees();
}
}
public class Employee : INotifyPropertyChanged {
private string name;
public string Name {
get { return name; }
set {
name = value;
RaiseProperChanged();
}
}
private string title;
public string Title {
get { return title; }
set {
title = value;
RaiseProperChanged();
}
}
public static Employee GetEmployee() {
var emp = new Employee() {
Name = "Waqas",
Title = "Software Engineer"
};
return emp;
}
public event PropertyChangedEventHandler PropertyChanged;
private void RaiseProperChanged(
[CallerMemberName] string caller = "") {
if (PropertyChanged != null) {
PropertyChanged(this, new PropertyChangedEventArgs(caller));
}
}
public static ObservableCollection<Employee> GetEmployees() {
var employees = new ObservableCollection<Employee>();
employees.Add(new Employee() { Name = "Ali", Title = "Developer" });
employees.Add(new Employee() { Name = "Ahmed", Title = "Programmer" });
employees.Add(new Employee() { Name = "Amjad", Title = "Desiner" });
employees.Add(new Employee() { Name = "Waqas", Title = "Programmer" });
employees.Add(new Employee() { Name = "Bilal", Title = "Engineer" });
employees.Add(new Employee() { Name = "Waqar", Title = "Manager" });
return employees;
}
}
}
जब ऊपर दिए गए कोड को निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
X:Phase साथ में x:Bind रेंडर करने के लिए उपयोग किया जाता है ListView तथा GridView आइटम वृद्धिशील रूप से और पैनिंग अनुभव में सुधार करते हैं।
आस्थगित लोड हो रहा है
डिफर्ड लोडिंग एक तकनीक है, जिसका उपयोग किसी एप्लिकेशन के स्टार्टअप पर XAML UI तत्वों की संख्या को कम करके स्टार्टअप लोडिंग समय को कम करने के लिए किया जा सकता है। यदि आपके एप्लिकेशन में 30 UI तत्व हैं और उपयोगकर्ता को स्टार्टअप में इन सभी तत्वों की आवश्यकता नहीं है, तो वे सभी तत्व, जिनकी आवश्यकता नहीं है, कुछ लोडिंग समय को हटाकर बचा सकते हैं।
x:DeferLoadStrategy = "Lazy" एक तत्व और उसके बच्चों के निर्माण में देरी करता है, जो स्टार्टअप समय को कम करता है लेकिन यह स्मृति उपयोग को थोड़ा बढ़ा देता है।
आस्थगित तत्व कॉलिंग द्वारा महसूस / बनाया जा सकता है FindName नाम के साथ जो तत्व पर परिभाषित किया गया था।
एक बार एक आस्थगित तत्व बनने के बाद, कई चीजें घटित होंगी -
तत्व पर लोड की गई घटना को उठाया जाएगा।
तत्व पर किसी भी बाइंडिंग का मूल्यांकन किया जाएगा।
यदि आवेदन स्थगित तत्व (संप्रदायों) वाली संपत्ति पर संपत्ति परिवर्तन सूचनाएं प्राप्त करने के लिए पंजीकृत है, तो अधिसूचना को उठाया जाएगा।
नीचे दिया गया एक उदाहरण है जिसमें x:DeferLoadStrategy = "Lazy" का उपयोग ग्रिड के लिए किया जाता है जिसमें चार टेक्स्ट ब्लॉक होते हैं और आपके एप्लिकेशन के स्टार्टअप पर तब तक लोड नहीं किए जाएंगे, जब तक आप इसे लोड नहीं करते।
<Page
x:Class = "UWPDeferredLoading.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPDeferredLoading"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid x:Name = "DeferredGrid" x:DeferLoadStrategy = "Lazy" Margin = "50">
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "Auto" />
</Grid.ColumnDefinitions>
<TextBlock Height = "100" Width = "100" Text = "TextBlock 1" Margin = "0,0,4,4" />
<TextBlock Height = "100" Width = "100" Text = "TextBlock 2"
Grid.Column = "1" Margin = "4,0,0,4" />
<TextBlock Height = "100" Width = "100" Text = "TextBlock 3"
Grid.Row = "1" Margin = "0,4,4,0" />
<TextBlock Height = "100" Width = "100" Text = "TextBlock 4"
Grid.Row = "1" Grid.Column = "1" Margin = "4,4,0,0" />
</Grid>
<Button x:Name = "RealizeElements" Content = "Show Elements"
Click = "RealizeElements_Click" Margin = "50"/>
</Grid>
</Page>
निम्नलिखित कार्यक्रम क्लिक इवेंट कार्यान्वयन है, जिसमें एप्लिकेशन मुख्य पृष्ठ पर ग्रिड लोड किया जाता है।
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPDeferredLoading {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void RealizeElements_Click(object sender, RoutedEventArgs e) {
this.FindName("DeferredGrid"); // This will realize the deferred grid
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको केवल एक बटन दिखाई देगा। Textblocks स्टार्टअप पर लोड नहीं हैं।
अब जब आप क्लिक करेंगे Show Elements बटन, यह टेक्स्ट ब्लॉक को लोड करेगा, जो आपके एप्लिकेशन के स्टार्टअप प्रदर्शन को बेहतर करेगा।
विंडोज 10 में, यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन अब कई डिवाइस परिवारों पर चलेंगे जैसे कि -
Desktop device family - टैबलेट, लैपटॉप, पीसी
Mobile device family - विंडोज फोन, फैबलेट
IoT device family - कॉम्पैक्ट डिवाइस जैसे कि वेअरबल्स या घरेलू उपकरण
Team device family - सरफेस हब
प्रत्येक डिवाइस परिवार की अपनी स्क्रीन और विंडो का आकार होता है। तो एक ऐप कैसे डिज़ाइन करें जो नाटकीय रूप से अलग-अलग स्क्रीन आकार और विभिन्न इनपुट विधियों के साथ कई उपकरणों पर एक महान उपयोगकर्ता अनुभव प्रदान करता है?
कई डिवाइस परिवारों के लिए अपने आवेदन को डिजाइन करने के लिए कुछ अतिरिक्त विचार, योजना और डिजाइन की आवश्यकता होती है। विंडोज 10 यूडब्ल्यूपी बिल्ट-इन फीचर्स और यूनिवर्सल बिल्डिंग ब्लॉक्स का एक सेट प्रदान करता है जो कई डिवाइसों के लिए डिज़ाइन करना आसान बनाता है और प्लेटफ़ॉर्म कंट्रोल द्वारा समर्थित विभिन्न स्क्रीन और विंडो आकारों में स्वचालित रूप से स्केल करता है।
नई अंतर्निहित सुविधाएँ
UWP एप्लिकेशन बनाते समय डेवलपर्स द्वारा उपयोग की जा सकने वाली नई सुविधाएँ निम्नलिखित हैं। ये फीचर ऑटोमैटिक और फ्री हैं।
प्रभावी पिक्सेल और प्लेटफार्म स्केलिंग
जब आपका यूडब्ल्यूपी एप्लिकेशन विंडोज 10 द्वारा समर्थित किसी भी डिवाइस पर चलता है, तो -
सिस्टम जिस तरह से वर्तमान में चल रहा है, उस डिवाइस की स्क्रीन पर नियंत्रण, फोंट और अन्य यूआई तत्वों को प्रदर्शित करने के लिए सिस्टम एल्गोरिदम का उपयोग करता है।
स्केलिंग एल्गोरिथ्म, माना आकार (भौतिक आकार के बजाय) को अनुकूलित करने के लिए देखने की दूरी और स्क्रीन घनत्व (पिक्सेल प्रति इंच) को नियंत्रित करता है।
स्केलिंग एल्गोरिथ्म सुनिश्चित करता है कि सरफेस हब पर 10 फीट की दूरी पर 36 px का फॉन्ट, उपयोगकर्ता के लिए 5 '' फोन पर 36 px फ़ॉन्ट के रूप में पढ़ने योग्य है, जो कुछ इंच दूर है।
यूनिवर्सल इनपुट और स्मार्ट इंटरैक्शन
यूनिवर्सल विंडोज प्लेटफॉर्म में अंतर्निहित स्मार्ट इंटरैक्शन इनपुट सिस्टम हैं, जो सभी उपकरणों के लिए इनपुट को समझते हैं। उदाहरण के लिए, जब आप अपने एप्लिकेशन में एक क्लिक इंटरैक्शन डिज़ाइन करते हैं, तो आपको यह जानने की ज़रूरत नहीं है कि क्लिक वास्तविक माउस क्लिक से आता है या उंगली के टैप से। सिस्टम इसे स्वचालित रूप से आपके लिए करेगा।
यूनिवर्सल बिल्डिंग ब्लॉक्स
कुछ मूल्यवान बिल्डिंग ब्लॉक हैं, जो यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) में कई डिवाइस परिवारों के लिए एप्लिकेशन डिजाइन करना आसान बनाते हैं।
यूनिवर्सल कंट्रोल
UWP यूनिवर्सल नियंत्रण का एक सेट प्रदान करता है जो सभी विंडोज 10 उपकरणों पर अच्छी तरह से काम करने की गारंटी है।
इस 'यूनिवर्सल कंट्रोल' सूची में रेडियो बटन, कॉम्बोक्स और टेक्स्ट बॉक्स आदि जैसे सामान्य नियंत्रण हैं।
इसमें कुछ परिष्कृत नियंत्रण भी शामिल हैं जैसे grid view तथा list view जो डेटा की एक धारा और एक टेम्पलेट से वस्तुओं की एक सूची उत्पन्न कर सकता है।
यूनिवर्सल स्टाइल्स
UWP ऐप स्वचालित रूप से उन शैलियों का एक डिफ़ॉल्ट सेट प्राप्त करता है जो आपको ये सुविधाएँ प्रदान करते हैं -
शैलियों का एक सेट जो स्वचालित रूप से आपके ऐप को एक प्रकाश या अंधेरे विषय देता है।
बातचीत के लिए डिफ़ॉल्ट एनिमेशन।
उच्च-विपरीत मोड के लिए स्वचालित समर्थन।
अन्य भाषाओं के लिए स्वचालित समर्थन। हमारी डिफ़ॉल्ट शैलियाँ स्वचालित रूप से विंडोज का समर्थन करने वाली हर भाषा के लिए सही फ़ॉन्ट का चयन करती हैं। आप एक ही ऐप में कई भाषाओं का उपयोग कर सकते हैं और वे ठीक से प्रदर्शित होंगे।
एक यूनिवर्सल विंडोज प्लेटफ़ॉर्म (UWP) एप्लिकेशन कई अलग-अलग डिवाइसों पर चल सकता है और प्रत्येक डिवाइस का इनपुट, स्क्रीन रिज़ॉल्यूशन, DPI घनत्व और अन्य विशिष्ट विशेषताओं का अपना रूप है।
विंडोज 10 में, नए यूनिवर्सल कंट्रोल, लेआउट पैनल और टूलिंग की मदद से आप अपने यूआई को उन डिवाइसों में आसानी से अनुकूलित कर सकते हैं, जिन पर आपका एप्लिकेशन चल सकता है। उदाहरण के लिए, जब आपका UWP एप्लिकेशन डेस्कटॉप कंप्यूटर, मोबाइल डिवाइस या टैबलेट पर चल रहा होता है, तो आप अलग-अलग स्क्रीन रिज़ॉल्यूशन, स्क्रीन साइज़ और DPI घनत्व का लाभ लेने के लिए UI को दर्जी कर सकते हैं।
विंडोज 10 में, आप निम्न विशेषताओं के साथ अपने यूआई को कई उपकरणों के लिए आसानी से लक्षित कर सकते हैं -
आप सार्वभौमिक नियंत्रण और लेआउट पैनल का उपयोग करके विभिन्न स्क्रीन रिज़ॉल्यूशन और स्क्रीन आकार के लिए अपने UI को बढ़ा सकते हैं।
सामान्य इनपुट हैंडलिंग आपको एक टच पैड, एक पेन, एक माउस, एक कीबोर्ड, या एक नियंत्रक जैसे Microsoft Xbox नियंत्रक के माध्यम से इनपुट प्राप्त करने की अनुमति देता है।
टूल्स की मदद से, आप अपने एप्लिकेशन UI को डिज़ाइन कर सकते हैं जो विभिन्न स्क्रीन रिज़ॉल्यूशन के अनुकूल हो सकते हैं।
अनुकूली स्केलिंग रिज़ॉल्यूशन और डीपीआई के अंतर को उपकरणों के बीच समायोजित करती है।
विंडोज 10 में, आप आसानी से किसी भी तरह से अनुप्रयोगों को व्यवस्थित कर सकते हैं, आकार और स्थिति को बदल सकते हैं। यह उपयोगकर्ता को आपके एप्लिकेशन का उपयोग करने के लिए किसी प्रकार का लचीलापन भी देता है, जिस तरह से वे चाहते हैं। विंडोज 10 में, आपके यूडब्ल्यूपी एप्लिकेशन में उत्तरदायी तकनीकों को लागू करने के विभिन्न तरीके हैं, इसलिए यह बहुत अच्छी लगती है कि स्क्रीन या विंडो का आकार क्या है।
VisualStateManager
विंडोज 10 में, VisualStateManagerकक्षा में दो नए तंत्र हैं जिनकी सहायता से आप अपने यूडब्ल्यूपी अनुप्रयोगों में एक उत्तरदायी डिज़ाइन लागू कर सकते हैं। नयाVisualState.StateTriggers डेवलपर खिड़की की ऊंचाई या खिड़की की चौड़ाई और फिर जैसी कुछ शर्तों की जांच करने की अनुमति देता है VisualState.Setters एपीआई उन कुछ शर्तों के जवाब में दृश्य राज्यों को परिभाषित करते हैं।
नीचे दिए गए उदाहरण पर एक नजर डालते हैं जिसमें स्टैक पैनल में कुछ नियंत्रण जोड़े जाते हैं।
<Page
x:Class = "UWPAdaptiveUI.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPAdaptiveUI"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<VisualStateManager.VisualStateGroups>
<VisualStateGroup>
<VisualState>
<VisualState.StateTriggers>
<!-- VisualState to be triggered when window
width is >=720 effective pixels. -->
<AdaptiveTrigger MinWindowWidth = "720" />
</VisualState.StateTriggers>
<VisualState.Setters>
<Setter Target = "myPanel.Orientation" Value = "Horizontal" />
</VisualState.Setters>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<StackPanel x:Name = "myPanel" Orientation = "Vertical">
<TextBlock Text = "Windows 10 Tutorials: Text block 1. "
Style = "{ThemeResource BodyTextBlockStyle}"/>
<TextBlock Text = "Windows 10 Tutorials: Text block 2. "
Style = "{ThemeResource BodyTextBlockStyle}"/>
<TextBlock Text = "Windows 10 Tutorials: Text block 3. "
Style = "{ThemeResource BodyTextBlockStyle}"/>
</StackPanel>
</Grid>
</Page>
अभी VisualStateManager, खिड़की की चौड़ाई के आधार पर स्टैक पैनल के उन्मुखीकरण को समायोजित करेगा। यदि चौड़ाई> = 720 है, तो अभिविन्यास क्षैतिज हो जाएगा अन्यथा यह लंबवत रहेगा। जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप निम्न विंडो देखेंगे, जिसमें ऊर्ध्वाधर क्रम में तीन पाठ ब्लॉक हैं।
आइए हम उपरोक्त विंडो की चौड़ाई का आकार बदलते हैं और आपको निम्न विंडो दिखाई देगी -
अब आप देख सकते हैं कि टेक्स्ट ब्लॉक क्षैतिज क्रम में हैं।
RelativePanel
RelativePanelयूआई तत्वों को तत्वों के बीच स्थानिक संबंधों को व्यक्त करने के लिए इस्तेमाल किया जा सकता है। आइए एक उदाहरण लेते हैं जिसमें रिश्तेदार पैनल में कुछ आयतें बनाई जाती हैं।
<Page
x:Class = "UWPAdaptiveUI.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPAdaptiveUI"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<VisualStateManager.VisualStateGroups>
<VisualStateGroup>
<VisualState>
<VisualState.StateTriggers>
<AdaptiveTrigger MinWindowWidth = "720" />
</VisualState.StateTriggers>
<VisualState.Setters>
<Setter Target = "GreenRect.(RelativePanel.RightOf)"
Value = "BlueRect" />
<Setter Target = "GreenRect.(RelativePanel.AlignRightWithPanel)"
Value = "True" />
</VisualState.Setters>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<RelativePanel BorderBrush = "Gray" BorderThickness = "10">
<Rectangle x:Name = "RedRect" Fill = "Red" MinHeight = "100"
MinWidth = "100"/>
<Rectangle x:Name = "BlueRect" Fill = "Blue" MinHeight = "100"
MinWidth = "100" RelativePanel.RightOf = "RedRect" />
<!-- Width is not set on the green and yellow rectangles.
It's determined by the RelativePanel properties. -->
<Rectangle x:Name = "GreenRect" Fill = "Green" MinHeight = "100"
RelativePanel.Below = "BlueRect" RelativePanel.AlignLeftWith = "RedRect"
RelativePanel.AlignRightWith = "BlueRect"/>
<Rectangle Fill = "Yellow" MinHeight = "100" RelativePanel.Below = "GreenRect"
RelativePanel.AlignLeftWith = "BlueRect"
RelativePanel.AlignRightWithPanel = "True"/>
</RelativePanel>
</Grid>
</Page>
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
जब आप उपरोक्त विंडो का आकार बदलते हैं, तो आप देखेंगे कि नीचे दिखाई गई नीली आयत के बाईं ओर अब हरे रंग की आयत को शीर्ष पंक्ति में समायोजित किया गया है।
इस अध्याय में, हम आपके एप्लिकेशन को विंडोज १० द्वारा समर्थित विभिन्न उपकरणों में अपनाने का प्रदर्शन करेंगे। हमने आपके यूआई और यूडब्ल्यूपी एप्लिकेशन में उपयोग की जाने वाली सभी ट्रिक्स, तकनीकों और नियंत्रणों को अपनाने के बारे में पहले ही जान लिया है।
अब, हम आपके कोड को अपनाने के बारे में जानेंगे, क्योंकि
एप्लिकेशन कोड सभी उपकरणों में समान नहीं हैं।
विशेष रूप से Xbox के लिए उपयोग किए जाने वाले API, मोबाइल उपकरणों के लिए उपलब्ध नहीं होंगे। यही बात होलोन्स आदि के लिए भी सही है।
Adaptive कोड आपके एप्लिकेशन को सशर्त रूप से लाइट कर सकता है और किसी विशिष्ट डिवाइस परिवार और / या प्लेटफ़ॉर्म / एक्सटेंशन API के किसी विशेष संस्करण पर चलने पर ही कोड निष्पादित कर सकता है।
लेखन संहिता
विंडोज 10 में, आप C ++, C #, विजुअल बेसिक या जावास्क्रिप्ट का उपयोग करके Visual Studio में UWP एप्लिकेशन को लागू कर सकते हैं।
C # और Visual Basic से आप UI डिजाइनिंग के लिए XAML का उपयोग कर सकते हैं।
C ++ से आप XAML का उपयोग करने के बजाय DirectX का उपयोग कर सकते हैं।
जावास्क्रिप्ट के लिए, आप अपनी प्रस्तुति परत के लिए HTML का उपयोग कर सकते हैं, जो एक क्रॉस प्लेटफॉर्म वेब मानक है।
विंडोज कोर एपीआई सभी उपकरणों के लिए उसी तरह से चलता है, जिसमें आपके कोड और यूआई के लिए आवश्यक अधिकांश कार्यक्षमता होती है। हालाँकि, कोड और यूआई के लिए विशेष उपकरण परिवारों के अनुरूप है, आपको अनुकूली कोड और अनुकूली यूआई का उपयोग करने की आवश्यकता है।
Calling an API that is NOT implemented by the target device family −
यूआई अलग-अलग स्क्रीनों पर आसानी से एडाप्ट करता है, लेकिन अलग-अलग डिवाइस परिवारों में न केवल अलग-अलग स्क्रीन साइज होते हैं, यह उससे बहुत अधिक है।
उदाहरण के लिए, मोबाइल फोन में कुछ हार्डवेयर बटन होते हैं जैसे कि बैक और कैमरा, जो अन्य उपकरणों जैसे पीसी पर उपलब्ध नहीं हो सकता है।
डिफ़ॉल्ट रूप से, कोर एपीआई में अधिकांश कार्यक्षमता होती है, जो सभी उपकरणों के लिए काम करती है, लेकिन डिवाइस की विशिष्ट कार्यक्षमता का उपयोग बाहरी यूडी विधानसभाओं की तरह ही आपके यूडब्ल्यूपी अनुप्रयोगों में एक्सटेंशन एसडीके को संदर्भित करके किया जा सकता है।
आपके आवेदन में आवश्यक किसी विशेष एक्सटेंशन को जोड़ने के लिए, नीचे दिए गए चरणों का पालन करें -
पर राइट क्लिक करें References।
चुनते हैं “Add References..”। निम्नलिखित संवाद खुल जाएगा।
एक्सटेंशन जोड़ना प्रोजेक्ट रेफरेंस को जोड़ना उतना ही सरल है।
अब आप सूची से कोई भी एक्सटेंशन SDK जोड़ सकते हैं, जिसमें डेस्कटॉप एक्सटेंशन, IoT एक्सटेंशन और मोबाइल एक्सटेंशन आदि शामिल हैं।
डेस्कटॉप और मोबाइल एक्सटेंशन दो सबसे सामान्य प्लेटफ़ॉर्म एक्सटेंशन SDK हैं। उदाहरण के लिए, मोबाइल एक्सटेंशन हार्डवेयर कैमरा बटन का उपयोग करने के लिए आवश्यक API को सक्षम करता है।
आप डिवाइस क्षमताओं का उपयोग करके जाँच कर सकते हैं Windows.Foundation.Metadata.ApiInformationवर्ग विधि, जो एक बूलियन आउटपुट देता है यदि प्रकार वर्तमान डिवाइस पर समर्थित है। उदाहरण के लिए, आप अपने विंडोज ऐप को इस तरह कोड वाले कैमरा बटन का उपयोग करने में सक्षम कर सकते हैं -
bool isHardwareButtonsAPIPresent =
Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.Phone.UI.Inpu t.HardwareButtons");
if (isHardwareButtonsAPIPresent) {
Windows.Phone.UI.Input.HardwareButtons.CameraPressed += HardwareButtons_CameraPressed;
}
डिवाइस पर मोबाइल एक्सटेंशन एसडीके सक्षम होने पर ही फोन-कैमरा बटन कोड निष्पादित होगा। इसी तरह, आप वर्तमान एपीआई संस्करण में किसी विशेष घटना, विधि या संपत्ति की जांच कर सकते हैंIsEventPresent, IsMethodPresent, IsPropertyPresent, के बजाय IsTypePresent जैसा की नीचे दिखाया गया।
bool isHardwareButtons_CameraPressedAPIPresent =
Windows.Foundation.Metadata.ApiInformation.IsEventPresent
("Windows.Phone.UI.Input.HardwareButtons", "CameraPressed");
U32P में Win32 एपीआई
एक यूनिवर्सल विडो प्लेटफ़ॉर्म (UWP) एप्लिकेशन या विंडोज रनटाइम कंपोनेंट, जो C ++ / CX में लिखे गए हैं, Win32 API तक पहुँच सकते हैं, जो अब UWP का एक हिस्सा हैं। विंडोज 10 के सभी डिवाइस परिवार आपके आवेदन के साथ लिंक करके Win32 API को लागू कर सकते हैंWindowsapp.lib।
Windowsapp.libयूडब्ल्यूपी एपीआई के लिए निर्यात प्रदान करने वाला "छाता" परिवाद है। से लिंक हो रहा हैWindowsapp.lib पर अपने एप्लिकेशन निर्भरता में जोड़ देगा dlls जो सभी विंडोज 10 डिवाइस परिवारों पर मौजूद हैं।
आइए हम एक सरल उदाहरण पर ध्यान दें जिसमें एप्लिकेशन डेस्कटॉप और फोन दोनों को लक्षित करता है। इसलिए, जब एप्लिकेशन डेस्कटॉप पर चलता है, तो यह स्टेटस बार नहीं दिखाएगा, लेकिन जब वही एप्लिकेशन फोन पर चलता है, तो यह स्टेटस बार प्रदर्शित करेगा।
नीचे दिया गया XAML कोड है जिसमें विभिन्न नियंत्रण जोड़े जाते हैं।
<Page
x:Class = "UWPAdoptiveCode.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPAdoptiveCode"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Page.Background>
<SolidColorBrush Color = "Green"/>
</Page.Background>
<Page.BottomAppBar>
<CommandBar x:Name = "commandBar" >
<AppBarButton Icon = "Accept" Label = "appbarbutton"/>
<AppBarButton Icon = "Cancel" Label = "appbarbutton"/>
</CommandBar>
</Page.BottomAppBar>
<Grid Background = "AliceBlue">
<VisualStateManager.VisualStateGroups>
<VisualStateGroup>
<VisualState>
<VisualState.StateTriggers>
<local:DeviceFamilyTrigger DeviceFamily = "Desktop" />
</VisualState.StateTriggers>
<VisualState.Setters>
<Setter Target = "StatusBarControls.Visibility"
Value = "Collapsed"/>
</VisualState.Setters>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<StackPanel HorizontalAlignment = "Left" Margin = "75,164,0,0"
VerticalAlignment = "Top" >
<RadioButton x:Name = "ShowAppBarRadioButton" Content = "Show AppBar"
HorizontalAlignment = "Stretch" VerticalAlignment = "Stretch"
IsChecked = "True" Checked = "RadioButton_Checked"/>
<RadioButton x:Name = "ShowOpaqueAppBarRadioButton"
Content = "Show Transparent AppBar" HorizontalAlignment = "Stretch"
VerticalAlignment = "Stretch" Checked = "RadioButton_Checked"/>
<RadioButton x:Name = "HideAppBarRadioButton" Content = "Hide AppBar"
HorizontalAlignment = "Stretch" VerticalAlignment = "Stretch"
Checked = "RadioButton_Checked"/>
</StackPanel>
<StackPanel x:Name = "StatusBarControls" Orientation = "Vertical"
Margin = "75,350,0,0" Visibility = "Visible">
<CheckBox x:Name = "StatusBarBackgroundCheckBox"
Content = "Set StatusBar Background"
Checked = "StatusBarBackgroundCheckBox_Checked"
Unchecked = "StatusBarBackgroundCheckBox_Unchecked"/>
<CheckBox x:Name = "StatusBarHiddenCheckBox"
Content = "Set StatusBar Hidden" Checked = "StatusBarHiddenCheckBox_Checked"
Unchecked = "StatusBarHiddenCheckBox_Unchecked"/>
</StackPanel>
</Grid>
</Page>
नीचे दिए गए विभिन्न घटनाओं के लिए C # कार्यान्वयन है।
using Windows.UI;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPAdoptiveCode {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
private Color? DefaultTitleBarButtonsBGColor;
private Color? DefaultTitleBarBGColor;
public MainPage() {
this.InitializeComponent();
//Windows.UI.ViewManagement.ApplicationView.GetForCurrentView().
VisibleBoundsCh anged += MainPage_VisibleBoundsChanged;
var viewTitleBar = Windows.UI.ViewManagement.ApplicationView.
GetForCurrentView().TitleBar;
DefaultTitleBarBGColor = viewTitleBar.BackgroundColor;
DefaultTitleBarButtonsBGColor = viewTitleBar.ButtonBackgroundColor;
}
private void RadioButton_Checked(object sender, RoutedEventArgs e) {
// Bottom AppBar shows on Desktop and Mobile
if (ShowAppBarRadioButton != null) {
if (ShowAppBarRadioButton.IsChecked.HasValue &&
(ShowAppBarRadioButton.IsChecked.Value == true)) {
commandBar.Visibility = Windows.UI.Xaml.Visibility.Visible;
commandBar.Opacity = 1;
} else {
commandBar.Visibility = Windows.UI.Xaml.Visibility.Collapsed;
}
}
if (ShowOpaqueAppBarRadioButton != null) {
if (ShowOpaqueAppBarRadioButton.IsChecked.HasValue &&
(ShowOpaqueAppBarRadioButton.IsChecked.Value == true)){
commandBar.Visibility = Windows.UI.Xaml.Visibility.Visible;
commandBar.Background.Opacity = 0;
} else{
commandBar.Background.Opacity = 1;
}
}
}
private void StatusBarHiddenCheckBox_Checked(object sender, RoutedEventArgs e){
// StatusBar is Mobile only
if (Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.UI.ViewManag ement.StatusBar")){
var ignore = Windows.UI.ViewManagement.StatusBar.GetForCurrentView().HideAsync();
}
}
private void StatusBarHiddenCheckBox_Unchecked(object sender, RoutedEventArgs e){
// StatusBar is Mobile only
if (Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.UI.ViewManag ement.StatusBar")){
var ignore = Windows.UI.ViewManagement.StatusBar.GetForCurrentView().ShowAsync();
}
}
private void StatusBarBackgroundCheckBox_Checked(object sender, RoutedEventArgs e){
// StatusBar is Mobile only
if (Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.UI.ViewManag ement.StatusBar")){
Windows.UI.ViewManagement.StatusBar.GetForCurrentView().
BackgroundColor = Windows.UI.Colors.Blue;
Windows.UI.ViewManagement.StatusBar.GetForCurrentView().
BackgroundOpacity = 1;
}
}
private void StatusBarBackgroundCheckBox_Unchecked(object sender, RoutedEventArgs e){
// StatusBar is Mobile only
if (Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.UI.ViewManag ement.StatusBar")){
Windows.UI.ViewManagement.StatusBar.GetForCurrentView().
BackgroundOpacity = 0;
}
}
}
public class DeviceFamilyTrigger : StateTriggerBase{
//private variables
private string _deviceFamily;
//Public property
public string DeviceFamily {
get {
return _deviceFamily;
}
set{
_deviceFamily = value;
var qualifiers = Windows.ApplicationModel.Resources.Core.ResourceContext.
GetForCurrentView().Qua lifierValues;
if (qualifiers.ContainsKey("DeviceFamily"))
SetActive(qualifiers["DeviceFamily"] == _deviceFamily);
else
SetActive(false);
}
}
}
}
जब ऊपर दिया गया कोड मोबाइल पर संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
आप चेकबॉक्स के साथ स्टेटस बार का बैकग्राउंड कलर बदल सकते हैं जैसा कि इमेज में दिखाया गया है।
आप स्टेटस बार को भी छिपा सकते हैं।
अब, जब आप डेस्कटॉप डिवाइस पर एक ही एप्लिकेशन चलाते हैं, तो आपको निम्न विंडो दिखाई देगी जिसमें स्टेटस बार और स्टेटस बार के लिए चेकबॉक्स दिखाई नहीं दे रहे हैं।
किसी भी एप्लिकेशन में, सबसे महत्वपूर्ण चीज डेटा है। अगर आप.net डेवलपर, आप अलग-अलग भंडारण के बारे में जान सकते हैं और यही अवधारणा यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) अनुप्रयोगों के माध्यम से चलती है।
फ़ाइल स्थान
ये ऐसे क्षेत्र हैं जहां आपका एप्लिकेशन डेटा एक्सेस कर सकता है। एप्लिकेशन में कुछ क्षेत्र शामिल हैं, जो उस विशेष एप्लिकेशन के लिए निजी है और दूसरों के लिए दुर्गम है, लेकिन कई अन्य क्षेत्र हैं, जहां आप किसी फ़ाइल के अंदर अपने डेटा को संग्रहीत और सहेज सकते हैं।
नीचे दिए गए प्रत्येक फ़ोल्डर का संक्षिप्त विवरण दिया गया है।
क्र.सं. | फ़ोल्डर और विवरण |
---|---|
1 | App package folder पैकेज मैनेजर ऐप के सभी संबंधित फ़ाइलों को ऐप पैकेज फ़ोल्डर में स्थापित करता है, और ऐप केवल इस फ़ोल्डर से डेटा पढ़ सकता है। |
2 | Local folder एप्लिकेशन स्थानीय डेटा को स्थानीय फ़ोल्डर में संग्रहीत करते हैं। यह स्टोरेज डिवाइस पर सीमा तक डेटा स्टोर कर सकता है। |
3 | Roaming folder एप्लिकेशन से संबंधित सेटिंग और गुण रोमिंग फ़ोल्डर में संग्रहीत किए जाते हैं। अन्य डिवाइस भी इस फ़ोल्डर से डेटा एक्सेस कर सकते हैं। इसमें प्रति एप्लिकेशन 100KB तक सीमित आकार है। |
4 | Temp Folder अस्थायी भंडारण का उपयोग और इस बात की कोई गारंटी नहीं है कि यह तब भी उपलब्ध होगा जब आपका आवेदन फिर से चलेगा। |
5 | Publisher Share एक ही प्रकाशक से सभी ऐप्स के लिए साझा किया गया संग्रहण। इसे ऐप मेनिफेस्ट में घोषित किया गया है। |
6 | Credential Locker पासवर्ड क्रेडेंशियल ऑब्जेक्ट के सुरक्षित भंडारण के लिए उपयोग किया जाता है। |
7 | OneDrive OneDrive मुफ़्त ऑनलाइन संग्रहण है जो आपके Microsoft खाते के साथ आता है। |
8 | Cloud क्लाउड पर डेटा स्टोर करें। |
9 | Known folders ये फ़ोल्डर पहले से ही मेरे चित्र, वीडियो और संगीत जैसे फ़ोल्डर को जानते हैं। |
10 | Removable storage USB संग्रहण डिवाइस या बाहरी हार्ड ड्राइव आदि। |
फ़ाइल हैंडलिंग API
विंडोज 8 में, फ़ाइल हैंडलिंग के लिए नए एपीआई पेश किए गए थे। ये API में स्थित हैंWindows.Storage तथा Windows.Storage.Streamsनामस्थान। आप इन API का उपयोग इसके बजाय कर सकते हैंSystem.IO.IsolatedStorageनाम स्थान। इन एपीआई का उपयोग करके, अपने विंडोज फोन ऐप को विंडोज स्टोर में पोर्ट करना आसान हो जाएगा, और आप आसानी से अपने एप्लिकेशन को विंडोज के भविष्य के संस्करणों में अपग्रेड कर सकते हैं।
स्थानीय, रोमिंग या अस्थायी फ़ोल्डर तक पहुंचने के लिए, आपको इन API को कॉल करना होगा -
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFolder roamingFolder = ApplicationData.Current.RoamingFolder;
StorageFolder tempFolder = ApplicationData.Current.TemporaryFolder;
स्थानीय फ़ोल्डर में एक नई फ़ाइल बनाने के लिए निम्नलिखित कोड का उपयोग करें -
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFile textFile = await localFolder.CreateFileAsync(filename,
CreationCollisionOption.ReplaceExisting);
यहां नई बनाई गई फ़ाइल को खोलने और उस फ़ाइल में कुछ सामग्री लिखने के लिए कोड है।
using (IRandomAccessStream textStream = await textFile.OpenAsync(FileAccessMode.ReadWrite)) {
using (DataWriter textWriter = new DataWriter(textStream)){
textWriter.WriteString(contents);
await textWriter.StoreAsync();
}
}
आप स्थानीय फ़ाइल से फिर से उसी फ़ाइल को खोल सकते हैं, जैसा कि नीचे दिए गए कोड में दिखाया गया है।
using (IRandomAccessStream textStream = await textFile.OpenReadAsync()) {
using (DataReader textReader = new DataReader(textStream)){
uint textLength = (uint)textStream.Size;
await textReader.LoadAsync(textLength);
contents = textReader.ReadString(textLength);
}
}
यह समझने के लिए कि डेटा का पढ़ना और लिखना कैसे काम करता है, आइए हम एक सरल उदाहरण पर एक नज़र डालें। नीचे दिया गया XAML कोड है जिसमें विभिन्न नियंत्रण जोड़े जाते हैं।
<Page
x:Class = "UWPFileHandling.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPFileHandling"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Button x:Name = "readFile" Content = "Read Data From File"
HorizontalAlignment = "Left" Margin = "62,518,0,0"
VerticalAlignment = "Top" Height = "37" Width = "174"
Click = "readFile_Click"/>
<TextBox x:FieldModifier = "public" x:Name = "textBox"
HorizontalAlignment = "Left" Margin = "58,145,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Height = "276" Width = "245"/>.
<Button x:Name = "writeFile" Content = "Write Data to File"
HorizontalAlignment = "Left" Margin = "64,459,0,0"
VerticalAlignment = "Top" Click = "writeFile_Click"/>
<TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"
Margin = "386,149,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Height = "266" Width = "250"
Foreground = "#FF6231CD"/>
</Grid>
</Page>
नीचे दिए गए विभिन्न घटनाओं के लिए C # कार्यान्वयन है और कार्यान्वयन भी है FileHelper पाठ फ़ाइल में डेटा पढ़ने और लिखने के लिए कक्षा।
using System;
using System.IO;
using System.Threading.Tasks;
using Windows.Storage;
using Windows.Storage.Streams;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPFileHandling {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public partial class MainPage : Page {
const string TEXT_FILE_NAME = "SampleTextFile.txt";
public MainPage(){
this.InitializeComponent();
}
private async void readFile_Click(object sender, RoutedEventArgs e) {
string str = await FileHelper.ReadTextFile(TEXT_FILE_NAME);
textBlock.Text = str;
}
private async void writeFile_Click(object sender, RoutedEventArgs e) {
string textFilePath = await FileHelper.WriteTextFile(TEXT_FILE_NAME, textBox.Text);
}
}
public static class FileHelper {
// Write a text file to the app's local folder.
public static async Task<string>
WriteTextFile(string filename, string contents) {
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFile textFile = await localFolder.CreateFileAsync(filename,
CreationCollisionOption.ReplaceExisting);
using (IRandomAccessStream textStream = await
textFile.OpenAsync(FileAccessMode.ReadWrite)){
using (DataWriter textWriter = new DataWriter(textStream)){
textWriter.WriteString(contents);
await textWriter.StoreAsync();
}
}
return textFile.Path;
}
// Read the contents of a text file from the app's local folder.
public static async Task<string> ReadTextFile(string filename) {
string contents;
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFile textFile = await localFolder.GetFileAsync(filename);
using (IRandomAccessStream textStream = await textFile.OpenReadAsync()){
using (DataReader textReader = new DataReader(textStream)){
uint textLength = (uint)textStream.Size;
await textReader.LoadAsync(textLength);
contents = textReader.ReadString(textLength);
}
}
return contents;
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
अब, आप टेक्स्टबॉक्स में कुछ लिखते हैं और क्लिक करते हैं “Write Data to File”बटन। कार्यक्रम एक स्थानीय फ़ोल्डर में पाठ फ़ाइल में डेटा लिखेंगे। यदि आप पर क्लिक करते हैं“Read Data from File” बटन, प्रोग्राम उसी टेक्स्ट फ़ाइल से डेटा पढ़ेगा, जो स्थानीय फ़ोल्डर में स्थित है और इसे टेक्स्ट ब्लॉक पर प्रदर्शित करेगा।
कई अनुप्रयोगों में, कुछ प्रकार के डेटा होते हैं, जिनका एक दूसरे से किसी प्रकार का संबंध होता है। इस प्रकार के डेटा, जो एक फ़ाइल में स्टोर करना मुश्किल है, एक डेटाबेस में संग्रहीत किया जा सकता है।
यदि आप किसी भी एप्लिकेशन में डेटाबेस के प्रकार, जैसे कि SQL सर्वर या Oracle डेटाबेस से परिचित हैं, तो यह समझना बहुत आसान है SQLite database।
SQLite क्या है?
SQLite एक सॉफ्टवेयर लाइब्रेरी है जो एक आत्म निहित, सर्वर कम, शून्य-कॉन्फ़िगरेशन, ट्रांसेक्शनल SQL डेटाबेस इंजन को लागू करता है।
महत्वपूर्ण विशेषताएं हैं -
SQLite दुनिया में सबसे व्यापक रूप से तैनात डेटाबेस इंजन है।
SQLite के लिए स्रोत कोड खुला स्रोत है।
पोर्टेबिलिटी और छोटे पदचिह्न के कारण खेल और मोबाइल एप्लिकेशन विकास पर इसका बड़ा प्रभाव पड़ा है।
SQLite के लाभ
SQLite के फायदे निम्नलिखित हैं -
- यह बहुत हल्का डेटाबेस है।
- यह प्लेटफॉर्म स्वतंत्र है और सभी प्लेटफार्मों पर काम करता है।
- इसमें एक छोटा मेमोरी फुटप्रिंट है।
- यह विश्वसनीय है।
- किसी भी सेटअप और स्थापना के लिए कोई ज़रूरत नहीं है।
- इसकी कोई निर्भरता नहीं है।
काम में लाना SQLite अपने यूनिवर्सल विंडोज प्लेटफ़ॉर्म (UWP) अनुप्रयोगों में, आपको नीचे दिए गए चरणों का पालन करने की आवश्यकता है।
नाम के साथ एक नया यूनिवर्सल विंडोज खाली ऐप बनाएं UWPSQLiteDemo।
के पास जाओ Toolsमेनू और एक्सटेंशन और अपडेट का चयन करें। निम्नलिखित संवाद खुल जाएगा।
- एक्सटेंशन और अपडेट का चयन करने के बाद, निम्न विंडो खुल जाएगी।
अब का चयन करें Online विकल्प और बाएँ फलक से SQLite के लिए खोजें।
यूनिवर्सल ऐप प्लेटफ़ॉर्म के लिए SQLite डाउनलोड और इंस्टॉल करें।
अब, टूल मेनू पर फिर से जाएं और चुनें NuGet Package Manager > Package Manager Console मेनू विकल्प जैसा कि नीचे दिखाया गया है।
पैकेज मैनेजर कंसोल में निम्नलिखित कमांड लिखें और इस कमांड को निष्पादित करने के लिए एंटर दबाएं -
Install-Package SQLite.Net-PCL
अब राईट क्लिक करे References समाधान एक्सप्लोरर में और चुनें Add References।
- निम्नलिखित संवाद खुल जाएगा।
चुनते हैं Extensions के नीचे बाएँ फलक से Universal Windows, यूनिवर्सल फलक में यूनिवर्सल ऐप प्लेटफ़ॉर्म के लिए SQLite की जाँच करें, और ओके पर क्लिक करें।
अब आप अपने UWP अनुप्रयोगों में SQLite पर जाने और उसका उपयोग करने के लिए तैयार हैं।
आप निम्न कोड का उपयोग करके एक डेटाबेस बना सकते हैं।
string path = Path.Combine(Windows.Storage.ApplicationData.
Current.LocalFolder.Path, "db.sqlite");
SQLite.Net.SQLiteConnection conn = new SQLite.Net.SQLiteConnection(new
SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);
एक तालिका बनाने के लिए आपको कॉल करने की आवश्यकता है CreateTable तालिका नाम ऑब्जेक्ट के साथ विधि।
conn.CreateTable<Customer>();
आप निम्न कोड का उपयोग करके डेटा को अपनी तालिका में सम्मिलित कर सकते हैं।
conn.Insert(new Customer(){
Name = textBox.Text,
Age = textBox1.Text
});
नीचे दी गई तालिका से डेटा पुनर्प्राप्त करने के लिए कोड है।
var query = conn.Table<Customer>();
string id = "";
string name = "";
string age = "";
foreach (var message in query) {
id = id + " " + message.Id;
name = name + " " + message.Name;
age = age + " " + message.Age;
}
आइए हम समझते हैं कि एक डेटाबेस, एक तालिका कैसे बनाएं और एक साधारण उदाहरण की मदद से डेटाबेस से डेटा कैसे डालें और पुनर्प्राप्त करें। हम नाम और आयु को जोड़ रहे हैं और फिर हम तालिका से समान डेटा प्राप्त करेंगे। नीचे दिया गया XAML कोड है जिसमें विभिन्न नियंत्रण जोड़े जाते हैं।
<Page
x:Class = "UWPSQLiteDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPSQLiteDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}" >
<Button x:Name = "Retrieve" Content = "Retrieve" HorizontalAlignment = "Left"
VerticalAlignment = "Top" Margin = "384,406,0,0"
Click = "Retrieve_Click"/>
<Button x:Name = "Add" Content = "Add" HorizontalAlignment = "Left"
VerticalAlignment = "Top" Margin = "291,406,0,0" Click = "Add_Click"/>
<TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"
TextWrapping = "Wrap" Text = "Name" VerticalAlignment = "Top"
Margin = "233,280,0,0" Width = "52"/>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left" TextWrapping = "Wrap"
VerticalAlignment = "Top" Margin = "289,274,0,0" Width = "370"/>
<TextBlock x:Name = "textBlock1" HorizontalAlignment = "Left"
TextWrapping = "Wrap" Text = "Age" VerticalAlignment = "Top"
Margin = "233,342,0,0" Width = "52"/>
<TextBox x:Name = "textBox1" HorizontalAlignment = "Left" TextWrapping = "Wrap"
VerticalAlignment = "Top" Margin = "289,336,0,0" Width = "191"/>
<TextBlock x:Name = "textBlock2" HorizontalAlignment = "Left"
Margin = "290,468,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Width = "324" Height = "131"/>
</Grid>
</Page>
नीचे दिए गए घटनाओं के लिए C # कार्यान्वयन है और SQLite database।
using SQLite.Net.Attributes;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPSQLiteDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
string path;
SQLite.Net.SQLiteConnection conn;
public MainPage(){
this.InitializeComponent();
path = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path,
"db.sqlite");
conn = new SQLite.Net.SQLiteConnection(new
SQLite.Net.Platform.WinRT.SQLitePlatformWinRT(), path);
conn.CreateTable<Customer>();
}
private void Retrieve_Click(object sender, RoutedEventArgs e) {
var query = conn.Table<Customer>();
string id = "";
string name = "";
string age = "";
foreach (var message in query) {
id = id + " " + message.Id;
name = name + " " + message.Name;
age = age + " " + message.Age;
}
textBlock2.Text = "ID: " + id + "\nName: " + name + "\nAge: " + age;
}
private void Add_Click(object sender, RoutedEventArgs e){
var s = conn.Insert(new Customer(){
Name = textBox.Text,
Age = textBox1.Text
});
}
}
public class Customer {
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
public string Name { get; set; }
public string Age { get; set; }
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
प्रवेश करें Name तथा Age और क्लिक करें Add बटन।
अब on पर क्लिक करें Retrieveबटन। आप निम्न डेटा को देखेंगेText Block।
आईडी फ़ील्ड एक प्राथमिक कुंजी और ऑटो इंक्रीमेंट फ़ील्ड है, जो ग्राहक वर्ग में निर्दिष्ट है।
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
ऐप टू ऐप कम्युनिकेशन का अर्थ है कि आपका एप्लिकेशन किसी अन्य एप्लिकेशन के साथ बात या संचार कर सकता है जो उसी डिवाइस पर स्थापित है। यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन में यह कोई नई सुविधा नहीं है और विंडोज 8.1 में भी उपलब्ध थी।
विंडोज 10 में, एक ही डिवाइस पर एप्लिकेशन के बीच आसानी से संवाद करने के लिए कुछ नए और बेहतर तरीके पेश किए गए हैं। दो ऐप्स के बीच संचार निम्नलिखित तरीकों से हो सकता है -
- एक एप्लिकेशन कुछ डेटा के साथ एक और ऐप लॉन्च कर रहा है।
- ऐप्स बिना कुछ लॉन्च किए केवल डेटा का आदान-प्रदान कर रहे हैं।
ऐप टू ऐप कम्युनिकेशन का मुख्य लाभ यह है कि आप एप्लिकेशन को छोटे-छोटे हिस्सों में तोड़ सकते हैं, जिन्हें आसानी से रखा, अद्यतन और उपभोग किया जा सकता है।
आपका ऐप तैयार हो रहा है
यदि आप नीचे दिए गए चरणों का पालन करते हैं, तो अन्य एप्लिकेशन आपके एप्लिकेशन को लॉन्च कर सकते हैं।
अनुप्रयोग पैकेज मेनिफ़ेस्ट में प्रोटोकॉल घोषणा जोड़ें।
पर डबल क्लिक करें Package.appxmanifest फ़ाइल, जो समाधान एक्सप्लोरर में उपलब्ध है जैसा कि नीचे दिखाया गया है।
के पास जाओ Declaration टैब और प्रोटोकॉल का नाम लिखें जैसा कि नीचे दिखाया गया है।
अगला कदम यह है कि activation कोड, इसलिए एप्लिकेशन दूसरे एप्लिकेशन द्वारा लॉन्च किए जाने पर उचित प्रतिक्रिया दे सकता है।
प्रोटोकॉल क्रियाकलापों का जवाब देने के लिए, हमें ओवरराइड करने की आवश्यकता है OnActivatedसक्रियण वर्ग की विधि। तो, निम्न कोड को इसमें जोड़ेंApp.xaml.cs फ़ाइल।
protected override void OnActivated(IActivatedEventArgs args) {
ProtocolActivatedEventArgs protocolArgs = args as ProtocolActivatedEventArgs;
if (args != null){
Frame rootFrame = Window.Current.Content as Frame;
// Do not repeat app initialization when the Window already has content,
// just ensure that the window is active
if (rootFrame == null){
// Create a Frame to act as the navigation context and navigate to the first page
rootFrame = new Frame();
// Set the default language
rootFrame.Language = Windows.Globalization.ApplicationLanguages.Languages[0];
rootFrame.NavigationFailed += OnNavigationFailed;
// Place the frame in the current Window
Window.Current.Content = rootFrame;
}
if (rootFrame.Content == null){
// When the navigation stack isn't restored, navigate to the
// first page, configuring the new page by passing required
// information as a navigation parameter
rootFrame.Navigate(typeof(MainPage), null);
}
// Ensure the current window is active
Window.Current.Activate();
}
}
एप्लिकेशन लॉन्च करने के लिए, आप बस का उपयोग कर सकते हैं Launcher.LaunchUriAsync विधि, जो इस विधि में निर्दिष्ट प्रोटोकॉल के साथ एप्लिकेशन लॉन्च करेगी।
await Windows.System.Launcher.LaunchUriAsync(new Uri("win10demo:?SomeData=123"));
आइए इसे एक सरल उदाहरण से समझते हैं जिसमें हमारे पास दो UWP एप्लिकेशन हैं ProtocolHandlerDemo तथा FirstProtocolHandler।
इस उदाहरण में, ProtocolHandlerDemo एप्लिकेशन में एक बटन होता है और बटन पर क्लिक करने से वह खुल जाएगा FirstProtocolHandler आवेदन।
प्रोटोकॉलहैंडलरडेमो एप्लिकेशन में XAML कोड, जिसमें एक बटन होता है, नीचे दिया गया है।
<Page
x:Class = "ProtocolHandlerDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:ProtocolHandlerDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Button x:Name = "LaunchButton" Content = " Launch First Protocol App"
FontSize = "24" HorizontalAlignment = "Center"
Click = "LaunchButton_Click"/>
</Grid>
</Page>
नीचे दिया गया C # कोड है, जिसमें बटन क्लिक घटना को लागू किया गया है।
using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace ProtocolHandlerDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage(){
this.InitializeComponent();
}
private async void LaunchButton_Click(object sender, RoutedEventArgs e) {
await Windows.System.Launcher.LaunchUriAsync(new
Uri("win10demo:?SomeData=123"));
}
}
}
अब हम पर एक नजर डालते हैं FirstProtocolHandlerआवेदन तालिका। नीचे दिया गया XAML कोड है जिसमें कुछ गुणों के साथ एक टेक्स्टब्लॉक बनाया गया है।
<Page
x:Class = "FirstProtocolHandler.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:FirstProtocolHandler"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<TextBlock Text = "You have successfully launch First Protocol Application"
TextWrapping = "Wrap" Style = "{StaticResource SubtitleTextBlockStyle}"
Margin = "30,39,0,0" VerticalAlignment = "Top" HorizontalAlignment = "Left"
Height = "100" Width = "325"/>
</Grid>
</Page>
सी # का कार्यान्वयन App.xaml.cs जिसमें दर्ज करें OnActicatedनीचे दिखाया गया है। निम्नलिखित कोड को ऐप क्लास के अंदर जोड़ेंApp.xaml.cs फ़ाइल।
protected override void OnActivated(IActivatedEventArgs args) {
ProtocolActivatedEventArgs protocolArgs = args as ProtocolActivatedEventArgs;
if (args != null) {
Frame rootFrame = Window.Current.Content as Frame;
// Do not repeat app initialization when the Window already has content,
// just ensure that the window is active
if (rootFrame == null) {
// Create a Frame to act as the navigation context and navigate to
the first page
rootFrame = new Frame();
// Set the default language
rootFrame.Language = Windows.Globalization.ApplicationLanguages.Languages[0];
rootFrame.NavigationFailed += OnNavigationFailed;
// Place the frame in the current Window
Window.Current.Content = rootFrame;
}
if (rootFrame.Content == null) {
// When the navigation stack isn't restored navigate to the
// first page, configuring the new page by passing required
// information as a navigation parameter
rootFrame.Navigate(typeof(MainPage), null);
}
// Ensure the current window is active
Window.Current.Activate();
}
}
जब आप संकलित करते हैं और निष्पादित करते हैं ProtocolHandlerDemo एक एमुलेटर पर आवेदन, आप निम्न विंडो देखेंगे।
अब, जब आप बटन पर क्लिक करते हैं, तो यह खुल जाएगा FirstProtocolHandler आवेदन नीचे दिखाया गया है।
विंडोज का उपयोग दुनिया भर में, विभिन्न बाजारों में और लक्षित दर्शकों के लिए किया जाता है जो संस्कृति, क्षेत्र या भाषा में भिन्न होते हैं। स्थानीयकरण विशिष्ट संस्कृतियों के लिए स्थानीयकृत संस्करणों में अनुप्रयोग संसाधनों का अनुवाद है जो अनुप्रयोग का समर्थन करता है।
जब आप किसी भी एप्लिकेशन को केवल एक ही भाषा में विकसित करते हैं, तो इसका मतलब है कि आप अपने व्यवसाय और ग्राहकों को सीमित कर रहे हैं। यदि आप अपने ग्राहक आधार को बढ़ाना चाहते हैं, जो आपके व्यवसाय को भी बढ़ाएगा, तो आपका आवेदन विश्व स्तर पर उपलब्ध और उपलब्ध होना चाहिए। आपके उत्पाद का लागत प्रभावी स्थानीयकरण अधिक ग्राहकों तक पहुंचने के लिए सबसे अच्छे और सबसे किफायती तरीकों में से एक है।
विंडोज 10 में, स्थानीय अनुप्रयोग बनाना आसान है resx फ़ाइल, जो स्थानीयकरण के लिए सबसे सरल उपाय है।
नीचे दिए गए सभी चरणों का पालन करके एक सरल उदाहरण की मदद से इसे समझते हैं।
UI संसाधन का अनुवाद
आप अपने UI के लिए संसाधन में स्ट्रिंग संसाधन डाल सकते हैं (resw) फाइलों को सीधे कोड या मार्कअप में डालने के बजाय, और फिर आप उन स्ट्रिंग्स को अपने कोड या मार्कअप से संदर्भित कर सकते हैं। संसाधन फ़ाइलों में तार जोड़ने के लिए नीचे दिए गए चरणों का पालन करें।
एक नया यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन बनाएं।
में Solution Explorerपरियोजना को राइट-क्लिक करें और चुनें Add > New Folder।
नए फ़ोल्डर का नाम बदलें "Strings"।
राइट-क्लिक करें Strings फ़ोल्डर और नाम के साथ एक नया फ़ोल्डर जोड़ें "en-US"। ये एक भाषा और देश / क्षेत्र के नाम के लिए विशिष्ट सम्मेलनों का नामकरण कर रहे हैं, और यह राष्ट्रीय भाषा समर्थन (NLS) एपीआई संदर्भ msdn.microsoft.com पृष्ठ पर पाया जा सकता है ।
पर राइट क्लिक करें en-US फ़ोल्डर और चयन करें Add > New Item...।
- निम्नलिखित संवाद खुल जाएगा।
चुनते हैं "Resources File (.resw)" और क्लिक करें Add बटन।
अब हमें एक्सएएमएल फाइल पर जाएं और नीचे दिखाए गए गुणों के साथ हब कंट्रोल जोड़ें।
<Page
x:Class = "UWPLocalizationDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPLocalizationDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Hub x:Name = "textBlock" x:Uid = "HubControl" Background = "Black"
Foreground = "White" Header = "Localization Demo"/>
</Grid>
</Page>
x:Uid = "HubControl" वे पहचानकर्ता हैं जिनका उपयोग स्थानीयकरण के लिए किया जाता है
अब, जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
हब से संबंधित सभी जानकारी जैसे कि हैडर, फोरग्राउंड और पृष्ठभूमि का रंग XAML में सेट किया गया है।
अब इसमें कुछ जानकारी जोड़ें Resource.resw में दर्ज करें Strings/en-US फ़ोल्डर नीचे दिखाया गया है।
आपको प्रत्येक नियंत्रण को संबद्ध करने की आवश्यकता है जिसके साथ स्थानीयकृत पाठ की आवश्यकता है।reswफ़ाइल। आप इसका उपयोग करके कर सकते हैंx:Uid इस तरह अपने XAML तत्वों पर विशेषता -
x:Uid = "HubControl" में प्रयोग किया जाता है resw हेडर, अग्रभूमि और पृष्ठभूमि रंग के लिए एक स्ट्रिंग असाइन करने के लिए फ़ाइल।
अब, जब आप एक एमुलेटर पर अपने एप्लिकेशन को संकलित और निष्पादित करते हैं, तो आपको निम्न विंडो दिखाई देगी। आप देख सकते हैं कि हेडर, फोरग्राउंड और बैकग्राउंड कलर वैल्यू को इसमें से लिया गया हैResources.resw फ़ाइल।
आप अन्य जोड़ सकते हैं Resource.resw अन्य भाषाओं जैसे फ्रेंच, जर्मन और जापानी आदि के लिए फाइलें मैन्युअल रूप से, जैसा कि हमने अंग्रेजी-यूएस के लिए किया था, लेकिन Microsoft भी एक प्रदान करता है Multilingual App Toolkit जिसकी मदद से आप आसानी से अपना अनुवाद कर सकते हैं Resource.resw अन्य भाषाओं में।
के पास जाओ Tools > Extensions और मेनू अपडेट करें और खोजें Multilingual app टूलकिट।
इस टूलकिट को डाउनलोड और इंस्टॉल करें। एक बार इंस्टॉलेशन समाप्त होने के बाद, Visual Studio को पुनरारंभ करें और उसी प्रोजेक्ट को खोलें।
अब इस टूलकिट को इसमें से सक्षम करें Tools > Multilingual App टूलकिट मेनू विकल्प।
अब आप अन्य भाषाओं के लिए अनुवाद जोड़ सकते हैं।
में परियोजना पर राइट क्लिक करें Solution Explorer और चुनें Multilingual App Toolkit > Add Translation मेनू से भाषा विकल्प।
निम्नलिखित Translation Languagesडायलॉग खुल जाएगा। आप उन संस्कृतियों के लिए अपने आवेदन को स्थानीयकृत करने के लिए अपनी इच्छित भाषा का चयन कर सकते हैं।
हमें चयन करें German भाषा और क्लिक करें OK बटन।
आप यह भी देख सकते हैं कि Resources.resw फ़ाइल फ़ोल्डर के अंदर बनाई गई है Strings\de।
अब, आप एक और देखेंगे MultiLingualResources के अंदर जोड़ा जाता है *.xlfफ़ाइल। इस फ़ाइल पर डबल क्लिक करें, जो खुल जाएगाMultilingual अनुवादित स्ट्रिंग्स की जांच करने और सत्यापित करने के लिए संपादक और यदि आवश्यक हो तो कुछ बदलाव करें।
परिवर्तन करें और सत्यापित करें कि पृष्ठभूमि का रंग भूरा हो गया है और हैडर पाठ को जर्मन में ठीक से अनुवादित किया गया है।
जैसा कि ऊपर के उदाहरण में, हब की पृष्ठभूमि का रंग नीले रंग से बदलकर भूरा हो गया है और अग्रभूमि का रंग समान रह गया है।
अब खोलें Resources.resw, जो अंदर है Strings\de फ़ोल्डर।
आप देख सकते हैं कि केवल दो तारों का उल्लेख यहां किया गया है, क्योंकि हमने बहुभाषी संपादक पर अग्रभूमि का रंग नहीं बदला है।
अपने एप्लिकेशन के स्थानीयकृत संस्करण की जांच करने के लिए, अपनी मशीन की संस्कृति को बदलें। अपनी मशीन की संस्कृति को बदलने के लिए दिए गए चरणों का पालन करें।
- पीसी सेटिंग्स पर जाएं और टाइम एंड लैंग्वेज चुनें।
बाएँ फलक से, का चयन करें Regions & language और पर क्लिक करें Add a language।
चुनते हैं Deutsch German ऊपर बताई गई भाषा जो एक और संवाद खोलेगी।
अब का चयन करें German (Germany) और इस संवाद बॉक्स को बंद करें।
- डिक्शनरी को डिफ़ॉल्ट भाषा के रूप में बनाएं।
- अब अपने आवेदन को निष्पादित करें, यह निम्नलिखित विंडो प्रदर्शित करेगा।
- अब आप अपने आवेदन का आउटपुट जर्मन भाषा में देख सकते हैं।
ऐतिहासिक रूप से, विंडोज में वातावरण है, जहां उपयोगकर्ता एक साथ कई एप्लिकेशन चला सकते हैं। उपयोगकर्ता विभिन्न अनुप्रयोगों के बीच आसानी से स्विच कर सकता है। यह मॉडल फोन या टैबलेट उपकरणों के लिए अच्छी तरह से काम नहीं करता है जहां उपयोग आम तौर पर एकल-अनुप्रयोग केंद्रित है।
विंडोज 8 स्टोर एप्लिकेशन प्रोग्रामर के सामने सबसे महत्वपूर्ण चुनौतियों में से एक आवेदन जीवनचक्र को प्रबंधित करना और समझना होगा। यदि आप विंडोज फोन एप्लिकेशन का निर्माण कर रहे हैं, तो इससे बहुत परिचित होंगे।
विंडोज 8 के तहत, ऑपरेटिंग सिस्टम एक एप्लिकेशन के जीवनकाल का प्रबंधन करता है, और जब उपयोगकर्ता किसी एप्लिकेशन को समाप्त कर सकता है, तो आमतौर पर उपयोगकर्ता नए अनुप्रयोगों को सचेत रूप से रनिंग एप्लिकेशन को समाप्त किए बिना खोलता है।
विंडोज 10 के लिए यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) इन मुद्दों को संबोधित करता है, डेस्कटॉप उपयोगकर्ताओं को कुछ शांत सामान की पेशकश करता है ताकि कई अनुप्रयोग एक से अधिक विंडो अनुभव के साथ चल सकें।
विंडोज एप्लिकेशन तीन राज्यों में बुनियादी स्तर पर मौजूद हो सकते हैं जैसा कि नीचे दिखाया गया है।
Running
Suspended
Terminate
जब कोई उपयोगकर्ता किसी भी एप्लिकेशन को लॉन्च / सक्रिय करता है, तो वह अंदर जाता है running राज्य।
यदि उपयोगकर्ता इसका उपयोग नहीं करता है और यह अब अग्रभूमि में नहीं है, तो अनुप्रयोगों को निलंबित किया जा सकता है।
निलंबित स्थिति से, अनुप्रयोग या तो उस अनुप्रयोग को फिर से शुरू कर सकते हैं या सिस्टम संसाधनों को पुनः प्राप्त करने के लिए OS को समाप्त कर सकते हैं।
प्रक्रिया राज्य संक्रमण
एक चल रहे एप्लिकेशन में प्रक्रिया की स्थिति को समझना महत्वपूर्ण है। जब उपयोगकर्ता पहली बार एप्लिकेशन लॉन्च करता है, तो स्प्लैश स्क्रीन दिखाई जाती है और फिर एप्लिकेशन चलना शुरू हो जाता है।
इस प्रक्रिया को इस प्रकार समझाया जा सकता है -
जब एप्लिकेशन निलंबित हो रहा है, तो आपके ऐप को उस निलंबित घटना को संभालने के लिए पांच सेकंड मिलते हैं।
जब आवेदन निलंबित हो जाता है, तो बिल्कुल कोई कोड नहीं चलता है और कोई संसाधन आवंटित नहीं किए जाते हैं।
जब यह फिर से शुरू होता है, तो ऐप को सूचित किया जाता है कि यह फिर से शुरू हो गया है। यदि आप एक निलंबित स्थिति से आ रहे हैं, तो आपको कोई कार्रवाई करने की आवश्यकता नहीं है।
स्मृति दबाव के तहत, आपके आवेदन को समाप्त करना संभव है।
याद रखें कि आपको उस बिंदु पर सूचित नहीं किया जाएगा, और इसलिए आप जो भी बचत करते हैं, आपको निलंबित आवेदन स्थिति में प्रवेश करते समय करना होगा।
जब आवेदन आगे और पीछे के बीच स्थानांतरित करता है Running तथा Suspended राज्यों, आग निलंबित और फिर से शुरू होने वाली घटनाओं।
कभी-कभी, आपको डेटा सहेजने की आवश्यकता होती है। फिर आपको एसिंक्रोनस तरीकों को कॉल करना होगा जैसा कि नीचे दिखाया गया है।
Application.Current.Suspending += new SuspendingEventHandler(App_Suspending);
async void App_Suspending(Object sender, Windows.ApplicationModel.SuspendingEventArgs e){
// Create a simple setting
localSettings.Values["FirstName"] = fName.Text;
localSettings.Values["LastName"] = lName.Text;
localSettings.Values["Email"] = email.Text;
}
Application.Current.Resuming += new EventHandler<Object>(App_Resuming);
private void App_Resuming(Object sender, Object e){
fName.Text = localSettings.Values["FirstName"];
lName.Text = localSettings.Values["LastName"];
email.Text = localSettings.Values["Email"];
}
आइए एक उदाहरण का अध्ययन करें जिसमें नियंत्रण दिए गए हैं जैसा कि नीचे दी गई XAML फ़ाइल में दिखाया गया है।
<Page
x:Class = "UWPLifeCycleDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPLifeCycleDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Hub Header = "Details" />
<StackPanel VerticalAlignment = "Top" HorizontalAlignment = "Left"
Margin = "12,64,0,0">
<TextBox Header = "First Name" Text = "{Binding FirstName,
Mode = TwoWay, UpdateSourceTrigger = PropertyChanged}"
Width = "200" />
<TextBox Header = "Last Name" Text = "{Binding LastName, Mode = TwoWay,
UpdateSourceTrigger = PropertyChanged}" Width = "200" />
<TextBox Header = "Email" Text = "{Binding Email, Mode = TwoWay,
UpdateSourceTrigger = PropertyChanged}" Width = "200" />
<Button Margin = "0,12">Submit</Button>
</StackPanel>
</Grid>
</Page>
नीचे दिया गया C # कोड है जिसमें निलंबन और फिर से शुरू होने वाली घटनाओं को लागू किया गया है। वर्तमान डेटा में संग्रहीत किया जाएगाsuspend event स्थानीय सेटिंग्स में और फिर डेटा में पुनर्प्राप्त किया जाएगा resume event नीचे दिखाए गए अनुसार स्थानीय सेटिंग्स से।
using System;
using System.ComponentModel;
using System.Runtime.CompilerServices;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
namespace UWPLifeCycleDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page{
var localSettings = Windows.Storage.ApplicationData.Current.LocalSettings;
public MainPage() {
this.InitializeComponent();
Application.Current.Suspending += new SuspendingEventHandler(App_Suspending);
Application.Current.Resuming += new EventHandler<Object>(App_Resuming);
}
async void App_Suspending(Object sender, Windows.ApplicationModel.SuspendingEventArgs e){
// Create a simple setting
localSettings.Values["FirstName"] = fName.Text;
localSettings.Values["LastName"] = lName.Text;
localSettings.Values["Email"] = email.Text;
}
private void App_Resuming(Object sender, Object e){
fName.Text = localSettings.Values["FirstName"];
lName.Text = localSettings.Values["LastName"];
email.Text = localSettings.Values["Email"];
}
}
public abstract class BindableBase : INotifyPropertyChanged {
private string _FirstName = default(string);
public string FirstName {
get { return _FirstName; }
set { Set(ref _FirstName, value); }
}
private string _LastName = default(string);
public string LastName {
get { return _LastName; }
set { Set(ref _LastName, value); }
}
private string _Email = default(string);
public string Email {
get { return _Email; }
set { Set(ref _Email, value); }
}
public event PropertyChangedEventHandler PropertyChanged;
public void RaisePropertyChanged([CallerMemberName]string propertyName = null) {
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
public void Set<T>(ref T storage, T value,
[CallerMemberName()]string propertyName = null){
if (!object.Equals(storage, value)){
storage = value;
RaisePropertyChanged(propertyName);
}
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी। अब वांछित जानकारी लिखें।
हमें जाने दो Lifecycle ईवेंट ड्रॉपडाउन मेनू और चयन करें suspended। अब आपका आवेदन निलंबित कर दिया जाएगा और वांछित जानकारी स्थानीय सेटिंग्स में संग्रहीत की जाएगी। नीचे दिए गए स्क्रीनशॉट को देखें।
अब, जब आप अपना आवेदन फिर से शुरू करना चाहते हैं, तो विकल्प चुनें Resume वहाँ से Lifecycle Events मेन्यू।
अब आप देखेंगे कि संग्रहीत जानकारी स्थानीय सेटिंग्स से पुनर्प्राप्त की जाती है और आवेदन उसी राज्य में फिर से शुरू किया जाता है जहां से इसे निलंबित कर दिया गया था।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) नए तंत्रों को पेश करता है, जो अनुप्रयोगों को कुछ कार्यक्षमता प्रदर्शन करने की अनुमति देता है, जबकि अनुप्रयोग अग्रभूमि में नहीं चल रहा है। UWP पृष्ठभूमि के लिए अपने निष्पादन समय को बढ़ाने के लिए अनुप्रयोगों की क्षमता को भी बढ़ाता हैBackground Tasks and Triggers। पृष्ठभूमि निष्पादन, अनुप्रयोग जीवनचक्र की वास्तविक पूरक पूंछ है।
पृष्ठभूमि कार्य की महत्वपूर्ण विशेषताएं हैं -
एक पृष्ठभूमि कार्य एक प्रणाली या समय घटना से शुरू हो रहा है और एक या अधिक स्थितियों से विवश हो सकता है।
जब कोई पृष्ठभूमि कार्य शुरू होता है, तो उसका संबद्ध हैंडलर पृष्ठभूमि के कार्य को चलाता और करता है।
एक पृष्ठभूमि कार्य तब भी चल सकता है जब पृष्ठभूमि कार्य पंजीकृत करने वाला ऐप निलंबित हो।
वे मानक एप्लिकेशन प्लेटफ़ॉर्म का हिस्सा हैं और अनिवार्य रूप से सिस्टम इवेंट (ट्रिगर) के लिए पंजीकरण करने की क्षमता के साथ एक ऐप प्रदान करते हैं। जब वह घटना होती है, तो वे पृष्ठभूमि में कोड का एक पूर्वनिर्धारित ब्लॉक चलाते हैं। सिस्टम ट्रिगर्स में नेटवर्क कनेक्टिविटी या सिस्टम टाइम ज़ोन में परिवर्तन जैसी घटनाएं शामिल हैं।
पृष्ठभूमि निष्पादन की गारंटी नहीं है, इसलिए यह महत्वपूर्ण कार्यों और सुविधाओं के लिए उपयुक्त नहीं है।
ओएस में एक सीमा होती है कि एक ही समय में कितने पृष्ठभूमि कार्य चल सकते हैं। इसलिए जब ट्रिगर को निकाल दिया जाता है और शर्तें पूरी हो जाती हैं, तब भी कार्य नहीं चल सकता है।
बैकग्राउंड टास्क बनाएं और रजिस्टर करें
बैकग्राउंड टास्क क्लास बनाएं और उसे चलाएं जब आपका ऐप अग्रभूमि में न हो। आप पृष्ठभूमि को लागू करने वाली कक्षाओं को लिखकर पृष्ठभूमि में कोड चला सकते हैंIBackgroundTaskइंटरफेस। निम्न नमूना कोड एक पृष्ठभूमि कार्य वर्ग के लिए एक बहुत ही मूल प्रारंभिक बिंदु दिखाता है।
public sealed class MyBackgroundTask : IBackgroundTask {
public void Run(IBackgroundTaskInstance taskInstance){
// write code
}
}
आप निम्नानुसार पृष्ठभूमि कार्य के लिए उपयोग का अनुरोध कर सकते हैं।
var access = await BackgroundExecutionManager.RequestAccessAsync();
switch (access) {
case BackgroundAccessStatus.Unspecified:
break;
case BackgroundAccessStatus.AllowedMayUseActiveRealTimeConnectivity:
break;
case BackgroundAccessStatus.AllowedWithAlwaysOnRealTimeConnectivity:
break;
case BackgroundAccessStatus.Denied:
break;
default:
break;
}
पृष्ठभूमि कार्य को बनाने और पंजीकृत करने के लिए, निम्न कोड का उपयोग करें।
var task = new BackgroundTaskBuilder {
Name = "My Task",
TaskEntryPoint = typeof(BackgroundStuff.MyBackgroundTask).ToString()
};
var trigger = new ApplicationTrigger();
task.SetTrigger(trigger);
task.Register();
await trigger.RequestAsync();
हम नीचे दिए गए सभी चरणों का पालन करके पृष्ठभूमि कार्य का एक सरल उदाहरण समझते हैं।
एक नया रिक्त UWP प्रोजेक्ट बनाएं ‘UWPBackgroundDemo’ और XAML फ़ाइल में एक बटन जोड़ें।
<Page
x:Class = "UWPBackgroundDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPBackgroundDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Button x:Name = "button" Content = "Button"
HorizontalAlignment = "Left" Margin = "159,288,0,0"
VerticalAlignment = "Top" Click = "button_Click"/>
</Grid>
</Page>
नीचे दिया गया है button click घटना कार्यान्वयन जिसमें पृष्ठभूमि कार्य पंजीकृत है।
using System;
using Windows.ApplicationModel.Background;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPBackgroundDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private async void button_Click(object sender, RoutedEventArgs e) {
var access = await BackgroundExecutionManager.RequestAccessAsync();
switch (access){
case BackgroundAccessStatus.Unspecified:
break;
case BackgroundAccessStatus.AllowedMayUseActiveRealTimeConnectivity:
break;
case BackgroundAccessStatus.AllowedWithAlwaysOnRealTimeConnectivity:
break;
case BackgroundAccessStatus.Denied:
break;
default:
break;
}
var task = new BackgroundTaskBuilder {
Name = "My Task",
TaskEntryPoint = typeof(BackgroundStuff.MyBackgroundTask).ToString()
};
var trigger = new ApplicationTrigger();
task.SetTrigger(trigger);
var condition = new SystemCondition(SystemConditionType.InternetAvailable);
task.Register();
await trigger.RequestAsync();
}
}
}
अब एक और प्रोजेक्ट बनाएं, लेकिन इस बार मेनू से विंडोज रनटाइम कंपोनेंट (यूनिवर्सल विंडोज) चुनें और नाम दें Background stuff इस परियोजना के लिए।
नीचे दिया गया C # कोड है। जिसमें हैMyBackgroundTask वर्ग आरोपण और यह पृष्ठभूमि कार्य चलाएगा।
using Windows.ApplicationModel.Background;
using Windows.UI.Notifications;
namespace BackgroundStuff {
public sealed class MyBackgroundTask : IBackgroundTask {
public void Run(IBackgroundTaskInstance taskInstance) {
SendToast("Hi this is background Task");
}
public static void SendToast(string message) {
var template = ToastTemplateType.ToastText01;
var xml = ToastNotificationManager.GetTemplateContent(template);
var elements = xml.GetElementsByTagName("Test");
var text = xml.CreateTextNode(message);
elements[0].AppendChild(text);
var toast = new ToastNotification(xml);
ToastNotificationManager.CreateToastNotifier().Show(toast);
}
}
}
इस परियोजना को सुलभ बनाने के लिए UWPBackgroundDemo प्रोजेक्ट, राइट क्लिक पर References > Add References समाधान एक्सप्लोरर में और जोड़ें BackgroundStuff परियोजना।
अब, हम पर चलते हैं Package.appxmanifest की फ़ाइल UWPBackgroundDemo घोषणाएँ टैब में प्रोजेक्ट करें और निम्न जानकारी जोड़ें।
पहले बैकग्राउंड स्टफ प्रोजेक्ट बनाएं, फिर निर्माण करें और निष्पादित करें UWPBackgroundDemo परियोजना।
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
जब आप क्लिक करें button, यह पृष्ठभूमि कार्य को चलाएगा और आपकी विंडो के दाईं ओर एक सूचना दिखाएगा।
इस अध्याय में, हम इस बारे में सीखेंगे कि कैसे यूडब्ल्यूपी ऐप किसी अन्य यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) एप्लिकेशन को सेवाएं प्रदान करने या उसे प्रदान करने में मदद कर सकते हैं। दरअसल, यह अध्याय अध्याय का विस्तार हैBackground execution और इसका एक विशेष मामला है।
विंडोज 10 में, एक ऐप सेवा एक ऐप या अन्य ऐप के लिए सेवाएं प्रदान करने का एक तरीका है।
एक ऐप सेवा पृष्ठभूमि कार्य के रूप में काम करती है।
अग्रभूमि एप्लिकेशन पृष्ठभूमि में कार्य करने के लिए किसी अन्य ऐप में ऐप सेवा को कॉल कर सकते हैं।
ऐप सेवाएं वेब सेवाओं की तरह हैं लेकिन ऐप सेवाओं का उपयोग विंडोज 10 डिवाइस पर किया जाता है।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) एप्लिकेशन विभिन्न तरीकों से एक और UWP एप्लिकेशन के साथ बातचीत कर सकते हैं -
- LaunchUriAsync का उपयोग करके URI एसोसिएशन
- LaunchFileAsync का उपयोग करके फ़ाइल एसोसिएशन
- LaunchUriForResultsAsync का उपयोग करके परिणामों के लिए लॉन्च करें
- ऐप सेवाएं
पहले तीन तरीकों का उपयोग तब किया जाता है जब दोनों अनुप्रयोग अग्रभूमि होते हैं, लेकिन ऐप सेवाओं का उपयोग किया जाता है background task और उस स्थिति में क्लाइंट एप्लिकेशन अग्रभूमि में होना चाहिए और ऐप सेवा का उपयोग करने के लिए उपलब्ध होना चाहिए।
एप्लिकेशन सेवाओं में बहुत फायदेमंद होते हैं जहां गैर-दृश्य सेवाएं प्रदान की जाती हैं उदाहरण के लिए एक बार कोड स्कैनर जिसमें एक अग्रभूमि ऐप छवि ले जाएगा और उन बाइट्स को बार कोड की पहचान करने के लिए ऐप सेवाओं को भेज देगा।
इन सभी अवधारणाओं को समझने के लिए, हम नाम के साथ एक नया UWP प्रोजेक्ट बनाते हैं AppServiceProvider Microsoft Visual Studio 2015 में।
अब में Package.appmenifest फ़ाइल, निम्नलिखित जानकारी जोड़ें।
ऐप सेवा बनाने के लिए, जिसे अग्रभूमि अनुप्रयोगों द्वारा लागू किया जा सकता है, आइए हम एक नया जोड़ें Windows Runtime के साथ समाधान के लिए घटक परियोजना MyAppService नाम, क्योंकि ऐप सेवाएँ पृष्ठभूमि कार्य के रूप में कार्यान्वित की जाती हैं।
में एक संदर्भ जोड़ें MyAppService में परियोजना AppServiceProvider परियोजना।
अब डिलीट करें class1.cs से फाइल करें MyAppService प्रोजेक्ट करें और इन्वेंट्री नाम के साथ एक नया वर्ग जोड़ें, जो लागू करेगा IBackgrounTask इंटरफेस।
IBackgrounTask इंटरफ़ेस में केवल एक विधि है “Run” जिसे पृष्ठभूमि कार्य के लिए कार्यान्वित करने की आवश्यकता है।
public sealed class Inventory : IBackgroundTask {
public void Run(IBackgroundTaskInstance taskInstance) {
}
}
जब पृष्ठभूमि कार्य बनाया जाता है, Run() methodकहा जाता है और जब रन विधि पूरी होती है, तो पृष्ठभूमि कार्यों को समाप्त कर दिया जाता है। बैकग्राउंड टास्क तक रहने के लिए, अनुरोधों को पूरा करने के लिए, कोड एक डिफरल लेता है।
ऐप सेवा कोड में है OnRequestedReceived()। इस उदाहरण में, इन्वेंट्री आइटम के लिए एक इंडेक्स सेवा को पास करता है, नाम और निर्दिष्ट इन्वेंट्री आइटम की कीमत प्राप्त करने के लिए।
private async void OnRequestReceived(AppServiceConnection sender,
AppServiceRequestReceivedEventArgs args) {
// Get a deferral because we use an awaitable API below to respond to the message
}
नीचे दिए गए C # में इन्वेंटरी वर्ग का पूर्ण कार्यान्वयन है।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Windows.ApplicationModel.AppService;
using Windows.ApplicationModel.Background;
using Windows.Foundation.Collections;
namespace MyAppService{
public sealed class Inventory : IBackgroundTask {
private BackgroundTaskDeferral backgroundTaskDeferral;
private AppServiceConnection appServiceconnection;
private String[] inventoryItems = new string[] { "Robot vacuum", "Chair" };
private double[] inventoryPrices = new double[] { 129.99, 88.99 };
public void Run(IBackgroundTaskInstance taskInstance) {
this.backgroundTaskDeferral = taskInstance.GetDeferral();
taskInstance.Canceled += OnTaskCanceled;
var details = taskInstance.TriggerDetails as AppServiceTriggerDetails;
appServiceconnection = details.AppServiceConnection;
appServiceconnection.RequestReceived += OnRequestReceived;
}
private async void OnRequestReceived(AppServiceConnection sender,
AppServiceRequestReceivedEventArgs args) {
var messageDeferral = args.GetDeferral();
ValueSet message = args.Request.Message;
ValueSet returnData = new ValueSet();
string command = message["Command"] as string;
int? inventoryIndex = message["ID"] as int?;
if (inventoryIndex.HasValue &&
inventoryIndex.Value >= 0 &&
inventoryIndex.Value < inventoryItems.GetLength(0)) {
switch (command) {
case "Price": {
returnData.Add("Result", inventoryPrices[inventoryIndex.Value]);
returnData.Add("Status", "OK");
break;
}
case "Item": {
returnData.Add("Result", inventoryItems[inventoryIndex.Value]);
returnData.Add("Status", "OK");
break;
}
default: {
returnData.Add("Status", "Fail: unknown command");
break;
}
} else {
returnData.Add("Status", "Fail: Index out of range");
}
}
await args.Request.SendResponseAsync(returnData);
messageDeferral.Complete();
}
private void OnTaskCanceled(IBackgroundTaskInstance sender,
BackgroundTaskCancellationReason reason){
if (this.backgroundTaskDeferral != null) {
// Complete the service deferral.
this.backgroundTaskDeferral.Complete();
}
}
}
}
हमें एक नया ब्लैंक UWP प्रोजेक्ट जोड़कर एक क्लाइंट ऐप बनाना है ClientApp और XAML फ़ाइल में नीचे दिखाए गए अनुसार एक बटन, एक टेक्स्ट बॉक्स और दो टेक्स्टब्लॉक जोड़ें।
<Page
x:Class = "ClientApp.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:ClientApp"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<TextBlock HorizontalAlignment = "Left" Text = "Enter Item No."
Margin = "52,40,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Height = "32" Width = "268"/>
<Button x:Name = "button" Content = "Get Info" HorizontalAlignment = "Left"
Margin = "255,96,0,0" VerticalAlignment = "Top" Click = "button_Click"/>
<TextBox x:Name = "textBox" HorizontalAlignment = "Left" Margin = "52,96,0,0"
TextWrapping = "Wrap" VerticalAlignment = "Top" Width = "168"/>
<TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"
Margin = "52,190,0,0" TextWrapping = "Wrap"
VerticalAlignment = "Top" Height = "32" Width = "268"/>
</Grid>
</Page>
नीचे दिया गया बटन-क्लिक ईवेंट कार्यान्वयन है जिसमें ऐप सेवाओं का अनुरोध किया गया है।
using System;
using Windows.ApplicationModel.AppService;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace ClientApp {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
private AppServiceConnection inventoryService;
public MainPage() {
this.InitializeComponent();
}
private async void button_Click(object sender, RoutedEventArgs e){
// Add the connection.
if (this.inventoryService == null) {
this.inventoryService = new AppServiceConnection();
this.inventoryService.AppServiceName = "com.microsoft.inventory";
this.inventoryService.PackageFamilyName =
"bb1a8478-8005-46869923-e525ceaa26fc_4sz2ag3dcq60a";
var status = await this.inventoryService.OpenAsync();
if (status != AppServiceConnectionStatus.Success) {
button.Content = "Failed to connect";
return;
}
}
// Call the service.
int idx = int.Parse(textBox.Text);
var message = new ValueSet();
message.Add("Command", "Item");
message.Add("ID", idx);
AppServiceResponse response = await
this.inventoryService.SendMessageAsync(message);
string result = "";
if (response.Status == AppServiceResponseStatus.Success) {
// Get the data that the service sent to us.
if (response.Message["Status"] as string == "OK") {
result = response.Message["Result"] as string;
}
}
message.Clear();
message.Add("Command", "Price");
message.Add("ID", idx);
response = await this.inventoryService.SendMessageAsync(message);
if (response.Status == AppServiceResponseStatus.Success){
// Get the data that the service sent to us.
if (response.Message["Status"] as string == "OK") {
result += " : Price = " + "$"+ response.Message["Result"] as string;
}
}
textBlock.Text = result;
}
}
}
इस एप्लिकेशन को चलाने के लिए, आपको सेट करना होगा ClientApp समाधान एक्सप्लोरर में स्टार्टअप परियोजना होने के लिए परियोजना और फिर इस समाधान को नियुक्त करें Build > Deploy उपाय।
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी। ऐप सेवाओं में, हमने केवल दो वस्तुओं की जानकारी जोड़ी है। तो, आप उन वस्तुओं की जानकारी प्राप्त करने के लिए या तो 0 या 1 दर्ज कर सकते हैं।
जब आप 0 दर्ज करते हैं और बटन पर क्लिक करते हैं, तो यह ऐप सेवा को पृष्ठभूमि के कार्य के रूप में चलाएगा और आइटम जानकारी को दिखाएगा textblock।
विंडोज 10 में, डेवलपर्स के लिए यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) एप्लिकेशन बनाना और उस एप्लिकेशन पर अपनी वेबसाइट को होस्ट करना आसान है, जिसे डाउनलोड करने के लिए विंडोज स्टोर में प्रकाशित किया जा सकता है।
लाभ
विंडोज 10 में इस नई सुविधा के साथ, वेब डेवलपर्स आसानी से अपनी वेब साइटों के घटकों को विंडोज ऐप में बदल सकते हैं।
हालाँकि, उन सभी घटकों को अभी भी अपने स्वयं के वेब सर्वर पर दूरस्थ रूप से होस्ट किया जाएगा।
इसके अतिरिक्त, वे सार्वभौमिक एपीआई तक भी पहुंच सकते हैं, जो डेवलपर्स को कुछ शांत सामान जैसे सूचना, कैमरा, कैलेंडर, कोरटाना, और अधिक का उपयोग करने की अनुमति देगा।
Microsoft को उम्मीद है कि यह सुविधा और क्षमता अधिक डेवलपर्स को विंडोज 10 प्लेटफॉर्म के लिए एप्लिकेशन लिखने के लिए आकर्षित करेगी, जिसमें शामिल हैं।
- Desktops
- Smartphones
- Xbox
- Tablets
- HoloLens और अन्य डिवाइस
वर्तमान में, इस सुविधा के साथ केवल एक समस्या है और वह है सुरक्षा। जाहिर है, Microsoft को इसे जल्द से जल्द संबोधित करने की आवश्यकता है।
आइए एक उदाहरण की मदद से समझते हैं जिसमें हम एक वेबसाइट होस्ट करेंगे और उस वेबसाइट को विंडोज ऐप में बदल देंगे।
नीचे दिए गए चरणों का पालन करें।
से एक नया यूनिवर्सल विंडोज प्रोजेक्ट बनाएं File > New > Project।
चुनते हैं JavaScript > Windows > Universal नई परियोजना और संवाद के बाएँ फलक से विकल्प।
मध्य फलक से, का चयन करें Blank App (Universal Windows)।
नाम फ़ील्ड में लिखें, UWPWebApp और क्लिक करें OK बटन।
अगर तुम देखो Solution Explorer विंडो, आपको कुछ फाइलें और फ़ोल्डर्स दिखाई देंगे।
हटाएं css, js, WinJS फ़ोल्डर्स और default.htmlफ़ाइल, क्योंकि इस उदाहरण में, हम सिर्फ एक वेबसाइट की मेजबानी कर रहे हैं और हम मानते हैं कि सभी सामग्री दूरस्थ सर्वर पर हैं। इसलिए, हमें अधिकांश स्थानीय फ़ाइलों की आवश्यकता नहीं है।
उपर्युक्त फ़ाइलों और फ़ोल्डरों को हटाने के बाद, अब डबल क्लिक करें package.appxmanifest फ़ाइल और आप निम्न विंडो देखेंगे।
अब वेबसाइट URL को प्रतिस्थापित करके निर्दिष्ट करें default.htmlURL द्वारा प्रारंभ पृष्ठ फ़ील्ड में। प्रदर्शन के उद्देश्य से, हम URL का उपयोग करेंगेhttps://www.google.com.pk/ वेबसाइट।
अब जाना है Content URIs नियम और अपने वेब ऐप के लिए नियम और पहुंच अनुमति को परिभाषित करें।
URI फ़ील्ड में, अपनी वेबसाइट लिंक निर्दिष्ट करें और फिर चयन करें Include वहाँ से Rule dropdown तथा All से WinRT Access।
जब आप इस एप्लिकेशन को चलाते हैं, तो आपको नीचे दिखाए गए अनुसार आपके ऐप पर Google प्रारंभ पृष्ठ दिखाई देगा।
जैसा कि हम पहले से ही जानते हैं, विंडोज 10 में हम एक एप्लिकेशन बना सकते हैं जिसे निष्पादित किया जा सकता है और कई विंडोज 10 उपकरणों पर चलाया जा सकता है। मान लें कि हमारे पास ये अलग-अलग डिवाइस हैं और हम यह महसूस करना चाहते हैं कि यह एक एप्लीकेशन है, भले ही यह अलग-अलग डिवाइस पर चल रही हो।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) में, आप सभी विंडोज 10 उपकरणों पर एक ही एप्लिकेशन चला सकते हैं, और आप उपयोगकर्ता को यह महसूस करा सकते हैं कि यह एक एप्लीकेशन है। इस रूप में जाना जाता हैconnecting experience।
जुड़े अनुभव की महत्वपूर्ण विशेषताएं -
विंडोज 10 अधिक व्यक्तिगत कंप्यूटिंग के युग का पहला चरण है जहां आपके एप्लिकेशन, सेवाएं और सामग्री आपके साथ सभी डिवाइसों पर निर्बाध रूप से और आसानी से स्थानांतरित हो सकती हैं।
जुड़े हुए अनुभव के साथ, आप उस एप्लिकेशन से संबंधित अपने डेटा और व्यक्तिगत सेटिंग्स को आसानी से साझा कर सकते हैं और यह सभी उपकरणों पर उपलब्ध होगा।
इस अध्याय में हम सीखेंगे -
जहां इन साझा डेटा या सेटिंग्स को संग्रहीत किया जाएगा ताकि यह आपके डिवाइस पर उस एक एप्लिकेशन के लिए उपलब्ध हो सके।
उपयोगकर्ता की पहचान कैसे की जाती है; यह एक ही उपयोगकर्ता है जो विभिन्न उपकरणों पर एक ही एप्लिकेशन का उपयोग कर रहा है।
विंडोज 10 एक साहसिक कदम आगे ले जाता है। जब आप Microsoft खाता (MSA) या अपने उद्यम या (काम) खाते के साथ विंडोज 10 में प्रवेश करते हैं, तो यह माना जाता है कि -
आपके पास MSA खाते के लिए OneDrive तक मुफ्त पहुंच है, और आपके पास सक्रिय निर्देशिका (AD) और Azure सक्रिय निर्देशिका (AAD) तक पहुंच है, जो आपके एंटरप्राइज़ खाते के साथ क्लाउड संस्करण है।
आपके पास विभिन्न अनुप्रयोगों और संसाधनों तक पहुंच है।
डिवाइस और एप्लिकेशन रोमिंग स्थिति और सेटिंग में हैं।
विंडोज 10 में रोमिंग
जब आप एक पीसी पर लॉगऑन करते हैं, तो आप लॉक स्क्रीन या बैकग्राउंड कलर जैसी कुछ प्राथमिकताएँ निर्धारित करते हैं या अपनी विभिन्न प्रकार की सेटिंग्स को वैयक्तिकृत करते हैं। यदि आपके पास एक से अधिक कंप्यूटर या डिवाइस हैं, जो विंडोज 10 पर चल रहे हैं, तो एक डिवाइस पर आपकी प्राथमिकताएं और सेटिंग्स क्लाउड से सिंक्रनाइज़ हो जाएंगी, जब आप उसी खाते के साथ अन्य डिवाइसों में लॉगिन करते हैं।
विंडोज 10 में, जब आपने अपनी एप्लिकेशन सेटिंग्स को सेट या व्यक्तिगत किया है, तो ये सेटिंग्स यूडब्ल्यूपी में उपलब्ध रोमिंग एपीआई के साथ घूमेंगी। जब आप उसी एप्लिकेशन को अन्य डिवाइस पर फिर से चलाते हैं, तो यह पहले सेटिंग्स को फिर से प्राप्त करेगा और उन सेटिंग्स को उस डिवाइस पर एप्लिकेशन पर लागू करेगा।
रोमिंग डेटा को क्लाउड पर अपलोड करने के लिए 100KB की सीमा है। यदि यह सीमा पार हो जाती है, तो सिंक्रनाइज़ेशन बंद हो जाएगा और बस एक स्थानीय फ़ोल्डर की तरह व्यवहार करेगा।
RoamingSettings एपीआई को शब्दकोश के रूप में उजागर किया जाता है जिसमें एक एप्लिकेशन डेटा को बचा सकता है।
Windows.Storage.ApplicationDataContainer roamingSettings =
Windows.Storage.ApplicationData.Current.RoamingSettings;
// Retrivve value from RoamingSettings
var colorName = roamingSettings.Values["PreferredBgColor"].ToString();
// Set values to RoamingSettings
roamingSettings.Values["PreferredBgColor"] = "Green";
जब डेटा में परिवर्तन होता है RoamingSettings तो यह आग DataChanged घटना, जहाँ आप अपनी सेटिंग्स को ताज़ा कर सकते हैं।
Windows.Storage.ApplicationData.Current.DataChanged += RoamingDataChanged;
private void RoamingDataChanged(Windows.Storage.ApplicationData sender, object args) {
// Something has changed in the roaming data or settings
}
आइए एक उदाहरण देखें, जिसमें हम एप्लिकेशन का बैकग्राउंड कलर सेट करेंगे और ये सेटिंग UWP में उपलब्ध रोमिंग एपीआई के साथ घूमेंगे।
नीचे दिया गया XAML कोड है जिसमें विभिन्न नियंत्रण जोड़े जाते हैं।
<Page
x:Class = "RoamingSettingsDemo.Views.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:RoamingSettingsDemo.Views"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid x:Name = "MainGrid" Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height = "80" />
<RowDefinition />
</Grid.RowDefinitions>
<StackPanel Orientation = "Horizontal" VerticalAlignment = "Top" Margin = "12,12,0,0">
<TextBlock Style = "{StaticResource HeaderTextBlockStyle}"
FontSize = "24" Text = "Connected Experience Demo" />
</StackPanel>
<Grid Grid.Row = "1" Margin = "0,80,0,0">
<StackPanel Margin = "62,0,0,0">
<TextBlock x:Name = "textBlock" HorizontalAlignment = "Left"
TextWrapping = "Wrap" Text = "Choose your background color:"
VerticalAlignment = "Top"/>
<RadioButton x:Name = "BrownRadioButton" Content = "Brown"
Checked = "radioButton_Checked" />
<RadioButton x:Name = "GrayRadioButton" Content = "Gray"
Checked = "radioButton_Checked"/>
</StackPanel>
</Grid>
</Grid>
</Page>
के लिए सी # कार्यान्वयन RoamingSettings और नीचे विभिन्न कार्यक्रम दिए गए हैं।
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The RoamingSettingsDemo Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=234238
namespace RoamingSettingsDemo.Views {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
protected override void OnNavigatedTo(NavigationEventArgs e) {
SetBackgroundFromSettings();
Windows.Storage.ApplicationData.Current.DataChanged += RoamingDataChanged;
}
protected override void OnNavigatedFrom(NavigationEventArgs e) {
Windows.Storage.ApplicationData.Current.DataChanged -= RoamingDataChanged;
}
private void RoamingDataChanged(Windows.Storage.ApplicationData sender, object args) {
// Something has changed in the roaming data or settings
var ignore = Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal,
() ⇒ SetBackgroundFromSettings());
}
private void SetBackgroundFromSettings() {
// Get the roaming settings
Windows.Storage.ApplicationDataContainer roamingSettings =
Windows.Storage.ApplicationData.Current.RoamingSettings;
if (roamingSettings.Values.ContainsKey("PreferBrownBgColor")) {
var colorName = roamingSettings.Values["PreferBrownBgColor"].ToString();
if (colorName == "Gray") {
MainGrid.Background = new SolidColorBrush(Colors.Gray);
GrayRadioButton.IsChecked = true;
} else if (colorName == "Brown") {
MainGrid.Background = new SolidColorBrush(Colors.Brown);
BrownRadioButton.IsChecked = true;
}
}
}
private void radioButton_Checked(object sender, RoutedEventArgs e){
if (GrayRadioButton.IsChecked.HasValue &&
(GrayRadioButton.IsChecked.Value == true)) {
Windows.Storage.ApplicationData.Current.RoamingSettings.
Values["PreferBrownBgCo lor"] = "Gray";
} else {
Windows.Storage.ApplicationData.Current.RoamingSettings.
Values["PreferBrownBgCo lor"] = "Brown";
}
SetBackgroundFromSettings();
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
आइए हम ग्रे कलर को बैकग्राउंड कलर के रूप में चुनें और इस ऐप को बंद करें।
अब, जब आप इस ऐप को इस डिवाइस या किसी अन्य डिवाइस पर चलाते हैं, तो आप देखेंगे कि बैकग्राउंड का रंग बदलकर ग्रे हो गया है। इससे पता चलता है कि ऐप ने पृष्ठभूमि के रंग बदलने की जानकारी को सफलतापूर्वक पुनर्प्राप्त कर लिया हैRoamingSettings।
यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) अनुप्रयोगों में, नेविगेशन नेविगेशन संरचनाओं, नेविगेशन तत्वों और सिस्टम स्तर की सुविधाओं का एक लचीला मॉडल है। यह ऐप्स, पेज और सामग्री के बीच बढ़ने के लिए विभिन्न प्रकार के सहज उपयोगकर्ता अनुभव प्रदान करता है।
ऐसी कुछ परिस्थितियाँ और परिदृश्य हैं जहाँ सभी सामग्री और कार्यक्षमता आसानी से एक ही पृष्ठ में फिट हो सकती हैं और कई पृष्ठों को बनाने के लिए डेवलपर्स की कोई आवश्यकता नहीं है। हालांकि, अधिकांश अनुप्रयोगों में, विभिन्न सामग्री और कार्यक्षमता के बीच बातचीत के लिए कई पृष्ठों का उपयोग किया जाता है।
जब किसी ऐप में एक से अधिक पेज होते हैं, तो डेवलपर्स के लिए सही नेविगेशन अनुभव प्रदान करना बहुत महत्वपूर्ण होता है।
पेज मॉडल
आमतौर पर, यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) अनुप्रयोगों में, सिंगल पेज नेविगेशन मॉडल का उपयोग किया जाता है।
महत्वपूर्ण विशेषताएं हैं -
एक एकल पृष्ठ नेविगेशन मॉडल आपके आवेदन और अतिरिक्त सामग्री और डेटा के सभी संदर्भों को एक केंद्रीय फ्रेम में रखता है।
आप अपने एप्लिकेशन की सामग्री को कई पृष्ठों में विभाजित कर सकते हैं। हालाँकि, एक पेज से दूसरे पेज पर जाने पर, आपका एप्लिकेशन पेजों को एक मुख्य पेज के रूप में लोड करता है।
न तो आपके एप्लिकेशन का मुख्य पृष्ठ अनलोड किया गया है और न ही कोड और डेटा अनलोड किया गया है, इससे राज्य का प्रबंधन करना आसान हो जाता है, और पृष्ठों के बीच चिकनी संक्रमण एनिमेशन प्रदान करता है।
बहु-पृष्ठ नेविगेशन का उपयोग अनुप्रयोग संदर्भ के बारे में चिंता किए बिना विभिन्न पृष्ठों या स्क्रीन के बीच नेविगेट करने के लिए भी किया जाता है। बहु-पृष्ठ नेविगेशन में, प्रत्येक पृष्ठ के कार्यों, उपयोगकर्ता इंटरफ़ेस और डेटा आदि का अपना सेट होता है।
बहु-पृष्ठ नेविगेशन आमतौर पर वेबसाइट के भीतर वेब पृष्ठों में उपयोग किया जाता है।
नेविगेशन संरचना
बहु-पृष्ठ नेविगेशन में, प्रत्येक पृष्ठ के कार्यों, उपयोगकर्ता इंटरफ़ेस और डेटा आदि का अपना सेट होता है। उदाहरण के लिए, एक फोटो एप्लिकेशन में फ़ोटो कैप्चर करने के लिए एक पृष्ठ हो सकता है, फिर जब उपयोगकर्ता फ़ोटो को संपादित करना चाहता है, तो वह दूसरे पृष्ठ पर नेविगेट करता है और छवि पुस्तकालय को बनाए रखने के लिए इसके पास एक और पृष्ठ है।
आपके एप्लिकेशन की नेविगेशन संरचना को परिभाषित किया जाता है कि ये पृष्ठ कैसे व्यवस्थित हैं।
आपके आवेदन में नेविगेशन की संरचना के तरीके निम्नलिखित हैं -
अनुक्रम
इस प्रकार की नेविगेशन संरचना में,
पृष्ठों को संरचना की तरह एक पेड़ में व्यवस्थित किया जाता है।
प्रत्येक चाइल्ड पेज में केवल एक माता-पिता होते हैं, लेकिन एक माता-पिता के पास एक या अधिक चाइल्ड पेज हो सकते हैं।
बाल पृष्ठ तक पहुंचने के लिए, आपको माता-पिता के माध्यम से यात्रा करनी होगी।
पीयर
इस प्रकार के नेविगेशन में -
- पृष्ठ अगल-बगल मौजूद हैं।
- आप किसी भी क्रम में एक पृष्ठ से दूसरे पृष्ठ पर जा सकते हैं।
अधिकांश बहु-पृष्ठ अनुप्रयोगों में, दोनों संरचनाएं एक साथ उपयोग की जाती हैं। कुछ पृष्ठों को सहकर्मी के रूप में और कुछ को पदानुक्रम में व्यवस्थित किया गया है।
आइए एक उदाहरण लेते हैं जिसमें तीन पृष्ठ होते हैं।
नाम के साथ एक खाली UWP एप्लिकेशन बनाएं UWPNavigation।
प्रोजेक्ट में दाईं ओर क्लिक करके दो और रिक्त पृष्ठ जोड़ें Solution Explorer और चुनें Add > New Item मेनू से विकल्प, जो निम्न संवाद विंडो खोलेगा।
मध्य फलक से रिक्त पृष्ठ का चयन करें और क्लिक करें Add बटन।
अब ऊपर दिए गए चरणों का पालन करके एक और पृष्ठ जोड़ें।
आपको समाधान एक्सप्लोरर में तीन पृष्ठ दिखाई देंगे - MainPage, BlankPage1, तथा BlankPage2।
नीचे दिए गए के लिए XAML कोड है MainPage जिसमें दो बटन जोड़े जाते हैं।
<Page
x:Class = "UWPNavigation.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPNavigation"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Hub Header = "Hi, this Main Page"/>
<Button Content = "Go to Page 1" Margin = "64,131,0,477" Click = "Button_Click"/>
<Button Content = "Go to Page 2" Margin = "64,210,0,398" Click = "Button_Click_1"/>
</Grid>
</Page>
नीचे दिए गए दो बटन के लिए C # कोड है MainPage, जो अन्य दो पृष्ठों पर नेविगेट करेगा।
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPNavigation {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
public MainPage() {
this.InitializeComponent();
}
private void Button_Click(object sender, RoutedEventArgs e){
this.Frame.Navigate(typeof(BlankPage1));
}
private void Button_Click_1(object sender, RoutedEventArgs e) {
this.Frame.Navigate(typeof(BlankPage2));
}
}
}
के लिए XAML कोड blank page 1 नीचे दिखाया गया है।
<Page
x:Class = "UWPNavigation.BlankPage1"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPNavigation"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Hub Header = "Hi, this is page 1"/>
<Button Content = "Go to Main Page" Margin = "64,94,0,514" Click = "Button_Click"/>
</Grid>
</Page>
बटन के लिए सी # कोड - ईवेंट पर क्लिक करें blank page 1, जो मुख्य पृष्ठ पर नेविगेट करेगा, नीचे दिखाया गया है।
using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=234238
namespace UWPNavigation {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class BlankPage1 : Page {
public BlankPage1() {
this.InitializeComponent();
}
private void Button_Click(object sender, RoutedEventArgs e) {
this.Frame.Navigate(typeof(MainPage));
}
}
}
नीचे दिए गए के लिए XAML कोड है blank page 2।
<Page
x:Class = "UWPNavigation.BlankPage2"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPNavigation"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Hub Header = "Hi, this is page 2"/>
<Button Content = "Go to Main Page" Margin = "64,94,0,514" Click = "Button_Click"/>
</Grid>
</Page>
नीचे दिए गए बटन पर क्लिक करने की घटना के लिए C # कोड है blank page 2, जो मुख्य पृष्ठ पर नेविगेट करेगा।
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=234238
namespace UWPNavigation {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class BlankPage2 : Page {
public BlankPage2(){
this.InitializeComponent();
}
private void Button_Click(object sender, RoutedEventArgs e) {
this.Frame.Navigate(typeof(MainPage));
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
जब आप किसी भी बटन पर क्लिक करते हैं, तो यह आपको संबंधित पेज पर नेविगेट करेगा। हम पर क्लिक करेंGo to Page 1 और निम्न पृष्ठ प्रदर्शित किया जाएगा।
जब आप बटन पर क्लिक करेंगे 'Go to Main Page', यह मुख्य पृष्ठ पर वापस नेविगेट करेगा।
आजकल, आपको कई एप्लिकेशन दिखाई देंगे, जिन्होंने किसी नेटवर्क पर वेब सेवाओं या अन्य उपकरणों के साथ एकीकृत किया है। ऑनलाइन मौसम सामग्री प्राप्त करना, नवीनतम समाचार, चैटिंग या पीयर-टू-पीयर गेम कुछ उदाहरण हैं जो नेटवर्क सेवाओं का उपयोग करते हैं। ये ऐप विभिन्न प्रकार के नेटवर्किंग एपीआई का उपयोग करके बनाया गया है। विंडोज 10 में, नेटवर्किंग एपीआई को उनकी गति और स्मृति प्रदर्शन के साथ-साथ डेवलपर्स को प्रदान की जाने वाली क्षमताओं और लचीलेपन के मामले में सुधार किया जाता है।
क्षमताओं
नेटवर्क के लिए, आपको अपने एप्लिकेशन मेनिफ़ेस्ट में उपयुक्त क्षमता वाले तत्वों को जोड़ना होगा। यदि आपके ऐप के प्रकट होने में कोई नेटवर्क क्षमता निर्दिष्ट नहीं है, तो आपके ऐप में कोई नेटवर्किंग क्षमता नहीं होगी, और नेटवर्क से कनेक्ट करने का कोई भी प्रयास विफल हो जाएगा।
निम्नलिखित सबसे अधिक उपयोग की जाने वाली नेटवर्किंग क्षमताएं हैं।
क्र.सं. | क्षमता और विवरण |
---|---|
1 | internetClient हवाई अड्डों और कॉफी शॉप की तरह सार्वजनिक स्थानों पर इंटरनेट और नेटवर्क तक पहुंच प्रदान करता है। अधिकांश एप्लिकेशन जिन्हें इंटरनेट एक्सेस की आवश्यकता होती है, उन्हें इस क्षमता का उपयोग करना चाहिए। |
2 | internetClientServer इंटरनेट और सार्वजनिक स्थानों जैसे हवाई अड्डों और कॉफी की दुकानों में इंटरनेट और नेटवर्क से इनबाउंड और आउटबाउंड नेटवर्क का उपयोग देता है। |
3 | privateNetworkClientServer ऐप को इनबाउंड और आउटबाउंड नेटवर्क एक्सेस के लिए उपयोगकर्ताओं के विश्वसनीय स्थानों, जैसे घर और काम पर देता है। |
अपनी एप्लिकेशन मैनिफ़ेस्ट फ़ाइल में एक या अधिक क्षमताओं को परिभाषित करने के लिए, नीचे दी गई छवि को देखें।
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) में निम्नलिखित लक्ष्य करके नेटवर्किंग APIs का एक बड़ा सेट है -
- डिवाइस की कनेक्टिविटी स्थिति को छोड़कर और सहकर्मी उपकरणों से कनेक्ट करना।
- अन्य वेब सेवाओं के साथ संचार करना और
- पृष्ठभूमि में बड़ी मीडिया फ़ाइलों को डाउनलोड करना
नेटवर्किंग टेक्नोलॉजीज
यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) में, डेवलपर्स के लिए निम्नलिखित नेटवर्किंग प्रौद्योगिकियाँ उपलब्ध हैं, जिनका उपयोग कई अलग-अलग स्थितियों में किया जा सकता है।
कुर्सियां
सॉकेट्स का उपयोग तब किया जाता है जब आप अपने स्वयं के प्रोटोकॉल के साथ किसी अन्य डिवाइस के साथ संवाद करना चाहते हैं।
आप दोनों का उपयोग कर सकते हैं, Windows.Networking.Sockets तथा Winsock यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) ऐप डेवलपर के रूप में अन्य उपकरणों के साथ संवाद करने के लिए।
Windows.Networking.Sockets एक आधुनिक एपीआई होने का लाभ है, जिसे यूडब्ल्यूपी डेवलपर्स द्वारा उपयोग के लिए डिज़ाइन किया गया है।
यदि आप क्रॉस-प्लेटफॉर्म नेटवर्किंग लाइब्रेरी या अन्य मौजूदा Winsock कोड का उपयोग कर रहे हैं, तो उपयोग करें Winsock APIs।
निम्न कोड दिखाता है कि सॉकेट श्रोता कैसे बनाएं।
try {
//Create a StreamSocketListener to start listening for TCP connections.
Windows.Networking.Sockets.StreamSocketListener socketListener = new
Windows.Networking.Sockets.StreamSocketListener();
//Hook up an event handler to call when connections are received.
socketListener.ConnectionReceived += SocketListener_ConnectionReceived;
//Start listening for incoming TCP connections on the specified port.
You can specify any port that's not currently in use.
await socketListener.BindServiceNameAsync("1337");
} catch (Exception e) {
//Handle exception.
}
निम्नलिखित कोड के कार्यान्वयन को दर्शाता है SocketListener_ConnectionReceived आयोजन प्रबंधकर्ता।
private async void SocketListener_ConnectionReceived(
Windows.Networking.Sockets.StreamSocketListen er sender,
Windows.Networking.Sockets.StreamSocketListenerConnectionReceivedEventArgs args){
//Read line from the remote client.
Stream inStream = args.Socket.InputStream.AsStreamForRead();
StreamReader reader = new StreamReader(inStream);
string request = await reader.ReadLineAsync();
//Send the line back to the remote client.
Stream outStream = args.Socket.OutputStream.AsStreamForWrite();
StreamWriter writer = new StreamWriter(outStream);
await writer.WriteLineAsync(request);
await writer.FlushAsync();
}
WebSocket
WebSocketsप्रोटोकॉल एक ग्राहक और वेब पर एक सर्वर के बीच एक तेज़ और सुरक्षित दो-तरफ़ा संचार प्रदान करता है। यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) डेवलपर इसका उपयोग कर सकते हैंMessageWebSocket तथा StreamWebSocket वेबसैट प्रोटोकॉल का समर्थन करने वाले सर्वर से जुड़ने के लिए कक्षाएं।
महत्वपूर्ण विशेषताएं हैं -
WebSocket प्रोटोकॉल के तहत, डेटा को पूर्ण-द्वैध एकल सॉकेट कनेक्शन पर तुरंत स्थानांतरित किया जाता है।
यह संदेशों को वास्तविक समय में दोनों समापन बिंदुओं से भेजने और प्राप्त करने की अनुमति देता है।
WebSockets वास्तविक समय के गेमिंग में उपयोग के लिए आदर्श हैं, जहां त्वरित सोशल नेटवर्क सूचनाएं और सूचना (गेम सांख्यिकी) के अप-टू-डेट डिस्प्ले को सुरक्षित करने और तेजी से डेटा हस्तांतरण का उपयोग करने की आवश्यकता है।
निम्न कोड दिखाता है कि सुरक्षित कनेक्शन पर संदेश कैसे भेजें और प्राप्त करें।
MessageWebSocket webSock = new MessageWebSocket();
//In this case we will be sending/receiving a string so we need to
set the MessageType to Utf8.
webSock.Control.MessageType = SocketMessageType.Utf8;
//Add the MessageReceived event handler.
webSock.MessageReceived += WebSock_MessageReceived;
//Add the Closed event handler.
webSock.Closed += WebSock_Closed;
Uri serverUri = new Uri("wss://echo.websocket.org");
try {
//Connect to the server.
await webSock.ConnectAsync(serverUri);
//Send a message to the server.
await WebSock_SendMessage(webSock, "Hello, world!");
} catch (Exception ex) {
//Add code here to handle any exceptions
}
निम्न कोड ईवेंट कार्यान्वयन दिखाता है, जो एक कनेक्टेड से एक स्ट्रिंग प्राप्त करेगा WebSocket।
//The MessageReceived event handler.
private void WebSock_MessageReceived(MessageWebSocket sender,
MessageWebSocketMessageReceivedEventArgs args){
DataReader messageReader = args.GetDataReader();
messageReader.UnicodeEncoding = UnicodeEncoding.Utf8;
string messageString = messageReader.ReadString(
messageReader.UnconsumedBufferLength);
//Add code here to do something with the string that is received.
}
HttpClient
HttpClient तथा Windows.Web.Http नामस्थान एपीआई, डेवलपर को HTTP 2.0 और HTTP 1.1 प्रोटोकॉल का उपयोग करके सूचना भेजने और प्राप्त करने की क्षमता प्रदान करता है।
यह करने के लिए इस्तेमाल किया जा सकता है -
- एक वेब सेवा या एक वेब सर्वर के साथ संवाद।
- कई छोटी फ़ाइलों को अपलोड या डाउनलोड करें।
- सामग्री को नेटवर्क पर स्ट्रीम करें।
निम्न कोड दिखाता है कि कैसे एक GET अनुरोध भेजने का उपयोग करें Windows.Web.Http.HttpClient तथा Windows.Web.Http.HttpResponseMessage।
//Create an HTTP client object
Windows.Web.Http.HttpClient httpClient = new Windows.Web.Http.HttpClient();
//Add a user-agent header to the GET request.
var headers = httpClient.DefaultRequestHeaders;
//The safe way to add a header value is to use the TryParseAdd method
and verify the return value is true,
//especially if the header value is coming from user input.
string header = "ie";
if (!headers.UserAgent.TryParseAdd(header)) {
throw new Exception("Invalid header value: " + header);
}
header = "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)";
if (!headers.UserAgent.TryParseAdd(header)) {
throw new Exception("Invalid header value: " + header);
}
Uri requestUri = new Uri("http://www.contoso.com");
//Send the GET request asynchronously and retrieve the response as a string.
Windows.Web.Http.HttpResponseMessage httpResponse = new
Windows.Web.Http.HttpResponseMessage();
string httpResponseBody = "";
try {
//Send the GET request
httpResponse = await httpClient.GetAsync(requestUri);
httpResponse.EnsureSuccessStatusCode();
httpResponseBody = await httpResponse.Content.ReadAsStringAsync();
} catch (Exception ex) {
httpResponseBody = "Error: " + ex.HResult.ToString("X") + " Message: " + ex.Message;
}
एक डेवलपर के रूप में, आपको अपने डेस्कटॉप पर उपलब्ध डेटा के अलावा अन्य डेटा की आवश्यकता हो सकती है। क्लाउड सेवाएं आपको उस डेटा तक पहुंचने में मदद कर सकती हैं। यह अध्याय क्लाउड सेवाओं की बेहतर समझ देता है, जिनकी आपको आवश्यकता हो सकती है।
Microsoft ने क्लाउड-कंप्यूटिंग प्लेटफ़ॉर्म और आधारभूत संरचना प्रदान की है, जिसे इस रूप में जाना जाता है Microsoft Azure, जहां आप सभी एप्लिकेशन और सेवाओं का निर्माण, तैनाती और प्रबंधन कर सकते हैं।
Azure को पहली बार Windows Azure के रूप में 1 फरवरी 2010 को रिलीज़ किया गया था। बाद में इसका नाम बदलकर 25 मार्च 2014 को Microsoft Azure कर दिया गया।
यह दोनों प्रदान करता है, PaaS and IaaS Microsoft विशिष्ट और तृतीय पक्ष सॉफ़्टवेयर और सिस्टम दोनों सहित कई अलग-अलग प्रोग्रामिंग भाषाओं, टूल और फ़्रेमवर्क की सेवाएं और समर्थन करता है।
Microsoft ने क्लाउड सेवाओं को विंडोज 10 के साथ अपग्रेड किया है। Microsoft खाता एकीकरण विंडोज 8 में पेश किया गया था, हालांकि OneDrive 2007 के बाद से लगभग है। विंडोज 10 के लिए, दोनों सेवाओं को बढ़ी हुई एकीकरण और नई कार्यक्षमता के साथ अद्यतन किया गया है, जो अधिक उपयोगकर्ताओं को आकर्षित कर रहे हैं।
माइक्रोसॉफ्ट खाता
आप अपने Microsoft खाते के साथ Microsoft के Azure क्लाउड प्रसाद का उपयोग कर सकते हैं। बेशक, यह मुफ्त नहीं है लेकिन आप 30 दिनों के निशुल्क परीक्षण का उपयोग कर सकते हैं।
जब आप पहली बार विंडोज 10 के साथ एक मशीन स्थापित करते हैं और Microsoft खाते के साथ लॉगिन करते हैं, तो आप उसी खाते का उपयोग Microsoft Azure सदस्यता के लिए कर सकते हैं। Microsoft Azure के लिए साइन अप करने के लिए यहां क्लिक करेंhttps://azure.microsoft.com/.
एक बार जब आप Microsoft Azure के लिए सदस्यता लेते हैं, तो Azure पोर्टल पर जाएं https://portal.azure.com/। आप निम्न पृष्ठ देखेंगे।
आप डेटाबेस में स्टोर कर सकते हैं, वर्चुअल मशीन आदि का उपयोग कर सकते हैं। आप अपने मोबाइल ऐप के बैक एंड को होस्ट और होस्ट भी कर सकते हैं।
नीचे दिए गए चरणों का पालन करके एक उदाहरण के साथ इसे आजमाएँ।
पर क्लिक करें New बाएँ फलक में विकल्प।
चुनते हैं Web + Mobile > Mobile App और अपने वेब ऐप को एक नाम दें।
आपके एप्लिकेशन को सबमिट करने और उसे लागू करने में कुछ समय लगेगा। एक बार जब यह प्रक्रिया पूरी हो जाती है, तो आप निम्न पृष्ठ देखेंगे। यहां, आप विभिन्न प्रकार के मोबाइल एप्लिकेशन जैसे विंडोज (सी #), आईओएस एंड्रॉइड आदि का चयन कर सकते हैं।
चूंकि, हम विंडोज 10 के बारे में बात कर रहे हैं, विंडोज (सी #) का चयन करें, जो निम्न पृष्ठ को खोलेगा।
यहां, आप दो डाउनलोड विकल्प देख सकते हैं। ये नमूना परियोजनाएं हैं, आप बस Visual Studio में डाउनलोड और निर्माण कर सकते हैं और फिर आप आसानी से Microsoft Azure पर प्रकाशित कर सकते हैं।
आइए हम पहले डाउनलोड करें, जो एक सर्वर प्रोजेक्ट है। यह एक जिप फाइल है।
जब डाउनलोड पूरा हो जाए, तो इसे अनज़िप करें और विजुअल स्टूडियो में खोलें।
अब, इस एप्लिकेशन का निर्माण करें। यदि कुछ त्रुटियां सूचीबद्ध हैं, तो इसे फिर से बनाएं।
एप्लिकेशन चलाएँ। आप निम्नलिखित वेबपेज देखेंगे, जो अब लोकलहोस्ट पर है।
अब क्लाउड पर इस एप्लिकेशन को होस्ट करने के लिए, राइट क्लिक करें Project में विकल्प Solution Explore जैसा की नीचे दिखाया गया।
चुनते हैं Publishमेनू से विकल्प। आप निम्नलिखित संवाद देखेंगे।
पहला विकल्प चुनें - Microsoft Azure Web Apps। निम्न डायलॉग बॉक्स खुलेगा।
अब on पर क्लिक करें Add an account Microsoft Azure खाते को जोड़ने के लिए मेनू से विकल्प।
अपनी साख निर्दिष्ट करें और क्लिक करें Sign in। निम्न संवाद विंडो खुल जाएगी।
साइन इन करने के बाद, मेनू से अपना एप्लिकेशन चुनें Existing Web Apps और क्लिक करें Ok।
नीचे दिखाया गया संवाद आपके आवेदन से संबंधित कुछ जानकारी जैसे नाम, सर्वर का नाम, URL इत्यादि प्रदर्शित करता है।
अब, पर क्लिक करें Validate Connectionबटन। सत्यापन के बाद, क्लिक करेंPublish बटन और आप देखेंगे कि आपका आवेदन अब होस्ट किया गया है Microsoft Azure।
इस अध्याय में, हम टाइल के माध्यम से एक उपयोगकर्ता के साथ बातचीत के बारे में बात करेंगे। यह विंडोज 10. का आइकॉनिक हिस्सा हैStart Screen साथ ही साथ Start Menu। दूसरे शब्दों में, यह एक एप्लिकेशन आइकन परिसंपत्ति है, जो विंडोज 10 ऑपरेटिंग सिस्टम में विभिन्न रूपों में दिखाई देती है। वे आपके यूनिवर्सल विंडोज प्लेटफॉर्म (UWP) ऐप के लिए कॉलिंग कार्ड हैं।
टाइल एनाटॉमी
टाइल की तीन अवस्थाएँ हैं।
Basic State स्टार्ट टाइल के बुनियादी घटकों में एक बैक प्लेट, एक आइकन और एक ऐप शीर्षक होता है।
Semi-Live state - यह एकमात्र अंतर के साथ मूल टाइल के समान है कि बिल्ला, जो एक संख्या है, 0-99 से संख्याओं को प्रदर्शित कर सकता है।
Live State - इस टाइल में अर्ध-लाइव स्टेट टाइल के सभी तत्व हैं और अतिरिक्त सामग्री प्लेट भी दिखाई देती है जहाँ आप अपनी इच्छानुसार कुछ भी डाल सकते हैं जैसे कि फोटो, टेक्स्ट आदि।
अद्यतन टाइलें
टाइल्स को अपडेट करने के चार तरीके हैं।
Scheduled - आप के साथ टेम्पलेट और समय निर्धारित कर सकते हैं ScheduledTileNotification।
Periodic- जब सूचना किसी यूआरआई से प्राप्त की जाती है और आप उस अवधि के बाद की जानकारी को खींचने के लिए समय निर्दिष्ट कर सकते हैं, जैसे कि 30 मिनट, 1 घंटा, 6 घंटे। आदि।
Local- स्थानीय एक को आपके आवेदन से अपडेट किया जा सकता है; या तो अग्रभूमि या पृष्ठभूमि ऐप से।
Push - यह सर्वर से सूचना को धक्का देकर सर्वर से अपडेट किया जाता है।
एक टाइल बनाने के लिए, दिए गए कोड का पालन करें।
var tileXml =
TileUpdateManager.GetTemplateContent(TileTemplateType.TileSquare150x150Text01);
var tileAttributes = tileXml.GetElementsByTagName("text");
tileAttributes[0].AppendChild(tileXml.CreateTextNode("Hello"));
var tileNotification = new TileNotification(tileXml);
TileUpdateManager.CreateTileUpdaterForApplication().Update(tileNotification);
Update badge बहुत सरल है क्योंकि यह सिर्फ एक संख्या है और आप नीचे दिखाए अनुसार बैज का मान सेट कर सकते हैं।
var type = BadgeTemplateType.BadgeNumber;
var xml = BadgeUpdateManager.GetTemplateContent(type);
var elements = xml.GetElementsByTagName("badge");
var element = elements[0] as Windows.Data.Xml.Dom.XmlElement;
element.SetAttribute("value", "7");
var updator = BadgeUpdateManager.CreateBadgeUpdaterForApplication();
var notification = new BadgeNotification(xml);
updator.Update(notification);
आइए हम विजुअल स्टूडियो में एक नया UWP प्रोजेक्ट बनाएं।
आप के तहत अलग png फ़ाइलों को देखेंगे Assets फ़ोल्डर में Solution Explorer।
हमें एक डिफ़ॉल्ट टाइल और इसकी छवि को पैकेज मेनिफ़ेस्ट में परिभाषित करें।
पर डबल क्लिक करें package.appxmanifest। यह प्रकट संपादक विंडो खोलता है।
चुनते हैं Visual Assets टैब।
आप किसी भी निर्दिष्ट आयाम के साथ अपने आवेदन टाइल के लिए छवियों और आइकन का चयन कर सकते हैं। के नीचेTile Images and Logos, डिफ़ॉल्ट चित्र जैसे सभी लोगो के लिए प्रदान किए जाते हैं
- स्क्वायर 71x71 लोगो
- स्क्वायर 150x150 लोगो
- स्क्वायर 310x310 लोगो
- लोगो स्टोर करें
जब आप अपने आवेदन को निष्पादित करते हैं और फिर अपनी स्टार्ट स्क्रीन पर जाते हैं, तो आप अपने आवेदन के लिए टाइल देखेंगे।
इस अध्याय में, हम सीखेंगे कि अनुप्रयोगों के बीच डेटा कैसे साझा करें। उपयोगकर्ताओं को अक्सर जानकारी मिलती है कि वे किसी के साथ साझा करने या किसी अन्य एप्लिकेशन में उपयोग करने के लिए उत्साहित हैं। आजकल, उपयोगकर्ता अन्य लोगों के साथ जुड़ने और साझा करने के लिए प्रौद्योगिकी का उपयोग करना चाहते हैं।
एक उपयोगकर्ता साझा करना चाह सकता है -
- उनके सामाजिक नेटवर्क के साथ एक लिंक
- एक तस्वीर को एक रिपोर्ट में कॉपी करें
- क्लाउड स्टोरेज के लिए एक फ़ाइल अपलोड करें
अनुप्रयोगों को आज, यह सुनिश्चित करने की आवश्यकता है कि जो डेटा वे उपयोग करते हैं, वह उपयोगकर्ताओं को साझा करने और आदान-प्रदान करने के लिए भी उपलब्ध है। शेयर एक हल्की सुविधा है, जो आपके UWP एप्लिकेशन में जोड़ना आसान है। ऐप्स के लिए अन्य ऐप्स के साथ डेटा एक्सचेंज करने के कई तरीके हैं।
UWP अनुप्रयोगों में, शेयर फीचर को निम्नलिखित तरीकों से समर्थित किया जा सकता है;
सबसे पहले, एप्लिकेशन एक स्रोत ऐप हो सकता है जो सामग्री प्रदान करता है जिसे उपयोगकर्ता साझा करना चाहता है।
दूसरा, ऐप एक लक्षित ऐप हो सकता है जिसे उपयोगकर्ता साझा सामग्री के लिए गंतव्य के रूप में चुनता है।
एक ऐप एक स्रोत ऐप और एक लक्ष्य ऐप भी हो सकता है।
सामग्री साझा करना
किसी एप्लिकेशन से सामग्री साझा करना, जो एक स्रोत ऐप है, बहुत सरल है। किसी भी साझाकरण ऑपरेशन को करने के लिए, आपको आवश्यकता होगीDataPackageवर्ग वस्तु। इस ऑब्जेक्ट में डेटा है, जिसे उपयोगकर्ता साझा करना चाहता है।
निम्नलिखित प्रकार की सामग्री को इसमें शामिल किया जा सकता है DataPackage वस्तु -
- सादे पाठ
- यूनिफ़ॉर्म रिसोर्स आइडेंटिफ़ायर (URI)
- HTML
- स्वरूपित पाठ
- Bitmaps
- Files
- डेवलपर-परिभाषित डेटा
डेटा साझा करते समय, आप उपर्युक्त स्वरूपों में से एक या अधिक को शामिल कर सकते हैं। अपने एप्लिकेशन में साझाकरण का समर्थन करने के लिए, आपको सबसे पहले इसका उदाहरण प्राप्त करना होगाDataTransferManager कक्षा।
यह तब एक घटना हैंडलर को पंजीकृत करेगा जिसे जब भी बुलाया जाता है DataRequested घटना होती है।
DataTransferManager dataTransferManager = DataTransferManager.GetForCurrentView();
dataTransferManager.DataRequested += new TypedEventHandler<DataTransferManager,
DataRequestedEventArgs>(this.ShareTextHandler);
जब आपका ऐप ए DataRequest ऑब्जेक्ट, फिर आपका एप्लिकेशन उस सामग्री को जोड़ने के लिए तैयार है जिसे उपयोगकर्ता साझा करना चाहता है।
private void ShareTextHandler(DataTransferManager sender, DataRequestedEventArgs e){
DataRequest request = e.Request;
// The Title is mandatory
request.Data.Properties.Title = "Share Text Example";
request.Data.Properties.Description = "A demonstration that shows how to share text.";
request.Data.SetText("Hello World!");
}
आपके आवेदन में जो भी सामग्री हो, उसमें दो गुण होने चाहिए -
- एक शीर्षक संपत्ति, जो अनिवार्य है और निर्धारित की जानी चाहिए।
- सामग्री ही।
साझा सामग्री प्राप्त करना
यदि आप चाहते हैं कि आपका आवेदन साझा सामग्री प्राप्त कर सकता है, तो आपको सबसे पहले यह घोषित करना होगा कि यह समर्थन करता है Share Contract। घोषणा के बाद, सिस्टम आपके आवेदन को सामग्री प्राप्त करने के लिए उपलब्ध होने देगा।
शेयर अनुबंध का समर्थन जोड़ने के लिए -
पर डबल क्लिक करें package.appmanifest फ़ाइल।
के पास जाओ Declarationsटैब। चुनेंShare Target वहाँ से Available Declarations सूची, और पर क्लिक करें Add बटन।
यदि आप चाहते हैं कि आपका एप्लिकेशन किसी भी प्रकार की फ़ाइल को साझा सामग्री के रूप में प्राप्त करे, तो आप फ़ाइल प्रकार और डेटा प्रारूप निर्दिष्ट कर सकते हैं।
आपके द्वारा समर्थित डेटा प्रारूप निर्दिष्ट करने के लिए जाएं Data Formats का अनुभाग, का Declarations पेज और क्लिक करें Add New।
आपके द्वारा समर्थित डेटा प्रारूप का नाम टाइप करें। उदाहरण के लिए,"Text"।
आपके द्वारा समर्थित फ़ाइल प्रकार को निर्दिष्ट करने के लिए, में Supported File Types का खंड Declarations पेज, क्लिक करें Add New।
वह फ़ाइल नाम एक्सटेंशन टाइप करें जिसका आप समर्थन करना चाहते हैं, जैसे, .pdf
यदि आप समर्थन करना चाहते हैं All file प्रकार, जाँच करें SupportsAnyFileType डिब्बा।
जब कोई उपयोगकर्ता आपके एप्लिकेशन को डेटा साझा करने के लिए लक्ष्य एप्लिकेशन के रूप में चुनता है OnShareTargetActivated घटना को निकाल दिया गया है।
आपके ऐप को डेटा को संसाधित करने के लिए इस घटना को संभालने की आवश्यकता है, जिसे उपयोगकर्ता साझा करना चाहता है।
protected override async void OnShareTargetActivated(ShareTargetActivatedEventArgs args) {
// Code to handle activation goes here.
}
वह सभी डेटा जो उपयोगकर्ता किसी एप्लिकेशन के साथ साझा करना चाहता है, एक में समाहित है ShareOperationवस्तु। आप इसमें मौजूद डेटा का प्रारूप भी देख सकते हैं।
नीचे दिए गए कोड स्निपेट को हैंडल करता है shared content सादे पाठ प्रारूप में।
ShareOperation shareOperation = args.ShareOperation;
if (shareOperation.Data.Contains(StandardDataFormats.Text)) {
string text = await shareOperation.Data.GetTextAsync();
// To output the text from this example, you need a TextBlock control
// with a name of "sharedContent".
sharedContent.Text = "Text: " + text;
}
आइए हम एक नया UWP प्रोजेक्ट बनाकर एक सरल उदाहरण देखें, जो एक वेबलिंक साझा करेगा।
नीचे दिया गया XAML कोड है जिसमें कुछ गुणों के साथ एक बटन बनाया गया है।
<Page
x:Class = "UWPSharingDemo.MainPage"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local = "using:UWPSharingDemo"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable = "d">
<Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
<StackPanel Orientation = "Vertical">
<TextBlock Text = "Share Web Link" Style = "{StaticResource
HeaderTextBlockStyle}" Margin = "30"></TextBlock>
<Button Content = "Invoke share contract" Margin = "10"
Name = "InvokeShareContractButton" Click = "InvokeShareContractButton_Click"
></Button>
</StackPanel>
</Grid>
</Page>
C # कोड जिसमें बटन क्लिक करने की घटना को लागू किया गया है और एक URI- साझाकरण कोड नीचे दिया गया है।
using System;
using Windows.ApplicationModel.DataTransfer;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
// The Blank Page item template is documented at
http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace UWPSharingDemo {
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page {
DataTransferManager dataTransferManager;
public MainPage() {
this.InitializeComponent();
dataTransferManager = DataTransferManager.GetForCurrentView();
dataTransferManager.DataRequested += dataTransferManager_DataRequested;
}
void dataTransferManager_DataRequested(DataTransferManager sender,
DataRequestedEventArgs args) {
Uri sharedWebLink = new Uri("https://msdn.microsoft.com");
if (sharedWebLink != null) {
DataPackage dataPackage = args.Request.Data;
dataPackage.Properties.Title = "Sharing MSDN link";
dataPackage.Properties.Description = "The Microsoft Developer Network (MSDN)
is designed to help developers write applications using Microsoft
products and technologies.";
dataPackage.SetWebLink(sharedWebLink);
}
}
private void InvokeShareContractButton_Click(object sender, RoutedEventArgs e) {
DataTransferManager.ShowShareUI();
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप एमुलेटर पर निम्न पृष्ठ देखेंगे।
जब बटन पर क्लिक किया जाता है, तो यह किस एप्लिकेशन पर साझा करने के विकल्प देगा।
मैसेजिंग पर क्लिक करें और निम्नलिखित विंडो प्रदर्शित होगी जहां से आप किसी को भी लिंक भेज सकते हैं।
इस अध्याय में, हम सीखेंगे कि अपने मौजूदा ऐप विंडोज 8.1 एप्लीकेशन को यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) में कैसे पोर्ट किया जाए। आप एक एकल विंडोज 10 ऐप पैकेज बना सकते हैं जिसे आपके ग्राहक सभी प्रकार के उपकरणों पर स्थापित कर सकते हैं।
आपके आवेदन को विंडोज 10 यूडब्ल्यूपी में पोर्ट करने के बाद, आपके ऐप को इससे लाभ होगा -
- नया हार्डवेयर रोमांचक
- महान मुद्रीकरण के अवसर
- एक आधुनिक एपीआई सेट,
- अनुकूली UI नियंत्रण,
- अनुकूली डिजाइन और कोड
- माउस, कीबोर्ड, टच और भाषण जैसे इनपुट मोडेलिटी की एक श्रृंखला।
एक UWP प्रोजेक्ट के लिए एक विंडोज 8.x प्रोजेक्ट को पोर्ट करना
आपके मौजूदा विंडोज 8.x एप्लिकेशन को यूनिवर्सल विंडोज प्लेटफॉर्म (यूडब्ल्यूपी) में पोर्ट करने के लिए दो विकल्प हैं।
Option 1 - एक है विजुअल स्टूडियो में एक नया विंडोज 10 प्रोजेक्ट बनाना और उसमें अपनी फाइलों को कॉपी करना।
Option 2 - दूसरा विकल्प अपनी मौजूदा परियोजना फाइलों की एक प्रति को संपादित करना है, जिसमें ऐप पैकेज प्रकट भी शामिल है।
पहले विकल्प का उपयोग करते समय नीचे दिए गए मुख्य चरण हैं।
Microsoft Visual Studio 2015 लॉन्च करें और नाम के साथ एक नया रिक्त अनुप्रयोग (Windows यूनिवर्सल) प्रोजेक्ट बनाएँ UWPBookStore।
आपका नया प्रोजेक्ट एक ऐप पैकेज (एक एपेक्स फ़ाइल) बनाता है जो सभी डिवाइस परिवारों पर चलेगा।
अपने यूनिवर्सल 8.1 ऐप प्रोजेक्ट में, सभी स्रोत कोड फ़ाइलों और विज़ुअल एसेट फ़ाइलों की पहचान करें जिन्हें आप पुन: उपयोग करना चाहते हैं। नीचे दिखाया गया एक नमूना आवेदन है, जिसमें तीन परियोजनाएं हैं। एक का उपयोग विंडोज के लिए किया जाता है, दूसरा मोबाइल के लिए है और तीसरा विंडोज और मोबाइल के लिए साझा प्रोजेक्ट है।
इस एप्लिकेशन को फ़ोन पर चलाने के बाद, आपको निम्न विंडो दिखाई देगी।
विंडो एप्लिकेशन को चलाने के बाद, आप निम्नलिखित आवेदन देखेंगे।
- अब, नए बनाए गए UWP प्रोजेक्ट एप्लिकेशन को खोलें
साझा प्रोजेक्ट से, फ़ोल्डर की प्रतिलिपि बनाएँ Assets\CoverImagesपुस्तक कवर छवि (.png) युक्त फ़ाइलें। को भी कॉपी करेंViewModel फ़ोल्डर और MainPage.xaml और गंतव्य में फ़ाइल को बदलें।
विंडोज प्रोजेक्ट से, कॉपी करें BookstoreStyles.xaml। इस फ़ाइल में सभी संसाधन कुंजियाँ Windows 10 ऐप में हल होंगी। समकक्ष में से कुछWindowsPhone फ़ाइल नहीं होगी
में Solution Explorer, सुनिश्चित करो Show All Files भिखमंगा है ON।
आपके द्वारा कॉपी की गई फ़ाइलों का चयन करें, उन्हें राइट-क्लिक करें और क्लिक करें Include In Project जैसा की नीचे दिखाया गया।
इसमें स्वचालित रूप से उनके फ़ोल्डर शामिल होंगे। फिर आप टॉगल कर सकते हैंShow All Files ‘OFF’ यदि आप चाहते हैं।
अब आपकी परियोजना संरचना इस तरह दिखाई देगी Solution Explorer।
स्रोत कोड और मार्कअप फ़ाइलों को संपादित करें जिन्हें आपने अभी कॉपी किया है और किसी भी संदर्भ को बदल सकते हैं Bookstore1_81 नामस्थान UWPBookStore नाम स्थान।
सबसे आसान तरीका है कि नाम के स्थान को बदल दिया जाए Replace In Filesसुविधा। दृश्य मॉडल में कोई कोड परिवर्तन की आवश्यकता नहीं है।
अब, जब उपरोक्त कोड निष्पादित किया जाता है, तो आप इसे स्थानीय मशीन पर और साथ ही नीचे दिखाए गए मोबाइल पर भी चला सकते हैं।
अब, दूसरा विकल्प ऐप पैकेज मेनिफ़ेस्ट सहित अपनी मौजूदा प्रोजेक्ट फ़ाइलों की एक प्रति संपादित करना है। परियोजना फ़ाइल औरpackage.appmanifest विंडोज / फोन 8.x से विंडोज 10 पर पोर्ट करते समय फ़ाइल को कुछ संशोधनों की आवश्यकता होती है।
Microsoft ने UWP प्रोजेक्ट अपग्रेड उपयोगिता प्रदान की है, जो आपके मौजूदा एप्लिकेशन को पोर्ट करते समय बहुत सहायक है। उपयोगिता को github.com से डाउनलोड किया जा सकता है ।
हम आपको बेहतर समझ के लिए ऊपर दिए गए उदाहरणों का अनुसरण करने की सलाह देते हैं।