无法解除/隐藏Android 5.0 Lollipop上的闹钟图标

时间:2015-05-16 12:17:37

标签: android alarmmanager android-5.0-lollipop android-alarms

自Android Lollipop 5.0(API21)发布以来,现在有一个API可以正式显示/隐藏警报图标。 stackoverflow上有关于此here的更多信息。

多亏了它,我设法在5.0+ Android设备上显示闹钟图标。不幸的是,如果警报被禁用,我无法解除/隐藏/取消图标。

以下是我正在做的事情(Stackoverflow和Android股票报警的多次尝试混合):

public static void setNextAlert(final Context context) {

final Alarm alarm = calculateNextAlert(context);

AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(ALARM_ALERT_ACTION);

PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);

int flags = alarm == null ? PendingIntent.FLAG_NO_CREATE : 0;
PendingIntent operation = PendingIntent.getBroadcast(context, 0 /* requestCode */,  intent, flags);


if (alarm != null) 
{
    if(UtilsAlarm.isLollipopOrLater())
    {
        PendingIntent viewIntent = PendingIntent.getActivity(context, alarm.id, intent, PendingIntent.FLAG_UPDATE_CURRENT);
        AlarmManager.AlarmClockInfo info = new AlarmManager.AlarmClockInfo(alarm.time, viewIntent);
        am.setAlarmClock(info, operation);
    }
    else
    {
        if(UtilsAlarm.isKitKatOrLater())
        {
            am.setExact(AlarmManager.RTC_WAKEUP, alarm.time, sender);
        }
        else
        {   
            am.set(AlarmManager.RTC_WAKEUP, alarm.time, sender);
        }

        setStatusBarIcon(context, true);
    }

    Calendar c = Calendar.getInstance();
    c.setTimeInMillis(alarm.time);
    String timeString = formatDayAndTime(context, c);
    saveNextAlarm(context, timeString);
} 
else 
{
    if(UtilsAlarm.isLollipopOrLater())
    {
        am.cancel(operation);
    }
    else
    {
        am.cancel(sender);
        setStatusBarIcon(context, false);
    }

    saveNextAlarm(context, "");
}

Intent i = new Intent(NEXT_ALARM_TIME_SET);
context.sendBroadcast(i); }

因此,如果我们的版本低于Lollipop,它仍然可以正常运行。但是,对于Lollipop设备,启用警报时会显示图标,但如果禁用它(并且没有启用其他警报),则当前会从下一个警报(预期结果)中取消该图标,但图标仍然存在于通知栏。

任何人都知道这个问题吗?

Thansk的帮助。

2 个答案:

答案 0 :(得分:2)

您的问题在int flags = alarm == null ? PendingIntent.FLAG_NO_CREATE : 0;

您告诉系统将null分配给PendingIntent operation,因为您之前使用此方法时已经存在相应的意图(请参阅FLAG_NO_CREATE的文档)。

稍后当您致电am.cancel(operation);时完全没有任何影响,因为operation == null。您的警报仍在系统中注册。警报响起时没有任何反应的唯一原因是您取消了上一行中的意图(而不是警报):PendingIntent sender = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);。因此,当您说“它当前已从下一个警报(预期结果)中取消”时,您的断言是错误的。警报没有取消;只是它的意图被取消了。

我建议你使用FLAG_UPDATE_CURRENT。

答案 1 :(得分:1)

我已经解决了在广播呼叫中将PendingIntent.FLAG_CANCEL_CURRENT更改为PendingIntent.FLAG_UPDATE_CURRENT

相关问题