Firebase 向け Google アナリティクスを使用して WebView でイベントをトラッキングする

1. はじめに

最終更新日: 2022-02-25

作成するアプリの概要

この Codelab では、WebView 内のウェブページからネイティブ コードにイベントを転送して、GA4F でイベントをトラッキングする方法について説明します。

WebView を使用してウェブページを呼び出すハイブリッド Android サンプルアプリを使用します。

学習内容

  • ハイブリッド アプリで GA4F(Firebase 向け Google アナリティクス)を初期化する方法
  • ウェブページでカスタム イベントとパラメータを作成する方法
  • WebView 内のウェブページでイベントをネイティブ コードに転送する方法
  • デバッグ方法
  • イベントをインポートして、アクション キャンペーンで使用する方法

必要なもの

  • Android Studio 3.6 以降
  • Firebase アカウント

2. 設定方法

コードを取得する

Firebase の公式ガイドに、サンプルコードが GitHub で提供されています。このプロジェクトではこのコードが必要です。

7074c0e83b5fd4b1.png

まず、コードをダウンロードして、お好みの開発環境で開きます。android と web の 2 つのディレクトリを使用します。「android」ディレクトリは Android アプリ用、「web」ディレクトリは WebView を介してアプリから呼び出されるウェブページ用です。

3. Firebase プロジェクトを作成して設定する

Firebase の利用を開始するには、Firebase プロジェクトを作成して設定する必要があります。

Firebase プロジェクトを作成する

  1. Firebase にログインします。

Firebase コンソールで、[プロジェクトを追加](または [プロジェクトを作成])をクリックし、Firebase プロジェクトに「Webview-test-codelab」または任意の名前を付けます。

fd93054e27d6b386.png

  1. プロジェクト作成オプションをクリックします。プロンプトが表示されたら、Firebase の利用規約に同意します。アクション イベントのトラッキングとコンバージョンの分析のために Google アナリティクス イベントが必要となるので、このプロジェクトでは Google アナリティクスを有効にする必要があります。

d711cb170a42a355.png

Firebase プロジェクトの詳細については、 Firebase プロジェクトについて理解するをご覧ください。

4. Android 用の Firebase 構成

Firebase コンソールで Android を構成する

  1. Firebase コンソールのホームで、次のように Android アイコンをクリックします。 143983fdc86ff670.png

または、左側のナビゲーション バーで [プロジェクトの概要] に移動し、[アプリに Firebase を追加して利用を開始しましょう] の下の [Android] ボタンをクリックします。

すると、次のような [Android アプリに Firebase を追加] 画面が表示されます。

74e684bd64bd8d9d.png

  1. Android パッケージ名(例: com.xxxx.myproject)は、アプリ ディレクトリの android/app/src/main/AndroidManifest.xml で確認できます。
package="com.xxxx.myproject"
  1. ここでは SHA-1 キーは必要ありません。このキーが必要になるのは、Google ログインまたはFirebase Dynamic Linksを使用する場合、または Google Play からアプリ内購入データをインポートする場合のみです。この Codelab では扱いません。
  2. [アプリを登録] をクリックします。
  3. Firebase コンソールで構成ファイル google-services.json をダウンロードし、アプリ プロジェクトの android/app ディレクトリにコピーして貼り付けます。 a2c930b2dd517980.png
  4. Firebase コンソールに戻り、残りの手順をスキップして、Firebase コンソールのメインページに戻ります。
  5. 最後に、Firebase によって生成された google-services.json ファイルを読み取るための Google Services Gradle プラグイン が必要です。
  6. IDE またはエディタで android/app/build.gradle を開き、ファイルの最後の行として次の行を追加します。
apply plugin: 'com.google.gms.google-services'
  1. android/build.gradle を開きます。次に、buildscript タグ内に新しい依存関係を追加します。
buildscript { 
   repositories {
      // ...
   }
   dependencies {
      // ...
      Classpath 'com.google.gms:google-services:4.3.3'
   }
}
  1. アプリがまだ実行中の場合は、Gradle で依存関係をインストールできるように、アプリを閉じて再ビルドします。

