Intereting Posts
В Google App Engine я могу связать токен Google OAuth 2 и токен SACSID, который я использовал с помощью AccountManager Android? Android-приложение с SSL В чем разница между Android Studio Beta Channel, Android Studio Canary Channel, Android Studio Dev Channel? Рисование сердца с острым углом в Android Дооснащение: сервер возвращает как ETag, так и Cache-Control: max-age = 60. Не следует ли использовать кеш при запросе <60s? Как получить клики по двум перекрывающимся кнопкам в одном макете кадра в android Как использовать 2 разных фона между ландшафтным режимом и портретным режимом Пользовательские кнопки Android Captcha в приложении для Android Как загружать большие изображения в Android и избегать ошибок в памяти? Проверьте, если MenuItem находится в переполнении ActionBar Неподдерживаемая версия major.minor 52.0 в моем приложении Android Gradle Unit Тестирование миграции из JARs – дублирование файлов hamcrest из junit и mockito Отключить инкрементную сборку для kapt Android: сброс активности onClick

Начало работы при загрузке

Я хотел бы начать свое приложение сразу после загрузки телефона. По-видимому, приложение запускается после загрузки, но оно сразу же падает (просто чтобы быть понятным, приложение нормально работает нормально). Я уже читал и пробовал разные решения ( link1 , link2 ), и на самом деле тот же код отлично работает с другим приложением, которое я разрабатывал. Вот код:

AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.bluetoothx10y" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="6" android:targetSdkVersion="15" /> <uses-feature android:name="android.hardware.usb.accessory"/> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> <uses-permission android:name="android.permission.WRITE_INTERNAL_STORAGE" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.BLUETOOTH"/> <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/> <uses-permission android:name="android.permission.DISABLE_KEYGUARD"/> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" > <receiver android:name=".StartMyActivityAtBootReceiver" android:enabled="true" android:exported="true"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> <activity android:name=".MainActivity" android:label="@string/app_name" android:screenOrientation="landscape" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> <intent-filter> <action android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED"/> </intent-filter> <meta-data android:name="android.hardware.usb.action.USB_ACCESSORY_ATTACHED" android:resource="@xml/accessory_filter"> </meta-data> </activity> <activity android:name=".DeviceListActivity" android:label="@string/app_name" android:theme="@android:style/Theme.Dialog" android:screenOrientation="landscape" /> </application> </manifest> 

StartMyActivityAtBootReceiver.java:

  public class StartMyActivityAtBootReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if ("android.intent.action.BOOT_COMPLETED".equals(intent.getAction())) { Intent myStarterIntent = new Intent(context, MainActivity.class); myStarterIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(myStarterIntent); } } } 

Может быть, это связано с тем, что я использую много прав пользователя?

 Try this: 

1] В файле AndroidManifest.xml:

  <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> <application ... <receiver android:name=".StartMyActivityAtBootReceiver" android:enabled="true" android:permission="android.permission.RECEIVE_BOOT_COMPLETED" > <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </receiver> </application> 

2] Внутри класса BroadcastReciever с именем StartMyActivityAtBootReceiver в качестве имени класса.

 @Override public void onReceive(Context context, Intent intent) { Intent i = new Intent(context, MainActivity.class); i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(i); } 

Это сработало для меня. Разница в коде выглядит следующим образом:

  • Android: permission = "android.permission.RECEIVE_BOOT_COMPLETED" внутри приемника.
  • Включен «категория android: name =» android.intent.category.DEFAULT «" внутри фильтра намерений.
  • Я не проверяю намерение в onRecieve, так как я знаю, что код будет выполнен, только если его true
 <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> <receiver android:name=".StartMyActivityAtBootReceiver" android:enabled="true" android:exported="true"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED"/> <action android:name="android.intent.action.QUICKBOOT_POWERON"/> </intent-filter> </receiver> 

Сделайте это так, если условие

  if(intent.getAction().equals(Intent.ACTION_BOOT_COMPLETED)) 

на месте

  <action android:name="android.intent.action.BOOT_COMPLETED" /> 

Добавить также это

 <action android:name="android.intent.action.QUICKBOOT_POWERON" /> 

Некоторые устройства, такие как HTC, не ловят BOOT_COMPLETED

Мне удалось решить эту проблему. Внутри OnCreate () у меня был этот код (связанный с USB-связью), который вызывал сбой:

  act_string = getIntent().getAction(); if( -1 != act_string.indexOf("android.intent.action.MAIN")){ restorePreference(); } else if( -1 != act_string.indexOf("android.hardware.usb.action.USB_ACCESSORY_ATTACHED")){ cleanPreference(); } 

Удаление этого кода позволило решить проблему после загрузки.

Я хотел бы добавить весь файл манифеста, который работал для меня на oppo neo 5. И даже позаботиться о том, чтобы какой-то телефон требовал специального доступа для достижения начальной загрузки или других специальных разрешений. Поэтому не забывайте разрешать доступ к вашим приложение!!.

Вот код –

  <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.javacodegeeks.androidserviceonbootexample" android:installLocation="internalOnly"> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> <action android:name="android.intent.action.QUICKBOOT_POWERON" /> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /> <uses-permission android:name="android.permission.BIND_ACCESSIBILITY_SERVICE" /> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="SilversithService" android:theme="@style/AppTheme"> <receiver android:name="com.javacodegeeks.androidserviceonbootexample.BroadcastReceiverOnBootComplete"> <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> <action android:name="android.intent.action.REBOOT"/> <category android:name="android.intent.category.HOME" /> </intent-filter> </receiver> <service android:name="com.javacodegeeks.androidserviceonbootexample.AndroidServiceStartOnBoot" android:enabled="true"></service> <activity android:name="com.javacodegeeks.androidserviceonbootexample.MainActivity" android:label="SilversithService"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>