IntentService, который запускается AlarmManager, не работает - PullRequest
2 голосов
/ 03 марта 2012


Я пытаюсь запустить IntentService с помощью AlarmManager, но служба не запущена. (Очевидно, мой сервис определен в манифесте ...)
Вот немного кода:

Запуск службы сигнализации:

    Intent myIntent = new Intent(Main.this, TestsNotification.class);
    PendingIntent pendingIntent = PendingIntent.getService(Main.this, 0, myIntent, 0);
             AlarmManager alarmManager = (AlarmManager)getSystemService(ALARM_SERVICE);
             Calendar calendar = Calendar.getInstance();
             calendar.setTimeInMillis(System.currentTimeMillis());
             calendar.set(Calendar.HOUR_OF_DAY, 15);
             alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), AlarmManager.INTERVAL_DAY, pendingIntent);

Вот мой IntentService:

public class TestsNotification extends IntentService {
    public TestsNotification() {
        super("myApp");
    }
    private SharedPreferences settings;
    private final String PREFERENCE_SETTINGS_FILENAME = "Settings";
    private int number=0;
    Tests tests;
@Override
public void onCreate() {
 // TODO Auto-generated method stub
    settings = getSharedPreferences(PREFERENCE_SETTINGS_FILENAME, MODE_PRIVATE);
    tests=new Tests();
}

@Override
public IBinder onBind(Intent intent) {
 // TODO Auto-generated method stub
 return null;
}

@Override
public void onDestroy() {
 // TODO Auto-generated method stub
 super.onDestroy();
}

@Override
public void onStart(Intent intent, int startId) {
 // TODO Auto-generated method stub
 super.onStart(intent, startId);
}

@Override
public boolean onUnbind(Intent intent) {
 // TODO Auto-generated method stub
 return super.onUnbind(intent);
}
public void Notify(String title)
{
    NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
    Intent intent= new Intent (this,Splash.class);
    PendingIntent pi = PendingIntent.getActivity(this, 0, intent, 0);
    String body = " בליך";
    //String title = "יש מחר מבחן!";
    Notification n =new Notification(R.drawable.test, body, System.currentTimeMillis());
    n.flags |=Notification.FLAG_AUTO_CANCEL;
    n.setLatestEventInfo(getApplicationContext(), title, body, pi);
    n.defaults = Notification.DEFAULT_ALL;
    number++;
    n.number=number;
    try {
    nm.notify(0,n);
    FileMethods FM = new FileMethods(this);
    Date current = new Date();
    FM.Write("LOG", "I Dont Care!",FM.Read("LOG", this, "") + current.getDay()+"/"+current.getMonth()+"/"+ current.getYear()+" "+current.getHours()+":"+current.getMinutes() + "Notified" + title+ "\n");
    }
    catch (Exception e) {
        e.printStackTrace();
    }
}
@Override
protected void onHandleIntent(Intent intent) {
    // TODO Auto-generated method stub
    String Attribute = "Class";
    String info = settings.getString(Attribute, "none");
    if(!info.equals("none")) {
        String classLetter = info.substring(0, info.lastIndexOf(" "));
        String classNum1 = info.substring(info.lastIndexOf(" ")+1);
        int classNum = Integer.parseInt(classNum1);
        try {
            Tests nextTest = this.tests.GetTests(classLetter, classNum)[0];
            Date current = new Date();
            Date testDate = new GregorianCalendar(nextTest.getDate().getYear(), nextTest.getDate().getMonth(), Integer.parseInt(nextTest.getDate().getDay())).getTime();
            long difference = testDate.getTime()-current.getTime();
            if (difference <=86400000) {
                Notify("יש מחר מבחן!");
            }//SHOULDNT BE HARDCODED!!!
            else {
                Notify("אין מחר מבחן!!");
            }
        } catch (ClientProtocolException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}
}

FileMethods - это просто класс для обработки чтения и записи файлов (чтобы приложение AlarmManager запускалось каждые 1 день)

Спасибо !!

Ответы [ 2 ]

2 голосов
/ 03 марта 2012

Поскольку вы используете set(), есть вероятность 40%, что вы указали время, которое прошло в прошлом.

Кроме того, если устройство в то время спит, оно может снова заснуть до запуска службы. Существует очень специфическая схема успешного использования сигналов тревоги _WAKEUP, включающая BroadcastReceiver и WakeLock. Мой WakefulIntentService пытается выполнить часть этой работы для вас.

Кроме того, onStart() является устаревшим для некоторых и не должен быть реализован на IntentService.

0 голосов
/ 03 марта 2012

Вы переопределяете #onCreate() в вашем IntentService без вызова <b>super</b>.onCreate().Не делайте этого.

@Override
public void onCreate() {
    super.onCreate();
    settings = getSharedPreferences(PREFERENCE_SETTINGS_FILENAME, MODE_PRIVATE);
    tests=new Tests();
}

Базовая реализация IntentService выполняет множество необходимых настроек в этом методе (таких как инициализация исполнителя и еще много чего), необходимых для фактического вызова IntentService#onHandleIntent(Intent).

...