当前位置: 首页 > 知识库问答 >
问题:

BroadcastReceiver在应用关闭/终止时无法显示通知

韩嘉胜
2023-03-14

我的任务是设置警报,以触发接收器在特定时间显示通知。

如果应用程序是打开的或只是在后台,代码就可以完美地工作。

在应用程序被杀死时,当执行警报时仍然可以触发接收器。

但是,没有显示通知。

我能做什么?

报警功能:

public static void makeAlarm(Context context,Date date) {
    Log.i("Alarm", "makeAlarm");
    AlarmManager alarmMgr;
    PendingIntent alarmIntent;
    alarmMgr = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
    Intent intent = new Intent(context, AlarmReceiver.class);
    alarmIntent = PendingIntent.getBroadcast(context, 0, intent, 0);
    alarmMgr.set(AlarmManager.RTC_WAKEUP,
            date.getTime(), alarmIntent);
}

报警接收器

public class AlarmReceiver extends BroadcastReceiver {
    public AlarmReceiver() {
    }

    @Override
    public void onReceive(Context context, Intent intent) {
                Log.i("Alarm", "onReceive");
                android.support.v4.app.NotificationCompat.Builder mBuilder =
                        new NotificationCompat.Builder(context)
                                .setSmallIcon(R.drawable.app_logo)
                                .setContentTitle("Title")
                                .setContentText("Message");

                Intent resultIntent = new Intent(context, MainActivity.class);
                TaskStackBuilder stackBuilder = TaskStackBuilder.create(context);
                stackBuilder.addParentStack(MainActivity.class);
                stackBuilder.addNextIntent(resultIntent);
                PendingIntent resultPendingIntent =
                        stackBuilder.getPendingIntent(
                                0,
                                PendingIntent.FLAG_UPDATE_CURRENT
                        );
                mBuilder.setContentIntent(resultPendingIntent);
                NotificationManager mNotificationManager =
                        (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
                Random rand = new Random();
                mNotificationManager.notify(rand.nextInt(), mBuilder.build());

    }
}

显示xml

<receiver
    android:name=".receiver.AlarmReceiver"
    android:enabled="true"
    android:exported="true" />

共有2个答案

堵鸿光
2023-03-14

当你用-

alarmMgr.set(AlarmManager.RTC_WAKEUP,date.getTime(), alarmIntent);

我想你在约会。getTIme()正在检索当前时间。因此,当尝试执行警报时,触发的时间将已经过去。更好的是,你可以做一些延迟(比如说,五秒钟)来触发你的闹钟。就用这条线-

alarmMgr.set(AlarmManager.RTC_WAKEUP,date.getTime() + 5*1000, alarmIntent);
平山
2023-03-14

请运行示例代码。我认为它可以按照您的要求工作。

public class MainActivity extends AppCompatActivity {

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

    setUpAlarm(10 * 1000);
}
public void setUpAlarm(long triggerTimeInMS) {
    AlarmManager alarmManager = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
    Intent intent = new Intent(this, AlarmReceiver.class);
    PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 1,  intent, 0);
    alarmManager.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+triggerTimeInMS , pendingIntent);
}
}

创建receiver类-

public class AlarmReceiver extends BroadcastReceiver {
private String TAG = "AlarmLog";

@Override
public void onReceive(Context context, Intent intent) {

    Toast.makeText(context, "Incoming Call Received", Toast.LENGTH_LONG).show();

    showNotification(context);

}

private void showNotification(Context context) {
    Uri soundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);

    NotificationCompat.Builder mBuilder =   new NotificationCompat.Builder(context)
            .setSmallIcon(R.drawable.alarm)
            .setContentTitle("Notification!") // title for notification
            .setContentText("Alarm Received")
            .setSound(soundUri)// message for notification
            .setAutoCancel(true); // clear notification after click
        NotificationManager mNotificationManager =
            (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
    mNotificationManager.notify(0, mBuilder.build());
}
}

不要忘记注册接收器。内部清单。xml放入以下代码-

    <application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    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="com.example.shajib.alarmtest.AlarmReceiver" />
</application>
 类似资料:
  • 仅当应用程序关闭时,数据有效负载的使用不会收到任何通知,并且不会触发消息接收方法。 在下图中显示数据负载,单击此处查看参数 回复是点击这里查看回复 响应成功1,但在redmi手机中未收到任何通知。

  • 我正在尝试使用WorkManager每10秒运行一个简单的工作。当应用程序在后台或前台运行时,它可以完美地工作。当我关闭应用程序(杀死应用程序)时,工作将不再被调用。 我在创建MainActivity时调用以下代码 工人阶级 这些代码在我的应用程序未关闭时运行良好。 我如何让它运行,即使应用程序关闭?

  • 我正在使用React Native推送通知(本地通知)[https://github.com/zo0r/react-native-push-notification]。 显示通知的逻辑如下所示。 我在react native中使用了“onSnapshot”函数来检查firestore数据是否更改。 如果更改,我在应用程序中显示本地通知。 当应用程序在前台或后台时,它运行良好。(Android和iO

  • 我今天一直在谷歌上搜索,但什么也找不到。我的场景如下: 我有一个Android应用程序可以自动回复收到的消息。我有下面的代码来创建一个持久的(不可刷的)通知,然后当应用程序通过onDestroy被销毁时,通知被移除。然而,当我打开recents面板并将我的应用程序扫走时,应用程序会停止自动回复服务,广播接收器也会停止,但onDestroy没有被调用,通知仍然可见。 我想简单地销毁通知,如果应用程序

  • 输出:pool-2=线程-1 pool-3=线程-1,pool-4=线程-1............. 我想要池-2=线程-1池-2=线程-1池-2=线程-1................ Threadpool不能从method()放到外部,每次都需要创建新的Threadpool。我可以完全终止线程池吗? 有什么需要帮忙的吗

  • 我使用的是PHP5.2,我已经在windows server中配置了它。我已经更新了php。用于关闭错误和通知的ini文件。我尝试过错误报告=全部