Android: как использовать AlarmManager

Мне нужно запустить блок кода через 20 минут после установки AlarmManager.

Может ли кто-нибудь показать мне пример кода о том, как использовать AlarmManager в Android?

Я играю с некоторым кодом в течение нескольких дней, и он просто не работает.

Ответ 1

"Некоторые примеры кода" не так просто, когда дело доходит до AlarmManager.

Вот фрагмент, показывающий настройку AlarmManager:

AlarmManager mgr=(AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
Intent i=new Intent(context, OnAlarmReceiver.class);
PendingIntent pi=PendingIntent.getBroadcast(context, 0, i, 0);

mgr.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime(), PERIOD, pi);

В этом примере я использую setRepeating(). Если вам нужен сигнал с одним выстрелом, вы просто используете set(). Обязательно укажите время запуска будильника в той же временной базе, что и исходный параметр, в set(). В моем примере выше я использую AlarmManager.ELAPSED_REALTIME_WAKEUP, поэтому моя база времени SystemClock.elapsedRealtime().

Вот более крупный пример проекта, демонстрирующий эту технику.

Ответ 2

Есть несколько хороших примеров в коде примера Android.

.\Android-SDK\Samples\андроид-10\ApiDemos\SRC\COM\например\Android\APIs\приложение

Для проверки:

  • AlarmController.java
  • OneShotAlarm.java

Сначала вам нужен приемник, который может прослушивать ваш сигнал тревоги при его срабатывании. Добавьте в свой файл AndroidManifest.xml следующее:

<receiver android:name=".MyAlarmReceiver" />

Затем создайте следующий класс

public class MyAlarmReceiver extends BroadcastReceiver { 
     @Override
     public void onReceive(Context context, Intent intent) {
         Toast.makeText(context, "Alarm went off", Toast.LENGTH_SHORT).show();
     }
}

Затем, чтобы вызвать будильник, используйте следующее (например, в своем основном действии):

AlarmManager alarmMgr = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(this, MyAlarmReceiver.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0);
Calendar time = Calendar.getInstance();
time.setTimeInMillis(System.currentTimeMillis());
time.add(Calendar.SECOND, 30);
alarmMgr.set(AlarmManager.RTC_WAKEUP, time.getTimeInMillis(), pendingIntent);

.


Или, еще лучше, создайте класс, который обрабатывает все это и использует его следующим образом

Bundle bundle = new Bundle();
// add extras here..
MyAlarm alarm = new MyAlarm(this, bundle, 30);

Таким образом, у вас есть все в одном месте (не забудьте отредактировать AndroidManifest.xml)

public class MyAlarm extends BroadcastReceiver {
    private final String REMINDER_BUNDLE = "MyReminderBundle"; 

    // this constructor is called by the alarm manager.
    public MyAlarm(){ }

    // you can use this constructor to create the alarm. 
    //  Just pass in the main activity as the context, 
    //  any extras you'd like to get later when triggered 
    //  and the timeout
     public MyAlarm(Context context, Bundle extras, int timeoutInSeconds){
         AlarmManager alarmMgr = 
             (AlarmManager)context.getSystemService(Context.ALARM_SERVICE);
         Intent intent = new Intent(context, MyAlarm.class);
         intent.putExtra(REMINDER_BUNDLE, extras);
         PendingIntent pendingIntent =
             PendingIntent.getBroadcast(context, 0, intent, 
             PendingIntent.FLAG_UPDATE_CURRENT);
         Calendar time = Calendar.getInstance();
         time.setTimeInMillis(System.currentTimeMillis());
         time.add(Calendar.SECOND, timeoutInSeconds);
         alarmMgr.set(AlarmManager.RTC_WAKEUP, time.getTimeInMillis(),
                      pendingIntent);
     }

      @Override
     public void onReceive(Context context, Intent intent) {
         // here you can get the extras you passed in when creating the alarm
         //intent.getBundleExtra(REMINDER_BUNDLE));

         Toast.makeText(context, "Alarm went off", Toast.LENGTH_SHORT).show();
     }
}

Ответ 3

Что вам нужно сделать, сначала создайте намерение, которое вам нужно запланировать. Затем получите ожидаемое действие этого намерения. Вы можете планировать мероприятия, услуги и трансляции. Чтобы запланировать действие, например MyActivity:

  Intent i = new Intent(getApplicationContext(), MyActivity.class);
  PendingIntent pi = PendingIntent.getActivity(getApplicationContext(),3333,i,
  PendingIntent.FLAG_CANCEL_CURRENT);

Отдайте этот ожидающий запрос alarmManager:

  //getting current time and add 5 seconds in it
  Calendar cal = Calendar.getInstance();
  cal.add(Calendar.SECOND, 5);
  //registering our pending intent with alarmmanager
  AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);
  am.set(AlarmManager.RTC_WAKEUP,cal.getTimeInMillis(), pi);

Теперь MyActivity будет запущен через 5 секунд после запуска приложения, независимо от того, остановите свое приложение или устройство в состоянии сна (из-за опции RTC_WAKEUP). Вы можете прочитать полный код примера Планирование действий, служб и трансляций #Android

Ответ 4

Я хотел прокомментировать, но < 50 rep, так что здесь. Дружелюбное напоминание о том, что если вы используете 5.1 или выше, и вы используете интервал менее минуты, это происходит:

Suspiciously short interval 5000 millis; expanding to 60 seconds

Смотрите здесь.

Ответ 5

Некоторые примеры кода, если вы хотите вызвать службу из Alarmmanager:

PendingIntent pi;
AlarmManager mgr;
mgr = (AlarmManager)ctx.getSystemService(Context.ALARM_SERVICE);
Intent i = new Intent(DataCollectionActivity.this, HUJIDataCollectionService.class);    
pi = PendingIntent.getService(DataCollectionActivity.this, 0, i, 0);
mgr.setRepeating(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime() , 1000, pi);

Вам не нужно запрашивать пользовательские сообщения.