我写了一个小程序来捕捉系统广播BOOT_COMPLETED
,但是它就是不起作用:
package com.alex.app.testsysreboot;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;
public class MyReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Log.i("my_tag", "system reboot completed.......");
}
}
manifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.alex.app.testsysreboot"
android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="8" />
<application android:icon="@drawable/icon" android:label="@string/app_name">
<receiver android:name=".MyReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"/>
</intent-filter>
</receiver>
</application>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
</manifest>
我关闭了AVD,然后在Eclipse中点击"运行"按钮,Eclipse启动了一个新的AVD,但是在系统启动后,我就是看不到LogCat中的日志…
我试过了,它对我很有效,
public class Autostart extends BroadcastReceiver
{
public void onReceive(Context arg0, Intent arg1)
{
Log.i("Autostart", "**********started************");
}
}
AndroidManifest文件<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="pack.saltriver" android:versionCode="1" android:versionName="1.0"
android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
<application android:icon="@drawable/icon" android:label="@string/app_name">
<receiver android:name=".Autostart">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
</application>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"></uses-permission>
</manifest>
你需要添加
android:enabled="true"
android:exported="true"
和
确保应用程序没有安装在SD卡上-安装在那里的IIRC应用程序不会收到BOOT_COMPLETED
。
另一点是启用了"快速启动"的设备(如几个HTC设备)(有时?)不发送BOOT_COMPLETED
。
自从Android 3.1+有一些更奇怪的关于BOOT_COMPLETED
与"非常第一次启动一个应用程序"-见http://commonsware.com/blog/2011/07/13/boot-completed-regression-confirmed.html
一个工作示例项目,源代码参见https://github.com/commonsguy/cw-advandroid/tree/master/SystemEvents/OnBoot
从http://arthurfmay.blogspot.com/2011/06/broadcastreceiver-bootcompleted-and.html因此,我从Eclipse中进入Android SDK和AVD管理器(在窗口菜单下),并从那里启动模拟器。我当然,这是在将应用程序加载到模拟器之后完成的。我开始模拟器和我的BroadcastReceiver在引导上工作得很好。在那里不需要在命令行上运行模拟器。