Java tutorial
/** * Copyright 2014 Facebook, Inc. * * You are hereby granted a non-exclusive, worldwide, royalty-free license to * use, copy, modify, and distribute this software in source code or binary * form for use in connection with the web services and APIs provided by * Facebook. * * As with any software that integrates with the Facebook platform, your use * of this software is subject to the Facebook Developer Principles and * Policies [http://developers.facebook.com/policy/]. This copyright notice * shall be included in all copies or substantial portions of the software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. * */ package com.myfuture.util; import android.app.Notification; import android.app.NotificationManager; import android.app.PendingIntent; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.support.v4.app.NotificationCompat; import android.support.v4.app.TaskStackBuilder; import com.parse.GetCallback; import com.parse.ParseException; import com.myfuture.R; import com.myfuture.model.Talk; import com.myfuture.view.TalkActivity; /** * A BroadcastReceiver to handle Intents sent by the AlarmManager for local * notifications. */ public class FavoritesNotificationReceiver extends BroadcastReceiver { /** * When the notification happens, it will vibrate for 750ms after 0ms. */ private static final long[] VIBRATION = { 0, 750 }; /** * Shows a notification for the given talk. Clicking the notification will * open the talk. */ private static void showStartNotification(Talk talk, final Context context) { if (!talk.isDataAvailable()) { throw new RuntimeException("Talk should have been fetched."); } // Set up an Intent to open the talk, with the back button going back to // the schedule. Intent talkIntent = new Intent(context, TalkActivity.class); talkIntent.setData(talk.getUri()); TaskStackBuilder stackBuilder = TaskStackBuilder.create(context); stackBuilder.addParentStack(TalkActivity.class); stackBuilder.addNextIntent(talkIntent); PendingIntent talkPendingIntent = stackBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT); // Build the UI for the notification. NotificationCompat.Builder builder = new NotificationCompat.Builder(context); builder.setSmallIcon(R.drawable.light_rating_important); builder.setContentTitle(talk.getTitle()); builder.setContentText("Starts in 5 minutes in " + talk.getRoom().getName()); builder.setContentIntent(talkPendingIntent); builder.setAutoCancel(true); builder.setVibrate(VIBRATION); Notification notification = builder.build(); /* * Display the notification. We use the label "start" to identify this * kind of notification. That would be useful for cancelling the * notification if we wanted. */ NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); manager.notify("start", talk.getObjectId().hashCode(), notification); } /** * This is called by Android to deliver the Intent to the receiver. */ @Override public void onReceive(final Context context, Intent intent) { // Grab the data for the talk this Intent is for. String talkId = Talk.getTalkId(intent.getData()); Talk.getInBackground(talkId, new GetCallback<Talk>() { @Override public void done(Talk talk, ParseException e) { if (talk != null) { showStartNotification(talk, context); } } }); } }