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());

07-24 09:49
查看更多