com.polidea.rxandroidble2.exceptions.BleScanException: Сканирование не выполнено из-за сбоя регистрации приложения (код 6) Samsung Galaxy 8

В настоящее время я работаю над приложением, в котором используется устройство ble. Я создал службу и получил все разрешения, необходимые для приложения Bluetooth, и Bluetooth включен. Когда служба запускается, она сканирует устройства ble и подключается к ним. Но при сканировании иногда это исключение.

com.polidea.rxandroidble2.exceptions.BleScanException: сканирование не удалось, поскольку не удалось зарегистрировать приложение (код 6)

Я использую эту библиотеку

[https://github.com/Polidea/RxAndroidBle][1]

Вот мой сервис

package mypackage.name

import android.app.Service
import android.content.Intent
import android.os.Binder
import android.os.IBinder
import com.cambfit.android.bluetoothdriver.*
import com.cambfit.android.core.base.viewmodel.SingleLiveEvent
import com.orhanobut.logger.Logger
import com.polidea.rxandroidble2.RxBleClient
import com.polidea.rxandroidble2.RxBleDevice
import com.polidea.rxandroidble2.exceptions.BleScanException
import com.polidea.rxandroidble2.scan.ScanFilter
import com.polidea.rxandroidble2.scan.ScanResult
import com.polidea.rxandroidble2.scan.ScanSettings
import dagger.android.AndroidInjection
import io.reactivex.Observable
import io.reactivex.disposables.CompositeDisposable
import io.reactivex.disposables.Disposable
import java.util.concurrent.TimeUnit
import javax.inject.Inject

class BluetoothService : Service() {

    @Inject
    lateinit var rxBleClient: RxBleClient

    private val binder by lazy { BluetoothServiceBinder() }

    private val compositeDisposable by lazy { CompositeDisposable() }
    private lateinit var scanDisposable: Disposable

    override fun onCreate() {
        AndroidInjection.inject(this)
        super.onCreate()
        observeBlueToothState()
    }

    override fun onDestroy() {
        compositeDisposable.dispose()
        super.onDestroy()
    }

    override fun onBind(intent: Intent?): IBinder? {
        return binder
    }

    private fun observeBlueToothState() {

        scanDisposable = rxBleClient.observeStateChanges()
            .startWith(rxBleClient.state)
            .switchMap { state ->
                when (state) {
                    RxBleClient.State.READY -> {
                        Logger.d("READY")
                        return@switchMap scanDevices()
                    }

                    RxBleClient.State.BLUETOOTH_NOT_AVAILABLE -> {
                        Logger.e("BLUETOOTH_NOT_AVAILABLE")
                        return@switchMap Observable.empty<ScanResult>()
                    }

                    RxBleClient.State.LOCATION_PERMISSION_NOT_GRANTED -> {
                        Logger.w("LOCATION_PERMISSION_NOT_GRANTED")
                        return@switchMap Observable.empty<ScanResult>()
                    }

                    RxBleClient.State.BLUETOOTH_NOT_ENABLED -> {
                        Logger.w("BLUETOOTH_NOT_ENABLED")
                        binder.enableBluetoothEvent.call()
                        return@switchMap Observable.empty<ScanResult>()
                    }

                    RxBleClient.State.LOCATION_SERVICES_NOT_ENABLED -> {
                        Logger.w("LOCATION_SERVICES_NOT_ENABLED")
                        return@switchMap Observable.empty<ScanResult>()
                    }

                    else -> {
                        Logger.w("OTHER")
                        return@switchMap Observable.empty<ScanResult>()
                    }
                }
            }
            .filter { scanResult -> scanResult.bleDevice.name != null }
            .subscribe({ scanResult ->

                //Logger.d(scanResult.toString())


            }, { throwable ->
                throwable.printStackTrace()
            })

        compositeDisposable.add(scanDisposable)
    }

    private fun scanDevices(): Observable<ScanResult> {
        return rxBleClient.scanBleDevices(ScanSettings.Builder().build(), ScanFilter.Builder().build())
            .retryWhen { errors ->
                errors.flatMap { error ->
                    if (error is BleScanException) return@flatMap Observable.timer(30, TimeUnit.SECONDS)
                    else return@flatMap Observable.error<Exception>(error)
                }
            }
    }

}

Любая помощь будет оценена по достоинству. Спасибо.


person Anik Dey    schedule 16.10.2019    source источник


Ответы (1)


Похоже, это ошибка Android и/или чрезмерное сканирование, выполняемое в других местах телефона. Быстрый поиск в Google показывает, что это известная проблема.

По сути, у вашего телефона заканчиваются системные ресурсы.

Это не похоже на то, что можно программно исправить в вашем коде.

Обходной путь — выключить/включить BT, чтобы ресурсы BT очищались.

person Dariusz Seweryn    schedule 22.10.2019
comment
Просто хотел добавить к этому. Я вижу это на Galaxy S5E. Я выключал и включал BT, чтобы добраться до этого состояния, поэтому повторное отключение не помогло. Повторное сканирование позже сработало (через ~ 10 секунд) - person behelit; 20.11.2019