Сохраняйте alarmmanager в рабочем состоянии, даже если приложение убито

#android #service #alarmmanager #android-broadcastreceiver

#Android #Обслуживание #alarmmanager #android-broadcastreceiver

Вопрос:

У меня есть код ниже того, что я запускаю из MainActivity, и он работает нормально, если приложение не убито или закрыто. Но если приложение убито / закрыто, а телефон переходит в спящий режим, оно не работает.

Приложение отключено / закрыто режим ожидания телефона = будильник останавливается

Приложение убито / закрыто экран включен = тревога работает нормально

Приложение в режиме реального времени режим сна телефона = будильник работает нормально

Мне нужна сигнализация, даже если приложение отключено, а телефон находится в спящем режиме.

AlarmLocation.class:

   public void onReceive(Context context, Intent intent) {

    PowerManager pm = (PowerManager) context.getSystemService(Context.POWER_SERVICE);
    PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "My WakeLock");
    wl.acquire();

    Log.i("ALARM","ID: " id);
    setAlarm(context);

    //job ends
    wl.release();
}


public void setAlarm(Context context){
    Log.i("SERVICE","ALARM");
    AlarmManager am =( AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
    Intent i = new Intent(context, AlarmLocation.class);
    id  ;
    PendingIntent pi = PendingIntent.getBroadcast(context, id, i, PendingIntent.FLAG_UPDATE_CURRENT);
    cancelAlarm(context);
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
            am.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP,System.currentTimeMillis() 1000*60*1,pi);
            Log.i("ALARM","M");
        }else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
                    am.setExact(AlarmManager.RTC_WAKEUP,System.currentTimeMillis() 1000*60*1,pi);
            Log.i("ALARM","KITKAT");
        } else {

            am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis(),1000*60*1,pi);

        }


}

public void cancelAlarm(Context context){
    Intent intent = new Intent(context, AlarmLocation.class);
    PendingIntent pi = PendingIntent.getBroadcast(context, id-1, intent, 0);
    AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
    alarmManager.cancel(pi);
}
 

Обслуживание:

    private AlarmLocation al= new AlarmLocation();

@Nullable
@Override
public IBinder onBind(Intent intent) {
    return null;
}

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    Log.i("SERVICE","OSM");
    NotificationCompat.Builder notify = new NotificationCompat.Builder(this)
            .setSmallIcon(R.drawable.cast_ic_notification_small_icon)
            .setContentTitle("TITLE")
            .setContentText("TEXT");
    startForeground(1,notify.build());

    al.setAlarm(this);
    super.onStartCommand(intent, flags, startId);
    return START_STICKY;
}

@Override
public void onStart(Intent intent, int startId) {
    Log.i("SERVICE","OS");
    //al.setAlarm(this);
    super.onStart(intent, startId);
}

@Override
public void onCreate() {

    super.onCreate();
}

@Override
public void onDestroy() {

    Log.i("SERVICE","DESTROYED");
    super.onDestroy();
}
 

В MainActivity:

 startService(new Intent(this,LocationChecker.class));
 

Ответ №1:

Это немного запутанно.

Это тот сервис, который вам нужен:

 public class NotificationService extends Service {

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        synchronized (this) {
            NotificationCompat.Builder mBuilder=new NotificationCompat.Builder(this)
                    .setSmallIcon(R.drawable.ic_launcher)
                    .setContentTitle(title)
                    .setContentText(text);
            if (isSound)
                mBuilder.setDefaults(Notification.DEFAULT_SOUND | Notification.DEFAULT_VIBRATE);
            NotificationManager mNotificationManager=(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
            mNotificationManager.notify(1, mBuilder.build());
        }
        return START_NOT_STICKY;
    }

    @Override
    public IBinder onBind(Intent intent) {
        //TODO for communication return IBinder implementation
        return null;
    }
}
 

В функции onCreate MainActivity вы должны запустить AlarmManager:

 Intent intent = new Intent(MainActivity.this, NotificationService.class);
PendingIntent pintent = PendingIntent.getService(MainActivity.this, 0, intent, 0);
AlarmManager alarm = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
alarm.setRepeating(AlarmManager.RTC_WAKEUP, (cal.getTimeInMillis()/interval)*interval interval, interval, pintent);
 

И не забудьте включить вибрацию в AndroidManifest.xml:

 <uses-permission android:name="android.permission.VIBRATE"/>