Приемники Android работают не так, как ожидалось
Честно говоря, они вообще ничего не делают. Позвольте мне начать с того, что я знаю, что Android переработал приемники в 3.1, в частности, контроль загрузки. Я знаю, что они сделали это так, что ACTION_BOOT_COMPLETED не может использоваться, если приложение не было ранее запущено пользователем. Тем не менее, люди успешно использовали их в текущем приложении, но я никогда не получаю мои приемники за мой BOOT_COMPLETED или мой SHUTDOWN.
Быстрое редактирование - пожалуйста, посмотрите в нижней части этого поста исправленный приемник выключения, я заставил его работать, и теперь я просто застрял в моих усилиях заставить BOOT_COMPLETED работать.
Мой манифест:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.smashingboxes.speedblock"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="12"
android:targetSdkVersion="18" />
<!-- PERMISSIONS -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
...
<!-- RECEIVERS -->
<receiver android:name=".BootReceiver"
android:enabled="true" >
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
<receiver android:name=".ShutdownReceiver" >
<intent-filter>
<action android:name="android.intent.action.SHUTDOWN" />
</intent-filter>
</receiver>
Теперь мои реализованные классы приемника довольно просты:
BOOT_COMPLETED Приемник (тот, который не работает)
public class BootReceiver extends BroadcastReceiver{
@Override
public void onReceive(Context c, Intent i) {
Intent starterIntent = new Intent(c, LaunchActivity.class);
// Start the activity (by utilizing the passed context)
starterIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
c.getApplicationContext().startService(starterIntent);
}
}
Я пробовал разные вещи в зависимости от того, что я видел в решениях, например, изменение моей активности запуска, чтобы включить
/* May need this, as of 3.1 we can't call BOOT_COMPLETED until the app has been run successfully */
Intent intent = new Intent("com.smashingboxes.speedblock.intent");
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
this.sendBroadcast(intent);
или включив это в мой интент-фильтр загрузочного приемника в моем манифесте
<action android:name="android.intent.action.QUICKBOOT_POWERON" />
Ничто не похоже на работу. Когда логи вставляются в методы моего приемника, они никогда не попадают. Очевидно, люди все еще используют эти два приемника довольно регулярно, поэтому у меня возникают проблемы с пониманием того, почему ни один из них не работает. Я что-то пропустил с моей регистрацией или что-то?
--РЕДАКТИРОВАТЬ--
Я решил проблему с выключенным приемником. Во-первых, я по глупости забыл часть тега ACTION_. Во-вторых, у HTC есть отдельные методы выключения, в моем случае мне нужно было добавить фильтр намерений в мой запрос Receiver:
<receiver android:name=".ShutdownReceiver" >
<intent-filter>
<action android:name="android.intent.action.ACTION_SHUTDOWN" />
<action android:name="android.intent.action.QUICKBOOT_POWEROFF" />
</intent-filter>
</receiver>
Теперь мой приемник выключения работает, но на загрузочном завершенном приемнике все равно не повезло.
1 ответ
Я нашел ответ, и я думаю, что на самом деле это важно отметить, поскольку кажется, что в какой-то момент другие столкнутся с проблемой. Моя проблема заключалась в том, что я запускал "Launcher Activity" под названием "LauncherActivity". По сути, он служил моим шлюзом для запуска служб, получателей и т. П. При запуске приложения. Это очень простой класс Activity:
public class LaunchActivity extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
/* May need this, as of 3.1 we can't call BOOT_COMPLETED until the app has been run successfully */
Intent intent = new Intent("com.smashingboxes.speedapp.intent");
intent.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES);
this.sendBroadcast(intent);
}
@Override
protected void onStart(){
super.onStart();
Intent serviceIntent = new Intent(this, MainService.class);
startService(serviceIntent);
// NOTE: It is VERY, VERY important that we DO NOT finish this activity.
// If we do, our BootReceiver will no longer receive its broadcast and
// we won't auto-start on boot
//finish();
}
}
Обратите внимание, что я вызывал finish() для LaunchActivity. Проблема с этим заключается в том, что оно, похоже, сообщало Android, что приложение находилось в состоянии остановки, что означает, что оно не разрешает прием широковещательной передачи BOOT_COMPLETED, даже если у меня было несколько служб, работающих в фоновом режиме. Активность Launcher ДОЛЖНА оставаться активной в течение всего жизненного цикла, иначе приемник BOOT_COMPLETED станет бесполезным. Что-то, что я не видел, упомянуто ранее, но опять же кое-что, на мой взгляд, стоит отметить.