Reorganizuję kod, aby moja aplikacja pobierała dane ze strony internetowej raz dziennie o określonej godzinie. Z moich badań wynika, że najbardziej odpowiednim podejściem jest AlarmManager
.AlarmManager, BroadcastReceiver i usługa nie działa
Tutorial śledzę to: http://mobile.tutsplus.com/tutorials/android/android-fundamentals-downloading-data-with-services/
Dotychczas AlarmManager
i BroadcastReceiver
wydają się działać, jednak Service
nigdy nie wydaje się uruchomić (tj. onStartCommand
nie wydaje się być nazywany)
Oto istotne fragmenty kodu mam tak daleko:
MyActivity.java
private void setRecurringAlarm(Context context) {
Calendar updateTime = Calendar.getInstance();
updateTime.setTimeZone(TimeZone.getDefault());
updateTime.set(Calendar.HOUR_OF_DAY, 20);
updateTime.set(Calendar.MINUTE, 30);
Intent downloader = new Intent(context, AlarmReceiver.class);
downloader.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, downloader, PendingIntent.FLAG_CANCEL_CURRENT);
AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
// should be AlarmManager.INTERVAL_DAY (but changed to 15min for testing)
alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, updateTime.getTimeInMillis(), AlarmManager.INTERVAL_FIFTEEN_MINUTES, pendingIntent);
Log.d("MyActivity", "Set alarmManager.setRepeating to: " + updateTime.getTime().toLocaleString());
}
AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent dailyUpdater = new Intent(context, MyService.class);
context.startService(dailyUpdater);
Log.d("AlarmReceiver", "Called context.startService from AlarmReceiver.onReceive");
}
}
MyService.java
public class MyService extends Service {
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.d("MyService", "About to execute MyTask");
new MyTask().execute();
return Service.START_FLAG_REDELIVERY;
}
@Override
public IBinder onBind(Intent intent) {
return null;
}
private class MyTask extends AsyncTask<String, Void, boolean> {
@Override
protected boolean doInBackground(String... strings) {
Log.d("MyService - MyTask", "Calling doInBackground within MyTask");
return false;
}
}
}
AndroidManifest.xml
<application ...>
...
<service android:name="MyService"></service>
<receiver android:name="AlarmReceiver"></receiver>
</application>
Kiedy tr igger the setRecurringAlarm
w MyActivity
log zostanie wydrukowany zgodnie z oczekiwaniami, podobnie, co 15 minut pojawi się log z AlarmReceiver
. Jednak nie widzę dziennik z MyService
:(
przykładem tego, co widzę w dziennikach:
DEBUG/MyActivity(688): Set alarmManager.setRepeating to: Jan 29, 2012 8:30:06 PM
DEBUG/AlarmReceiver(688): Called context.startService from AlarmReceiver.onReceive
DEBUG/AlarmReceiver(688): Called context.startService from AlarmReceiver.onReceive
nie może wydawać się, aby dowiedzieć się, co zrobiłem źle - moje rozumienie ze Android Dev Docs jest to, że w AlarmReceiver
gdy zgłoszę context.startService(dailyUpdater)
które powinny z kolei wezwanie onStartCommand
w MyService
, chociaż nie wydaje się być przypadek!
Co robię źle, że jest przyczyną MyService
aby nie zacząć
+1 Dzięki kod mi pomóc .. – Nirali
Ty również uruchomiony w nieoczywistych zachowań blokada wybudzenia z usług począwszy od odpowiedzi na alarmy. Jest kilka szczegółów i rekomendacji w odpowiedziach na http://stackoverflow.com/questions/25852309/does-alarmmanager-require-the-pendingintent-to-be-of-type-broadcastreceiver – ctate