Андроид:Как использовать AlarmManager
-
23-08-2019 - |
Вопрос
Мне нужно запустить блок кода через 20 минут после AlarmManager
устанавливается.
Может ли кто-нибудь показать мне пример кода о том, как использовать AlarmManager
в ِAndroid?
Я несколько дней играл с кодом, и он просто не работал.
Решение
«Некоторый пример кода» не так уж и прост, когда дело доходит до 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()
.
Вот более крупный пример проекта демонстрация этой техники.
Другие советы
В примере кода Android есть несколько хороших примеров.
.\android-sdk\samples\android-10\ApiDemos\src\com\example\android\apis\app
Стоит проверить:
- 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();
}
}
Что вам нужно сделать, так это сначала создать намерение, которое нужно запланировать.Затем получите pendingIntent этого намерения.Вы можете планировать мероприятия, услуги и трансляции. Чтобы запланировать действие, например 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
Я хотел прокомментировать, но <50 представителей, так что начнем.Дружеское напоминание: если вы используете версию 5.1 или выше и используете интервал менее минуты, происходит следующее:
Suspiciously short interval 5000 millis; expanding to 60 seconds
Видеть здесь.
Пример кода, когда вы хотите вызвать службу из 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);
Вам не нужно спрашивать разрешения пользователя.