Как создать уведомление в определенное время в будущем? (Android)

#android #notifications

#Android #уведомления

Вопрос:

Прямо сейчас я хочу выбрать определенное время и отправить уведомление пользователю, но приложение отправляет уведомление только при запуске в фоновом режиме. Как я могу отправить уведомление, когда приложение полностью закрыто?

Это мой MainActivity.java класс

 package com.vortex.notification;

import androidx.appcompat.app.AppCompatActivity;

import android.app.AlarmManager;
import android.app.NotificationChannel;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Intent;
import android.os.Build;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

import java.util.Calendar;

public class MainActivity extends AppCompatActivity {

    private Button button;

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

        findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Calendar calendar = Calendar.getInstance();

                calendar.set(Calendar.HOUR_OF_DAY,4);
                calendar.set(Calendar.MINUTE,48);
                calendar.set(Calendar.SECOND,3);

                Intent intent = new Intent(getApplicationContext(),Notification_reciver.class);

                PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(),100,intent,PendingIntent.FLAG_UPDATE_CURRENT);

                AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
                alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,calendar.getTimeInMillis(),AlarmManager.INTERVAL_DAY,pendingIntent);
            }
        });


    }

    private void createNotificationChannel() {

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            CharSequence name = "LemubitReminderChanel";
            String description = "Chanel for Lemubit Reminder";
            int importance = NotificationManager.IMPORTANCE_DEFAULT;
            NotificationChannel channel = new NotificationChannel("notifyLemubit", name, importance);
            channel.setDescription(description);


            NotificationManager notificationManager = getSystemService(NotificationManager.class);
            notificationManager.createNotificationChannel(channel);
        }
    }

}
  

Это мой Notification_reciver.java класс

 package com.vortex.notification;

import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;

import androidx.core.app.NotificationCompat;

public class Notification_reciver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        NotificationManager notificationManager = (NotificationManager) context.getSystemService(context.NOTIFICATION_SERVICE);

        Intent repating_intent = new Intent(context,Repating_activity.class);
        repating_intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

        PendingIntent pendingIntent = PendingIntent.getActivity(context,100,repating_intent,PendingIntent.FLAG_UPDATE_CURRENT);

        NotificationCompat.Builder builder = new NotificationCompat.Builder(context,"notifyLemubit")
                .setContentIntent(pendingIntent)
                .setSmallIcon(android.R.drawable.arrow_up_float)
                .setContentTitle("Bildirim Başlığı")
                .setContentText("Bildirim Yazısı")
                .setAutoCancel(true);

        notificationManager.notify(100,builder.build());

    }
}
  

И это мое Manifest.xml

 <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.vortex.notification">

    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <receiver android:name=".Notification_reciver" >
            <intent-filter>
                <action android:name="NOTIFICATION_SERVICE" />
            </intent-filter>
        </receiver>

    </application>

</manifest>
  

Ответ №1:

У меня была такая же проблема, и я решил ее, изменив эту строку

 PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(),100,intent,PendingIntent.FLAG_UPDATE_CURRENT);
  

Для этого:

 PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(),100,intent,0);
  

И в манифесте измените свой приемник с этого

 <receiver android:name=".Notification_reciver" >
    <intent-filter>
        <action android:name="NOTIFICATION_SERVICE" />
    </intent-filter>
</receiver>
  

Для этого:

 <receiver android:name=".Notification_reciver"
    android:enabled="true"
    android:exported="true"
    android:process=":remote" >
    <intent-filter>
        <action android:name="NOTIFICATION_SERVICE" />
    </intent-filter>
</receiver>
  

Комментарии:

1. Я думаю, что все еще что-то не так. Уведомление приходит, когда приложение работает в фоновом режиме, но не тогда, когда оно полностью закрыто.

2. также попробуйте setInexactRepeating() вместо setRepeating()

3. к сожалению, это не сработало, приложение работает как и раньше.