3

我正在尝试使用相对简单的解决方案在启动时执行一些代码。基本上我想在启动时安排/重新安排警报以在将来执行某个任务。

在我的清单中,我有:

<uses-permission android:name="com.android.alarm.permission.SET_ALARM"/>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />

<receiver android:name="com.cswt.lcyairport.alarm.AlarmReceiver">
     <intent-filter>
          <action android:name="android.intent.action.BOOT_COMPLETED"/>
     </intent-filter>
</receiver>

我的代码:

@Override
public void onReceive(Context context, Intent intent) {
    this.context = context;

    String action = intent.getAction();
    if (action.equals(Intent.ACTION_BOOT_COMPLETED)) {

        // Setup alarm
        scheduleAlarm();

        //Intent pushIntent = new Intent(context, MainActivity.class); 
        //pushIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        //context.startActivity(pushIntent);

    }

}

private void scheduleAlarm() {
    long interval = 10*1000;

    Intent intentAlarm = new Intent(AlarmReceiver.ACTION_GO_TO_GATE);

    PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intentAlarm, PendingIntent.FLAG_UPDATE_CURRENT);

    AlarmManager alarmManager = (AlarmManager)       context.getSystemService(Context.ALARM_SERVICE);
    alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, 10000, interval, pendingIntent);
}

如果我取消注释代码以启动活动,它会很好地工作,并且我看到 BOOT_COMPLETED 被我的接收器捕获。但是,尝试启动警报不起作用(也尝试显示通知但它不起作用)。我该如何解决这个问题?

4

3 回答 3

2

您必须使用不同的请求代码并将它们保存在某处以便在设备重新启动后再次使用。您必须使用与 PendingIntent 设置警报相同的请求代码。然后它会在重新启动后工作。而且您还必须确保不再使用请求代码,因为假设您设置了一个带有请求代码 0 和 PendingIntent 的警报,那么如果您设置另一个警报请求代码 0,那么您之前的警报将被更新的警报替换一。因此,您不会收到第一个警报。

编辑:使用以下代码段设置警报

public void SetAlarm(Calendar calendar, int reqCode) { 

 String dateName = idea.getText().toString(); String dateNote = 
 note.getText().toString(); Log.d("SetAlarm Texts", "Date : " + dateName + " 
 Note: " + dateNote);

Intent myIntent = new Intent(mActivity, AlarmReceiver.class);

myIntent.putExtra("title", "Her : " + dateName);

myIntent.putExtra("notes", dateNote);

myIntent.putExtra("code", reqCode);

PendingIntent pendingIntent = PendingIntent.getBroadcast(mActi vity, reqCode, myIntent, 0); 

AlarmManager alarmManager = (AlarmManager) mActivity.getSystemService(Context.ALARM_ SERVICE);

alarmManager.set(AlarmManager.RT C, calendar.getTimeInMillis(), pendingIntent);

}
于 2013-10-18T04:57:37.080 回答
1

在使用 getService、getActivity 或 getBroadCast 创建待处理意图时,您必须使用标志 FLAG_UPDATE_CURRENT。这样它才能保持当前待处理的意图。它不会替换它。请参考此链接http://developer.android.com/reference/android/ app/PendingIntent.html#FLAG_UPDATE_CURRENT

Intent in = new Intent(arg0, Myservice.class);
PendingIntent pin = PendingIntent.getService(arg0, 0, in,PendingIntent.FLAG_UPDATE_CURRENT);
Calendar cal = Calendar.getInstance();
cal.setTimeInMillis(System.currentTimeMillis() + 1000 * 60);
AlarmManager am = (AlarmManager) arg0.getApplicationContext().getSystemService(arg0.ALARM_SERVICE);
am.setRepeating(AlarmManager.RTC, cal.getTimeInMillis(), 30 * 1000, pin);
于 2014-06-25T18:35:34.890 回答
0

您是否在清单中添加了必要的权限??

<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
于 2013-10-18T04:47:43.230 回答