#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"/>