web-dev-qa-db-ja.com

Android-起動時にサービスを開始

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設定で実行中のサービスを確認します。これはすべて正しいように聞こえますか、何か不足していますか?繰り返しますが、どんな助けも大歓迎です。

91
Gady

これが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();
    }
}
269
Lalit Poptani

起動後にデバイスがスリープ状態になるため、サービスが完了する前にシャットダウンされる場合があります。最初にウェイクロックを取得する必要があります。幸いなことに、 サポートライブラリはクラスを提供します これを行うには:

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" />
2
phreakhead

以下が動作するはずです。確認しました。あなたの問題はどこかにあるかもしれません。

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>
2
Vivek

mine と非常によく似ていますが、レシーバーには完全なパッケージ名を使用しています。

<receiver Android:name=".StartupIntentReceiver">

私は持っています:

<receiver Android:name="com.your.package.AutoStart"> 
1
ciscogambo

完全なパッケージなしで成功しましたが、コールチェーンが中断される場所を知っていますか? Log()でデバッグすると、どの時点で機能しなくなりますか?

IntentServiceにあると思いますが、これはすべて問題ありません。

1
Phix

コメントで述べたように、検索を簡単にするために、これは3.1以降では不可能です https://stackoverflow.com/a/19856367/6505257

0
MrKew