每当手机插上电源时,我都会激活我的应用程序.这是我的表现
<receiver android:name=".PowerConnectionReceiver">
<intent-filter>
<action android:name="android.intent.action.ACTION_POWER_CONNECTED"/>
<action android:name="android.intent.action.ACTION_POWER_DISCONNECTED"/>
</intent-filter>
</receiver>
Run Code Online (Sandbox Code Playgroud)
这是我的广播接收器
@Override
public void onReceive(Context context, Intent intent) {
Log.w("TAG", "Just received connection broadcast");
IntentFilter ifilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
Intent batteryStatus = context.registerReceiver(null, ifilter); //this line is causing the crash
int status = batteryStatus.getIntExtra(BatteryManager.EXTRA_STATUS, 0);
Run Code Online (Sandbox Code Playgroud)
现在,导致我的朋友电话崩溃的线路(我的一切工作正常)就是这一行
Intent batteryStatus = context.registerReceiver(null, ifilter);
Run Code Online (Sandbox Code Playgroud)
有人可以告诉我是什么原因以及如何解决它?我的手机是最新的Android JB的Galaxy nexus,他的手机是LG optimus与姜饼
这是logcat
02-27 01:25:19.399: D/AndroidRuntime(5326): Shutting down VM
02-27 01:25:19.399: W/dalvikvm(5326): threadid=1: thread exiting with uncaught exception (group=0x40018560)
02-27 01:25:19.419: E/AndroidRuntime(5326): FATAL EXCEPTION: main
02-27 01:25:19.419: E/AndroidRuntime(5326): java.lang.RuntimeException: Unable to start receiver com.doublep.wakey.PowerConnectionReceiver: android.content.ReceiverCallNotAllowedException: IntentReceiver components are not allowed to register to receive intents
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ActivityThread.handleReceiver(ActivityThread.java:1926)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ActivityThread.access$2400(ActivityThread.java:123)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:989)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.os.Looper.loop(Looper.java:130)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ActivityThread.main(ActivityThread.java:3835)
02-27 01:25:19.419: E/AndroidRuntime(5326): at java.lang.reflect.Method.invokeNative(Native Method)
02-27 01:25:19.419: E/AndroidRuntime(5326): at java.lang.reflect.Method.invoke(Method.java:507)
02-27 01:25:19.419: E/AndroidRuntime(5326): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
02-27 01:25:19.419: E/AndroidRuntime(5326): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
02-27 01:25:19.419: E/AndroidRuntime(5326): at dalvik.system.NativeStart.main(Native Method)
02-27 01:25:19.419: E/AndroidRuntime(5326): Caused by: android.content.ReceiverCallNotAllowedException: IntentReceiver components are not allowed to register to receive intents
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ReceiverRestrictedContext.registerReceiver(ContextImpl.java:151)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ReceiverRestrictedContext.registerReceiver(ContextImpl.java:145)
02-27 01:25:19.419: E/AndroidRuntime(5326): at com.doublep.wakey.PowerConnectionReceiver.onReceive(PowerConnectionReceiver.java:46)
02-27 01:25:19.419: E/AndroidRuntime(5326): at android.app.ActivityThread.handleReceiver(ActivityThread.java:1915)
02-27 01:25:19.419: E/AndroidRuntime(5326): ... 10 more
Run Code Online (Sandbox Code Playgroud)
你得到了ReceiverCallNotAllowedException.
此异常从抛出
registerReceiver(BroadcastReceiver, IntentFilter)并且bindService(Intent, ServiceConnection, int)当正从一个广播接收器组件中使用这些方法.在这种情况下,组件在从接收Intent返回时将不再处于活动状态,因此使用异步API无效.
这意味着,你不能注册一个BroadcastReceiver 内一个BroadcastReceiver.
编辑:
侦听ACTION_BATTERY_CHANGEDIntent 的BroadcastReceiver的工作示例:
private int mBatteryLevel;
private IntentFilter mBatteryLevelFilter;
BroadcastReceiver mBatteryReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
mBatteryLevel = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
Toast.makeText(context, "Current Battery Level: " + mBatteryLevel, Toast.LENGTH_LONG).show();
}
};
private void registerMyReceiver() {
mBatteryLevelFilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
registerReceiver(mBatteryReceiver, mBatteryLevelFilter);
}
Run Code Online (Sandbox Code Playgroud)
现在你只需要打电话registerMyReceiver().
| 归档时间: |
|
| 查看次数: |
3226 次 |
| 最近记录: |