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

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

ただいまの
回答率

90.23%

Notificationで通知をさせたいです。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 191

bake

score 7

//タイマー終了後のところでNotificationを用いて、タイマー終了後にステータスバーに表示させたいのですができません。
よろしくお願いします。(OnFinishのところでtoastやsettextはタイマー終了後に反映されてます。)

public class TimerActivity extends AppCompatActivity {

    private TextView timerText;
    private EditText edit;
    private AlarmManager aManager;
    private Calendar calendar;
    private SharedPreferences data;

    long countNumber = 5000;

    // インターバル msec
    long interval = 100;

    // 表示形式を設定
    private SimpleDateFormat dataFormat = new SimpleDateFormat("mm:ss.SSS");

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.my_fragment);

        edit= (EditText)findViewById(R.id.timesec);
        aManager = (AlarmManager)getSystemService(Context.ALARM_SERVICE);

        data = PreferenceManager.getDefaultSharedPreferences(this);

        //  レイアウトと関連
        Button startButton = findViewById(R.id.start_button);
        Button stopButton = findViewById(R.id.stop_button);
        Button resetButton = findViewById(R.id.reset_button);
        Button setButton = findViewById(R.id.set_button);
        Button button1 = (Button) findViewById(R.id.main_button);

        //テキストに初期時間の設定msec
        timerText = findViewById(R.id.timer);
        timerText.setText(dataFormat.format(5000));

        // インスタンス生成
        // CountDownTimer(long millisInFuture, long countDownInterval)
        final CountDown countDown = new CountDown(countNumber, interval);

        //タイマー開始
        startButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // 開始
                countDown.start();
            }
        });

        //タイマー中止
        stopButton.setOnClickListener(new View.OnClickListener(){

            @Override
            public void onClick(View v) {
                // 中止
                countDown.cancel();
            }
        });

        //タイマーリセット
        resetButton.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {
                // リセット
                timerText.setText(dataFormat.format(180000));
            }
        });

        setButton.setOnClickListener(new View.OnClickListener() {


            @Override
            public void onClick(View v) {
                //時間をセットする。
//                String timesec = edit.getText().toString();
//                timerText.setText(timesec);
//                long timesec1 = Long.valueOf(timesec);
//
//                countNumber = timesec1;

//                SharedPreferences data = getSharedPreferences("save", Context.MODE_PRIVATE);
//                SharedPreferences.Editor editor = data.edit();
//                editor.putLong( "save", timesec1 );
//                editor.commit();

            }
          });
    }

   class CountDown extends CountDownTimer {

        CountDown(long millisInFuture, long countDownInterval) {
            super(millisInFuture, countDownInterval);
        }
        //タイマー終了後
        @Override
        public void onFinish() {

            // 完了
            Toast.makeText(TimerActivity.this,"タイマーが終了しました。",Toast.LENGTH_LONG).show();

        //ステータスバーに通知:表示されない
            Intent intent = new Intent(TimerActivity.this, AlarmNotificationActivity.class);
            PendingIntent pendingIntent = PendingIntent.getActivity(TimerActivity.this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);

            NotificationCompat.Builder builder = new NotificationCompat.Builder(TimerActivity.this);
            Notification notification = builder

                    // 通知のタイトル
                    .setContentTitle("タイマー終了!")
                    // この通知が未だ表示されていない時だけ、音やバイブレーション、ショートメッセージの表示を行う
                    .setOnlyAlertOnce(false)
                    // タップしたら消えるようにする
                    // 通知の詳細メッセージ
                    .setContentText("00:00.000")
                    // 通知のアイコン
                    .setSmallIcon(R.drawable.ic_launcher)
                    // 通知を表示した瞬間、通知バーに表示するショートメッセージ
                    .setTicker("通知だヨ!")
                    // 通知をタップした時に使う PendingIntent
                    .setContentIntent(pendingIntent)
                    .setAutoCancel(true)
                    .build();
            NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

            manager.notify(0, notification);

            timerText.setText(dataFormat.format(0));
        }

        // インターバルで呼ばれる
        @Override
        public void onTick(long millisInFuture) {
            timerText.setText(dataFormat.format(millisInFuture));

        }
    }
}


public class AlarmNotificationActivity extends AppCompatActivity {


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Notification notification = new Notification();
        NotificationManager manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
        manager.notify(0, notification);
    }
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • y_waiwai

    2019/07/02 07:25 編集

    できないとのことですが、現状のコードではどう言う動作になりますか?

    キャンセル

  • bake

    2019/07/02 13:14

    エラーは表示されないのですが、notificationのコードは反映されておらず、何も動作しません。

    キャンセル

回答 1

checkベストアンサー

0

通知を表示させようとしているAndroidのOSは何でしょうか?
もし、Android 8.0 Oreo以上であるならば通知の仕方が変わっており
通知チャンネルを使用する必要があります。
以下、通知チャンネルを使用したNotificaitonの作成方法のサンプルです。

OreoでNotificationを表示させる方法

Android 8.0 Oreo 通知対応チェックリスト

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/07/02 21:31

    回答ありがとうございます!
    実機ではなくエミュレータを使っていまして.osは8以上だったのですが
    以前、チャンネルを使わずにoncreate下でnotificationの部分だけを実装して通知ができた事を確認できています。

    キャンセル

  • 2019/07/02 22:10

    一応、手元の環境だとエミュレータでonCreateに書いてもoreoの場合は通知が表示されませんでした。
    NotificationChannelだとエミュレータでも表示されたのでそちらをお試しください。
    また、oreoでNotificationChannelを使わずに通知ができたコードを書いていただければそちらを調べてみようと思います。
    ヘッドアップ通知されないなどはpriorityが関係している場合もありますが、今回のケースとは少し違うかなと思います。一応、ご参考までに。
    https://qiita.com/mstssk/items/c448fa79fb8618cc0bc

    キャンセル

  • 2019/07/03 00:40

    ご丁寧に本当にありがとうございます!channelでやってみます。コードの方明日送らせていただきます。

    キャンセル

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

  • ただいまの回答率 90.23%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる