0

私はこのコードを使用しており、発火するまでの時間が経過しても発火する時間が残っているため、AlarmManager はすぐに発火します。ログに出力しているので、確認できます。

public void SetAlarm(Context context, Date date, List<String> temp) {

    Log.d("Alarm Set", "Entered");
    Log.d("Alarm Set", date.getHours() + " " + date.getMinutes());

    AlarmManager am = (AlarmManager) context
            .getSystemService(Context.ALARM_SERVICE);

    Intent i = new Intent(context, Alarm.class);
    i.putStringArrayListExtra("list", (ArrayList<String>) temp);

    PendingIntent pi = PendingIntent.getBroadcast(context, 0, i,
            PendingIntent.FLAG_ONE_SHOT);
    date.setMinutes(date.getMinutes() - 5);

    Calendar rightNow = Calendar.getInstance();
    long offset = rightNow.get(Calendar.ZONE_OFFSET)
            + rightNow.get(Calendar.DST_OFFSET);
    long sinceMidnight = (rightNow.getTimeInMillis() + offset)
            % (24 * 60 * 60 * 1000);

    long time_in_milis = (1000 * 60 * ((date.getHours() * 60) + date
            .getMinutes())) - sinceMidnight;
    Log.d("Alarm Time in Mili Seconds", "" + time_in_milis);

    am.set(AlarmManager.RTC_WAKEUP, time_in_milis * 10000, pi);
}
4

1 に答える 1

1

私があなたのコードを正しく読んでいれば、time_in_milis[sic] を時差として計算していることになります。ただし、set()絶対タイムスタンプが必要です。

言い換えれば、かなり低いタイムスタンプを提供しているため、過去にアラームを効果的にスケジュールできます。

簡単なテスト シナリオの場合は、合格してみてください -- 約 1 分後にアラームが起動するはずです (が不正確なアラームを設定System.currentTimeMillis() + 60000していることを思い出してください)。set()

于 2015-11-05T22:43:54.390 に答える