Форум программистов, компьютерный форум, киберфорум
Наши страницы
Программирование Android
Войти
Регистрация
Восстановить пароль
 
Nickomed
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 5
1

Не работает AlarmManager

11.11.2017, 18:42. Просмотров 402. Ответов 3

Хочу выводить уведомление "через заданное время". Использую AlarmManager, в PendingIntent кладу BroadcastReceiver, в котором уже вызываю уведомление. Проблема: оно не срабатывает, если я закрываю приложение не через аппаратную кнопку "домик", а захожу через аппаратную кнопку недавних приложений в список этих самых приложений - и убираю оттуда своё.

Немножко оффтопик:
Что пробовал:
  • .set()
  • .setExact()
  • .setExactAndAllowWhileIdle()
  • добавлять в белый список doze
  • Забыть про AlarmManager и (возможно) использовать JobScheduler, но в моём случае это не особо подошло.

Топик:
Нашёл на github простую рабочую реализацию AlarmManager'a (в 40 строк вся максимум), вот ссылка на неё. В этой самой реализации не нашёл ничего необычного: два обычных класса с двумя обычными методами. Но оно работает :D
Добавляет огонька то, что если я создам новый проект, создам в нём ТАКИЕ ЖЕ два класса, такой же манифест, то работать снова не будет.

Вопрос:
а) что не так в моей реализации (с копированием тех же файлов)? Возможно, я забываю прописать какие-то permissions, dependencies, gradle properties, ...?
б) если кому-то знакома описанная проблема в целом, то какие есть способы борьбы с ней?

P.S.: прошу прощения за "домик" и т.п. :)
P.P.S.: наверное, вопрос тупой, но я уже в отчаянии)
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.11.2017, 18:42
Ответы с готовыми решениями:

Не работает AlarmManager
Суть проблемы в том что когда заеться время уведомления в это время нет.... Тут код есть...

AlarmManager работает ли? Состояние
Как узнать состояние работающего (запущенного ) AlarmManager ? Добавлено через 2 минуты то...

AlarmManager не работает после закрытия приложения
Всем привет, сделал ресивер + нацепил туда alarm вот код в классе ресивера public void...

AlarmManager
Добрый вечер, как задать время вручную ? alarmManager.set(AlarmManager.RTC,...

AlarmManager
Всем привет. Взял код AlarmManager отсюда. В свой проект добавил AlarmManagerBroadcastReceiver.java...

3
vxg
Модератор
3278 / 2075 / 327
Регистрация: 13.01.2012
Сообщений: 8,055
12.11.2017, 07:40 2
Nickomed, у вас постоянно висящий сервис? Нет / убит - нет уведомления
0
Nickomed
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 5
12.11.2017, 10:38  [ТС] 3
vxg, спасибо за ответ!

Нет, сервис у меня не постоянно висящий, попробую переписать так. Дело в том, что я в принципе не пишу собственный класс - и не наследуюсь от Service. Есть ли какой-то вариант сделать его постоянно висящим в следующей реализации?

MainActivity.class В моём случае этот код вызывается, по сути, в onPause, но если его переписать в "более привычное" место (например, запускать просто по нажатию кнопки), поведение не меняется.
Java
1
2
3
4
intent = new Intent(this, NotificationSetter.class);
pendingIntent = PendingIntent.getBroadcast(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);
AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 5000, pendingIntent);
NotificationSetter.class В манифесте ресивер зарегистрирован.
Java
1
2
3
4
5
6
7
public class NotificationSetter extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.d("abc", "received");
        //setting a notification and doing smth else
    }
}
В логах ничего нет, да и оповещения не всплывают.
Я бы согласился с Вами, что лучше просто написать свой сервис - и сделать его sticky (вы же про это?), но у господина с гитхаба, про которого я писал, реализация, насколько мне понятно, такая же. С тем лишь отличием, что она рабочая

Добавлено через 2 часа 0 минут
UPD:

