Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 5

Не работает AlarmManager

11.11.2017, 18:42. Показов 3085. Ответов 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
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.11.2017, 18:42
Ответы с готовыми решениями:

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

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

AlarmManager работает с задержкой во времени
Добрый день форумчане, в моем приложении Alarm Manager работает неправильно, работает но с задержкой по времены //Как работает...

3
Модератор
 Аватар для vxg
3407 / 2178 / 354
Регистрация: 13.01.2012
Сообщений: 8,448
12.11.2017, 07:40
Nickomed, у вас постоянно висящий сервис? Нет / убит - нет уведомления
0
0 / 0 / 0
Регистрация: 11.11.2017
Сообщений: 5
12.11.2017, 10:38  [ТС]
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
3407 / 2178 / 354
Регистрация: 13.01.2012
Сообщений: 8,448
12.11.2017, 10:53
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.11.2017, 10:53
Помогаю со студенческими работами здесь

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

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

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

AlarmManager и TextView
Здравствуйте. Задача такая: есть AlarmManager и TextView. Как заставить AlarmManager отсчитывать время, заданное пользователем, и...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru