Google の Firebase を使ったPush通知を Defold で実装する方法です。
手順
Firebase プロジェクトの設定
https://console.firebase.google.com/ へアクセスしプロジェクトを作成する。
data:image/s3,"s3://crabby-images/6bd8a/6bd8a8e415d5d49df8a8c92f98c7bfdc44ee5480" alt=""
プロジェクト名に名前を付けて次へ続行します。
data:image/s3,"s3://crabby-images/e4873/e48735a7b50e0395017c820db3441457e77af1c3" alt=""
このプロジェクトでGoogle アナリティクスを有効にするか否かを聞かれます。特に理由が無ければ有効にしたまま続行します。
data:image/s3,"s3://crabby-images/13b9f/13b9f2979b40f3104ff5b04c5973296abf1be06a" alt=""
アナリティクスの地域を設定して、各種利用規約に同意、プロジェクトを作成します。
data:image/s3,"s3://crabby-images/2725f/2725f135b03642aeb4103b8cea00b63eea3fedcd" alt=""
しばらく待つとプロジェクトの準備が完了します。それまでは画面右下の彼と同様に一息つくと良いかもしれません。
data:image/s3,"s3://crabby-images/97a6e/97a6e4f82df573dac4b9ee7ee1b9ca985dc62875" alt=""
準備が出来たらアプリにFirebase を追加します。今回はAndroid デバイスに追加します。画面のAndroidのロゴを選択します。
data:image/s3,"s3://crabby-images/f40b4/f40b47a8f6aef74045ebeebae7e60a15816e0919" alt=""
アプリを登録します。アプリのパッケージ名を入力し「アプリを登録」します。他は省略可です。
data:image/s3,"s3://crabby-images/afba3/afba3d2ecc06f3080ea3a09e39dcf909b8c8c5e5" alt=""
「AndroidアプリにFirebase を追加」画面が表示されたら、パッケージ名を確認した後、設定ファイル “google-services.json” をダウンロードします。
data:image/s3,"s3://crabby-images/77a14/77a14421c99716abff4ed9778618aa312390d025" alt=""
次へ進むとFirebase SDK の追加画面になりますが何もせず次へ進みます。
data:image/s3,"s3://crabby-images/29f21/29f2182b29e0adaa0de6ce8db11cedc6ac58daf4" alt=""
「Android アプリにFirebase を追加」画面になりますがこちらも「このステップをスキップ」します。
data:image/s3,"s3://crabby-images/8de41/8de412266239059569dab37e37cc971d966ffe7c" alt=""
これで準備はOKです。
Defold Engine の設定
まずプロジェクトに Push アセットを追加します。追加できたら別途 https://github.com/defold/extension-push こちらから “generate_xml_from_google_services_json.exe” と “generate_xml_from_google_services_json.py” もダウンロードしておき、プロジェクトのルートフォルダへコピーしておきます。
data:image/s3,"s3://crabby-images/ad5a8/ad5a837633efea92eeca2d844fe8aef889bc3071" alt=""
data:image/s3,"s3://crabby-images/089e6/089e6076bf9894c92a383c2dc367599680c29952" alt=""
google-services.json を google-services.xml へ変換する
さきほど配置した generate_xml_from_google_services_json.exe を使って google-services.json から google-services.xml を作成します。
xml ファイルはコマンドラインから叩くだけで作成できます。Windows環境のサンプルはこんな感じです。
.\generate_xml_from_google_services_json.exe -i google-services.json -o google-services.xml
正常終了すると json ファイルと同じフォルダにxml ファイルが作成されます。
data:image/s3,"s3://crabby-images/04dcc/04dcc4e84d8d8c610b01099ccc13e4a5393d90cf" alt=""
google-services.xml ファイルを配置する
google-services.xml の配置場所を変更します。フォルダが無い場合は作成します。
<プロジェクトのルート>\bundle\android\res\values\google-services.xml
Bundle Resources の設定
配置したxml ファイルをビルドに含めるため Bundle Resources にパスを設定します。
data:image/s3,"s3://crabby-images/e4fb7/e4fb7eeab05386ecfdc6378cf4e983c323933d31" alt=""
これでDefold Engine 側の設定は完了です。
Push 通知してみる
Firebase へ戻りメニューから [Cloud Messaging] を開きます。開いたら [Send your first message]を選択してメッセージを送信する準備を行います。
data:image/s3,"s3://crabby-images/dcbbd/dcbbdca16159230a0670f995ed0bd485b266cfef" alt=""
あとは手順に従ってパラメータを入力します。
data:image/s3,"s3://crabby-images/19486/1948683fb9595c3a8b3dbafcdf27e0f359a6a704" alt=""
data:image/s3,"s3://crabby-images/b5d31/b5d31aa48b6b08eec1c06e40df2cd50a8192b684" alt=""
data:image/s3,"s3://crabby-images/bc249/bc2492dfa178be320cdf90433b61f572e62869ee" alt=""
最後まで進めて「確認」するとメッセージの送信確認ポップアップが表示されますので「公開」します。メッセージが端末へ送信されます。
data:image/s3,"s3://crabby-images/d75eb/d75ebf575bcdf4d2cc38fde6cf318acbc09bbd48" alt=""
結果
data:image/s3,"s3://crabby-images/94058/940584fc480f8d6a1c7039ceb34cb48e272641d8" alt=""
正常に動作しました。