次の方法で共有


ホスト アプリと同じプロセスで実行するようにアプリ サービスを変換する

AppServiceConnectionを使用すると、別のアプリケーションがバックグラウンドでアプリを起動し、アプリとの直接通信を開始できます。

インプロセス App Services の導入により、実行中の 2 つのフォアグラウンド アプリケーションは、App Service 接続経由で直接通信を行うことができます。 App Services はフォアグラウンド アプリケーションと同じプロセスで実行できるようになりました。これにより、アプリ間の通信がはるかに簡単になり、サービス コードを別のプロジェクトに分割する必要がなくなります。

アウトプロセス モデル App Service をインプロセス モデルに変換するには、2 つの変更が必要です。 1 つ目はマニフェストの変更です。

<Package
   ...
  <Applications>
      <Application Id=...
          ...
          EntryPoint="...">
          <Extensions>
              <uap:Extension Category="windows.appService">
                  <uap:AppService Name="InProcessAppService" />
              </uap:Extension>
          </Extensions>
          ...
      </Application>
  </Applications>

EntryPoint 属性を <Extension> 要素から削除します。アプリ サービスを呼び出したときに使われるエントリ ポイントが OnBackgroundActivated() になったためです。

2 つ目の変更は、サービス ロジックを別のバックグラウンド タスク プロジェクトから、 OnBackgroundActivated()から呼び出すことができるメソッドに移動することです。

これで、アプリケーションで App Service を直接実行できるようになりました。 たとえば、App.xaml.cs では次のようになります。

[注] 下のコードは、例 1 (アウトプロセス サービス) で提供されているものとは異なります。 下のコードは単に説明のために用意されているものです。例 2 (インプロセス サービス) の一部として使用しないでください。 この記事で例 1 (アウトプロセス サービス) から例 2 (インプロセス サービス) への移行を続けるために、下のコード例ではなく、例 1 で提供されているコードを引き続き使用します。

using Windows.ApplicationModel.AppService;
using Windows.ApplicationModel.Background;
...

sealed partial class App : Application
{
  private AppServiceConnection _appServiceConnection;
  private BackgroundTaskDeferral _appServiceDeferral;

  ...

  protected override void OnBackgroundActivated(BackgroundActivatedEventArgs args)
  {
      base.OnBackgroundActivated(args);
      IBackgroundTaskInstance taskInstance = args.TaskInstance;
      AppServiceTriggerDetails appService = taskInstance.TriggerDetails as AppServiceTriggerDetails;
      _appServiceDeferral = taskInstance.GetDeferral();
      taskInstance.Canceled += OnAppServicesCanceled;
      _appServiceConnection = appService.AppServiceConnection;
      _appServiceConnection.RequestReceived += OnAppServiceRequestReceived;
      _appServiceConnection.ServiceClosed += AppServiceConnection_ServiceClosed;
  }

  private async void OnAppServiceRequestReceived(AppServiceConnection sender, AppServiceRequestReceivedEventArgs args)
  {
      AppServiceDeferral messageDeferral = args.GetDeferral();
      ValueSet message = args.Request.Message;
      string text = message["Request"] as string;

      if ("Value" == text)
      {
          ValueSet returnMessage = new ValueSet();
          returnMessage.Add("Response", "True");
          await args.Request.SendResponseAsync(returnMessage);
      }
      messageDeferral.Complete();
  }

  private void OnAppServicesCanceled(IBackgroundTaskInstance sender, BackgroundTaskCancellationReason reason)
  {
      _appServiceDeferral.Complete();
  }

  private void AppServiceConnection_ServiceClosed(AppServiceConnection sender, AppServiceClosedEventArgs args)
  {
      _appServiceDeferral.Complete();
  }
}

上記のコードでは、 OnBackgroundActivated メソッドが App Service のアクティブ化を処理します。 AppServiceConnectionを介した通信に必要なすべてのイベントが登録され、アプリケーション間の通信が完了したときに完了としてマークできるようにタスク遅延オブジェクトが格納されます。

アプリが要求を受信し、ValueSet を読み取るとKey文字列とValue文字列が存在するかどうかを確認するために提供されます。 存在する場合、アプリ サービスはResponseのペアを返し、文字列値をTrueAppServiceConnectionの反対側のアプリに戻します。

他のアプリとの接続と通信の詳細については、 App Service の作成と使用に関するページを参照してください。