先日開催されたGoogle I/O
そこで無制限で使い放題だって発表されたFirebase Notification
今回はプッシュ通知を送る必要があったのでさっそく導入してみました!
正直導入が簡単すぎて……さすがGoogle、恐ろしい子……
#Firebaseを使う準備
まずはFirebaseにアプリを登録するところから始めます。
このステップさえやってしまえばこれ以降いとも簡単にFirebaseの機能が使えるようになります。
まず、Firebaseのページを開きます。
![fire.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F05d20957-2b57-06f7-ff39-37807ec26be0.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=a1a41e75660b9beb566f646bdc46366d)
![start.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F7108ef46-36a8-7745-5a85-89ebdcbb86a3.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=be32e1b05cc282890d649c54ddd63060)
![new.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F3eb99902-7270-714d-71d6-ff32e6b7ae3b.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=76de4cbab6e1ad1599554bd88799ca7c)
![regist.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F89b5f435-68ef-f48d-0a59-e11819a0b80e.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=abf54f6f4cdded30561700137c07872d)
![a.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2Fd4318201-2076-9ee0-5e36-51a99eb1ba64.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=346ad44075efbcb836fd9c3f84b2b4fc)
![gh.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F9563f124-302b-4781-7a5d-c3d1d5d313f1.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=a7dec938ddccf114766f5b6c0ae03739)
![ggggg.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F378cd926-52ba-b64a-e002-10d3bcc62d81.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=3116bfd7b67ed7d668cd7af0b5da7be9)
![jjj.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2Fe329a0bf-7f4e-965a-5283-0c7d164136ea.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=dc2aebea4d47b7b749ad5f3c4b3cce49)
buildscript {
dependencies {
// Add this line
classpath 'com.google.gms:google-services:3.0.0'
}
}
...
// Add to the bottom of the file
apply plugin: 'com.google.gms.google-services'
次にbuld.gradleに上記2行を追加するだけでFirebaseの準備が終わります。
これでFirebaseのいろいろな機能が使えるようになりました!
やったぜ!
#一番簡単なNotification導入
compile 'com.google.firebase:firebase-messaging:9.0.0'
この1行を追加します。おわり。
これだけでコンソールから送ったメッセージをNotificationに表示することが出来ます。
簡単!
ただこのままではアプリがバックグラウンドにいる時しかメッセージを受け取れません。
これ気づかなくてかなり悩んだw
よく見るとドキュメントに目立つように書いてあるんだからちゃんと読めよってお話。
フォアグラウンドでの処理は後述するとしてとりあえずメッセージを送ってみましょう!
#Notificationを送信してみる
このアイコン(もしくは左のメニュー)からNotificationのページに遷移します。
![nn.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2Fb27ed95d-72bd-115f-bd89-883956093496.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=8553d8ecceae8a6c642556d69bebfe4b)
![y.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F976bd776-17e2-bbd3-ea5e-423086717b53.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=0457b5b4555b6ffb3ab468757e83d9d2)
![aaaa.PNG](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.amazonaws.com%2F0%2F82960%2F28139a21-fcac-898c-c6c0-600b5683e4b2.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=452316d481ef40f89ded80d009945f4d)
2秒くらいできます。すごい!
これで誰でも簡単にプッシュ通知が可能になります。やったね!
#フォアグラウンドにいる時もメッセージを受け取る
フォアグラウンドにいる時にも処理を行いたい場合はFirebaseMessagingServiceを継承したクラスを作り、そこで処理を行う必要があります。
public class MessageService extends FirebaseMessagingService {
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
super.onMessageReceived(remoteMessage);
Log.d("NANAMIN", remoteMessage.getNotification().getBody());
// プッシュ通知来た時にやりたいことをここら辺に書く
}
}
また、マニフェストに以下を追加します。
<service
android:name=".service.MessageService">
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT"/>
</intent-filter>
</service>
これでアプリがフォアグラウンドにいる時も処理ができるようになりました。
今までお金かかりそうだしなんか大変そうだし敬遠しがちだったプッシュ通知、ここまで簡単に実装できるとなるとアプリ作る時にかなり幅が広がる感じがしますね。