2

我正在尝试在我的应用程序中实现接近警报通知服务,并且我希望在我收到通知的任何位置附近时收集 POI(兴趣点)。我不断收到此错误

07-18 12:56:27.069: W/dalvikvm(12518): threadid=1: thread exiting with uncaught exception  (group=0x41ee1930)
07-18 12:56:27.079: E/AndroidRuntime(12518): FATAL EXCEPTION: main
07-18 12:56:27.079: E/AndroidRuntime(12518): java.lang.RuntimeException: Error receiving broadcast Intent { act=com.phlok.proximityalarm.broadcast flg=0x10 (has extras) } in com.phlok.multiplealert.ProximityIntentReceiver@42268478
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:768)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.os.Handler.handleCallback(Handler.java:725)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.os.Handler.dispatchMessage(Handler.java:92)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.os.Looper.loop(Looper.java:137)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.app.ActivityThread.main(ActivityThread.java:5231)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at java.lang.reflect.Method.invokeNative(Native Method)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at java.lang.reflect.Method.invoke(Method.java:511)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:106)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at dalvik.system.NativeStart.main(Native Method)
07-18 12:56:27.079: E/AndroidRuntime(12518): Caused by: java.lang.NullPointerException
07-18 12:56:27.079: E/AndroidRuntime(12518):    at com.phlok.multiplealert.ProximityIntentReceiver.onReceive(ProximityIntentReceiver.java:35)
07-18 12:56:27.079: E/AndroidRuntime(12518):    at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:758)
07-18 12:56:27.079: E/AndroidRuntime(12518):    ... 10 more

这是我的代码:

public class ProximityAlertService extends Service {


private static final String TAG = "ProximityAlertService";
private static final long POINT_RADIUS = 100; // in Meters
private static final long PROX_ALERT_EXPIRATION = -1; // It will never expire
private static final String PROX_ALERT_INTENT = "com.phlok.proximityalarm.broadcast";
ArrayList <LatLonPair> positions;


@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    Toast.makeText(this,"Start",Toast.LENGTH_LONG).show();

    createPositions();
    registerIntents();
    Log.d(TAG,"adding...");
    return super.onStartCommand(intent, flags, startId);

}


private void setProximityAlert(double  latitude, double longitude, final long eventID, int requestCode) {

    LocationManager locationManager= (LocationManager) getSystemService(Context.LOCATION_SERVICE);
    Bundle extras = new Bundle();
    extras.putLong("name", eventID);
    extras.putInt("id", requestCode);
    Intent intent = new Intent(PROX_ALERT_INTENT);
    intent.putExtra(PROX_ALERT_INTENT, extras);
    PendingIntent proximityIntent = PendingIntent.getBroadcast(this, requestCode , intent, PendingIntent.FLAG_CANCEL_CURRENT);
    locationManager.addProximityAlert(
            latitude, // the latitude of the central point of the alert region
            longitude, // the longitude of the central point of the alert region
            POINT_RADIUS, // the radius of the central point of the alert region, in meters
            PROX_ALERT_EXPIRATION, // time for this proximity alert, in milliseconds, or -1 to indicate no expiration 
            proximityIntent // will be used to generate an Intent to fire when entry to or exit from the alert region is detected
            );
    requestCode++; 
    Log.d(TAG,String.valueOf(latitude));
    IntentFilter filter = new IntentFilter(PROX_ALERT_INTENT); 
    registerReceiver(new ProximityIntentReceiver(), filter);
}

private void createPositions() {
    positions = new ArrayList<LatLonPair>();
    positions.add(new LatLonPair(53.4010626,-6.1804462));
    positions.add(new LatLonPair(53.4513078,-6.1537115));
    positions.add(new LatLonPair(53.4265686,-6.1715556));
    Log.d(TAG,"Locations added...");
}

private void registerIntents() {
    for(int i = 0; i < positions.size(); i++) {
        LatLonPair latLon = positions.get(i);
        setProximityAlert(latLon.getLatitude(),latLon.getLongitude(),i+1,i);
        Log.d(TAG,"Intenets Registered");
    }
}

那是广播接收器代码

public class ProximityIntentReceiver extends BroadcastReceiver {

//  private static final int NOTIFICATION_ID = 1000;


@SuppressWarnings("deprecation")
@Override
public void onReceive(Context context, Intent intent) {

    String key = LocationManager.KEY_PROXIMITY_ENTERING;
    Boolean entering = intent.getBooleanExtra(key, false);
    if (entering) {
        Log.d(getClass().getSimpleName(), "entering");
    }else {
        Log.d(getClass().getSimpleName(), "exiting");
    }
    NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);

    Intent notificationIntent = new Intent(context, ProximityAlertService.class);
    PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, notificationIntent, 0);
    Notification notification = createNotification();
    notification.setLatestEventInfo(context, "Phlok Alert!", "Omar,You are near" + intent.getBundleExtra("com.phlok.multiplealert.").get("name"), pendingIntent);
    notificationManager.notify( intent.getBundleExtra("com.phlok.multiplealert.").getInt("id"), notification);
}
private Notification createNotification() {
    Notification notification = new Notification();
    notification.icon = R.drawable.ic_launcher;
    notification.when = System.currentTimeMillis();
    notification.flags |= Notification.FLAG_AUTO_CANCEL;
    notification.flags |= Notification.FLAG_SHOW_LIGHTS;
    notification.defaults |= Notification.DEFAULT_VIBRATE;
    notification.defaults |= Notification.DEFAULT_LIGHTS;
    notification.ledARGB = Color.WHITE;
    notification.ledOnMS = 1500;
    notification.ledOffMS = 1500;
    return notification;
}

}

任何帮助都感激不尽

谢谢

4

1 回答 1

0

检查包名是否在 onRecieve() 方法“com.phlok.multiplealert”中。)

于 2013-07-18T12:15:42.593 回答