Pengembangan Windows 10 - Panduan Cepat
Tutorial ini dirancang untuk orang yang ingin belajar bagaimana mengembangkan aplikasi Windows 10. Dalam tutorial ini, kita akan belajar -
- Pengembangan aplikasi Windows 10
- Pembaruan OS baru yang dirilis oleh Microsoft
- Fitur baru untuk pengembang di pembaruan
Banyak skenario aplikasi menarik sekarang mungkin yang tidak tersedia untuk kami pada rilis pertama. Microsoft tidak hanya menambahkan API baru, mereka juga memperluas API yang ada.
Aplikasi Windows Universal
Aplikasi Universal Windows pertama kali diperkenalkan di Windows 8 sebagai Windows Runtime, yang dibangun di atas Platform Aplikasi Universal.
Sekarang, di Windows 10, nama Platform Aplikasi Universal telah diubah menjadi Platform Windows Universal (UWP). Anda dapat membangun aplikasi modern dan sepenuhnya imersif dengan menargetkan perangkat Windows 10 untuk Windows Store seperti PC, tablet, ponsel, dll.
Di Windows 10, Anda dapat dengan mudah mengembangkan aplikasi untuk menjangkau semua perangkat yang didukung di Windows 10 hanya dengan -
- Satu set API
- Satu paket aplikasi
- Dan satu toko
Platform Windows Universal juga mendukung ukuran layar yang berbeda dan model interaksi yang berbeda seperti panel sentuh, mouse & keyboard, pengontrol game, atau pena.
Karakteristik aplikasi UWP
Berikut adalah beberapa karakteristik aplikasi Universal Windows, yang membuatnya lebih unggul dari Windows 10.
Anda dapat menargetkan keluarga perangkat dan bukan OS seperti Windows 8.1.
Aplikasi dikemas dan didistribusikan menggunakan .AppX format pengemasan, yang memastikan bahwa aplikasi Anda dapat diterapkan dan diperbarui dengan lancar.
Anda dapat mengirimkan aplikasi Anda ke toko Windows dan itu akan membuatnya tersedia di semua keluarga perangkat, atau hanya perangkat yang Anda pilih. Anda dapat dengan mudah mengelola semua aplikasi Anda untuk perangkat Windows di satu tempat.
Anda dapat membatasi ketersediaan aplikasi Anda untuk keluarga perangkat tertentu.
API inti Platform Windows Universal (UWP) sama di semua keluarga perangkat Windows. Jadi aplikasi Anda dapat berjalan di semua perangkat Windows 10 jika hanya menggunakan API inti.
Dengan bantuan SDK Ekstensi, Anda dapat menerangi aplikasi Anda untuk perangkat tertentu.
Pilihan Pengembangan
Aplikasi Universal Windows dapat dibuat dalam salah satu bahasa berikut -
- C # atau Visual Basic dengan XAML
- JavaScript dengan HTML
- C ++ dengan DirectX dan / atau XAML
Anda juga dapat menulis komponen dalam satu bahasa dan menggunakannya dalam aplikasi yang dikembangkan dalam bahasa lain.
Windows Runtime (WinRT) adalah arsitektur aplikasi platform-homogen, yang mendukung pengembangan di C ++ / CX, C #, VB.NET dan JavaScript. Aplikasi WinRT secara native mendukung arsitektur x86 dan ARM. Beberapa fitur penting adalah.
Ini pertama kali diperkenalkan di Windows Server 2012 pada September 2012.
WinRT API menyediakan akses ke semua fitur platform inti menggunakan JavaScript, C #, Visual Basic, dan C ++.
Komponen WinRT mendukung berbagai bahasa dan API seperti bahasa asli, terkelola, dan skrip.
Platform Windows Universal (UWP)
Aplikasi Universal Windows dibangun di atas Universal Windows Platform (UWP), yang pertama kali diperkenalkan di Windows 8 sebagai Windows Runtime. Di Windows 10, Universal Windows Platform (UWP) diperkenalkan, yang selanjutnya memajukan model Windows Runtime (WinRT).
Di Windows 8.1, WinRT, untuk pertama kalinya, diselaraskan antara aplikasi Windows Phone 8.1 dan aplikasi Windows 8.1 dengan bantuan aplikasi Universal Windows 8 untuk menargetkan ponsel Windows dan aplikasi Windows menggunakan basis kode bersama.
Windows 10 Unified Core, yang sekarang dikenal sebagai Windows Core, telah mencapai titik di mana UWP, sekarang, menyediakan platform aplikasi umum yang tersedia di setiap perangkat yang berjalan di Windows 10.
UWP tidak hanya dapat memanggil WinRT API yang umum untuk semua perangkat, tetapi juga API (termasuk Win32 dan .NET API) yang khusus untuk keluarga perangkat yang menjalankan aplikasi.
Perangkat yang Didukung oleh Windows 10
Aplikasi Windows 8.1 dan Windows Phone 8.1 menargetkan OS; baik Windows atau Windows Phone. Aplikasi Windows 10 tidak menargetkan OS tetapi menargetkan satu atau lebih keluarga perangkat.
Keluarga perangkat juga memiliki API sendiri, yang menambahkan fungsionalitas untuk kelompok perangkat tersebut. Anda dapat dengan mudah menentukan semua perangkat, di dalam keluarga perangkat, di mana aplikasi Anda dapat diinstal dan dijalankan dari Windows Store. Berikut adalah representasi hierarki dari keluarga perangkat.
Keuntungan dari UWP
Universal Windows Platform (UWP) menyediakan beberapa hal untuk pengembang. Mereka adalah -
- Satu Sistem Operasi dan Satu Inti Terpadu untuk semua perangkat.
- Satu Platform Aplikasi untuk menjalankan aplikasi di setiap keluarga.
- One Dev Center untuk mengirimkan aplikasi dan dasbor.
- Satu Toko untuk semua perangkat.
Pengaturan untuk Pengembangan UWP
Langkah-langkah berikut perlu diikuti untuk mulai membuat aplikasi Universal Windows Platform (UWP) Anda sendiri untuk Windows 10.
Windows 10 OS- Aplikasi UWP membutuhkan versi terbaru Windows untuk dikembangkan. Anda juga dapat mengembangkan aplikasi UWP di Windows 8.1 tetapi tidak ada dukungan untuk desainer UI Window.
Windows 10 developer tools- Di Visual studio 2015, Anda dapat merancang, membuat kode, menguji, dan men-debug aplikasi UWP Anda. Anda dapat mengunduh dan menginstal Microsoft Visual Studio Community 2015 gratis darihttps://dev.windows.com/en-us/downloads
Enable development mode for Windows 10 -
Pergi ke Start > Settings.
Pilih Update & security.
Lalu pilih "For developers".
Klik pada Developer mode
Untuk aplikasi UWP, penting untuk menguji aplikasi Anda di perangkat.
Register as an app developer- Anda dapat mulai mengembangkan aplikasi, tetapi untuk mengirimkan aplikasi Anda ke toko, Anda memerlukan akun pengembang. Anda dapat membuat akun pengembang Anda di sinihttps://msdn.microsoft.com/enus/library/windows/apps/bg124287.aspx
Setelah mengikuti langkah-langkah di atas, Anda sekarang siap untuk memulai pengembangan aplikasi Universal Windows Platform (UWP).
Dalam bab ini, kami akan membuat aplikasi sederhana pertama kami "Hello world" di Universal Windows Platform (UWP) menggunakan XAML dan C # pada Windows 10. Kami akan mendemonstrasikan bagaimana aplikasi UWP tunggal yang dibuat di Visual Studio dapat dijalankan dan dijalankan pada perangkat Windows 10 apa pun.
Mari kita mulai membuat Aplikasi dengan mengikuti langkah-langkah yang diberikan di bawah ini.
Luncurkan Visual Studio 2015.
Klik pada File menu dan pilih New > Project.
Pengikut New Projectjendela dialog akan ditampilkan. Anda dapat melihat berbagai jenis templat di panel kiri kotak dialog.
Di panel kiri, Anda dapat melihat tampilan pohon. PilihUniversal template dari Templates > Visual C# > Windows.
Dari panel tengah, pilih Blank App (Universal Windows) template
Beri nama proyek dengan menulis UWPHelloWorld dalam Name field.
Klik OK untuk membuat proyek UWP baru.
Anda dapat melihat proyek yang baru dibuat di Solution Explorer.
Ini adalah aplikasi kosong tetapi berisi banyak file, yang merupakan persyaratan minimum untuk aplikasi UWP apa pun.
MainPage.xaml dan MainPage.xaml.cs dijalankan ketika Anda menjalankan aplikasi Anda.
Secara default, MainPage.xaml file berisi informasi berikut.
<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>
Diberikan di bawah ini adalah informasi default yang tersedia di 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();
}
}
}
Mari kita tambahkan beberapa Blok Teks, kotak teks, dan tombol seperti yang ditunjukkan pada kode XAML di bawah ini.
<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>
- Diberikan di bawah ini adalah tombol peristiwa klik di 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”;
}
}
}
Dalam proyek UWP, device preview pilihan tersedia di Design Window, dengan bantuan yang Anda dapat mengubah tata letak dengan mudah, agar sesuai dengan ukuran layar semua perangkat dalam keluarga perangkat yang Anda targetkan untuk aplikasi Anda.
Anda dapat menjalankan dan menguji aplikasi Anda baik di mesin lokal, simulator atau emulator, atau di perangkat jarak jauh. Anda dapat memilih perangkat target dari menu berikut seperti yang ditunjukkan di bawah ini -
Mari kita jalankan kode di atas pada mesin lokal dan Anda akan melihat jendela berikut. Sekarang, tulis nama apa saja di kotak teks dan klik tombolClick Me.
Sekarang, jika Anda ingin menguji aplikasi Anda pada emulator, Anda dapat memilih emulator tertentu dari menu dan menjalankan aplikasi Anda. Anda akan melihat emulator berikut -
Kami menyarankan Anda untuk menjalankan aplikasi di atas dengan perangkat yang berbeda.
Manfaat Windows Store bagi pengembang adalah Anda dapat menjual aplikasi Anda. Anda dapat mengirimkan aplikasi tunggal Anda untuk setiap keluarga perangkat.
Windows 10 Store adalah tempat aplikasi dikirimkan, sehingga pengguna dapat menemukan aplikasi Anda.
Di Windows 8, Store hanya terbatas pada aplikasi dan Microsoft menyediakan banyak toko yaitu Xbox Music Store, Xbox Game Store, dll.
Di Windows 8, semua ini adalah toko yang berbeda tetapi di Windows 10, ini disebut Windows Store. Ini dirancang sedemikian rupa sehingga pengguna dapat menemukan berbagai aplikasi, game, lagu, film, perangkat lunak, dan layanan di satu tempat untuk semua perangkat Windows 10.
Monetisasi
Monetisasi berarti menjual aplikasi Anda di seluruh desktop, seluler, tablet, dan perangkat lain. Ada berbagai cara untuk menjual aplikasi dan layanan Anda di Windows Store untuk mendapatkan uang.
Anda dapat memilih salah satu metode berikut -
Cara termudah adalah mengirimkan aplikasi Anda di toko dengan opsi unduhan berbayar.
Opsi Trails, di mana pengguna dapat mencoba aplikasi Anda sebelum membelinya dengan fungsionalitas terbatas.
Tambahkan iklan ke aplikasi Anda dengan Microsoft Advertising.
Microsoft Advertising
Ketika Anda menambahkan Iklan ke aplikasi Anda dan pengguna mengklik Iklan tersebut, maka pengiklan akan membayar Anda. Microsoft Advertising memungkinkan pengembang untuk menerima Iklan dari Microsoft Advertising Network.
Aplikasi Microsoft Advertising SDK untuk Universal Windows disertakan di perpustakaan yang diinstal oleh Visual Studio 2015.
Anda juga dapat menginstalnya dari visualstudiogallery
Sekarang, Anda dapat dengan mudah mengintegrasikan Iklan video dan spanduk ke dalam aplikasi Anda.
Mari kita lihat contoh sederhana di XAML, untuk menambahkan Iklan spanduk di aplikasi Anda menggunakan AdControl.
Buat proyek aplikasi kosong Universal Windows baru dengan nama UWPBannerAd.
Dalam Solution Explorer, klik kanan References
Pilih Add References, yang akan membuka file Reference Manager dialog.
Dari panel kiri, pilih Extensions di bawah opsi Universal Windows dan centang file Microsoft Advertising SDK for XAML.
Klik OK untuk melanjutkan.
Diberikan di bawah ini adalah kode XAML di mana AdControl ditambahkan dengan beberapa properti.
<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>
Ketika kode di atas dikompilasi dan dijalankan pada mesin lokal, Anda akan melihat jendela berikut dengan spanduk MSN di atasnya. Ketika Anda mengklik banner ini, itu akan membuka situs MSN.
Anda juga dapat menambahkan file video bannerdalam aplikasi Anda. Mari kita pertimbangkan contoh lain di mana ketikaShow ad tombol diklik, itu akan memutar iklan video Xbox One.
Diberikan di bawah ini adalah kode XAML di mana kami menunjukkan bagaimana tombol ditambahkan dengan beberapa properti dan acara.
<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>
Diberikan di bawah ini adalah implementasi event klik di 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();
}
}
}
}
Ketika kode di atas dikompilasi dan dijalankan pada mesin lokal, Anda akan melihat jendela berikut, yang berisi file Show Ad tombol.
Sekarang, saat Anda mengklik Show Ad tombol, itu akan memutar video di aplikasi Anda.
XAML Singkatan dari Extensible Application Markup Language. Ini adalah kerangka kerja Antarmuka Pengguna dan menawarkan pustaka kontrol ekstensif yang mendukung pengembangan UI untuk Windows. Beberapa dari mereka memiliki representasi visual seperti Button, Textbox dan TextBlock dll; sementara kontrol lain digunakan sebagai wadah untuk kontrol atau konten lain, seperti gambar dll. Semua kontrol XAML diwarisi dari“System.Windows.Controls.Control”.
XAML Emerging Story
XAML digunakan di banyak platform Microsoft penting seperti Windows Presentation Foundation (WPF), Silverlight dan sekarang, aplikasi Windows. Sekarang, Microsoft Office 2016 juga merupakan keluarga aplikasi UWP. XAML adalah Platform yang kaya, yang menyediakan fitur dan kontrol yang sangat keren yang dapat digunakan dalam aplikasi UWP.
Hierarki kontrol pewarisan lengkap ditampilkan di bawah ini.
Kontrol Tata Letak
Tata Letak Kontrol sangat penting dan kritis untuk kegunaan aplikasi. Ini digunakan untuk mengatur sekelompok elemen GUI di aplikasi Anda. Ada beberapa hal penting yang perlu dipertimbangkan saat memilih panel tata letak -
- Posisi elemen anak.
- Ukuran elemen anak.
- Layering elemen anak yang tumpang tindih di atas satu sama lain.
Daftar Layout Controls diberikan di bawah -
S.No. | Kontrol & Deskripsi |
---|---|
1 | StackPanel StackPaneladalah panel tata letak yang sederhana dan berguna di XAML. Pada panel stack, elemen anak dapat diatur dalam satu baris baik secara horizontal maupun vertikal berdasarkan properti orientasi. |
2 | WrapPanel Di WrapPanel, elemen turunan diposisikan dalam urutan berurutan dari kiri ke kanan atau dari atas ke bawah berdasarkan properti orientasi. Satu-satunya perbedaan antara StackPanel dan WrapPanel adalah ia tidak menumpuk semua elemen turunan ke dalam satu baris tetapi membungkus elemen yang tersisa ke baris lain jika tidak ada ruang tersisa. |
3 | DockPanel DockPanelmendefinisikan area untuk mengatur elemen anak relatif satu sama lain, baik secara horizontal atau vertikal. Dengan DockPanel Anda dapat dengan mudah memasang elemen anak ke atas, bawah, kanan, kiri dan tengah dengan properti Dock. Dengan LastChildFill properti, elemen turunan terakhir mengisi ruang yang tersisa terlepas dari nilai dok lainnya saat disetel untuk elemen itu. |
4 | Canvas Canvasadalah panel tata letak dasar tempat elemen anak dapat diposisikan secara eksplisit menggunakan koordinat yang relatif terhadap sisi mana pun seperti kiri, kanan, atas, dan bawah. Biasanya Canvas digunakan untuk elemen grafis 2D (seperti Ellipse, Rectangle, dll.) Tetapi tidak untuk elemen UI karena menentukan koordinat absolut akan menimbulkan masalah saat mengubah ukuran, melokalkan, atau menskalakan aplikasi XAML. |
5 | Grid Gridmenyediakan area yang fleksibel, yang terdiri dari baris dan kolom. Di Grid, elemen anak dapat diatur dalam bentuk tabel. Elemen dapat ditambahkan ke baris dan kolom tertentu dengan menggunakanGrid.Row dan Grid.Column properti. |
6 | SplitView SplitViewmewakili wadah dengan dua tampilan; satu tampilan untuk konten utama dan tampilan lain yang biasanya digunakan untuk perintah navigasi. |
7 | RelativePanel RelativePanel mendefinisikan area di mana Anda dapat memposisikan dan menyelaraskan objek anak dalam kaitannya satu sama lain atau panel induk. |
8 | ViewBox ViewBox mendefinisikan dekorator konten yang dapat memperluas dan menskalakan satu anak untuk mengisi ruang yang tersedia. |
9 | FlipView FlipView merepresentasikan kontrol item yang menampilkan satu item pada satu waktu, dan memungkinkan perilaku "membalik" untuk melintasi koleksi itemnya. |
10 | GridView GridView adalah kontrol yang menampilkan kumpulan item dalam baris dan kolom dan dapat digulir secara horizontal. |
Kontrol UI
Berikut adalah daftar Kontrol UI, yang dapat dilihat oleh pengguna akhir.
S.No. | Kontrol & Deskripsi UI |
---|---|
1 | Button Kontrol yang merespons masukan pengguna |
2 | Calendar Merepresentasikan kontrol yang memungkinkan pengguna untuk memilih tanggal dengan menggunakan tampilan kalender visual. |
3 | CheckBox Kontrol yang dapat dipilih atau dihapus pengguna. |
4 | ComboBox Daftar drop-down item, pengguna dapat memilih dari. |
5 | ContextMenu Mendapat atau menyetel elemen menu konteks yang harus muncul setiap kali menu konteks diminta melalui antarmuka pengguna (UI) dari dalam elemen ini. |
6 | DataGrid Merepresentasikan kontrol yang menampilkan data dalam kisi yang dapat disesuaikan. |
7 | DatePicker Kontrol yang memungkinkan pengguna memilih tanggal. |
8 | Dialogs Sebuah aplikasi juga dapat menampilkan jendela tambahan untuk dilakukan pengguna untuk mengumpulkan atau menampilkan informasi penting. |
9 | Flyout Merepresentasikan kontrol yang menampilkan UI ringan yang berupa informasi, atau memerlukan interaksi pengguna. Tidak seperti dialog, Flyout dapat dihilangkan dengan mengklik atau mengetuk di luarnya, menekan tombol kembali perangkat, atau menekan tombol 'Esc'. |
10 | Image Kontrol yang menampilkan gambar. |
11 | ListBox Kontrol yang menampilkan daftar item sebaris yang dapat dipilih pengguna. |
12 | Menus Merepresentasikan kontrol menu Windows yang memungkinkan Anda untuk mengatur secara hierarki elemen yang terkait dengan perintah dan penangan kejadian. |
13 | MenuFlyout Merupakan flyout yang menampilkan menu perintah. |
14 | PasswordBox Kontrol untuk memasukkan kata sandi. |
15 | Popup Menampilkan konten di atas konten yang ada, dalam batas-batas jendela aplikasi. |
16 | ProgressBar Kontrol yang menunjukkan kemajuan dengan menampilkan bilah. |
17 | ProgressRing Kontrol yang menunjukkan kemajuan tak tentu dengan menampilkan cincin. |
18 | RadioButton Kontrol yang memungkinkan pengguna untuk memilih satu opsi dari sekelompok opsi. |
19 | RichEditBox Kontrol yang memungkinkan pengguna mengedit dokumen teks kaya dengan konten seperti teks yang diformat, hyperlink, dan gambar. |
20 | ScrollViewer Kontrol wadah yang memungkinkan pengguna menggeser dan memperbesar kontennya. |
21 | SearchBox Kontrol yang memungkinkan pengguna memasukkan kueri penelusuran. |
22 | Slider Kontrol yang memungkinkan pengguna memilih dari berbagai nilai dengan menggerakkan kontrol Thumb di sepanjang trek. |
23 | TextBlock Kontrol yang menampilkan teks. |
24 | TimePicker Kontrol yang memungkinkan pengguna menetapkan nilai waktu. |
25 | ToggleButton Tombol yang dapat diubah antara 2 status. |
26 | ToolTip Jendela pop-up yang menampilkan informasi untuk suatu elemen. |
27 | Window Jendela root yang menyediakan opsi perkecil / maksimalkan, bilah judul, tombol batas, dan tombol tutup. |
Diberikan di bawah ini adalah contoh, yang berisi berbagai jenis kontrol dalam a SplitView. Dalam file XAML, kontrol berbeda dibuat dengan beberapa properti dan acara.
<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>
Diberikan di bawah ini adalah Events implementasi di 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;
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut -
Saat Anda mengklik tombol hamburger di sisi kiri atas, itu akan membuka / menutup SplitView panel.
Dalam SplitView Panel, Anda dapat melihat Flyout, MenuFlyout dan FlipView kontrol.
Dalam SplitView Konten, Anda dapat melihat Hyperlink, Relative Panel, ViewBox, dan tombol lain serta kontrol kotak teks.
Data binding adalah mekanisme dalam aplikasi XAML, yang menyediakan cara sederhana dan mudah untuk aplikasi Windows Runtime menggunakan kelas parsial untuk menampilkan dan berinteraksi dengan data. Pengelolaan data sepenuhnya terpisah dari cara data ditampilkan dalam mekanisme ini.
Data binding memungkinkan aliran data antara elemen UI dan objek data pada antarmuka pengguna. Saat pengikatan dibuat dan data atau model bisnis Anda berubah, pengikatan tersebut mencerminkan pembaruan secara otomatis ke elemen UI dan sebaliknya. Dimungkinkan juga untuk mengikat, bukan ke sumber data standar, melainkan ke elemen lain di laman. Pengikatan data dapat berupa -
- Pengikatan data satu arah
- Pengikatan data dua arah
- Pengikatan Elemen
Pengikatan Data satu arah
Dalam pengikatan satu arah, data diikat dari sumbernya, (objek yang menyimpan data) ke targetnya (objek yang menampilkan data).
Mari kita lihat contoh sederhana dari pengikatan data satu arah. Diberikan di bawah ini adalah kode XAML di mana empat blok teks dibuat dengan beberapa properti.
<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>
Properti teks dari dua blok teks diatur ke “Name” dan “Title” secara statis, sedangkan dua properti Teks lainnya dari blok teks terikat ke "Nama" dan "Judul" yang merupakan variabel kelas dari kelas Karyawan seperti yang ditunjukkan di bawah ini.
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;
}
}
}
Dalam Employee class, kami memiliki variabel Name dan Title dan satu metode statis di mana employee objectdiinisialisasi dan akan mengembalikan objek karyawan itu. Oleh karena itu, kami mengikat properti, Nama dan Judul, tetapi kami belum memilih objek yang memiliki properti tersebut. Cara termudah adalah dengan menetapkan suatu objekDataContext, yang propertinya kami ikat di MainPage Pembuat.
Ketika Anda menjalankan aplikasi ini, Anda dapat langsung melihatnya di MainWindow bahwa Anda telah berhasil terikat ke Nama dan Judul objek Karyawan itu.
Pengikatan Data dua arah
Dalam Pengikatan Dua Arah, pengguna dapat memodifikasi data melalui antarmuka pengguna dan memperbarui data di sumbernya. Misalnya, jika sumber berubah saat pengguna melihat tampilan, Anda ingin tampilan diperbarui.
Mari kita lihat contoh yang diberikan di bawah ini di mana dua label, dua kotak teks dan satu tombol dibuat dengan beberapa properti dan acara.
<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>
Kami dapat mengamati yang berikut -
Properti Teks dari kedua kotak teks terikat ke "Name" dan "Age" yang merupakan variabel kelas Person class seperti gambar dibawah.
Di Person class, kami hanya memiliki dua variabel - Nama dan Umur, dan objeknya diinisialisasi di MainWindow kelas.
Dalam kode XAML, kami mengikat properti - Name dan Age, tetapi kami belum memilih objek yang memiliki properti tersebut.
Cara yang lebih mudah adalah dengan menetapkan objek ke DataContext, yang propertinya kami ikat dalam kode C # seperti yang ditunjukkan di bawah ini di 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;
}
}
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut. KlikDisplay tombol.
Mari kita ubah Nama dan Umur dan klik Display tombol lagi.
Anda dapat melihatnya di tombol klik ‘Display’, teks kotak teks tidak digunakan untuk menampilkan data TextBlock tetapi variabel kelas digunakan.
Saya sarankan Anda untuk menjalankan kode di atas dengan kedua kasus untuk pemahaman yang lebih baik.
Pengikatan Elemen
Dimungkinkan juga untuk mengikat, bukan ke sumber data standar, melainkan ke elemen lain di laman. Mari kita buat aplikasi bernamaElementBindingdi mana Slider dan Rectangle dibuat dan dengan slider, lebar dan tinggi persegi panjang terikat. Diberikan di bawah ini adalah kode di 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>
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Dengan slider, Anda dapat mengubah ukuran persegi panjang seperti yang ditunjukkan di bawah ini.
Performa aplikasi seperti seberapa cepat aplikasi Anda muncul saat startup atau menavigasi untuk menampilkan konten berikutnya, dll. Sangatlah penting.
Kinerja sebuah aplikasi dapat dipengaruhi oleh banyak hal, termasuk kemampuan mesin rendering XAML untuk mengurai semua kode XAML yang Anda miliki di aplikasi Anda. XAML adalah alat yang sangat kuat untuk membuat UI, tetapi dapat menjadi lebih kuat dengan menggunakan teknik baru, yang sekarang tersedia di aplikasi Windows 10.
Misalnya, dalam aplikasi Anda, ada hal-hal tertentu yang ingin Anda tunjukkan saat halaman dimuat dan kemudian tidak membutuhkannya nanti. Mungkin juga saat startup Anda tidak memerlukan semua elemen UI untuk dimuat.
Di aplikasi Windows 10, beberapa fitur baru ditambahkan di XAML, yang meningkatkan kinerja XAML.
Kinerja aplikasi Universal Windows apa pun dapat ditingkatkan dengan teknik berikut;
- Rendering Progresif
- Pemuatan yang Ditunda
Rendering Progresif
Di Windows 10, dua fitur baru dan sangat keren diperkenalkan di XAML. Mereka adalah -
x: Bind
Ini adalah sintaks baru yang diperkenalkan di XAML yang digunakan untuk mengikat, yang bekerja hampir sama dengan Binding sintaks tidak. x:Bindmemiliki dua perbedaan utama; ini memberikan validasi sintaks waktu kompilasi dan kinerja yang lebih baik.
X: Fase
Ini memberikan kemampuan untuk memprioritaskan rendering kontrol XAML dalam template data. Setiap elemen UI hanya dapat memiliki satu fase yang ditentukan. Jika demikian, itu akan berlaku untuk semua binding pada elemen. Jika fase tidak ditentukan, fase 0 diasumsikan.
Dalam aplikasi Universal Windows Platform (UWP), kedua fitur baru ini memberikan peningkatan kinerja. Ini juga dapat digunakan di aplikasi Windows 8.x yang ada yang bermigrasi ke Windows 10.
Diberikan di bawah ini adalah contoh di mana objek karyawan terikat GridView dengan menggunakan x:Bind kata kunci.
<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>
Pada kode XAML di atas, x:Phase = "1"didefinisikan dengan Judul. Oleh karena itu, pada fase pertama,Name akan diberikan dan kemudian Title akan diberikan.
Diberikan di bawah ini adalah Employee class implementasi di 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;
}
}
}
Ketika kode yang diberikan di atas dijalankan, Anda akan melihat jendela berikut.
Itu X:Phase dengan x:Bind digunakan untuk merender ListView dan GridView item secara bertahap dan meningkatkan pengalaman panning.
Pemuatan yang Ditunda
Pemuatan tertunda adalah teknik yang dapat digunakan untuk meminimalkan waktu pemuatan startup dengan mengurangi jumlah elemen XAML UI saat memulai aplikasi. Jika aplikasi Anda berisi 30 elemen UI dan pengguna tidak membutuhkan semua elemen ini saat startup, semua elemen tersebut, yang tidak diperlukan, dapat menghemat waktu pemuatan dengan menunda.
x:DeferLoadStrategy = "Lazy" menunda pembuatan elemen dan turunannya, yang mengurangi waktu startup tetapi sedikit meningkatkan penggunaan memori.
Elemen yang ditangguhkan dapat direalisasikan / dibuat dengan Memanggil FindName dengan nama yang ditentukan pada elemen.
Setelah elemen yang ditangguhkan dibuat, beberapa hal akan terjadi -
Acara Dimuat pada elemen akan dimunculkan.
Setiap binding pada elemen akan dievaluasi.
Jika aplikasi terdaftar untuk menerima pemberitahuan perubahan properti pada properti yang mengandung elemen ditangguhkan, pemberitahuan akan dimunculkan.
Diberikan di bawah ini adalah contoh di mana x:DeferLoadStrategy = "Lazy" digunakan untuk kisi yang berisi empat blok teks dan tidak akan dimuat saat aplikasi Anda dimulai, sampai Anda memuatnya.
<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>
Program berikut adalah implementasi event click, di mana grid dimuat pada halaman utama aplikasi.
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
}
}
}
Ketika kode di atas di patuhi dan dijalankan, Anda hanya akan melihat sebuah tombol. ItuTextblocks tidak dimuat saat startup.
Sekarang saat Anda mengklik Show Elements tombol, itu akan memuat blok teks, yang akan meningkatkan kinerja startup aplikasi Anda.
Di Windows 10, aplikasi Universal Windows Platform (UWP) sekarang akan berjalan di sejumlah keluarga perangkat seperti -
Desktop device family - Tablet, laptop, PC
Mobile device family - Ponsel Windows, phablet
IoT device family - Perangkat kompak seperti perangkat yang dapat dikenakan atau peralatan rumah tangga
Team device family - Hub permukaan
Setiap keluarga perangkat memiliki ukuran layar dan jendelanya sendiri. Jadi, bagaimana cara merancang aplikasi yang memberikan pengalaman pengguna yang luar biasa di beberapa perangkat dengan ukuran layar yang sangat berbeda dan metode masukan yang berbeda?
Mendesain aplikasi Anda untuk beberapa kelompok perangkat memerlukan beberapa pertimbangan, perencanaan, dan desain tambahan. Windows 10 UWP menyediakan sekumpulan fitur bawaan dan blok penyusun universal yang membuatnya lebih mudah untuk mendesain untuk beberapa perangkat dan secara otomatis menyesuaikan skala di layar dan ukuran jendela yang berbeda, didukung oleh kontrol platform.
Fitur Bawaan Baru
Berikut ini adalah fitur-fitur baru yang dapat digunakan developer saat membuat aplikasi UWP. Fitur-fitur ini otomatis dan gratis.
Piksel Efektif dan Penskalaan Platform
Saat aplikasi UWP Anda berjalan di perangkat apa pun yang didukung oleh Windows 10, maka -
Sistem menggunakan algoritme untuk menormalkan cara kontrol, font, dan elemen UI lainnya ditampilkan di layar perangkat yang sedang menjalankannya.
Algoritme penskalaan, mengontrol jarak pandang dan kepadatan layar (piksel per inci) untuk mengoptimalkan ukuran yang seharusnya (bukan ukuran fisik).
Algoritme penskalaan memastikan bahwa font 36 px di Surface Hub 10 kaki jauhnya dapat dibaca oleh pengguna seperti font 36 px pada ponsel 5 '' yang berjarak beberapa inci.
Input Universal dan Interaksi Cerdas
Platform Windows Universal memiliki sistem input interaksi cerdas terintegrasi, yang memahami input untuk semua perangkat. Misalnya, saat Anda mendesain interaksi klik dalam aplikasi Anda, Anda tidak perlu mengetahui apakah klik tersebut berasal dari klik mouse yang sebenarnya atau ketukan jari. Sistem akan melakukannya secara otomatis untuk Anda.
Blok Bangunan Universal
Ada beberapa blok penyusun yang berharga, yang mempermudah desain aplikasi untuk banyak keluarga perangkat di Universal Windows Platform (UWP).
Kontrol Universal
UWP menyediakan satu set Kontrol Universal yang dijamin berfungsi dengan baik di semua perangkat Windows 10.
Daftar 'Kontrol universal' ini berisi kontrol umum seperti tombol radio, kotak kombo, dan kotak teks, dll.
Ini juga berisi beberapa kontrol canggih seperti grid view dan list view yang dapat menghasilkan daftar item dari aliran data dan templat.
Gaya Universal
Aplikasi UWP secara otomatis mendapatkan serangkaian gaya default yang memberi Anda fitur-fitur ini -
Serangkaian gaya yang secara otomatis memberi aplikasi Anda tema terang atau gelap.
Animasi default untuk interaksi.
Dukungan otomatis untuk mode kontras tinggi.
Dukungan otomatis untuk bahasa lain. Gaya default kami secara otomatis memilih font yang benar untuk setiap bahasa yang didukung Windows. Anda bahkan dapat menggunakan banyak bahasa di aplikasi yang sama dan mereka akan ditampilkan dengan benar.
Aplikasi Universal Windows Platform (UWP) dapat berjalan di berbagai perangkat dan setiap perangkat memiliki bentuk input, resolusi layar, kepadatan DPI, dan karakteristik unik lainnya sendiri-sendiri.
Di Windows 10, dengan bantuan kontrol universal baru, panel tata letak, dan perkakas, Anda dapat menyesuaikan UI dengan mudah ke perangkat yang dapat menjalankan aplikasi Anda. Misalnya, saat aplikasi UWP Anda berjalan baik di komputer desktop, perangkat seluler, atau tablet, Anda dapat menyesuaikan UI untuk memanfaatkan berbagai resolusi layar, ukuran layar, dan kepadatan DPI.
Di Windows 10, Anda dapat dengan mudah menargetkan UI Anda ke beberapa perangkat dengan fitur berikut -
Anda dapat menyempurnakan UI untuk berbagai resolusi layar dan ukuran layar dengan menggunakan kontrol universal dan panel tata letak.
Penanganan input umum memungkinkan Anda menerima input melalui panel sentuh, pena, mouse, keyboard, atau pengontrol seperti pengontrol Microsoft Xbox.
Dengan bantuan Tools, Anda dapat mendesain UI aplikasi Anda yang dapat beradaptasi dengan resolusi layar yang berbeda.
Penskalaan adaptif menyesuaikan dengan resolusi dan perbedaan DPI di seluruh perangkat.
Di Windows 10, Anda dapat dengan mudah mengatur, mengubah ukuran, dan memposisikan aplikasi dengan cara apa pun yang Anda inginkan. Ini juga memberikan semacam fleksibilitas kepada pengguna untuk menggunakan aplikasi Anda seperti yang mereka inginkan. Di Windows 10, ada berbagai cara untuk mengimplementasikan teknik responsif di aplikasi UWP Anda, sehingga terlihat bagus tidak peduli apa pun ukuran layar atau jendelanya.
VisualStateManager
Di Windows 10, file VisualStateManagerclass memiliki dua mekanisme baru yang dengannya Anda dapat mengimplementasikan desain responsif dalam aplikasi UWP Anda. Yang baruVisualState.StateTriggers memungkinkan pengembang untuk memeriksa kondisi tertentu seperti tinggi jendela atau lebar jendela dan kemudian VisualState.Setters API menentukan status visual sebagai respons terhadap kondisi tertentu tersebut.
Mari kita lihat contoh yang diberikan di bawah ini di mana beberapa kontrol ditambahkan di panel tumpukan.
<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>
Sekarang VisualStateManager, akan menyesuaikan orientasi panel tumpukan berdasarkan lebar jendela. Jika lebarnya> = 720, maka orientasinya menjadi Horizontal jika tidak maka akan tetap vertikal. Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut, yang berisi tiga blok teks dalam urutan vertikal.
Mari kita ubah ukuran lebar jendela di atas dan Anda akan melihat jendela berikut -
Sekarang Anda dapat melihat bahwa blok teks berada dalam urutan horizontal.
RelativePanel
RelativePaneldapat digunakan untuk menata elemen UI dengan mengekspresikan hubungan spasial antar elemen. Mari kita ambil contoh di mana beberapa persegi panjang dibuat di panel relatif.
<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>
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Saat Anda mengubah ukuran jendela di atas, Anda akan melihat bahwa persegi panjang hijau sekarang disesuaikan di baris atas di sebelah kiri persegi panjang biru seperti yang ditunjukkan di bawah ini.
Dalam bab ini, kami akan mendemonstrasikan penerapan aplikasi Anda ke berbagai perangkat yang didukung oleh Windows 10. Kami telah mempelajari tentang mengadopsi UI Anda dan semua trik, teknik, dan kontrol yang digunakan dalam aplikasi UWP.
Sekarang, kita akan belajar tentang mengadopsi kode Anda, karena
Kode aplikasi tidak sama di semua perangkat.
API yang digunakan, terutama untuk Xbox, tidak akan tersedia untuk perangkat seluler. Hal yang sama berlaku untuk HoloLens dll.
Adaptive kode dapat menerangi aplikasi Anda secara bersyarat dan mengeksekusi kode hanya ketika dijalankan pada kelompok perangkat tertentu dan / atau pada versi tertentu dari platform / API ekstensi.
Menulis Kode
Di Windows 10, Anda dapat menerapkan aplikasi UWP di Visual Studio dengan menggunakan C ++, C #, Visual Basic, atau JavaScript.
Dengan C # dan Visual Basic Anda dapat menggunakan XAML untuk mendesain UI.
Dengan C ++ Anda dapat menggunakan DirectX daripada menggunakan XAML.
Untuk JavaScript, Anda dapat menggunakan HTML untuk lapisan presentasi Anda, yang merupakan standar Web lintas platform.
Windows Core API berjalan dengan cara yang sama untuk semua perangkat, yang berisi sebagian besar fungsionalitas yang Anda perlukan untuk kode dan UI Anda. Namun, untuk kode dan UI yang disesuaikan untuk kelompok perangkat tertentu, Anda perlu menggunakan kode adaptif dan UI adaptif.
Calling an API that is NOT implemented by the target device family −
UI beradaptasi dengan layar yang berbeda dengan mudah, tetapi berbagai jenis perangkat tidak hanya memiliki ukuran layar yang berbeda, tetapi juga memiliki lebih dari itu.
Misalnya, ponsel memiliki beberapa tombol perangkat keras seperti Kembali dan Kamera, yang mungkin tidak tersedia di perangkat lain seperti PC.
Secara default, API inti berisi sebagian besar fungsionalitas, yang berfungsi untuk semua perangkat, tetapi fungsionalitas khusus perangkat dapat digunakan dengan mereferensikan SDK Ekstensi dalam aplikasi UWP Anda seperti rakitan eksternal.
Untuk menambahkan SDK ekstensi tertentu, yang diperlukan dalam aplikasi Anda, ikuti langkah-langkah yang diberikan di bawah ini -
Klik kanan pada References.
Pilih “Add References..”. Dialog berikut akan terbuka.
Menambahkan ekstensi semudah menambahkan referensi proyek.
Sekarang Anda dapat menambahkan SDK ekstensi apa pun dari daftar, yang berisi Ekstensi Desktop, Ekstensi IoT, dan Ekstensi Seluler dll.
Ekstensi Desktop dan Seluler adalah dua SDK Ekstensi platform yang paling umum. Ekstensi Seluler, misalnya, mengaktifkan API yang diperlukan untuk menggunakan tombol kamera perangkat keras.
Anda dapat memeriksa kemampuan perangkat dengan menggunakan Windows.Foundation.Metadata.ApiInformationmetode kelas, yang mengembalikan keluaran Boolean jika jenisnya didukung pada perangkat saat ini. Misalnya, Anda dapat mengaktifkan aplikasi Windows Anda untuk menggunakan tombol Kamera dengan kode seperti ini -
bool isHardwareButtonsAPIPresent =
Windows.Foundation.Metadata.ApiInformation.
IsTypePresent("Windows.Phone.UI.Inpu t.HardwareButtons");
if (isHardwareButtonsAPIPresent) {
Windows.Phone.UI.Input.HardwareButtons.CameraPressed += HardwareButtons_CameraPressed;
}
Kode tombol kamera ponsel hanya akan dijalankan jika Mobile Extension SDK diaktifkan di perangkat. Demikian pula, Anda juga dapat memeriksa kejadian, metode, atau properti tertentu dalam versi API saat ini dengan menggunakanIsEventPresent, IsMethodPresent, IsPropertyPresent, dari pada IsTypePresent seperti gambar dibawah.
bool isHardwareButtons_CameraPressedAPIPresent =
Windows.Foundation.Metadata.ApiInformation.IsEventPresent
("Windows.Phone.UI.Input.HardwareButtons", "CameraPressed");
Win32 API di UWP
Aplikasi Universal Widows Platform (UWP) atau Windows Runtime Component, yang ditulis dalam C ++ / CX, dapat mengakses Win32 API, yang juga merupakan bagian dari UWP sekarang. Semua keluarga perangkat Windows 10 dapat mengimplementasikan Win32 API dengan menghubungkan aplikasi Anda denganWindowsapp.lib.
Windowsapp.libadalah lib "umbrella" yang menyediakan ekspor untuk UWP API. Menautkan keWindowsapp.lib akan menambah ketergantungan aplikasi Anda pada dlls yang ada di semua keluarga perangkat Windows 10.
Mari kita lihat contoh sederhana di mana aplikasi menargetkan desktop dan ponsel. Oleh karena itu, ketika aplikasi berjalan di desktop, itu tidak akan menampilkan bilah status, tetapi ketika aplikasi yang sama berjalan di ponsel, itu akan menampilkan bilah status.
Diberikan di bawah ini adalah kode XAML di mana kontrol yang berbeda ditambahkan.
<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>
Diberikan di bawah ini adalah implementasi C # untuk berbagai acara.
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);
}
}
}
}
Ketika kode yang diberikan di atas dikompilasi dan dijalankan pada Ponsel, Anda akan melihat jendela berikut.
Anda dapat mengubah warna latar belakang bilah status dengan kotak centang seperti yang ditunjukkan pada gambar.
Anda juga dapat menyembunyikan bilah status.
Sekarang, ketika Anda menjalankan aplikasi yang sama pada perangkat desktop, Anda akan melihat jendela berikut di mana bilah status dan kotak centang khusus untuk bilah status tidak terlihat.
Dalam aplikasi apa pun, salah satu yang terpenting adalah data. Jika Anda.net pengembang, Anda mungkin tahu tentang penyimpanan terisolasi dan konsep yang sama mengikuti melalui aplikasi Universal Windows Platform (UWP).
Lokasi File
Ini adalah area tempat aplikasi Anda dapat mengakses data. Aplikasi berisi beberapa area, yang bersifat pribadi untuk aplikasi tertentu dan tidak dapat diakses oleh yang lain, tetapi ada banyak area lain, di mana Anda dapat menyimpan dan menyimpan data Anda di dalam file.
Diberikan di bawah ini adalah deskripsi singkat dari setiap folder.
S.No. | Folder & Deskripsi |
---|---|
1 | App package folder Manajer paket menginstal semua file terkait aplikasi ke dalam folder paket Aplikasi, dan aplikasi hanya dapat membaca data dari folder ini. |
2 | Local folder Aplikasi menyimpan data lokal ke dalam folder lokal. Itu dapat menyimpan data hingga batas pada perangkat penyimpanan. |
3 | Roaming folder Setting dan properti yang berhubungan dengan aplikasi disimpan dalam folder roaming. Perangkat lain juga dapat mengakses data dari folder ini. Ini memiliki ukuran terbatas hingga 100KB per aplikasi. |
4 | Temp Folder Gunakan penyimpanan sementara dan tidak ada jaminan bahwa itu akan tetap tersedia saat aplikasi Anda berjalan kembali. |
5 | Publisher Share Penyimpanan bersama untuk semua aplikasi dari penerbit yang sama. Itu dideklarasikan dalam manifes aplikasi. |
6 | Credential Locker Digunakan untuk penyimpanan aman objek kredensial kata sandi. |
7 | OneDrive OneDrive adalah penyimpanan online gratis yang disertakan dengan akun Microsoft Anda. |
8 | Cloud Simpan data di cloud. |
9 | Known folders Folder-folder tersebut sudah dikenal folder-folder seperti My Pictures, Videos, dan Music. |
10 | Removable storage Perangkat penyimpanan USB atau hard drive eksternal dll. |
API Penanganan File
Di Windows 8, API baru diperkenalkan untuk penanganan file. API ini terletak diWindows.Storage dan Windows.Storage.Streamsruang nama. Anda dapat menggunakan API ini sebagai gantiSystem.IO.IsolatedStoragenamespace. Dengan menggunakan API ini, akan lebih mudah untuk mem-porting aplikasi Windows Phone Anda ke Windows Store, dan Anda dapat dengan mudah meningkatkan aplikasi Anda ke versi Windows yang akan datang.
Untuk mengakses folder lokal, roaming, atau temp, Anda perlu memanggil API ini -
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFolder roamingFolder = ApplicationData.Current.RoamingFolder;
StorageFolder tempFolder = ApplicationData.Current.TemporaryFolder;
Untuk membuat file baru di folder lokal gunakan kode berikut -
StorageFolder localFolder = ApplicationData.Current.LocalFolder;
StorageFile textFile = await localFolder.CreateFileAsync(filename,
CreationCollisionOption.ReplaceExisting);
Berikut adalah kode untuk membuka file yang baru dibuat dan menulis beberapa konten di file itu.
using (IRandomAccessStream textStream = await textFile.OpenAsync(FileAccessMode.ReadWrite)) {
using (DataWriter textWriter = new DataWriter(textStream)){
textWriter.WriteString(contents);
await textWriter.StoreAsync();
}
}
Anda dapat membuka file yang sama lagi, dari folder lokal seperti yang ditunjukkan pada kode yang diberikan di bawah ini.
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);
}
}
Untuk memahami cara kerja membaca dan menulis data, mari kita lihat contoh sederhana. Diberikan di bawah ini adalah kode XAML di mana kontrol yang berbeda ditambahkan.
<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>
Diberikan di bawah ini adalah implementasi C # untuk berbagai acara dan juga implementasi dari FileHelper kelas untuk membaca dan menulis data ke file teks.
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;
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Sekarang, Anda menulis sesuatu di kotak teks dan klik “Write Data to File”tombol. Program akan menulis data ke dalam file teks di folder lokal. Jika Anda mengklik“Read Data from File” tombol, program akan membaca data dari file teks yang sama, yang terletak di folder lokal dan akan menampilkannya di blok teks.
Dalam banyak aplikasi, terdapat tipe data tertentu, yang memiliki semacam hubungan satu sama lain. Jenis data ini, yang sulit untuk disimpan dalam sebuah file, dapat disimpan dalam database.
Jika Anda terbiasa dengan jenis database, seperti SQL server atau database Oracle di aplikasi apa pun, maka sangat mudah untuk dipahami. SQLite database.
Apa itu SQLite?
SQLite adalah pustaka perangkat lunak yang mengimplementasikan mesin database SQL transaksional, tanpa server, tanpa konfigurasi, dan mandiri.
Fitur penting adalah -
SQLite adalah mesin database yang paling banyak digunakan di dunia.
Kode sumber untuk SQLite adalah Open source.
Ini berdampak besar pada pengembangan game dan aplikasi seluler, karena portabilitas dan footprint yang kecil.
Keuntungan SQLite
Berikut ini adalah keunggulan SQLite -
- Ini adalah database yang sangat ringan.
- Ini adalah platform independen dan berfungsi di semua platform.
- Ini memiliki jejak memori yang kecil.
- Itu bisa diandalkan.
- Tidak perlu penyiapan dan penginstalan apa pun.
- Ini tidak memiliki ketergantungan.
Menggunakan SQLite di aplikasi Universal Windows Platform (UWP) Anda, Anda perlu mengikuti langkah-langkah yang diberikan di bawah ini.
Buat aplikasi kosong Universal Windows baru dengan nama UWPSQLiteDemo.
Pergi ke Toolsmenu dan pilih Ekstensi dan Pembaruan. Dialog berikut akan terbuka.
- Setelah memilih Extensions and Updates, jendela berikut akan terbuka.
Sekarang pilih Online opsi dan cari SQLite, dari panel kiri.
Unduh dan Instal SQLite untuk Platform Aplikasi Universal.
Sekarang, buka menu Alat lagi dan pilih NuGet Package Manager > Package Manager Console pilihan menu seperti yang ditunjukkan di bawah ini.
Tulis perintah berikut di Package Manager Console dan tekan enter untuk menjalankan perintah ini -
Install-Package SQLite.Net-PCL
Sekarang klik kanan References di penelusur solusi dan pilih Add References.
- Dialog berikut akan terbuka.
Pilih Extensions dari panel kiri di bawah Universal Windows, periksa SQLite untuk Platform Aplikasi Universal di panel tengah, dan klik Ok.
Sekarang Anda siap untuk pergi dan menggunakan SQLite di aplikasi UWP Anda.
Anda dapat membuat database dengan menggunakan kode berikut ini.
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);
Untuk membuat tabel, Anda perlu menelepon CreateTable metode dengan objek nama tabel.
conn.CreateTable<Customer>();
Anda dapat memasukkan data ke dalam tabel Anda dengan menggunakan kode berikut.
conn.Insert(new Customer(){
Name = textBox.Text,
Age = textBox1.Text
});
Diberikan di bawah ini adalah kode untuk mengambil data dari tabel.
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;
}
Mari kita pahami cara membuat database, tabel, dan cara menyisipkan dan mengambil data dari database dengan bantuan contoh sederhana. Kami akan menambahkan Nama dan usia dan kemudian kami akan mengambil data yang sama dari tabel. Diberikan di bawah ini adalah kode XAML di mana kontrol yang berbeda ditambahkan.
<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>
Diberikan di bawah ini adalah implementasi C # untuk acara dan 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; }
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Masukkan Name dan Age dan klik Add tombol.
Sekarang klik Retrievetombol. Anda akan melihat data berikut diText Block.
Bidang ID adalah bidang Kunci Utama dan Kenaikan Otomatis, yang ditentukan di kelas Pelanggan.
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
Komunikasi aplikasi ke aplikasi berarti bahwa aplikasi Anda dapat berbicara atau berkomunikasi dengan aplikasi lain yang diinstal pada perangkat yang sama. Ini bukan fitur baru di aplikasi Universal Windows Platform (UWP) dan juga tersedia di Windows 8.1.
Di Windows 10, beberapa cara baru dan lebih baik diperkenalkan untuk dengan mudah berkomunikasi antar aplikasi pada perangkat yang sama. Komunikasi antara dua aplikasi dapat dilakukan dengan cara berikut -
- Satu aplikasi meluncurkan aplikasi lain dengan beberapa data.
- Aplikasi hanya bertukar data tanpa meluncurkan apa pun.
Keuntungan utama komunikasi aplikasi ke aplikasi adalah Anda dapat memecah aplikasi menjadi beberapa bagian yang lebih kecil, yang dapat dipelihara, diperbarui, dan digunakan dengan mudah.
Mempersiapkan Aplikasi Anda
Jika Anda Ikuti langkah-langkah yang diberikan di bawah ini, aplikasi lain dapat meluncurkan aplikasi Anda.
Tambahkan deklarasi protokol dalam manifes paket aplikasi.
Klik dua kali pada Package.appxmanifest file, yang tersedia di Solution Explorer seperti yang ditunjukkan di bawah ini.
Pergi ke Declaration tab dan tulis Nama protokol seperti yang ditunjukkan di bawah ini.
Langkah selanjutnya adalah menambahkan file activation kode, sehingga aplikasi bisa merespons dengan tepat saat diluncurkan oleh aplikasi lain.
Untuk menanggapi aktivasi protokol, kita perlu mengganti file OnActivatedmetode kelas aktivasi. Jadi, tambahkan kode berikut iniApp.xaml.cs mengajukan.
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();
}
}
Untuk meluncurkan aplikasi, Anda cukup menggunakan Launcher.LaunchUriAsync metode, yang akan meluncurkan aplikasi dengan protokol yang ditentukan dalam metode ini.
await Windows.System.Launcher.LaunchUriAsync(new Uri("win10demo:?SomeData=123"));
Mari kita pahami ini dengan contoh sederhana di mana kita memiliki dua aplikasi UWP ProtocolHandlerDemo dan FirstProtocolHandler.
Dalam contoh ini, file ProtocolHandlerDemo aplikasi berisi satu tombol dan dengan mengklik tombol tersebut, itu akan membuka FirstProtocolHandler aplikasi.
Kode XAML dalam aplikasi ProtocolHandlerDemo, yang berisi satu tombol diberikan di bawah ini.
<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>
Diberikan di bawah ini adalah kode C #, di mana acara klik tombol diimplementasikan.
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"));
}
}
}
Sekarang mari kita lihat FirstProtocolHandlertabel aplikasi. Diberikan di bawah ini adalah kode XAML di mana textblock dibuat dengan beberapa properti.
<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>
Implementasi C # dari App.xaml.cs file di mana OnActicateddiganti ditampilkan di bawah. Tambahkan kode berikut di dalam kelas App diApp.xaml.cs mengajukan.
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();
}
}
Saat Anda mengompilasi dan menjalankan file ProtocolHandlerDemo aplikasi pada emulator, Anda akan melihat jendela berikut.
Sekarang, ketika Anda mengklik tombolnya, itu akan membuka FirstProtocolHandler aplikasi seperti yang ditunjukkan di bawah ini.
Windows digunakan di seluruh dunia, di berbagai pasar yang berbeda dan untuk target audiens yang berbeda dalam budaya, wilayah, atau bahasa. Pelokalan adalah penerjemahan sumber daya aplikasi ke dalam versi yang dilokalkan untuk budaya tertentu yang didukung aplikasi.
Ketika Anda mengembangkan aplikasi apa pun hanya dalam satu bahasa, itu berarti Anda hanya membatasi bisnis dan pelanggan Anda. Jika Anda ingin meningkatkan basis pelanggan Anda, yang juga akan meningkatkan bisnis Anda, maka aplikasi Anda harus tersedia dan dapat dijangkau secara global. Lokalisasi produk Anda yang hemat biaya adalah salah satu cara terbaik dan paling ekonomis untuk menjangkau lebih banyak pelanggan.
Di Windows 10, aplikasi yang dapat dilokalkan sangat mudah dibuat resx file, yang merupakan solusi paling sederhana untuk pelokalan.
Mari kita pahami ini dengan bantuan contoh sederhana dengan mengikuti semua langkah yang disebutkan di bawah ini.
Menerjemahkan Sumber Daya UI
Anda dapat menempatkan sumber daya string untuk UI Anda ke dalam sumber daya (resw) alih-alih menempatkannya secara langsung dalam kode atau markup, lalu Anda dapat merujuk string tersebut dari kode atau markup Anda. Ikuti langkah-langkah yang diberikan di bawah ini untuk menambahkan string ke file sumber daya.
Buat aplikasi Universal Windows Platform (UWP) baru.
Dalam Solution Explorer, klik kanan proyek dan pilih Add > New Folder.
Ubah nama folder baru menjadi "Strings".
Klik kanan file Strings folder dan tambahkan folder baru dengan nama "en-US". Ini adalah konvensi penamaan khusus untuk bahasa dan nama negara / kawasan, dan dapat ditemukan di halaman msdn.microsoft.com Referensi API Dukungan Bahasa Nasional (NLS) .
Klik kanan pada file en-US folder dan pilih Add > New Item….
- Dialog berikut akan terbuka.
Pilih "Resources File (.resw)" dan Klik Add tombol.
Sekarang mari kita masuk ke file XAML dan menambahkan kontrol Hub dengan beberapa properti seperti yang ditunjukkan di bawah ini.
<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" adalah pengenal yang digunakan untuk pelokalan
Sekarang, ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Semua informasi yang terkait dengan Hub seperti Header, Foreground dan warna latar belakang diatur di XAML.
Sekarang tambahkan beberapa informasi di Resource.resw file di Strings/en-US folder seperti yang ditunjukkan di bawah ini.
Anda perlu mengaitkan setiap kontrol yang membutuhkan teks yang dilokalkan dengan.reswmengajukan. Anda dapat melakukan ini dengan menggunakanx:Uid atribut pada elemen XAML Anda seperti ini -
x:Uid = "HubControl" digunakan dalam resw file untuk menetapkan string untuk warna header, latar depan dan latar belakang.
Sekarang, saat Anda mengompilasi dan menjalankan aplikasi Anda pada emulator, Anda akan melihat jendela berikut. Anda dapat melihat bahwa nilai warna header, latar depan dan latar belakang diambil dariResources.resw mengajukan.
Anda dapat menambahkan lainnya Resource.resw file untuk bahasa lain seperti Prancis, Jerman, dan Jepang dll. Secara manual, seperti yang kami lakukan untuk Inggris-AS, tetapi Microsoft juga menyediakan Multilingual App Toolkit dengan bantuannya, Anda dapat dengan mudah menerjemahkan Resource.resw ke dalam bahasa lain.
Pergi ke Tools > Extensions dan Perbarui menu dan cari file Multilingual app toolkit.
Unduh dan instal toolkit ini. Setelah penginstalan selesai, mulai ulang Visual Studio dan buka proyek yang sama.
Sekarang aktifkan toolkit ini dari Tools > Multilingual App Opsi menu Toolkit.
Sekarang Anda dapat menambahkan terjemahan untuk bahasa lain.
Klik kanan pada proyek di Solution Explorer dan pilih Multilingual App Toolkit > Add Translation Pilihan bahasa dari menu.
Pengikut Translation Languagesdialog akan terbuka. Anda dapat memilih bahasa apa pun yang Anda inginkan, untuk melokalkan aplikasi Anda untuk budaya tersebut.
Mari kita pilih German bahasa dan klik OK tombol.
Anda juga dapat melihat bahwa file Resources.resw file dibuat di dalam folder Strings\de.
Sekarang, Anda akan melihat yang lain MultiLingualResources ditambahkan di dalam *.xlfmengajukan. Klik dua kali pada file ini, yang akan membuka fileMultilingual editor untuk memeriksa dan memverifikasi string yang diterjemahkan dan membuat beberapa perubahan jika diperlukan.
Lakukan perubahan dan verifikasi apakah warna Background telah berubah menjadi coklat dan teks Header diterjemahkan dengan benar ke dalam bahasa Jerman.
Seperti pada contoh di atas, warna latar belakang Hub telah berubah dari warna biru menjadi coklat dan warna latar depan tetap sama.
Sekarang buka Resources.resw, yang ada di dalam Strings\de map.
Anda dapat melihat bahwa hanya dua string yang disebutkan di sini, karena kami belum mengubah warna latar depan pada editor multibahasa.
Untuk memeriksa versi lokal dari aplikasi Anda, ubah budaya mesin Anda. Untuk mengubah budaya mesin Anda, ikuti langkah-langkah yang diberikan.
- Mari kita pergi ke pengaturan PC dan pilih Waktu & Bahasa.
Dari panel kiri, pilih Regions & language dan klik Add a language.
Pilih Deutsch German bahasa seperti yang ditunjukkan di atas yang akan membuka dialog lain.
Sekarang pilih German (Germany) dan tutup kotak dialog ini.
- Jadikan Deutsch sebagai bahasa default.
- Sekarang jalankan aplikasi Anda, itu akan menampilkan jendela berikut.
- Sekarang Anda dapat melihat output aplikasi Anda dalam bahasa Jerman.
Secara historis, Windows memiliki lingkungan, di mana pengguna dapat menjalankan banyak aplikasi secara bersamaan. Pengguna dapat beralih di antara aplikasi yang berbeda dengan mudah. Model ini tidak berfungsi dengan baik untuk perangkat ponsel atau tablet yang penggunaannya biasanya berfokus pada aplikasi tunggal.
Salah satu tantangan paling signifikan yang dihadapi pemrogram aplikasi Windows 8 Store adalah mengelola dan memahami siklus hidup aplikasi. Jika Anda telah membangun aplikasi telepon Windows, sebagian besar dari ini akan menjadi hal yang biasa.
Di bawah Windows 8, sistem operasi mengelola masa pakai aplikasi, dan sementara pengguna dapat menghentikan aplikasi, biasanya pengguna membuka aplikasi baru tanpa secara sadar menghentikan aplikasi yang sedang berjalan.
Platform Windows Universal (UWP) untuk Windows 10 mengatasi masalah ini, menawarkan beberapa hal keren kepada pengguna desktop sehingga banyak aplikasi dapat berjalan dengan pengalaman berjendela ganda.
Aplikasi Windows dapat ada dalam tiga status di tingkat dasar seperti yang ditunjukkan di bawah ini.
Running
Suspended
Terminate
Ketika pengguna meluncurkan / mengaktifkan aplikasi apa pun, maka itu masuk ke dalam running negara.
Aplikasi dapat ditangguhkan jika pengguna tidak menggunakannya dan tidak lagi berada di latar depan.
Dari status Ditangguhkan, aplikasi dapat melanjutkan aplikasi tersebut atau menghentikan OS untuk mendapatkan kembali sumber daya sistem.
Proses Transisi Status
Penting untuk memahami transisi status proses dalam aplikasi yang sedang berjalan. Saat pengguna pertama kali meluncurkan aplikasi, layar splash ditampilkan dan kemudian aplikasi mulai berjalan.
Prosesnya dapat dijelaskan sebagai berikut -
Saat aplikasi ditangguhkan, aplikasi Anda mendapat lima detik untuk menangani peristiwa yang ditangguhkan tersebut.
Saat aplikasi ditangguhkan, sama sekali tidak ada kode yang berjalan dan tidak ada sumber daya yang dialokasikan.
Saat dilanjutkan, aplikasi akan diberi tahu bahwa ia telah dilanjutkan. Jika Anda berasal dari status ditangguhkan, Anda tidak perlu melakukan tindakan apa pun.
Di bawah tekanan memori, aplikasi Anda mungkin saja dihentikan.
Ingatlah bahwa Anda tidak akan diberitahu pada saat itu, dan setiap penghematan yang Anda lakukan, Anda harus lakukan ketika Anda masuk ke dalam status aplikasi ditangguhkan.
Saat aplikasi transit bolak-balik Running dan Suspended menyatakan, masing-masing menangguhkan kebakaran dan melanjutkan peristiwa.
Terkadang, Anda perlu menyimpan data. Maka Anda harus memanggil metode asynchronous seperti yang ditunjukkan di bawah ini.
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"];
}
Mari kita pelajari contoh di mana kontrol ditambahkan seperti yang ditunjukkan pada file XAML yang diberikan di bawah ini.
<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>
Diberikan di bawah ini adalah kode C # di mana acara Tangguhkan dan Lanjutkan diimplementasikan. Data saat ini akan disimpan disuspend event di pengaturan lokal dan kemudian data akan diambil di resume event dari pengaturan lokal seperti yang ditunjukkan di bawah ini.
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);
}
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut. Sekarang tulis informasi yang diinginkan.
Mari kita pergi ke Lifecycle Acara menu tarik-turun dan pilih suspended. Sekarang aplikasi Anda akan ditangguhkan dan informasi yang diinginkan akan disimpan di pengaturan lokal. Lihat tangkapan layar yang diberikan di bawah ini.
Sekarang, ketika Anda ingin melanjutkan lamaran Anda, pilih opsi Resume dari Lifecycle Events Tidak bisa.
Sekarang Anda akan melihat bahwa informasi yang disimpan diambil dari pengaturan lokal dan aplikasi dilanjutkan pada keadaan yang sama dari saat itu ditangguhkan.
Platform Windows Universal (UWP) memperkenalkan mekanisme baru, yang memungkinkan aplikasi untuk melakukan beberapa fungsi saat aplikasi tidak berjalan di latar depan. UWP juga meningkatkan kemampuan aplikasi untuk memperpanjang waktu eksekusinya di latar belakangBackground Tasks and Triggers. Eksekusi latar belakang adalah ekor pelengkap nyata untuk siklus hidup aplikasi.
Fitur penting dari Tugas Latar Belakang adalah -
Tugas latar belakang dipicu oleh sistem atau peristiwa waktu dan dapat dibatasi oleh satu atau beberapa ketentuan.
Saat tugas latar belakang dipicu, penangannya yang terkait akan menjalankan dan menjalankan tugas latar belakang.
Tugas latar belakang dapat berjalan bahkan saat aplikasi yang mendaftarkan tugas latar belakang ditangguhkan.
Mereka adalah bagian dari platform aplikasi standar dan pada dasarnya menyediakan aplikasi dengan kemampuan untuk mendaftar untuk peristiwa sistem (pemicu). Saat peristiwa itu terjadi, mereka menjalankan blok kode yang telah ditentukan di latar belakang. Pemicu sistem mencakup peristiwa seperti perubahan konektivitas jaringan atau zona waktu sistem.
Eksekusi Latar Belakang tidak dijamin, jadi tidak cocok untuk fungsi dan fitur penting.
OS memiliki batasan berapa banyak tugas latar belakang yang dapat dijalankan pada waktu yang sama. Jadi, meskipun pemicu diaktifkan dan ketentuan terpenuhi, tugas tetap tidak dapat dijalankan.
Buat dan Daftarkan Tugas Latar Belakang
Buat kelas tugas latar belakang dan daftarkan untuk dijalankan saat aplikasi Anda tidak berada di latar depan. Anda dapat menjalankan kode di latar belakang dengan menulis kelas yang mengimplementasikanIBackgroundTaskantarmuka. Kode contoh berikut menunjukkan titik awal yang sangat dasar untuk kelas tugas latar belakang.
public sealed class MyBackgroundTask : IBackgroundTask {
public void Run(IBackgroundTaskInstance taskInstance){
// write code
}
}
Anda dapat meminta akses untuk tugas latar belakang sebagai berikut.
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;
}
Untuk membuat dan mendaftarkan tugas latar belakang, gunakan kode berikut.
var task = new BackgroundTaskBuilder {
Name = "My Task",
TaskEntryPoint = typeof(BackgroundStuff.MyBackgroundTask).ToString()
};
var trigger = new ApplicationTrigger();
task.SetTrigger(trigger);
task.Register();
await trigger.RequestAsync();
Mari kita pahami contoh sederhana tugas latar belakang dengan mengikuti semua langkah yang diberikan di bawah ini.
Buat proyek UWP kosong baru ‘UWPBackgroundDemo’ dan tambahkan satu tombol di file 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>
Diberikan di bawah ini adalah button click implementasi acara di mana tugas latar belakang terdaftar.
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();
}
}
}
Sekarang buat proyek lain, tapi kali ini pilih Windows Runtime Component (Universal Windows) dari menu dan beri nama Background stuff untuk proyek ini.
Diberikan di bawah ini adalah kode C #. yang mengandungMyBackgroundTask kelas implantasi dan itu akan menjalankan tugas latar belakang.
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);
}
}
}
Untuk membuat proyek ini dapat diakses di UWPBackgroundDemo proyek, klik kanan References > Add References di Solution Explorer dan tambahkan BackgroundStuff proyek.
Sekarang, mari kita pergi ke Package.appxmanifest file dari UWPBackgroundDemo proyek dan tambahkan informasi berikut di tab Deklarasi.
Pertama buat proyek Background stuff, lalu buat dan jalankan file UWPBackgroundDemo proyek.
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Saat Anda mengklik button, itu akan menjalankan tugas latar belakang dan akan menampilkan pemberitahuan di ujung kanan jendela Anda.
Dalam bab ini, kita akan belajar tentang bagaimana aplikasi UWP dapat membantu atau menyediakan layanan untuk aplikasi Universal Windows Platform (UWP) lainnya. Sebenarnya chapter ini merupakan perpanjangan dari chapter tersebutBackground execution dan merupakan kasus khusus darinya.
Di Windows 10, layanan aplikasi adalah cara atau mekanisme aplikasi untuk menyediakan layanan ke aplikasi lain.
Sebuah layanan aplikasi bekerja dalam bentuk tugas latar belakang.
Aplikasi latar depan bisa memanggil layanan aplikasi di aplikasi lain untuk melakukan tugas di latar belakang.
Layanan aplikasi seperti layanan web tetapi layanan aplikasi digunakan pada perangkat Windows 10.
Aplikasi Universal Windows Platform (UWP) dapat berinteraksi dengan aplikasi UWP lain dengan berbagai cara -
- Asosiasi URI menggunakan LaunchUriAsync
- Asosiasi file menggunakan LaunchFileAsync
- Luncurkan untuk hasil menggunakan LaunchUriForResultsAsync
- Layanan aplikasi
Tiga cara pertama digunakan saat kedua aplikasi berada di latar depan, tetapi layanan Aplikasi digunakan di background task dan dalam hal ini aplikasi klien harus berada di latar depan dan tersedia untuk menggunakan layanan Aplikasi.
Layanan aplikasi sangat bermanfaat dalam aplikasi yang menyediakan layanan non-visual, misalnya pemindai kode batang di mana aplikasi latar depan akan mengambil gambar dan mengirimkan byte tersebut ke layanan aplikasi untuk mengidentifikasi kode batang.
Untuk memahami semua konsep ini, mari kita buat proyek UWP baru dengan nama tersebut AppServiceProvider di Microsoft Visual Studio 2015.
Sekarang di Package.appmenifest file, tambahkan informasi berikut.
Untuk membuat layanan aplikasi, yang bisa dipanggil oleh aplikasi latar depan, mari kita tambahkan Windows Runtime Proyek komponen untuk solusi dengan MyAppService nama, karena layanan aplikasi diimplementasikan sebagai tugas latar belakang.
Tambahkan referensi ke MyAppService proyek di AppServiceProvider proyek.
Sekarang hapus class1.cs file dari MyAppService proyek dan tambahkan kelas baru dengan nama inventaris, yang akan mengimplementasikan IBackgrounTask antarmuka.
Itu IBackgrounTask antarmuka hanya memiliki satu metode “Run” yang perlu diterapkan untuk tugas latar belakang.
public sealed class Inventory : IBackgroundTask {
public void Run(IBackgroundTaskInstance taskInstance) {
}
}
Saat tugas latar belakang dibuat, Run() methoddipanggil dan ketika metode Run selesai, maka tugas latar belakang dihentikan. Untuk tetap mengikuti tugas latar belakang, untuk melayani permintaan, kode tersebut mengambil penangguhan.
Kode layanan aplikasi ada di OnRequestedReceived(). Dalam contoh ini, indeks untuk item inventaris diteruskan ke layanan, untuk mengambil nama dan harga item inventaris yang ditentukan.
private async void OnRequestReceived(AppServiceConnection sender,
AppServiceRequestReceivedEventArgs args) {
// Get a deferral because we use an awaitable API below to respond to the message
}
Diberikan di bawah ini adalah implementasi lengkap kelas Inventaris di 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();
}
}
}
}
Mari kita buat aplikasi klien dengan menambahkan proyek UWP kosong baru ClientApp dan tambahkan satu tombol, satu kotak teks dan dua blok teks seperti yang ditunjukkan di bawah ini di file 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>
Diberikan di bawah ini adalah implementasi peristiwa klik-tombol di mana layanan Aplikasi diminta.
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;
}
}
}
Untuk menjalankan aplikasi ini, Anda perlu menyetel ClientApp proyek untuk menjadi proyek startup di Solution Explorer dan kemudian Terapkan solusi ini dari Build > Deploy Larutan.
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut. Di layanan Aplikasi, kami baru saja menambahkan informasi dari dua item. Jadi, Anda bisa memasukkan 0 atau 1 untuk mendapatkan informasi dari item tersebut.
Ketika Anda memasukkan 0 dan mengklik tombol, itu akan menjalankan layanan Aplikasi sebagai tugas latar belakang dan akan menampilkan informasi item di textblock.
Di Windows 10, sangat mudah bagi pengembang untuk membuat aplikasi Universal Windows Platform (UWP) dan menghosting situs web mereka di aplikasi tersebut yang kemudian dapat dipublikasikan ke Windows Store untuk diunduh.
Keuntungan
Dengan fitur baru di Windows 10 ini, pengembang web dapat dengan mudah mengonversi komponen situs web mereka menjadi aplikasi Windows.
Namun, semua komponen tersebut masih akan dihosting dari jarak jauh di server web mereka sendiri.
Selain itu, mereka juga dapat mengakses API universal, yang memungkinkan pengembang mengakses beberapa hal keren seperti notifikasi, kamera, kalender, Cortana, dan banyak lagi.
Microsoft berharap fitur dan kemampuan ini akan menarik lebih banyak pengembang untuk menulis aplikasi untuk platform Windows 10, termasuk.
- Desktops
- Smartphones
- Xbox
- Tablets
- HoloLens dan perangkat lainnya
Saat ini, hanya ada satu masalah dengan fitur ini dan itu adalah keamanan. Jelas, Microsoft perlu mengatasi masalah ini secepat mungkin.
Mari kita pahami dengan bantuan contoh di mana kita akan meng-host situs web dan mengubah situs web itu menjadi aplikasi Windows.
Ikuti langkah-langkah yang diberikan di bawah ini.
Buat Proyek Windows Universal baru dari File > New > Project.
Pilih JavaScript > Windows > Universal opsi dari panel kiri proyek dan dialog baru.
Dari panel tengah, pilih Blank App (Universal Windows).
Tulis di kolom nama, UWPWebApp dan klik OK tombol.
Jika Anda melihat file Solution Explorer jendela, Anda akan melihat beberapa file dan folder.
Hapus css, js, WinJS folder dan default.htmlfile, karena dalam contoh ini, kami hanya menghosting situs web dan kami berasumsi bahwa semua konten ada di server jarak jauh. Oleh karena itu, kami tidak membutuhkan sebagian besar file lokal.
Setelah menghapus file dan folder yang disebutkan di atas, sekarang klik dua kali pada file package.appxmanifest file dan Anda akan melihat jendela berikut.
Sekarang tentukan URL situs web dengan mengganti default.htmldi bidang Halaman awal di dekat URL. Untuk tujuan demonstrasi, kami akan menggunakan URLhttps://www.google.com.pk/ situs web.
Sekarang pergi ke Content URIs tab dan tentukan aturan dan izin akses untuk aplikasi web Anda.
Di bidang URI, tentukan tautan situs web Anda, lalu pilih Include dari Rule dropdown dan All dari WinRT Access.
Saat Anda menjalankan aplikasi ini, Anda akan melihat halaman awal google di aplikasi Anda seperti yang ditunjukkan di bawah ini.
Seperti yang sudah kita ketahui, di Windows 10 kita bisa membuat aplikasi yang bisa dijalankan dan dijalankan di beberapa perangkat Windows 10. Misalkan kita memiliki perangkat yang berbeda ini dan kita ingin membuatnya terasa seperti satu aplikasi meskipun berjalan pada perangkat yang berbeda.
Di Universal Windows Platform (UWP), Anda dapat menjalankan satu aplikasi di semua perangkat Windows 10, dan Anda dapat memberikan perasaan kepada pengguna bahwa itu adalah satu aplikasi. Ini dikenal sebagaiconnecting experience.
Fitur penting dari pengalaman terhubung -
Windows 10 adalah langkah pertama menuju era komputasi yang lebih personal di mana aplikasi, layanan, dan konten Anda dapat bergerak bersama Anda di seluruh perangkat, dengan mulus dan mudah.
Dengan pengalaman terhubung, Anda dapat dengan mudah membagikan data dan pengaturan pribadi yang terkait dengan aplikasi itu dan akan tersedia di semua perangkat.
Dalam bab ini kita akan belajar -
tempat data atau pengaturan yang dibagikan ini akan disimpan sehingga dapat tersedia di perangkat Anda untuk satu aplikasi itu.
bagaimana pengguna diidentifikasi; bahwa itu adalah pengguna yang sama yang menggunakan aplikasi yang sama pada perangkat yang berbeda.
Windows 10 mengambil langkah maju yang berani. Saat Anda masuk ke Windows 10 dengan akun Microsoft (MSA) atau dengan akun perusahaan atau (kantor), diasumsikan bahwa -
Anda memiliki akses gratis ke akun OneDrive untuk MSA, dan Anda memiliki akses ke Active Directory (AD) dan Azure Active Directory (AAD), yang merupakan versi cloud dengan akun perusahaan Anda.
Anda memiliki akses ke aplikasi dan sumber daya yang berbeda.
Perangkat dan aplikasi berada dalam status dan pengaturan roaming.
Roaming di Windows 10
Saat Anda logon ke PC, Anda mengatur beberapa preferensi seperti layar kunci atau warna latar belakang atau mempersonalisasi berbagai jenis pengaturan Anda. Jika Anda memiliki lebih dari satu komputer atau perangkat, yang berjalan pada Windows 10, preferensi dan pengaturan Anda pada satu perangkat akan disinkronkan dari cloud, saat Anda masuk ke perangkat lain dengan akun yang sama.
Di Windows 10, ketika Anda telah mengatur atau mempersonalisasi pengaturan aplikasi Anda, maka pengaturan ini akan menjelajah dengan Roaming API yang tersedia di UWP. Saat Anda menjalankan aplikasi yang sama lagi di perangkat lain, pertama-tama aplikasi akan mengambil pengaturan dan menerapkan pengaturan tersebut ke aplikasi di perangkat itu.
Ada batas 100 KB untuk mengupload data roaming ke cloud. Jika batas ini melebihi, maka sinkronisasi akan berhenti dan hanya akan berperilaku seperti folder lokal.
Itu RoamingSettings API diekspos sebagai kamus tempat aplikasi dapat menyimpan data.
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";
Saat data berubah RoamingSettings lalu mengaktifkan DataChanged acara, di mana Anda dapat menyegarkan pengaturan Anda.
Windows.Storage.ApplicationData.Current.DataChanged += RoamingDataChanged;
private void RoamingDataChanged(Windows.Storage.ApplicationData sender, object args) {
// Something has changed in the roaming data or settings
}
Mari kita lihat contoh, di mana kita akan mengatur warna latar belakang aplikasi dan pengaturan ini akan menjelajah dengan Roaming API yang tersedia di UWP.
Diberikan di bawah ini adalah kode XAML di mana kontrol yang berbeda ditambahkan.
<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>
Implementasi C # untuk RoamingSettings dan acara berbeda diberikan di bawah ini.
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();
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Mari kita pilih warna abu-abu sebagai warna latar belakang dan tutup aplikasi ini.
Sekarang, ketika Anda menjalankan aplikasi ini di perangkat ini atau perangkat lain, Anda akan melihat bahwa warna latar belakang telah berubah menjadi abu-abu. Ini menunjukkan bahwa aplikasi telah berhasil mengambil informasi perubahan warna latar belakangRoamingSettings.
Dalam aplikasi Universal Windows Platform (UWP), navigasi adalah model fleksibel dari struktur navigasi, elemen navigasi, dan fitur tingkat sistem. Ini memungkinkan berbagai pengalaman pengguna yang intuitif untuk berpindah antar aplikasi, halaman, dan konten.
Ada beberapa situasi dan skenario di mana semua konten dan fungsionalitas dapat dengan mudah masuk ke dalam satu halaman dan pengembang tidak perlu membuat banyak halaman. Namun, di sebagian besar aplikasi, banyak halaman digunakan untuk interaksi antara konten dan fungsionalitas yang berbeda.
Ketika sebuah aplikasi memiliki lebih dari satu halaman, maka sangat penting bagi pengembang untuk memberikan pengalaman navigasi yang tepat.
Model Halaman
Biasanya, dalam aplikasi Universal Windows Platform (UWP), model navigasi halaman tunggal digunakan.
Fitur penting adalah -
Model navigasi halaman tunggal mempertahankan semua konteks aplikasi Anda serta konten dan data tambahan ke dalam bingkai pusat.
Anda dapat membagi konten aplikasi Anda menjadi beberapa halaman. Namun, saat berpindah dari satu halaman ke halaman lain, aplikasi Anda memuat halaman-halaman tersebut ke dalam formulir halaman utama.
Baik halaman utama aplikasi Anda tidak dibongkar maupun kode dan data dibongkar, hal ini membuatnya lebih mudah untuk mengelola status, dan memberikan animasi transisi yang lebih mulus antar halaman.
Navigasi multi-halaman juga digunakan untuk menavigasi antara halaman atau layar yang berbeda tanpa mengkhawatirkan konteks aplikasi. Dalam navigasi multi-halaman, setiap halaman memiliki serangkaian fungsi, antarmuka pengguna, dan data sendiri-sendiri, dll.
Navigasi multi-halaman biasanya digunakan di halaman web dalam situs web.
Struktur Navigasi
Dalam navigasi multi-halaman, setiap halaman memiliki sekumpulan fungsi, antarmuka pengguna dan datanya sendiri, dll. Misalnya, aplikasi foto mungkin memiliki satu halaman untuk mengambil foto, kemudian ketika pengguna ingin mengedit foto, ia menavigasi ke halaman lain. dan untuk memelihara perpustakaan gambar, ia memiliki halaman lain.
Struktur navigasi aplikasi Anda ditentukan oleh bagaimana halaman ini diatur.
Berikut adalah cara untuk menyusun navigasi dalam aplikasi Anda -
Hirarki
Dalam jenis penataan navigasi ini,
Halaman diatur menjadi struktur seperti pohon.
Setiap halaman anak hanya memiliki satu halaman induk, tetapi halaman induk dapat memiliki satu atau lebih halaman anak.
Untuk mencapai halaman anak, Anda harus melalui orang tua.
Rekan
Dalam jenis navigasi ini -
- Halaman ada berdampingan.
- Anda dapat berpindah dari satu halaman ke halaman lain dalam urutan apa pun.
Di sebagian besar aplikasi multi-halaman, kedua struktur digunakan secara bersamaan. Beberapa halaman diatur sebagai rekan dan beberapa di antaranya diatur ke dalam hierarki.
Mari kita ambil contoh yang berisi tiga halaman.
Buat aplikasi UWP kosong dengan nama UWPNavigation.
Tambahkan dua halaman kosong lagi dengan mengklik kanan pada proyek di Solution Explorer dan pilih Add > New Item pilihan dari menu, yang akan membuka jendela dialog berikut.
Pilih halaman Kosong dari panel tengah dan klik Add tombol.
Sekarang tambahkan satu halaman lagi dengan mengikuti langkah-langkah yang diberikan di atas.
Anda akan melihat tiga halaman di Solution Explorer - MainPage, BlankPage1, dan BlankPage2.
Diberikan di bawah ini adalah kode XAML untuk MainPage di mana dua tombol ditambahkan.
<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>
Diberikan di bawah ini adalah kode C # untuk dua tombol MainPage, yang akan membuka dua halaman lainnya.
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));
}
}
}
Kode XAML untuk blank page 1 ditampilkan di bawah.
<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>
Kode C # untuk tombol - acara klik di blank page 1, yang akan mengarahkan ke halaman utama ditunjukkan di bawah ini.
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));
}
}
}
Diberikan di bawah ini adalah kode XAML untuk 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>
Diberikan di bawah ini adalah kode C # untuk acara klik tombol blank page 2, yang akan membuka halaman utama.
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));
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat jendela berikut.
Saat Anda mengklik tombol apa pun, itu akan menavigasi Anda ke halaman masing-masing. Mari kita klikGo to Page 1 dan halaman berikut akan ditampilkan.
Saat Anda mengklik tombol 'Go to Main Page', ini akan menavigasi kembali ke halaman utama.
Saat ini, Anda akan melihat banyak aplikasi, yang entah bagaimana telah terintegrasi dengan layanan web atau perangkat lain di jaringan. Mengambil konten cuaca online, berita terbaru, chatting atau permainan peer-to-peer adalah beberapa contoh yang menggunakan layanan jaringan. Aplikasi ini dibuat menggunakan berbagai macam API jaringan. Di Windows 10, API jaringan ditingkatkan dalam hal kecepatan dan kinerja memori serta kemampuan dan fleksibilitas yang mereka berikan kepada pengembang.
Kemampuan
Untuk membuat jaringan, Anda harus menambahkan elemen kemampuan yang sesuai ke manifes aplikasi Anda. Jika tidak ada kemampuan jaringan yang ditentukan dalam manifes aplikasi Anda, aplikasi Anda tidak akan memiliki kemampuan jaringan, dan segala upaya untuk menyambung ke jaringan akan gagal.
Berikut ini adalah kapabilitas jaringan yang paling sering digunakan.
S.No. | Kemampuan & Deskripsi |
---|---|
1 | internetClient Menyediakan akses keluar ke Internet dan jaringan di tempat umum, seperti bandara dan kedai kopi. Sebagian besar aplikasi yang membutuhkan akses Internet harus menggunakan kemampuan ini. |
2 | internetClientServer Memberi aplikasi akses jaringan masuk dan keluar dari Internet dan jaringan di tempat umum seperti bandara dan kedai kopi. |
3 | privateNetworkClientServer Memberi aplikasi akses jaringan masuk dan keluar di tempat tepercaya pengguna, seperti rumah dan kantor. |
Untuk menentukan satu atau lebih kemampuan dalam file manifes aplikasi Anda, lihat gambar yang diberikan di bawah ini.
Platform Windows Universal (UWP) berisi sekumpulan besar API jaringan dengan menargetkan berikut ini -
- Menanyakan status konektivitas perangkat dan menghubungkan ke perangkat peer.
- Berkomunikasi dengan layanan web REST dan
- Mendownload file media besar di latar belakang
Teknologi Jaringan
Di Universal Windows Platform (UWP), teknologi jaringan berikut tersedia untuk pengembang, yang dapat digunakan dalam banyak situasi berbeda.
Soket
Soket digunakan saat Anda ingin berkomunikasi dengan perangkat lain dengan protokol Anda sendiri.
Anda bisa menggunakan keduanya, Windows.Networking.Sockets dan Winsock untuk berkomunikasi dengan perangkat lain sebagai pengembang aplikasi Universal Windows Platform (UWP).
Windows.Networking.Sockets memiliki keuntungan sebagai API modern, yang dirancang untuk digunakan oleh pengembang UWP.
Jika Anda menggunakan pustaka jaringan lintas platform atau kode Winsock lain yang sudah ada, gunakan Winsock APIs.
Kode berikut menunjukkan cara membuat pendengar soket.
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.
}
Kode berikut menunjukkan implementasi dari SocketListener_ConnectionReceived penanganan acara.
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
Itu WebSocketsprotokol menyediakan komunikasi dua arah yang cepat dan aman antara klien dan server melalui web. Pengembang Universal Windows Platform (UWP) dapat menggunakan fileMessageWebSocket dan StreamWebSocket kelas untuk terhubung dengan server yang mendukung protokol Websocket.
Fitur penting adalah -
Di bawah Protokol WebSocket, data ditransfer segera melalui koneksi soket tunggal dupleks penuh.
Ini memungkinkan pesan untuk dikirim dan diterima dari kedua titik akhir secara real time.
WebSockets ideal untuk digunakan dalam permainan waktu nyata di mana pemberitahuan jejaring sosial instan dan tampilan informasi terkini (statistik permainan) perlu diamankan dan menggunakan transfer data yang cepat.
Kode berikut menunjukkan cara mengirim dan menerima pesan pada koneksi yang aman.
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
}
Kode berikut menunjukkan implementasi acara, yang akan menerima string dari terhubung 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 dan Windows.Web.Http namespace API, memberikan kemampuan kepada pengembang untuk mengirim dan menerima informasi menggunakan protokol HTTP 2.0 dan HTTP 1.1.
Ini dapat digunakan untuk -
- berkomunikasi dengan layanan web atau server web.
- Unggah atau unduh sejumlah file kecil.
- Alirkan konten melalui jaringan.
Kode berikut menunjukkan cara mengirim permintaan GET menggunakan Windows.Web.Http.HttpClient dan 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;
}
Sebagai pengembang, Anda mungkin memerlukan data selain yang tersedia di desktop Anda. Layanan cloud dapat membantu Anda mengakses data itu. Bab ini memberikan pemahaman yang lebih baik tentang layanan cloud, yang mungkin Anda perlukan.
Microsoft telah menyediakan platform komputasi awan dan infrastruktur, yang dikenal sebagai Microsoft Azure, tempat Anda dapat membangun, menerapkan, dan mengelola semua aplikasi dan layanan.
Azure pertama kali dirilis pada 1 Februari 2010, sebagai Windows Azure. Kemudian diubah namanya menjadi Microsoft Azure pada 25 Maret 2014.
Ini menyediakan keduanya, PaaS and IaaS layanan dan mendukung berbagai bahasa pemrograman, alat, dan kerangka kerja, termasuk perangkat lunak dan sistem khusus Microsoft dan pihak ketiga.
Microsoft telah meningkatkan layanan cloud dengan Windows 10. Integrasi akun Microsoft telah diperkenalkan di Windows 8 OneDrive telah ada sejak 2007. Untuk Windows 10, kedua layanan tersebut telah diperbarui dengan peningkatan integrasi dan fungsionalitas baru, yang menarik lebih banyak pengguna.
Akun Microsoft
Anda dapat menggunakan penawaran cloud Azure Microsoft dengan akun Microsoft Anda. Tentu saja, ini tidak gratis tetapi Anda dapat menggunakan uji coba gratis selama 30 hari.
Saat Anda pertama kali menyiapkan mesin dengan Windows 10 dan masuk dengan akun Microsoft, Anda dapat menggunakan akun yang sama untuk langganan Microsoft Azure. Untuk mendaftar ke Microsoft Azure klik di sinihttps://azure.microsoft.com/.
Setelah Anda berlangganan Microsoft Azure, buka Portal Azure https://portal.azure.com/. Anda akan melihat halaman berikut.
Anda dapat menyimpan di database, menggunakan mesin Virtual, dll. Anda juga dapat membuat dan menghosting bagian belakang aplikasi seluler Anda.
Mari kita coba ini dengan contoh dengan mengikuti langkah-langkah yang disebutkan di bawah ini.
Klik pada New opsi di panel kiri.
Pilih Web + Mobile > Mobile App dan beri nama untuk aplikasi Web Anda.
Perlu beberapa saat untuk mengirimkan dan menerapkan aplikasi Anda. Setelah proses ini selesai, Anda akan melihat halaman berikut. Di sini, Anda dapat memilih berbagai jenis aplikasi seluler seperti Windows (C #), iOS Android, dll.
Karena, kita berbicara tentang Windows 10, pilih Windows (C #), yang akan membuka halaman berikut.
Di sini, Anda dapat melihat dua opsi unduhan. Ini adalah contoh proyek, Anda cukup mengunduh dan membangun di Visual Studio dan kemudian Anda dapat dengan mudah menerbitkan ke Microsoft Azure.
Mari kita unduh yang pertama, yaitu proyek server. Ini adalah file zip.
Saat pengunduhan selesai, buka zip ini dan buka di Visual Studio.
Sekarang, buat aplikasi ini. Jika beberapa kesalahan terdaftar, buat lagi.
Jalankan aplikasinya. Anda akan melihat halaman web berikut, yang sekarang ada di localhost.
Sekarang untuk menghosting aplikasi ini di cloud, klik kanan file Project opsi di Solution Explore seperti gambar dibawah.
Pilih Publishopsi dari menu. Anda akan melihat dialog berikut.
Pilih opsi pertama - Microsoft Azure Web Apps. Kotak dialog berikut akan terbuka.
Sekarang klik Add an account opsi dari menu untuk menambahkan akun Microsoft Azure.
Tentukan kredensial Anda dan klik Sign in. Jendela dialog berikut akan terbuka.
Setelah masuk, pilih aplikasi Anda dari menu Existing Web Apps dan klik Ok.
Dialog yang ditampilkan di bawah ini menampilkan beberapa informasi terkait aplikasi Anda seperti nama, nama server, URL, dll.
Sekarang, klik Validate Connectiontombol. Setelah validasi, klikPublish dan Anda akan melihat bahwa aplikasi Anda sekarang dihosting di Microsoft Azure.
Dalam bab ini, kita akan berbicara tentang interaksi dengan pengguna melalui ubin. Ini adalah bagian ikon dari Windows 10. Ubin ditampilkan diStart Screen serta di Start Menu. Dengan kata lain, ini adalah aset ikon aplikasi, yang muncul dalam berbagai bentuk di seluruh sistem operasi Windows 10. Mereka adalah kartu panggil untuk aplikasi Universal Windows Platform (UWP) Anda.
Anatomi Ubin
Ada tiga status ubin.
Basic State - Komponen dasar ubin Mulai terdiri dari pelat belakang, ikon, dan judul aplikasi.
Semi-Live state - Ini sama dengan ubin dasar dengan satu-satunya perbedaan bahwa lencana, yaitu angka, dapat menampilkan angka dari 0-99.
Live State - Ubin ini berisi semua elemen ubin status semi-live dan juga menampilkan pelat konten tambahan tempat Anda dapat meletakkan apa pun yang Anda inginkan seperti foto, teks, dll.
Memperbarui Ubin
Ada empat cara untuk memperbarui ubin.
Scheduled - Anda dapat mengatur template dan waktu dengan ScheduledTileNotification.
Periodic- Ketika informasi diambil dari URI dan Anda dapat menentukan waktu untuk menarik informasi setelah periode waktu tersebut, seperti 30 menit, 1 jam, 6 jam. dll.
Local- Yang lokal dapat diperbarui dari aplikasi Anda; baik dari latar depan atau aplikasi latar belakang.
Push - Ini diperbarui dari server dengan mendorong informasi dari server.
Untuk membuat ubin, ikuti kode yang diberikan.
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 cukup sederhana karena hanya berupa angka dan Anda dapat mengatur nilai lencana seperti yang ditunjukkan di bawah ini.
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);
Mari kita buat proyek UWP baru di Visual Studio.
Anda akan melihat file png yang berbeda di bawah Assets folder di Solution Explorer.
Mari kita tentukan ubin default dan gambarnya di manifes paket.
Klik dua kali pada file package.appxmanifest. Ini membuka jendela editor manifes.
Pilih Visual Assets tab.
Anda dapat memilih gambar dan ikon untuk ubin aplikasi Anda dengan salah satu dimensi yang ditentukan. Di bawahTile Images and Logos, gambar default disediakan untuk semua logo seperti
- Logo persegi 71x71
- Logo Persegi 150x150
- Logo Persegi 310x310
- Logo Toko
Ketika Anda menjalankan aplikasi dan kemudian pergi ke layar awal, Anda akan melihat ubin untuk aplikasi Anda.
Pada bab ini, kita akan belajar bagaimana membagi data antar aplikasi. Pengguna sering menemukan informasi yang mereka ingin bagikan dengan seseorang atau menggunakannya di aplikasi lain. Saat ini, pengguna ingin menggunakan teknologi untuk terhubung dan berbagi dengan orang lain.
Seorang pengguna mungkin ingin berbagi -
- Tautan dengan jejaring sosial mereka
- Salin gambar ke dalam laporan
- Unggah file ke penyimpanan cloud
Aplikasi saat ini, perlu memastikan bahwa data yang mereka gunakan juga tersedia bagi pengguna untuk dibagikan dan dipertukarkan. Berbagi adalah fitur ringan, yang mudah ditambahkan ke aplikasi UWP Anda. Ada beberapa cara bagi aplikasi untuk bertukar data dengan aplikasi lain.
Dalam aplikasi UWP, fitur berbagi dapat didukung dengan cara berikut;
Pertama, aplikasi dapat menjadi aplikasi sumber yang menyediakan konten yang ingin dibagikan oleh pengguna.
Kedua, aplikasi dapat menjadi aplikasi target yang dipilih pengguna sebagai tujuan untuk konten bersama.
Aplikasi juga bisa menjadi aplikasi sumber dan aplikasi target.
Berbagi Konten
Berbagi konten dari aplikasi, yang merupakan aplikasi sumber, sangat sederhana. Untuk melakukan operasi berbagi apa pun, Anda memerlukanDataPackageobjek kelas. Objek ini berisi data yang ingin dibagikan oleh pengguna.
The following types of content can be included in DataPackage object −
- Plain text
- Uniform Resource Identifiers (URIs)
- HTML
- Formatted text
- Bitmaps
- Files
- Developer-defined data
While sharing data, you can include one or more of the above-mentioned formats. To support sharing in your application, you first need to get the instance of the DataTransferManager class.
It will then register an event handler that is called whenever a DataRequested event occurs.
DataTransferManager dataTransferManager = DataTransferManager.GetForCurrentView();
dataTransferManager.DataRequested += new TypedEventHandler<DataTransferManager,
DataRequestedEventArgs>(this.ShareTextHandler);
When your app receives a DataRequest object, then your application is ready to add the content that the user wants to share.
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!");
}
Any content that your application shares, must contain two properties −
- A Title property, which is mandatory and must be set.
- The content itself.
Receiving Shared Content
If you want that your application can receive shared content then the first thing you need to do is to declare that it supports the Share Contract. After declaration, the system will let your application be available to receive content.
To add support of the Share Contract −
Double click on the package.appmanifest file.
Go to the Declarations tab. Choose Share Target from the Available Declarations list, and click on the Add button.
If you want your application to receive any kind of file as shared content, then you can specify the file types and data formats.
To specify the Data Formats that you support go to the Data Formats section, of the Declarations page and click Add New.
Type the name of the data format you support. For example, "Text".
To specify the file type that you support, in the Supported File Types section of the Declarations page, click Add New.
Type the file name extension that you want to support, e.g, .pdf
If you want to support All file types, check the SupportsAnyFileType box.
When a user selects your application as target application for sharing data then OnShareTargetActivated event is fired.
Your app needs to handle this event to process the data, which the user wants to share.
protected override async void OnShareTargetActivated(ShareTargetActivatedEventArgs args) {
// Code to handle activation goes here.
}
All the data that the user wants to share with any application is contained in a ShareOperation object. You can also check the format of the data it contains.
Given below is the code snippet that handles shared content in plain text format.
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;
}
Let us have look at a simple example by creating a new UWP project, which will share a weblink.
Diberikan di bawah ini adalah kode XAML di mana tombol dibuat dengan beberapa properti.
<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>
Kode C # di mana peristiwa klik-tombol diimplementasikan dan kode berbagi URI diberikan di bawah ini.
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();
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan melihat halaman berikut di emulator.
Ketika tombol diklik, itu akan memberikan opsi untuk berbagi di aplikasi mana.
Klik pesan dan jendela berikut akan ditampilkan dari mana Anda dapat mengirim tautan ke siapa pun.
Dalam bab ini, kita akan mempelajari cara mem-porting aplikasi Windows 8.1 aplikasi Anda yang ada ke Universal Windows Platform (UWP). Anda dapat membuat satu paket aplikasi Windows 10 yang dapat diinstal pelanggan Anda ke semua jenis perangkat.
Setelah mem-porting aplikasi Anda ke Windows 10 UWP, aplikasi Anda akan mendapatkan keuntungan dari -
- Perangkat keras baru yang menarik
- Peluang monetisasi yang bagus
- Satu set API modern,
- Kontrol UI adaptif,
- Desain dan Kode Adaptif
- Rentang modalitas input seperti mouse, keyboard, sentuhan, dan ucapan.
Porting Proyek Windows 8.x ke Proyek UWP
Ada dua opsi untuk mem-port aplikasi Windows 8.x Anda yang ada ke Universal Windows Platform (UWP).
Option 1 - Salah satunya adalah membuat proyek Windows 10 baru di Visual Studio dan menyalin file Anda ke dalamnya.
Option 2 - Opsi lainnya adalah mengedit salinan file proyek Anda yang ada, termasuk manifes paket aplikasi.
Di bawah ini diberikan adalah langkah-langkah utama saat menggunakan opsi pertama.
Luncurkan Microsoft Visual Studio 2015 dan buat proyek Aplikasi Kosong (Windows Universal) baru dengan nama UWPBookStore.
Proyek baru Anda membuat paket aplikasi (file appx) yang akan berjalan di semua keluarga perangkat.
Dalam proyek aplikasi Universal 8.1 Anda, identifikasi semua file kode sumber dan file aset visual yang ingin Anda gunakan kembali. Di bawah ini adalah contoh aplikasi, yang memiliki tiga proyek. Satu digunakan untuk Windows, yang kedua untuk seluler dan yang ketiga adalah proyek bersama untuk Windows dan seluler.
Setelah menjalankan aplikasi ini di ponsel, Anda akan melihat jendela berikut.
Setelah menjalankan aplikasi window, Anda akan melihat aplikasi berikut.
- Sekarang, buka aplikasi proyek UWP yang baru dibuat
Dari Proyek Bersama, salin folder tersebut Assets\CoverImagesberisi file gambar sampul buku (.png). Salin jugaViewModel folder dan MainPage.xaml dan ganti file di tujuan.
Dari proyek Windows, salin BookstoreStyles.xaml. Semua kunci sumber daya di file ini akan diselesaikan di aplikasi Windows 10. Beberapa di antaranya setaraWindowsPhone file tidak akan.
Dalam Solution Explorer, yakinkan Show All Files adalah toggled ON.
Pilih file yang Anda salin, klik kanan, dan klik Include In Project seperti gambar dibawah.
Ini secara otomatis akan menyertakan folder berisi mereka. Anda kemudian dapat beralihShow All Files ‘OFF’ jika kamu suka.
Sekarang struktur proyek Anda akan terlihat seperti ini di Solution Explorer.
Edit kode sumber dan file markup yang baru saja Anda salin dan ubah referensi apa pun ke Bookstore1_81 namespace ke UWPBookStore namespace.
Cara termudah adalah dengan mengganti name space dengan Replace In Filesfitur. Tidak ada perubahan kode yang diperlukan dalam model tampilan.
Sekarang, ketika kode di atas dijalankan, Anda dapat menjalankannya di mesin lokal maupun di ponsel seperti yang ditunjukkan di bawah ini.
Sekarang, opsi kedua adalah mengedit salinan file proyek Anda yang ada, termasuk manifes paket aplikasi. File proyek danpackage.appmanifest file memerlukan beberapa modifikasi saat porting dari Windows / phone 8.x ke Windows 10.
Microsoft telah menyediakan utilitas peningkatan proyek UWP, yang sangat membantu saat mem-porting aplikasi Anda yang sudah ada. Utilitas dapat diunduh dari github.com .
Kami menyarankan Anda untuk mengikuti contoh di atas selangkah demi selangkah untuk pemahaman yang lebih baik.