В настоящее время я работаю в приложении, которое включает в себя все устройства. Я создал службу и получил все разрешения, которые требуются приложению Bluetooth, и Bluetooth включен. Когда служба запускается, она сканирует все устройства и подключается к ней. Но при сканировании иногда это дает мне это исключение.
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)
}
}
}
}
Любая помощь будет оценена. Благодарю.