есть много вопросов, связанных с этой темой. но я не могу заставить его работать на моем устройстве 4.2.1 на эмуляторе 5.0 он работает нормально .:Android BroadcastReceiver не срабатывает
здесь манифеста:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.bootService"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="10"
android:targetSdkVersion="21" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<receiver
android:name=".MyBroadcastReceiver"
android:enabled="true"
android:label="MyBroadcastReceiver" >
<intent-filter android:priority="1001" >
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<service android:name=".PingService" >
</service>
<service android:name=".UpdateService" >
</service>
<receiver android:name=".OnBootReceiver" >
<intent-filter android:priority="1001" >
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
</application>
</manifest>
Я попробовал его с 2-мя приемниками: ни один из них не работает. Вот один из приемников, которые должны написать логфайл для SD, который работает отлично от активности Launcher:
public class MyBroadcastReceiver extends BroadcastReceiver {
// Restart service every 30 seconds
private static final long REPEAT_TIME = 1000 * 10;
@Override
public void onReceive(Context context, Intent intent) {
Log.e("MyBroadcastReceiver", "BroadcastReceiver");
appendLog("MyBroadcastReceiver BroadcastReceiver \n");
AlarmManager service = (AlarmManager) context
.getSystemService(Context.ALARM_SERVICE);
Intent i = new Intent(context, UpdateService.class);
PendingIntent pending = PendingIntent.getBroadcast(context, 0, i,
PendingIntent.FLAG_CANCEL_CURRENT);
Calendar cal = Calendar.getInstance();
cal.add(Calendar.SECOND, 30);
service.setInexactRepeating(AlarmManager.RTC_WAKEUP,
cal.getTimeInMillis(), REPEAT_TIME, pending);
Log.wtf("MyBroadcastReceiver", "Alarm went off");
}
public static void appendLog(String text) {
File logFile = new File("sdcard/logfile.txt");
if (!logFile.exists()) {
try {
logFile.createNewFile();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
try {
// BufferedWriter for performance, true to set append to file flag
BufferedWriter buf = new BufferedWriter(new FileWriter(logFile,
true));
buf.append(text);
buf.newLine();
buf.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Я не могу увидеть ошибку. Кто-нибудь делает? PS приложение запускается один раз, поэтому это: http://commonsware.com/blog/2011/07/05/boot-completed-regression.html покрыто.
спасибо,
BOOT_COMPLETED это означает, что когда устройство перезагружается и готово к использованию. Надеюсь, вы понимаете, что это значит. –
@ MurtazaHussain, конечно. Приведенный выше код должен предоставить файл журнала на SD-карте после завершения загрузки. – user1616685
Однако он не работает. – user1616685