public int onStartCommand(Intent intent, int flags, int startId) {
...
for (int i = 1; i < dayStore.getInt("lessonCount" , 0)+1; i++) {
String lesson = dayStore.getString("Lesson" + i , "null");
String lessonWithoutTime = (lesson.substring(6, lesson.length()-6)).replace(".", "");
String lessonTitleRaw = lessonWithoutTime.split(" ")[0];
String lessonTitle = lessonTitleRaw.replace(".", "");
String startTime = lesson.substring(0, 5);
//---------------------------------------------------
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY, Integer.parseInt(startTime.substring(0,2)));
calendar.set(Calendar.MINUTE, 0);
calendar.add(Calendar.MINUTE, Integer.parseInt(startTime.substring(3,5))-5);
Intent notifications = new Intent(this, StartNotification.class);
notifications.putExtra("LessonTitle", lessonTitle);
notifications.putExtra("StartTime", startTime);
PendingIntent pendingNotifications = PendingIntent.getService(this, 0, notifications, 0);
AlarmManager startNotif = (AlarmManager) this.getSystemService(Context.ALARM_SERVICE);
startNotif.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), pendingNotifications);
}
stopSelf();
return super.onStartCommand(intent, flags, startId);
}
因此,在上面的代码中,它经历了一个“ for i”循环,在此循环中,它为每节课的开始创建一个AlarmManager。当AlarmManager停止运行时,它将打开一个名为“ StartNotification”的服务,该服务将发出这样的通知...
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.main_icon)
.setContentTitle(lesson)
.setTicker(lesson + " starts in 5 minutes")
.setContentText(lesson + " from " + startTime + " to " + endTime);
mBuilder.setDefaults(Notification.DEFAULT_LIGHTS);
mBuilder.setDefaults(Notification.DEFAULT_VIBRATE);
NotificationManager mNotificationManager = (NotificationManager) this.getSystemService(this.NOTIFICATION_SERVICE);
mNotificationManager.notify(1, mBuilder.build());
stopSelf();
问题是AlarmManager不起作用,或者日历可能有问题。因为当我将其更改为此
startNotif.set(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 1000, pendingNotifications);
(来自calendar.getTimeInMillis
-> System.currentTimeMillis() + 1000
)时,它工作正常,但仅适用于第一个警报。尽管您认为所有警报/通知(在这种情况下为5)会同时(在1000台磨机中)发出,但只有第一个警报/通知会发出。我知道所有警报都已设置,因为我已经广泛使用Log.D:s。
日历具有正确的毫秒数,我已经通过许多不同的方式进行了检查。
这些是我的许可:
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.CLEAR_APP_CACHE"/>
<uses-permission android:name="com.android.alarm.permission.SET_ALARM"/>
和服务:
<service android:enabled="true" android:name=".Notifications" />
<service android:enabled="true" android:name=".StartNotification" />
...
最佳答案
首先,您需要更改创建PendingIntent
的行。问题是您正在创建具有某些待定意图的第一个警报,而在第二个循环(要为第二课创建警报)上,您正在使用相同的待定意图,依此类推。
当对两个不同的警报使用相同的挂起意图时,将仅设置最后一个警报,然后触发该警报,并从系统中删除前一个警报。
5个课程中的每一个都需要不同的待定意图。在您的情况下,您需要使用不同的requestCode
,因为您的intents
相同(PendingIntent不会比较其他字符)。简单的解决方案可能是传递i
循环的整数for
。
PendingIntent pendingNotifications = PendingIntent.getService(this, i, notifications, 0);
您还需要考虑重置这些警报的频率。如果您认为可能在最近的将来再次设置相同课程的警报,请考虑使用
flags
挂起的意图。原因是更新现有的挂起的意图或使用旧的意图,但是重置时间等等。因此,也请考虑一下。日历对象的代码似乎很好。只需确保(使用日志)从字符串获取它们所设置的分钟和小时是正确的。也许您也可以尝试下面的代码来获取特定于语言环境的时间。
Calendar calendar = Calendar.getInstance(TimeZone.getDefault());