Android 用のアプリの設定は完了です。

5. ウェブでアナリティクスのウェブ インターフェースを開発し、カスタム イベントを記録する

Google アナリティクスで WebView のイベントをトラッキングするには、ウェブと Android アプリの両方にコードを挿入する必要があります。

このパートでは、ウェブページに配置する必要があるコードについて説明します。a0f31cdf21ea85d1.png

まず、HTML ファイルで使用する JavaScript ファイルを作成します。サンプルコードでは、js ファイルの名前は index.js です。Android 用の「AnayticsWebInterface」を呼び出す関数「logEvent」と、iOS 用の「messageHander」を次のコードのように作成する必要があります。

66a13d9290c3b2c7.png

また、次の例のように、HTML ファイルでイベントをトラッキングする場所でこの関数を呼び出します。

1bf11ba7b8fae269.png

Android アプリの WebView でイベントがトリガーされると、「window.AnalyticsWebInterface」が呼び出され、アプリの WebInterface コードにイベントが転送されます。

6. ウェブ ディレクトリをホストしてウェブページの URL を取得する

アプリの WebView 内でウェブページを呼び出す前に、ウェブページの URL が必要になります。ウェブページをホストする方法はたくさんあります。この Codelab では、便宜上 Firebase Hosting サービスを使用します。

  • ターミナルでウェブ ディレクトリ(例: cd web)に移動し、次のコマンドを実行します。
  • npm install -g firebase-tools

これにより、Firebase CLI がインストールされます。

  • firebase login
  • firebase init
  • 設定する機能を選択するよう求められたら、[Hosting] を選択します。
  • Android アプリ用に設定したプロジェクトを選択します。
  • 残りのプロンプトはすべてデフォルトを受け入れます。
  • firebase deploy --only hosting - Firebase Hosting にデプロイします。

a2c132502ffa8a04.png

  • ウェブページの URL を取得したら、Android Studio でアプリ プロジェクトに移動し、この手順で作成したウェブ URL を次の例のように WebView 内に挿入します。

86b44d7bf72383a7.png

7. Android アプリでインターフェース コードを開発する

GA4F で WebView のイベントをトラッキングするには、ウェブと Android の両方にコードを挿入する必要があります。このパートでは、WebView のウェブページからイベントを受信するために Android アプリに配置する必要があるコードについて説明します。

「AnalyticsWebInterface」クラスを作成する「AnalyticsWebInterface.java」ファイルを作成します。このクラスでは、次の例のように、ウェブ js ファイルの logEvent 関数を接続する @JavascriptInterface をコーディングする必要があります。

796981318ff44346.png

次に、次の例のように、WebView を呼び出すアクティビティに JavaScript インターフェースを追加する必要があります。

b1bd1d9bb50d418f.png

完全なコードについては、「設定方法」の手順で GitHub からダウンロードしたサンプルコードをご覧ください。

8. イベントの確認とデバッグ

イベントをデバッグするには、テストデバイスを接続するかエミュレータを起動した後、Android Studio ターミナルで次のコードを使用します。

adb shell setprop debug.firebase.analytics.app [アプリ パッケージ名]

> adb shell setprop log.tag.FA VERBOSE

> adb shell setprop log.tag.FA-SVC VERBOSE

> adb logcat -v time -s FA FA-SVC

アプリで [LOG EVENT 1] をクリックすると、コードが正しく動作している場合は、次のようなログが表示されます。

f84d06d3534ad034.png

Firebase コンソールで確認する場合は、[リアルタイム] タブを使用することもできます。Firebase コンソールに移動し、次の例のように [リアルタイム] タブをクリックします。

次に、[比較を追加] 機能を使用して Android プラットフォーム イベントをフィルタします。

aa804eb02f0b7d3f.png

コードが正しく実装されている場合は、[リアルタイム] タブに Android アプリからのイベントが表示されます。 334afcae650c58d4.png

