Windows10 Dev - Komunikasi Aplikasi

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 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.