Мне нужно запустить блок кода через 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
Стоит проверить:
Во-первых, вам нужен приемник, который может прослушивать ваш будильник, когда он срабатывает. Добавьте в файл 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);
Передайте это pendingIntent в 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
Пример кода, если вы хотите вызвать службу из 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);
Вам не нужно спрашивать разрешения пользователя.
AlarmManager используется для запуска некоторого кода в определенное время.
Чтобы запустить диспетчер аварийных сигналов, вам необходимо сначала получить экземпляр из системы. Затем передайте PendingIntent, который будет выполнен в указанное вами время в будущем.
AlarmManager manager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
Intent alarmIntent = new Intent(context, MyAlarmReceiver.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, alarmIntent, 0);
int interval = 8000; //repeat interval
manager.setInexactRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(), interval, pendingIntent);
Будьте осторожны при использовании Alarm Manager. Обычно диспетчер сигналов тревоги не может повториться раньше, чем через минуту. Также в режиме низкого энергопотребления продолжительность может увеличиваться до 15 минут.