4

私は、ウェブサイトへの呼び出し、応答の確認、新しい何かがあるかどうかの通知で構成される「単純な」通知機能をコーディングしています。

Service を使用して http 操作を実行していますが、AlarmManager に Service の呼び出しを特定の頻度で繰り返してもらいたいと考えています。私はこのようなチュートリアルや他の例をチェックしてきました.ユーザーが設定画面を離れるたびに(これまでに唯一のアクティビティ)、BOOTが完了した後にサービスをスケジュールしたいので、クラスを作成しましたスケジューリング コードをラップします。

public class Scheduler {

public static boolean cancelScheduledService(Context ctx, Intent serviceIntent) {
    boolean success = true;
    Log.v("novUmbria", "Scheduler.cancelScheduledService");
    try {
        AlarmManager am = (AlarmManager) ctx.getSystemService(Context.ALARM_SERVICE);
        am.cancel(
                PendingIntent.getBroadcast(
                        ctx, 0,
                        new Intent(ctx, NotificadorService.class),
                        // si ya existe, no genera un 2º
                        PendingIntent.FLAG_CANCEL_CURRENT
                        )

                );
        Log.v("novUmbria", "Scheduler.cancelScheduledService Servicio cancelado");
    } catch (Exception e) {
        Log.e("novUmbria", "Scheduler.cancelScheduledService Excepción: " + e.getMessage());
        success = false;
    }
    return success;
}

public static boolean scheduleService(Context ctx, Intent serviceIntent, long interval) {
    boolean success = true;
    Log.v("novUmbria", "Scheduler.scheduleService Servicio ");
    try {
        Calendar cal = Calendar.getInstance();
        SimpleDateFormat timeformat = new SimpleDateFormat("HH:mm");
        // timeformat.setTimeZone(TimeZone.getTimeZone("Europe/Madrid"));

        AlarmManager am = (AlarmManager) ctx.getSystemService(Context.ALARM_SERVICE);
        am.setRepeating(
                // am.setInexactRepeating(
                // AlarmManager.ELAPSED_REALTIME_WAKEUP,
                AlarmManager.RTC_WAKEUP,
                cal.getTimeInMillis(),
                interval,
                PendingIntent.getBroadcast(
                        ctx, 0,
                        new Intent(ctx, NotificadorService.class),
                        // si ya existe, no genera un 2º
                        PendingIntent.FLAG_CANCEL_CURRENT
                        )

                );
        Log.v("novUmbria", "Scheduler.scheduleService Servicio programado a las "
                + timeformat.format(cal.getTime())
                + " cada " + (interval / 60000) + " minutos"
                );

        startService(ctx, serviceIntent);
        Log.v("novUmbria", "Scheduler.scheduleService Servicio iniciado"
                );

    } catch (Exception e) {
        Log.e("novUmbria", "Scheduler.scheduleService Excepción: " + e.getMessage());
        success = false;
    }
    return success;
}

public static boolean startService(Context ctx, Intent serviceIntent) {
    boolean success = true;
    Log.v("novUmbria", "Scheduler.startService");
    try {
        ctx.startService(serviceIntent);
        Log.v("novUmbria", "Scheduler.startService Servicio iniciado");
    } catch (Exception e) {
        Log.e("novUmbria", "Scheduler.startService Excepción: " + e.getMessage());
        success = false;
    }
    return success;
}

}

設定アクティビティからのスケジューラへの呼び出しは次のとおりです

//Settings Activity
 @Override
protected void onStop() {
    Log.v("novUmbria", "SettingsActivity.onStop");
    Intent serviceIntent = new Intent(getApplicationContext(), NotificadorService.class);
    Scheduler.cancelScheduledService(getApplicationContext(), serviceIntent);
    long frequency = 1000 * 60 / 2;
    Scheduler.scheduleService(getApplicationContext(),
            serviceIntent,
            frequency
            );
    Log.v("novUmbria", "SettingsActivity.onStop scheduleService");
    super.onStop();
}

つまり、logcat は、サービスがスケジュールされ (または、より適切に言えば、例外を発生させない)、初めて実行されることを教えてくれます。しかし、その後は間隔が長くても短くても二度と繰り返されません。RTC、RTC_WAKEUP、ELAPSED_REALTIME などのいくつかのフラグを試しましたが、何も得られませんでした。

私のテスト デバイスは完全に更新された Nexus 4 です。再起動したので、BOOT_COMPLETE レシーバーが正常に動作することを確認しましたが、サービス呼び出しが繰り返されることはありません。

どこに問題があるかについてのアイデアはありますか?

前もって感謝します。

4

1 に答える 1