Проблема решена. Заработало то, что никак не должно было..)
Создал новый проект, скопировал туда все классы и ресурсы старого, переписал ручками манифест, все gradle-файлы, которые отображаются в студии, одинаковы в обоих проектах. Отличается только имя основного пакета и applicationId в build.gradle. Вроде бы ничего не должно поменяться, ан нет, всё как надо. Магия? Для меня магия.
Если интересно, реализация в целом та же, что выше.

Если кто знает, буду искренне рад прочитать, почему это могло произойти. Но в принципе тема теряет свою актуальность. Всем обратившим внимание спасибо
0
vxg
Модератор
3278 / 2075 / 327
Регистрация: 13.01.2012
Сообщений: 8,055
12.11.2017, 10:53 4
Nickomed, могу только попробовать вырвать кусок из своего проекта (правда у меня там все же есть сервис)
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
public class App extends Application {
 
    private static App mInstance;
 
    public App() {
        mInstance = this;
    }
 
    public static Context getAppContext() {
        return mInstance.getApplicationContext();
    }
 
...
 
}
 
// это было в сервисе
 
    private static final int NOTIFICATION_START_ID_1 = 1;
 
    public static void setAlarm(int cmd, long t) {
        Intent i = new Intent(App.getAppContext(), AlarmReceiver.class);
        i.putExtra("cmd", cmd);
        PendingIntent pi = PendingIntent.getBroadcast(App.getAppContext(), cmd, i, PendingIntent.FLAG_UPDATE_CURRENT);
        AlarmManager am = (AlarmManager) App.getAppContext().getSystemService(ALARM_SERVICE);
        if (Build.VERSION.SDK_INT >= 23) {// Wakes up the device in Doze Mode
            am.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, t, pi);
        } else if (Build.VERSION.SDK_INT >= 19) {// Wakes up the device in Idle Mode
            am.setExact(AlarmManager.RTC_WAKEUP, t, pi);
        } else {// Old APIs
            am.set(AlarmManager.RTC_WAKEUP, t, pi);
        }
    }
 
    private static Notification getNotification(String content, int id) {
        Context context = App.getAppContext();
        Intent resultIntent = new Intent(context, MainActivity.class);
 
        TaskStackBuilder stackBuilder = TaskStackBuilder.create(context);
        stackBuilder.addParentStack(MainActivity.class);
        stackBuilder.addNextIntent(resultIntent);
        PendingIntent resultPendingIntent = stackBuilder.getPendingIntent(id, FLAG_UPDATE_CURRENT);
 
        NotificationCompat.Builder builder = new NotificationCompat.Builder(context)
                .setContentTitle(context.getString(R.string.app_name))
                .setContentText(content)
                .setSmallIcon(R.mipmap.ic_launcher)
                .setContentIntent(resultPendingIntent)
                .setDefaults(Notification.DEFAULT_SOUND)
                .setAutoCancel(true);
        return builder.build();
    }
 
    public static void showNotification() {
        NotificationManager notificationManager = (NotificationManager) App.getAppContext().getSystemService(Service.NOTIFICATION_SERVICE);
        Notification notification = getNotification("Пришло время икс", NOTIFICATION_START_ID_1);
        notificationManager.notify(NOTIFICATION_START_ID_1, notification);
    }
 
// это в ресивере
 
public class AlarmReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        int cmd = intent.getIntExtra("cmd", -1);
        if (cmd == 1) {
            showNotification();
        }
    }
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.11.2017, 10:53

AlarmManager описание
Здравствуйте. Подскажите хороший гайд по работе AlarmManager. А то в основном примеры толком не...

AlarmManager + Notification
Взялся за создания Нотификаций в определённое время. До этого такого ещё такого не делал, без...

AlarmManager.setWindow
Здравствуйте. Сделал alarmManager.setWindow(AlarmManager.RTC, calendar2.getTimeInMillis(),...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru