Android App Bundle について

Android App Bundle は、アプリのコンパイル済みコードとリソースがすべて含まれた公開形式です。APK の生成と署名は Google Play が行います。

Google Play は App Bundle から、デバイス設定ごとに最適化した APK を生成、配信します。それによって、個々のデバイスでアプリを実行するのに必要なコードとリソースだけがダウンロードされます。デベロッパー側では、多様なデバイスのサポートを最適化するために複数の APK をビルド、署名、管理する必要がなくなり、ユーザー側では、よりサイズが小さく、最適化された APK をダウンロードできるようになります。

最適化された APK の配信をサポートする App Bundle をビルドすることは、ほとんどのアプリ プロジェクトでそれほど難しくありません。すでに確立された規則に従ってアプリのコードとリソースを整理している場合は、Android Studio またはコマンドラインを使用して署名付き Android App Bundle を作成し、Google Play にアップロードすると、APK 配信の最適化が自動的なメリットになります。

App Bundle 形式を使用してアプリを公開する場合は、アプリ プロジェクトに機能モジュールを追加できる Play Feature Delivery を利用することもできます。これらのモジュールは、指定した条件に基づいてアプリにのみ含まれている、または後からランタイムで Play Core Library の使用をダウンロードする際に利用できる機能とリソースを備えています。

App Bundle を使用してアプリを公開するゲーム デベロッパーは、Play Asset Delivery を使用できます。Play Asset Delivery は、大量のゲームアセットを配信するための Google Play のソリューションであり、柔軟な配信方法と高いパフォーマンスをデベロッパーに提供します。

Android App Bundle を使用したアプリの公開が推奨される理由について、次の動画をご覧ください。

圧縮ダウンロード サイズの制限

Android App Bundle を使用して公開すると、最小ダウンロード サイズでアプリをインストールできるようになり、圧縮ダウンロード サイズも増加します。つまり、ユーザーがアプリをダウンロードする場合、アプリのインストールに必要な圧縮 APK の合計サイズ(ベース APK と設定 APK など)を 4 GB 以下にする必要があります。オンデマンドでの機能モジュール(およびその構成 APK)のダウンロードなど、後続のダウンロードも、この圧縮ダウンロード サイズの制限に従う必要があります。Asset Pack はこのサイズ制限に含まれませんが、他のサイズ制限があります。

Google Play Console で、アプリやそのオンデマンド機能のダウンロードのいずれかが最大サイズの上限を超えていることが検出された場合は、エラーが発生します。

なお、Android App Bundle は APK 拡張(*.obb)ファイルに対応していません。そのため、App Bundle の公開時にこのエラーが発生した場合は、以下のリソースのいずれかを使用して、圧縮 APK ダウンロード サイズを削減してください。

  • 設定 APK のタイプごとに enableSplit = true を設定して、すべての設定 APK を有効にする。これにより、ユーザーがデバイスでアプリを実行するために必要なコードとリソースだけがダウンロードされるようになります。
  • 未使用のコードやリソースを削除してアプリを縮小します
  • おすすめの方法に従ってアプリのサイズを削減します
  • 一部のユーザーのみが使用する機能を機能モジュールに変換して、アプリが後でオンデマンドでダウンロードできるようにすることを検討します。アプリのリファクタリングが必要になる場合があることに留意してください。最初に、説明されている他の推奨事項を試してください。

その他の考慮事項

Android App Bundle を使用してアプリをビルドまたは配信する際の既知の問題は次のとおりです。ここに記載されていない問題が発生した場合は、バグを報告してください。

  • サイドローディングされたアプリ(Google Play ストアを使用せずにインストールされ、必要な分割 APK が欠けているアプリ)の部分的なインストールは、Google 認定デバイスと Android 10(API レベル 29)以上を搭載したデバイスのすべてで失敗します。Google Play ストアからアプリをダウンロードする場合は、アプリに必要なすべてのコンポーネントを Google が確実にインストールします。
  • リソース テーブルを動的に変更するツールを使用すると、App Bundle から生成された APK が予期しない動作をする場合があります。そのため、App Bundle をビルドする場合は、こうしたツールを無効にすることをおすすめします。

  • 機能モジュールのビルド構成で、ベース(または他の)モジュールのプロパティと競合するプロパティを構成する可能性があります。たとえば、ベース モジュールで buildTypes.release.debuggable = true を設定し、機能モジュールでは false に設定できます。このように競合すると、ビルドとランタイムの問題が発生します。デフォルトでは、機能モジュールはベース モジュールから一部のビルド構成を継承します。したがって、機能モジュールのビルド構成で、保持する必要がある構成と省略する必要がある構成を把握しておいてください。

参考情報

Android App Bundle の詳細については、次のリソースをご覧ください。

ブログ投稿

動画