数時間後には、ログに記録されたイベントを Firebase コンソールの [イベント] タブで確認できるようになります。Firebase コンソールの [アナリティクス] セクションにある [イベント] タブをクリックします。イベントをクリックするだけで、イベント event1 内の値を確認することもできます。

b72cf934a76e174b.png

Google 広告で event1 をコンバージョンとしてインポートするには、[コンバージョンとしてマークを付ける] スイッチを右にスライドして、コンバージョンとしてマークします。

486010186b929deb.png

イベントが [コンバージョン] タブに表示されていれば、そのイベントをコンバージョンとして確認できたということです。これで、Google 広告で Firebase からこのイベントをインポートできるようになります。

デバッグ目的の場合は、Firebase DebugView を使用します。詳細については、イベントのデバッグをご覧ください。

9. Google 広告にアナリティクス イベントをインポートする

Firebase の設定が完了したら、アクション イベントのあるアプリ キャンペーンを立ち上げることができます。まず、Firebase を Google 広告にリンク します。Firebase を Google 広告にリンク すると、アプリイベントに Firebase イベントをインポートできます。また、この処理により、オーディエンスについてより深く知ることができ、Google 広告でのアプリ キャンペーンの成果を高めることができます。

  1. [プロジェクトの概要] の横のボタンをクリックして、Firebase 設定 に移動します。
  2. [統合] タブで、Google 広告リンク ボタンが表示されます。[リンク] をクリックして、[続行] をクリックします。

67fc1b7f75f9dcaa.png

  1. Google 広告アカウントを選択します。

これで Firebase の部分は完了です。

Google 広告に移動します。

  1. ログインして、[ツールと設定] > [測定] > [コンバージョン] に移動し、カスタム イベントをコンバージョンとしてインポートします。
  2. [+] ボタンをクリックして、新しいコンバージョン アクションを追加します。

1eb800ed1ae776cc.png

  1. [Google アナリティクス 4 プロパティ(Firebase)] を選択し、[続行] をクリックします。

8b0a0b34b1d3eae2.png

  1. コンバージョンとしてマークされたすべてのアナリティクス イベントが表示されます。以前に実装した event1 イベントを探します。

e2bd5e1f7b9b73d9.png

  1. アクションを確認し、[インポート]、[続行] の順にクリックします。

2402f11ee4e3ed2e.png

コンバージョン アクションとして event1 を設定すると、event1 イベントでアプリ アクション キャンペーンを開始できます。

10. インポートされたイベントを使ってアプリ アクション キャンペーンを開始する

  1. 現在のアカウントの [キャンペーン] タブに移動し、[+] ボタンをクリックして新しいキャンペーンを作成します。[新しいキャンペーンを作成] をクリックして、[続行] をクリックします。
  2. [アプリ インストール] オプションでアプリ インストール広告キャンペーンを起動します。

eda56ea9bd38c6d5.png

  1. アプリ名、パッケージ名、またはパブリッシャーを入力してアプリを検索します。
  2. [入札] セクションで、プルダウン メニューから [アプリ内コンバージョン] を選択します。
  3. 表示されたリストでカスタム イベントを見つけます。目標コンバージョン単価を設定し、その他のオプションを入力します。

438e581eb1b40003.png

  1. キャンペーンの設定を完了します。

11. 完了

これで Firebase と Google 広告の統合が完了しました。これにより、Firebase にインポートしたイベントを使ってキャンペーンのパフォーマンスを向上させることができます。

学習した内容

  • ハイブリッド アプリで GA4F(Firebase 向け Google アナリティクス)を初期化する方法
  • ウェブページでカスタム イベントとパラメータを作成する方法
  • WebView 内のウェブページでイベントをネイティブ コードに転送する方法
  • デバッグ方法
  • イベントをインポートして、アクション キャンペーンで使用する方法

12. 参考資料

公式ガイド

  • WebView でアナリティクスを使用する - Firebase - Google

Firebase と Google 広告の設定