我有一个方法来设置我想要触发闹钟的时间。在这个方法中,我还获得了一个取消警报的停止按钮
if(alarmManager != null){
alarmManager.cancel(pi);
}我的问题是,当我设置闹钟时,走出应用程序,然后再次进入取消闹钟,我得到了一个nullPointer。我猜这是因为当我离开应用程序时,PendingIntent也会关闭(设置为空)。
我如何防止这种情况发生,以便我可以取消警报?
下面是整个方法:
@SuppressWarnings("deprecation")
public void setTime(){
Calendar mcurrentTime = Calendar.getInstance();
int hour = mcurrentTime.get(Calendar.HOUR_OF_DAY);
int minute = mcurrentTime.get(Calendar.MINUTE);
TimePickerDialog mTimePicker;
mTimePicker = new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener()
{
int callCount = 0; //To track number of calls to onTimeSet()
@Override
public void onTimeSet(TimePicker timePicker, int selectedHour, int selectedMinute)
{
if(callCount == 1) // On second call
{
String timeString = "";
timeString = selectedHour + ":" + selectedMinute + ":00";
Log.d("TEST", "Chosen time : "+ timeString);
setAlarm(timePicker, selectedHour, selectedMinute);
}
callCount++; // Incrementing call count.
}
}, hour, minute, true);
mTimePicker.setButton(DialogInterface.BUTTON_POSITIVE, "Set", mTimePicker);
mTimePicker.setButton(DialogInterface.BUTTON_NEGATIVE, "Stop", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
if(alarmManager != null){
alarmManager.cancel(pi);
}
}
});
mTimePicker.setTitle(R.string.time);
mTimePicker.show();
}发布于 2014-10-23 18:27:31
您可以将用于构建PendingIntent的数据保存在如here所示的包中
因此,当您再次打开您的应用程序时,您将能够重建PendingIntent,并在需要时取消警报。
编辑:首先,您必须覆盖onSaveInstanceState并保存用于创建PendingIntent对象的数据,如下所示:
@Override
public void onSaveInstanceState(Bundle savedInstanceState) {
// Save the pending intent id
savedInstanceState.putInt(PENDING_INTENT_ID, mPendingIntentId);
// Always call the superclass so it can save the view hierarchy state
super.onSaveInstanceState(savedInstanceState);
}之后,在您的onCreate方法中,将检查savedInstanceState是否不为空。如果不为null,则从savedInstanceState (捆绑包)对象恢复项目,如下所示
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); // Always call the superclass first
// Check whether we're recreating a previously destroyed instance
if (savedInstanceState != null) {
// Restore value of members from saved state
mPendingIntentId = savedInstanceState.getInt(PENDING_INTENT_ID);
} else {
// Probably initialize members with default values for a new instance
mPendingIntentId = YOUR_DEFAULT_INT_VALUE;
}
mPendingIntent = PendingIntent.getBroadcast(this, mPendingIntentId, YOUR_INTENT, PendindIntent.FLAG_UPDATE_CURRENT);
}PendingIntent将在您每次进入应用程序时重新创建,因此您将能够取消在上一步中触发的相同警报。
编辑2:在您的案例中,另一种方法是,因为您只有一个警报,并且它的id总是相同的(应该用于PendingIntent的requestId),所以无论何时您想要添加或取消警报,都可以简单地重新创建PendingIntent。像下面这样的方法会帮助你解决这个问题。
private PendingIntent getPendingIntent(Context context){
return PendingIntent.getBroadcast(context, 0, new Intent(context, YourBroadcastReceiver.class), PendingIntent.FLAG_CANCEL_CURRENT);
}https://stackoverflow.com/questions/26525731
复制相似问题