विंडोज 10 विकास - अनुकूली कोड
इस अध्याय में, हम आपके एप्लिकेशन को विंडोज 10 द्वारा समर्थित विभिन्न उपकरणों के लिए अपनाएंगे।
अब, हम आपके कोड को अपनाने के बारे में जानेंगे, क्योंकि
एप्लिकेशन कोड सभी उपकरणों में समान नहीं हैं।
विशेष रूप से 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) एप्लिकेशन या Windows रनटाइम कंपोनेंट, जो C ++ / CX में लिखे गए हैं, Win32 API तक पहुँच सकते हैं, जो अब UWP का एक हिस्सा हैं। सभी विंडोज़ 10 डिवाइस परिवार आपके आवेदन के साथ लिंक करके Win32 API को लागू कर सकते हैंWindowsapp.lib।
Windowsapp.libUWP एपीआई के लिए निर्यात प्रदान करने वाला "छाता" परिवाद है। से जुड़ रहा है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);
}
}
}
}
जब ऊपर दिया गया कोड मोबाइल पर संकलित और निष्पादित किया जाता है, तो आपको निम्न विंडो दिखाई देगी।
आप इमेज में दिखाए अनुसार चेकबॉक्स के साथ स्टेटस बार का बैकग्राउंड कलर बदल सकते हैं।
आप स्टेटस बार को भी छिपा सकते हैं।
अब, जब आप डेस्कटॉप डिवाइस पर एक ही एप्लिकेशन चलाते हैं, तो आपको निम्न विंडो दिखाई देगी जिसमें स्टेटस बार और स्टेटस बार के लिए चेकबॉक्स दिखाई नहीं दे रहे हैं।