Search code examples
androidbroadcastreceiverandroid-alarmsrepeatingalarmandroid-broadcastreceiver

Alarm Receiver for multiple alarms is not getting invoked


I am trying to implement repeating multiple alarms at different specific times. The problem is the Alarm Receiver is not getting invoked at any given time.

My code in the activity:

private void setAlarms() {
    Intent myIntent=new Intent(this, AlarmReceiver.class);
    myIntent.putExtra("MedName",medication_name);
    myIntent.setAction("b5.project.medibro.receivers.AlarmReceiver");
    AlarmManager am = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
    //am.set(AlarmManager.RTC_WAKEUP, time, pendingIntent);
    ArrayList<PendingIntent> intentArray = new ArrayList<PendingIntent>();
    int counter=0;
    for(String timer: timers){
       //timers is an array of Strings in the format hh:mm
         try {
            String[] comps=timer.split(":");
            Calendar cal=Calendar.getInstance();
            cal.set(Calendar.HOUR_OF_DAY, Integer.valueOf(comps[0]));
            cal.set(Calendar.MINUTE, Integer.valueOf(comps[1]));
            cal.set(Calendar.SECOND, 0);
            cal.set(Calendar.MILLISECOND, 0);
            Log.d(TAG,comps[0]+" "+comps[1]+ "Alarm Time: " + cal.getTime().toString());
            PendingIntent pendingIntent = PendingIntent.getService(this, counter, myIntent,0);
            am.setInexactRepeating(AlarmManager.RTC_WAKEUP,
                    cal.getTimeInMillis(),
                    AlarmManager.INTERVAL_DAY,
                    pendingIntent);
            counter++;
        } catch (ParseException e) {
            e.printStackTrace();
            Log.d(TAG,"Time Parsing error: "+e.getMessage());
        }
    }
}

and this is my Alarm Receiver:

public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
    if(intent.getAction().equals("b5.project.medibro.receivers.AlarmReceiver")) {
        Toast.makeText(context, "I'm running", Toast.LENGTH_SHORT).show();
        Log.d("Alarm Receiver", "Alarm is invoked. ");

        NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
        builder.setSmallIcon(R.drawable.messenger_bubble_large_blue);
        builder.setContentTitle("Time to take your medicine");
        String medName = intent.getStringExtra("MedName");
        String text = "Medicine name: " + medName;
        builder.setContentText(text);

        Notification notification = builder.build();
        NotificationManagerCompat.from(context).notify(0, notification);
        Toast.makeText(context, "I'm running", Toast.LENGTH_SHORT).show();
    }
}

}

Manifest declaration:(its within application tags)

<receiver android:name="b5.project.medibro.receivers.AlarmReceiver"
        android:enabled="true">
        <intent-filter>
            <action android:name="b5.project.medibro.receivers.AlarmReceiver"/>
        </intent-filter>
    </receiver>

I feel the above code should execute the broadcast receiver atleast once but nothing shows up in the logcat. Can someone tell me what am I missing?


Solution

  • Instead of getService try getBroadcast:

    PendingIntent pendingIntent = PendingIntent.getService(this, counter, myIntent,0);
    
    PendingIntent pendingIntent = PendingIntent.getBroadcast(this, counter, myIntent,0);
    

    Also look at http://developer.android.com/reference/android/app/PendingIntent.html#getBroadcast(android.content.Context, int, android.content.Intent, int), and figure out the flags you need, 'cause I wouldn't be surprised if only the last alarm (in the for loop) will be working.