質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.36%

  • Android

    6986questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Firebaseでの通知受信について

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,745

WestField

score 12

FirebaseでPush通知を処理するプログラムを作っています。
端末がスリープ状態にある時、通知を受けた時点でスリープから復帰したいのですが、
どうしても出来ません。

import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.media.AudioManager;
import android.media.RingtoneManager;
import android.net.Uri;

import com.google.firebase.messaging.FirebaseMessagingService;
import com.google.firebase.messaging.RemoteMessage;

import java.util.Map;

import biz.flashsystem.cmasystem.HomeActivity;
import biz.flashsystem.cmasystem.R;

import static android.app.Notification.DEFAULT_ALL;
import static android.app.Notification.PRIORITY_MAX;

/**
 * Created by WestField_w7 on 2016/09/13.
 */
public class FcmMessagingService extends FirebaseMessagingService {
    private String TAG = "FcmMessagingService";

    @Override
    public void onMessageReceived(RemoteMessage remoteMessage) {
        if (remoteMessage.getData().size() > 0) {
            Map<String, String> data = remoteMessage.getData();

            String title = data.get("custom_title");
            String body = data.get("custom_body");

            sendNotification(title, body);
        }

        if (remoteMessage.getNotification() != null) {

        }
    }

    private void sendNotification(String messageTitle, String messageBody) {
        Intent intent = new Intent(this, HomeActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0 /* Request code */, intent,
                PendingIntent.FLAG_ONE_SHOT);

        Uri defaultSoundUri= RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);

        Notification notification = new Notification.Builder(this)
                .setSmallIcon(R.mipmap.ic_launcher)
                .setContentTitle(messageTitle)
                .setContentText(messageBody)
                .setAutoCancel(true)
                .setDefaults(DEFAULT_ALL)
                .setPriority(PRIORITY_MAX)
                .setContentIntent(pendingIntent)
                .build();

        NotificationManager notificationManager =
                (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

        notificationManager.notify(1, notification);
    }
}

現在は上記のように作っているのですが、上記だとスリープから復帰するどころか音も鳴らずバイブもしません。

どうすれば良いのでしょうか?

宜しくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.media.AudioManager;
import android.media.RingtoneManager;
import android.net.Uri;
import android.os.PowerManager;
import android.support.v7.app.NotificationCompat;
import android.util.Log;

import com.google.firebase.messaging.FirebaseMessagingService;
import com.google.firebase.messaging.RemoteMessage;
import com.google.firebase.messaging.RemoteMessage.Notification;

import java.util.Map;

import static android.app.Notification.DEFAULT_ALL;
import static android.app.Notification.PRIORITY_MAX;

/**
 * Created by WestField_w7 on 2016/09/13.
 */
public class FcmMessagingService extends FirebaseMessagingService {
    private String TAG = "FcmMessagingService";
    private AudioManager audioManager;
    private PowerManager.WakeLock wakelock;
    private int volumeLevel;

    @Override
    public void onMessageReceived(RemoteMessage remoteMessage) {
        Map<String, String> fcm_data = remoteMessage.getData();
        RemoteMessage.Notification fcm_notification = remoteMessage.getNotification();

        wakeUp();

        if (fcm_data.size() > 0) {
            int level = Integer.parseInt(fcm_data.get("level")) * 2;
            setAlertSound(level);
            sendNotification(fcm_data.get("title"), fcm_data.get("body"));
            setAlertSound(volumeLevel);
        }

        if (fcm_notification != null) {
            sendNotification(fcm_notification.getTitle(), fcm_notification.getBody());
        }
    }

    private void sendNotification(String messageTitle, String messageBody) {
        try{
            Log.d(TAG + "R57",messageTitle);
            Intent intent = new Intent(this, HomeActivity.class).setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);
            PendingIntent contentIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);

            Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_RINGTONE);
            NotificationCompat.Builder builder = (android.support.v7.app.NotificationCompat.Builder) new NotificationCompat.Builder(getApplicationContext())
                    .setSmallIcon(R.mipmap.ic_launcher)
                    .setVibrate(new long[]{0, 1000})
                    .setSound(alarmSound)
                    .setAutoCancel(true)
                    .setContentText(messageBody)
                    .setContentTitle(messageTitle)
                    .setColor(getResources().getColor(R.color.tableColor))
                    .setContentIntent(contentIntent);

            NotificationManager mNotificationManager = (NotificationManager) this.getSystemService(Context.NOTIFICATION_SERVICE);
            mNotificationManager.notify(1,builder.build());

        }catch(Exception e){
            e.printStackTrace();
        }
    }

    private void setAlertSound(int level){
        //Log.d(TAG + "R81",String.valueOf(level));
        audioManager = (AudioManager)getSystemService(Context.AUDIO_SERVICE);
        audioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);

        volumeLevel = audioManager.getStreamVolume(AudioManager.STREAM_NOTIFICATION);

        audioManager.setStreamVolume(AudioManager.STREAM_NOTIFICATION,level,1);
    }

    private void wakeUp(){
        wakelock = ((PowerManager) getSystemService(android.content.Context.POWER_SERVICE))
                .newWakeLock(PowerManager.FULL_WAKE_LOCK
                        | PowerManager.ACQUIRE_CAUSES_WAKEUP
                        | PowerManager.ON_AFTER_RELEASE, "disableLock");
        wakelock.acquire(20000);
    }
}

サーバ側JSON

{
"to": "device token",
"data": {
"title": "タイトル",
"body": "本文",
"level": "通知音量レベル"
}
}

以上で通知を受信した時に復帰させる事が出来ました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

PowerManagerを使ってスリープ状態から復帰しないとできないと思いますよ。
まずはWakeLockのキーワードで調べましょう。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/12/29 09:24

    ご回答有難う御座います。
    仰る通りでPowerManagerを使わないと復帰出来ないのは確かです。
    しかしながら、よくよく調べてみるとFirebaseの通知仕様に原因がある事が判りました。
    現状の状態でonMessageRevcievedにWakeLockを組み込んでも上手くいかなかったのは
    Notificationの仕様上アプリが起動していない状態ではonMessageRecievedを通過せずに自動的に表示されるようになっているようです。
    アプリが起動している状態ではonMessageRecievedを通るようです。
    FirebaseのPush通知仕様にNotificationとdataの2種類の構造があり、data構造を持つ通知だと起動していない状態でもonMessageRecievedを通るような事が書かれていましたので、試してみたいと思います。

    キャンセル

同じタグがついた質問を見る

  • Android

    6986questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。