Приемник вещания и служба не работают при закрытии приложения (android)

Извините всех. Во-первых, мой приемник не работает, когда приложение закрыто на моих устройствах из-за AUTO START MANAGER. Я чувствую себя глупо ... И я узнал очень важные вещи, когда пытался это решить.

Во-первых, запрос разрешения Android 6.0 широковещательных приемников не работает в Android 6.0 Marshmallow < / а>

Во-вторых: Android - дублированная трансляция состояния телефона на Lollipop.

http://www.skoumal.net/en/android-duplicated-phone-state-broadcast-on-lollipop/

Спасибо...

Я новичок в Android и хочу изучить BroadcastReceiver & Service. Этот код BroadcastReceiver прослушивает снятую трубку и состояние ожидания моего телефона и отправляет намерение. Служба что-то делает. Пока приложение работает все нормально. После закрытия приложения BroadcastReceiver и Сервис не работают.

Обновление: также я замечаю, что при запуске приложения и во всем нормальном режиме служба запускалась дважды и дважды останавливалась.

Я вижу это сообщение во время запуска службы:

  1. Toast.makeText (контекст, "" + phoneState + "" + запись, Toast.LENGTH_SHORT) .show ();

  2. Toast.makeText (getApplicationContext (), «сервисная работа», Toast.LENGTH_SHORT) .show ();

снова 1. Toast.makeText (context, "" + phoneState + "" + record, Toast.LENGTH_SHORT) .show ();

еще раз 2. Toast.makeText (getApplicationContext (), "сервисная работа", Toast.LENGTH_SHORT) .show ()

Я вижу это сообщение, пока служба останавливается:

  1. Toast.makeText (контекст, "" + phoneState + "" + запись, Toast.LENGTH_SHORT) .show ();

  2. Toast.makeText (getApplicationContext (), «служба будет остановлена.», Toast.LENGTH_SHORT) .show ();

снова 1. Toast.makeText (context, "" + phoneState + "" + record, Toast.LENGTH_SHORT) .show ();

снова 2. Toast.makeText (getApplicationContext (), «служба будет остановлена.», Toast.LENGTH_SHORT) .show ();

Все повторяется.

Манифест:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="devapp.deneme">

    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
    <uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS"/>

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:enabled="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <service
            android:name=".MyService"
            android:enabled="true"
            android:exported="true" />

        <receiver
            android:name="devapp.deneme.MyReceiver"
            android:enabled="true"
            android:exported="true">
            <intent-filter>
                <action android:name="android.intent.action.NEW_OUTGOING_CALL"/>
                <action android:name="android.intent.action.PHONE_STATE"/>
            </intent-filter>
        </receiver>
    </application>

</manifest>

Приемник вещания

package devapp.deneme;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.TelephonyManager;
import android.widget.Toast;

public class MyReceiver extends BroadcastReceiver {

    public MyReceiver(){

    }

    Intent service = null;
    Bundle bundle = null;
    String phoneState = null;
    boolean record = false;

    @Override
    public void onReceive(Context context, Intent intent) {

        service = new Intent(context, MyService.class);
        bundle = intent.getExtras();
        phoneState = bundle.getString(TelephonyManager.EXTRA_STATE);

        if (phoneState!=null){
            if ((phoneState.equals(TelephonyManager.EXTRA_STATE_OFFHOOK))||(phoneState.equals(TelephonyManager.EXTRA_STATE_IDLE))){
                service.putExtra("durum", phoneState);
                if (phoneState.equals(TelephonyManager.EXTRA_STATE_OFFHOOK)) {
                    record = true;
                }
                else {
                    record = false;
                }
            }
            service.putExtra("record",record);
            Toast.makeText(context, "" +phoneState +" " +record, Toast.LENGTH_SHORT).show();
            context.startService(service);
        }
    }
}

Услуга

package devapp.deneme;

import android.app.Service;
import android.content.Intent;
import android.os.IBinder;
import android.widget.Toast;

public class MyService extends Service {
    public MyService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    public int onStartCommand (Intent intent, int flags, int startId){

        boolean record = intent.getBooleanExtra("record", false);
        if (record) {
            Toast.makeText(getApplicationContext(), "service work", Toast.LENGTH_SHORT).show();
        }
        else {
            Toast.makeText(getApplicationContext(), "service will be stopped.", Toast.LENGTH_SHORT).show();
            stopSelf();
        }
        return super.onStartCommand(intent, flags, startId);
    }
}

person Murat    schedule 25.07.2016    source источник
comment
Под закрытием, если вы имеете в виду принудительное закрытие, это не сработает.   -  person Shaishav    schedule 25.07.2016
comment
С помощью диспетчера задач сдвиньте вправо или влево   -  person Murat    schedule 25.07.2016
comment
Все дело в уровне API и разрешении: stackoverflow.com/questions/33036523/   -  person Murat    schedule 26.07.2016


Ответы (2)


Вы должны добавить следующее в класс обслуживания

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {

           // your business logic 

        return START_STICKY;
}
person Parvinder Maan    schedule 06.12.2017

Запускаем сервис как липкий. Измените свой onStartCommand метод обслуживания, как показано ниже

public int onStartCommand (Intent intent, int flags, int startId){

    boolean record = intent.getBooleanExtra("record", false);
    if (record) {
        Toast.makeText(getApplicationContext(), "service work", Toast.LENGTH_SHORT).show();
    }
    else {
        Toast.makeText(getApplicationContext(), "service will be stopped.", Toast.LENGTH_SHORT).show();
        stopSelf();
    }
     return START_STICKY;  // or START_REDELIVER_INTENT or START_STICKY_COMPATIBILITY
}
person Mithun Sarker Shuvro    schedule 25.07.2016
comment
Я отработал это 2 дня. Я пробовал их раньше. На мой взгляд проблема с ресивером. Но я не могу решить. Также я пробовал разные два устройства. - person Murat; 25.07.2016
comment
Все дело в уровне API и разрешении: stackoverflow.com/questions/33036523/ - person Murat; 26.07.2016