私は今、途方に暮れています。
私のアプリケーションでは、ユーザーは希望する曜日と時間を選択してアラームを設定できます。
以下の関数は、ルール セットをチェックし、時間基準を持つルールを探します。その場合、選択した日ごとにアラームが設定され、繰り返し (7 日ごと) に設定されます。
複数のアラーム (単一のアラームとは対照的) の意味について、かなりの数の投稿を読みました。私は次のことを考慮したと思います:
- すべてのアラームに新しいインテントを使用する - すべてのアラーム
に新しい PendingIntent を使用する
- すべてのアラームに異なるリクエスト コードを使用する
要求コードは ArrayList に収集されるため、プログラムの終了時に別の関数がすべてのアラームをクリアできます。
問題は、アラームが鳴らないことです。エラーをこの関数まで追跡することができました。AlarmManager インスタンスは問題ありません。一番下(アスタリスクのある行の後)にテストアラームを設定しています。それが発火します。どうして???
clearAlarms();
int i=0;
ArrayList<Rule> allRulesWithTimeFrames = new ArrayList<Rule>();
allRulesWithTimeFrames = Rule.findRuleCandidatesByTimeFrame();
for(Rule oneRule : allRulesWithTimeFrames)
{
for(Trigger oneTrigger : oneRule.getTriggerSet())
{
if(oneTrigger.getTriggerType() == Event_Enum.timeFrame)
{
Calendar calNow, calSet;
Time setTime;
if(oneTrigger.getTriggerParameter())
setTime = oneTrigger.getTimeFrame().getTriggerTimeStart();
else
setTime = oneTrigger.getTimeFrame().getTriggerTimeStop();
calNow = Calendar.getInstance();
calSet = (Calendar) calNow.clone();
calSet.set(Calendar.HOUR_OF_DAY, setTime.getHours());
calSet.set(Calendar.MINUTE, setTime.getMinutes());
calSet.set(Calendar.SECOND, 0);
calSet.set(Calendar.MILLISECOND, 0);
// At this point calSet would be a scheduling candidate. It's just the day the might not be right, yet.
long milliSecondsInAWeek = 1000 * 60 * 60 * 24 * 7;
for(int dayOfWeek : oneTrigger.getTimeFrame().getDayList())
{
// --------------------
// Here's a lot of code I will spare you. It only changes
// the variable calSetWorkingCopy.
// --------------------
SimpleDateFormat sdf = new SimpleDateFormat("E dd.MM.yyyy HH:mm");
i++;
String calSetWorkingCopyString = sdf.format(calSetWorkingCopy.getTime()) + " RequestCode: " + String.valueOf(i);
Miscellaneous.logEvent("i", "AlarmManager", "Setting repeating alarm because of rule: " + oneRule.getName() + " beginning at " + calSetWorkingCopyString);
Intent alarmIntent = new Intent(automationServiceRef, AlarmListener.class);
PendingIntent alarmPendingIntent = PendingIntent.getBroadcast(automationServiceRef, i, alarmIntent, 0);
centralAlarmManagerInstance.setInexactRepeating(AlarmManager.RTC_WAKEUP, calSetWorkingCopy.getTimeInMillis(), milliSecondsInAWeek, alarmPendingIntent);
requestCodeList.add(i);
}
}
}
}
// ************* The below code is working *************
// get a Calendar object with current time
Calendar cal = Calendar.getInstance();
// add 5 minutes to the calendar object
cal.add(Calendar.SECOND, 10);
SimpleDateFormat sdf2 = new SimpleDateFormat("E dd.MM.yyyy HH:mm");
String calSetWorkingCopyString2 = sdf2.format(cal.getTime());
Miscellaneous.logEvent("i", "AlarmManager", "Setting repeating alarm because of hardcoded test: beginning at " + calSetWorkingCopyString2);
Intent alarmIntent2 = new Intent(automationServiceRef, AlarmListener.class);
PendingIntent alarmPendingIntent2 = PendingIntent.getBroadcast(automationServiceRef, 0, alarmIntent2, 0);
centralAlarmManagerInstance.setInexactRepeating(AlarmManager.RTC_WAKEUP, cal.getTimeInMillis(), 5000, alarmPendingIntent2);
requestCodeList.add(0);