Stack Exchangeや他の場所で見たすべてのものから、Android OSの起動時にIntentServiceを開始するようにすべてが正しくセットアップされています。残念ながら、起動時に開始されず、エラーも発生しません。たぶん専門家が助けることができる...
マニフェスト:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
package="com.phx.batterylogger"
Android:versionCode="1"
Android:versionName="1.0"
Android:installLocation="internalOnly">
<uses-sdk Android:minSdkVersion="8" />
<uses-permission Android:name="Android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission Android:name="Android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission Android:name="Android.permission.BATTERY_STATS" />
<application Android:icon="@drawable/icon" Android:label="@string/app_name">
<service Android:name=".BatteryLogger"/>
<receiver Android:name=".StartupIntentReceiver">
<intent-filter>
<action Android:name="Android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
</application>
</manifest>
スタートアップ用のBroadcastReceiver:
package com.phx.batterylogger;
import Android.content.BroadcastReceiver;
import Android.content.Context;
import Android.content.Intent;
public class StartupIntentReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent serviceIntent = new Intent(context, BatteryLogger.class);
context.startService(serviceIntent);
}
}
UPDATE:以下の提案をすべて試し、StartupIntentReceiverのonReceiveハンドラーにLog.v("BatteryLogger", "Got to onReceive, about to start service");
などのロギングを追加しましたが、何も記録されません。したがって、BroadcastReceiverに到達することすらありません。
私はAPKをデプロイして正しくテストしていると思います。Eclipseでデバッグを実行すると、コンソールはXoomタブレットの\ BatteryLogger\bin\BatteryLogger.apkに正常にインストールすると言います。次に、テストするために、タブレットを再起動し、DDMSのログを見て、OS設定で実行中のサービスを確認します。これはすべて正しいように聞こえますか、何か不足していますか?繰り返しますが、どんな助けも大歓迎です。
これがAutoStartアプリケーションの完全な例です。
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">
<uses-permission Android:name="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>
<activity Android:name=".hello"></activity>
<service Android:enabled="true" Android:name=".service" />
</application>
</manifest>
autostart.Java
public class autostart extends BroadcastReceiver
{
public void onReceive(Context context, Intent arg1)
{
Intent intent = new Intent(context,service.class);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
context.startForegroundService(intent);
} else {
context.startService(intent);
}
Log.i("Autostart", "started");
}
}
service.Java
public class service extends Service
{
private static final String TAG = "MyService";
@Override
public IBinder onBind(Intent intent) {
return null;
}
public void onDestroy() {
Toast.makeText(this, "My Service Stopped", Toast.LENGTH_LONG).show();
Log.d(TAG, "onDestroy");
}
@Override
public void onStart(Intent intent, int startid)
{
Intent intents = new Intent(getBaseContext(),hello.class);
intents.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(intents);
Toast.makeText(this, "My Service Started", Toast.LENGTH_LONG).show();
Log.d(TAG, "onStart");
}
}
hello.Java-アプリケーションを1回実行した後、デバイスを起動するたびにポップアップします。
public class hello extends Activity
{
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Toast.makeText(getBaseContext(), "Hello........", Toast.LENGTH_LONG).show();
}
}
起動後にデバイスがスリープ状態になるため、サービスが完了する前にシャットダウンされる場合があります。最初にウェイクロックを取得する必要があります。幸いなことに、 サポートライブラリはクラスを提供します これを行うには:
public class SimpleWakefulReceiver extends WakefulBroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
// This is the Intent to deliver to our service.
Intent service = new Intent(context, SimpleWakefulService.class);
// Start the service, keeping the device awake while it is launching.
Log.i("SimpleWakefulReceiver", "Starting service @ " + SystemClock.elapsedRealtime());
startWakefulService(context, service);
}
}
次に、サービスでウェイクロックを解除します。
@Override
protected void onHandleIntent(Intent intent) {
// At this point SimpleWakefulReceiver is still holding a wake lock
// for us. We can do whatever we need to here and then tell it that
// it can release the wakelock.
...
Log.i("SimpleWakefulReceiver", "Completed service @ " + SystemClock.elapsedRealtime());
SimpleWakefulReceiver.completeWakefulIntent(intent);
}
WAKE_LOCKパーミッションを追加することを忘れないでください:
<uses-permission Android:name="Android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission Android:name="Android.permission.WAKE_LOCK" />
以下が動作するはずです。確認しました。あなたの問題はどこかにあるかもしれません。
public class MyReceiver extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
Log.d("TAG", "MyReceiver");
Intent serviceIntent = new Intent(context, Test1Service.class);
context.startService(serviceIntent);
}
}
public class Test1Service extends Service {
/** Called when the activity is first created. */
@Override
public void onCreate() {
super.onCreate();
Log.d("TAG", "Service created.");
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.d("TAG", "Service started.");
return super.onStartCommand(intent, flags, startId);
}
@Override
public void onStart(Intent intent, int startId) {
super.onStart(intent, startId);
Log.d("TAG", "Service started.");
}
@Override
public IBinder onBind(Intent arg0) {
return null;
}
}
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
package="com.test"
Android:versionCode="1"
Android:versionName="1.0"
Android:installLocation="internalOnly">
<uses-sdk Android:minSdkVersion="8" />
<application Android:icon="@drawable/icon" Android:label="@string/app_name">
<uses-permission Android:name="Android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission Android:name="Android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission Android:name="Android.permission.BATTERY_STATS"
/>
<!-- <activity Android:name=".MyActivity">
<intent-filter>
<action Android:name="Android.intent.action.MAIN" />
<category Android:name="Android.intent.category.LAUNCHER"></category>
</intent-filter>
</activity> -->
<service Android:name=".Test1Service"
Android:label="@string/app_name"
>
</service>
<receiver Android:name=".MyReceiver">
<intent-filter>
<action Android:name="Android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
</application>
</manifest>
mine と非常によく似ていますが、レシーバーには完全なパッケージ名を使用しています。
<receiver Android:name=".StartupIntentReceiver">
私は持っています:
<receiver Android:name="com.your.package.AutoStart">
完全なパッケージなしで成功しましたが、コールチェーンが中断される場所を知っていますか? Log()
でデバッグすると、どの時点で機能しなくなりますか?
IntentServiceにあると思いますが、これはすべて問題ありません。
コメントで述べたように、検索を簡単にするために、これは3.1以降では不可能です https://stackoverflow.com/a/19856367/6505257