应用程序关闭时,警报不起作用

时间:2018-06-11 07:27:35

标签: java android alarmmanager background-service

基本上,我正在尝试构建一个警报应用程序,其中包含一些具有预定义日期和时间的按钮。我已经尝试过首先使用AlarmManager和广播接收器但是没有用。因此,我使用了带有alarmManager的前台服务,但是当应用程序被销毁时,警报不会触发。我是新手。我试着在互联网上搜索,但我没有运气。希望这里有很多人帮助我。提前致谢。

这里我只想设置一个警报进行测试。否则,我使用变量作为多个警报的请求代码。

的AndroidManifest.xml

 <receiver android:name=".AlarmReceiver" />

    <activity
        android:name=".Activity.PlayerDetailsActivity"
        android:theme="@style/AppTheme.NoActionBar"></activity>
    <activity android:name=".Activity.FixtureActivity" />

    <service android:name=".MyService"/>

MyService.java

public class MyService extends Service {
public MyService() {
}

@Override
public IBinder onBind(Intent intent) {
    // TODO: Return the communication channel to the service.
    throw new UnsupportedOperationException("Not yet implemented");
}

@Override
public int onStartCommand(Intent intent, int flags, int startId) {

    Toast.makeText(this, "Started", Toast.LENGTH_SHORT).show();
    Log.e("service","service");
    long longExtra = intent.getLongExtra(Constants.ALARM_TIME, 0000);

    //Testing Area Start
    Calendar calendar = Calendar.getInstance();
    calendar.setTimeInMillis(longExtra);

    int mMin = calendar.get(Calendar.MINUTE);
    int mMonth = calendar.get(Calendar.MONTH);
    int mDay = calendar.get(Calendar.DAY_OF_MONTH);
    int mHour = calendar.get(Calendar.HOUR_OF_DAY);

    Log.e("hour min month day"," "+mHour + " : "+mMin+" month : "+mMonth+" "+" Date : "+mDay+" ");
    String currentDateTime=getDeviceDateTime();
    Log.e("CurrentdateTime",""+currentDateTime);


    Log.e("longExtra",""+longExtra);
    //Testing Area End

        String CHANNEL_ID = "my_channel_01";
    NotificationChannel channel = null;
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
        channel = new NotificationChannel(CHANNEL_ID,
                "Channel human readable title",
                NotificationManager.IMPORTANCE_DEFAULT);

    ((NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE)).createNotificationChannel(channel);

        Notification notification = new NotificationCompat.Builder(this, CHANNEL_ID)
                .setContentTitle("dfdf")
                .setSmallIcon(R.drawable.ic_notifications_black_24dp)
                .setContentText("dfdfd").build();
        startForeground(3, notification);
    }

    /*Intent alertIntent = new Intent(getApplicationContext(), AlarmReceiver.class);
    AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);

    Log.d("I",""+longExtra);
    alarmManager.set(AlarmManager.RTC_WAKEUP, 6000000, PendingIntent.getBroadcast(getApplicationContext(), 0, alertIntent,
            PendingIntent.FLAG_ONE_SHOT));*/

    AlarmManager manager= (AlarmManager)getSystemService(ALARM_SERVICE);
    Intent myIntent;
    myIntent = new Intent(getApplicationContext(),AlarmReceiver.class);
    myIntent.putExtra("check",true);
    PendingIntent pendingIntent = PendingIntent.getBroadcast(this,0,myIntent,0);
    Long finalTime =longExtra-System.currentTimeMillis();
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
        manager.setExact(AlarmManager.RTC_WAKEUP,longExtra,pendingIntent);
    }
    else
        manager.set(AlarmManager.RTC_WAKEUP,longExtra,pendingIntent);


    return START_NOT_STICKY;
}





@Override
public void onDestroy() {
    super.onDestroy();
}
}

Alarmreceiver.java

 public class AlarmReceiver extends BroadcastReceiver
{
public static final String CHANNEL_ID = "47";
@Override
public void onReceive(Context context, Intent intent)
{
    intent = new Intent(context, SplashActivity.class);
    intent.putExtra("not",true);
    intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK);
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);

    Uri alarmSound = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);


    NotificationCompat.Builder notificationCompat = new NotificationCompat.Builder(context,CHANNEL_ID);
    notificationCompat.setSmallIcon(R.drawable.ic_notifications_black_24dp);
    notificationCompat.setContentTitle("My Noticiation");
    notificationCompat.setContentText(getPreferences(context).getDateTime());
    notificationCompat.setContentIntent(pendingIntent);
    notificationCompat.setSound(alarmSound);

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {

        int importance = NotificationManager.IMPORTANCE_DEFAULT;
        NotificationChannel channel = new NotificationChannel(CHANNEL_ID, "channel name", importance);
        // Register the channel with the system; you can't change the importance
        // or other notification behaviors after this
        NotificationManager notificationManager = context.getSystemService(NotificationManager.class);
        notificationManager.createNotificationChannel(channel);
    }

    Notification notification = notificationCompat.build();

    NotificationManagerCompat notificationManager = NotificationManagerCompat.from(context);
    notificationManager.notify(100,notification);
    Toast.makeText(context, "Alarm Working", Toast.LENGTH_SHORT).show();
}
}

4 个答案:

答案 0 :(得分:0)

你必须开始服务,然后才能设置警报和消防接收器

从您的活动类

开始
Intent intent=new Intent(this,MyService.class); 
startService(intent);

答案 1 :(得分:0)

考虑使用JobScheduler作为持久性机制。它是清醒的,为您处理唤醒锁定。唯一的缺点是Android SDK&gt; = 21(Lollipop)。 在镇上还有一位新朋友可以为你提供向后兼容性:WorkManager并且可以与所有版本的Android一起使用,甚至可以在Lollipop下面使用。

答案 2 :(得分:0)

Intent myIntent;
    myIntent = new Intent(this, AlarmReceiver.class);
    myIntent.putExtra("check",true);
    PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, myIntent, 0);

============================
您会这​​样更改上面的代码吗?

Intent myIntent;

myIntent = new Intent(this , MyService.class);

myIntent.setAction("REQUEST_FROM_ALARM_MANAGER");

PendingIntent pendingIntent = PendingIntent.getForegroundService(this,0,myIntent,0);

================================================ =====
和服务类

@RequiresApi(api = Build.VERSION_CODES.O)

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

    mContext = this;

    Log.e(TAG, "onStartCommand " + intent);

    if(intent == null) {
        return START_NOT_STICKY;
    }

    if("REQUEST_FROM_ALARM_MANAGER".equals(intent.getAction())){
        // show Notification here for your foreground service

    }
    return START_NOT_STICKY;
 } 

答案 3 :(得分:-1)

你必须启动一个能够存活到你的应用程序的服务,你可以看到here如何做到这一点