Search code examples
androidalarmmanager

Android AlarmManager will not execute at current time


In my android manifest i have defined a broadcastReceiver like this:

<receiver android:name="com.myexample.mycompany.countdownapp.MainActivity$WarningReceiver"
            android:enabled="true"/>

and then in my mainActivity i have a WarningReceiver class. The entire mainActivity is very small and looks like this:

package com.myexample.mycompany.countdownapp;

import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.Toast;

import java.util.Calendar;

public class MainActivity extends AppCompatActivity {


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        //10 seconds later
        Calendar cal = Calendar.getInstance();
        cal.add(Calendar.SECOND, 0);


        AlarmManager alarmMgr = (AlarmManager) getSystemService(Context.ALARM_SERVICE);

        Intent intent = new Intent(this, WarningReceiver.class);
        PendingIntent alarmIntent = PendingIntent.getBroadcast(this, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);

        alarmMgr.set(AlarmManager.ELAPSED_REALTIME,
                cal.getTimeInMillis(), alarmIntent);

    }




    public static class WarningReceiver extends BroadcastReceiver {

        public Void sendWarningEvent() throws Exception {
            // fire off warning event
            Log.v("WarningReceiver", "sendWarningEvent called from WarningReceiver");
            return null;
        }

        @Override
        public void onReceive(Context context, Intent intent) {
            try {

                Toast.makeText(context,
                        "WarningReceiver.onReceive()",
                        Toast.LENGTH_LONG).show();

                sendWarningEvent();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

When i run the app nothing gets fired. What am i doing wrong ?


Solution

  • Try this:

    alarmMgr.set(AlarmManager.RTC_WAKEUP,cal.getTimeInMillis(), alarmIntent);
    

    instead of:

    alarmMgr.set(AlarmManager.ELAPSED_REALTIME,cal.getTimeInMillis(), alarmIntent);