簡體   English   中英

Android廣播接收器未在RECEIVE_BOOT_COMPLETED上運行服務

[英]Android broadcast receiver not running Service on RECEIVE_BOOT_COMPLETED

我正在嘗試創建一個使用計步器的Android應用程序。 當前在用戶重新啟動/打開和關閉手機時無法啟動服務。 我正在使用5.1,並且已經在模擬器上進行了測試。 由於日志未出現在控制台中,因此我不確定它是否正常工作。

任何幫助深表感謝!

應用清單類別:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="app.apphub.devon.walkingquest">
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".WalkingQuestSplashScreen">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <receiver android:name=".BootReceiver" android:exported="true" android:enabled="true"
        android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
        <intent-filtering>
            <action android:name="android.intent.action.BOOT_COMPLETED"/>
        </intent-filtering>

    </receiver>
    <service android:name=".StepCounterSensorRegister" android:enabled="true" android:exported="true"/>
</application>

</manifest>

Boot Receiver類:公共類BootReceiver擴展了BroadcastReceiver {

@Override
public void onReceive(Context context, Intent intent) {
    if (intent.getAction().equals(Intent.ACTION_BOOT_COMPLETED)) {
        Log.i("BROADCAST", "WALKING_QUEST_BOOT");
        Intent _intent = new Intent("app.apphub.devon.walkingquest.StepCounterSensorRegister");
        intent.setClass(context, StepCounterSensorRegister.class);
        context.startService(_intent);
        //context.startService(_intent);
        //Toast.makeText(context,"Airplane mode on",Toast.LENGTH_LONG).show();
    }
    else {
        Log.i("FAIL","BROADCAST FAILED");
    }
}

StepCounterSensorRegister類:

public class StepCounterSensorRegister extends Service implements SensorEventListener {

SensorManager sensorManager;
Sensor sensor;
long globalSteps;
boolean flag = false;


@Override
public void onCreate(){

}

public int onStartCommand(Intent intent, int flags, int startId) {
    //Must run in background thread
    Log.i("START","STEP_COUNTER_STARTED");
    registerSensor(sensorManager.SENSOR_DELAY_UI);
    return START_STICKY;
}

public void onSensorChanged(SensorEvent event) {

    if(!flag){

    }
    if(event.sensor.getType() == Sensor.TYPE_STEP_COUNTER){
        Log.i("STEPS DETECTED",""+globalSteps);
        globalSteps++;
    }
}

public boolean registerSensor(int accuracy) {
    sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
    try {
        sensor = sensorManager.getDefaultSensor(Sensor.TYPE_STEP_COUNTER);
    }catch (Exception e){
        Log.i("ERROR", e.getMessage());
    }

    if(sensor == null) {
        Log.i("FAILED","Sensor returned null");
        return false;
    }
    else {
        Log.i("SUCCESS", "Successfully registered sensor");
        sensorManager.registerListener(this, sensor, accuracy);
        return true;
    }

}

我看到的兩件事是您在清單中聲明了錯誤:

 <receiver android:name=".BootReceiver" android:exported="true" android:enabled="true"
        android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
        <intent-filtering>
            <action android:name="android.intent.action.BOOT_COMPLETED"/>
        </intent-filtering>

    </receiver>
  1. intent-filtering不存在,它是intent-filter
  2. 權限android:permission="android.permission.RECEIVE_BOOT_COMPLETED"在此處放置不當,請勿將其放在接收者標簽內。 您已經在上面定義了它。

並確保在Logcat中設置了正確的過濾器,並且使用了兩個不同的標簽“ BROADCAST”和“ FAIL”,也許這也出錯了。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM