mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-15 12:17:33 +01:00
Attempt to fix connection problems on Samsung devices
This commit is contained in:
parent
7b709dd975
commit
a2bd8212f6
@ -26,6 +26,8 @@ import android.bluetooth.BluetoothGattDescriptor;
|
|||||||
import android.bluetooth.BluetoothGattService;
|
import android.bluetooth.BluetoothGattService;
|
||||||
import android.bluetooth.BluetoothProfile;
|
import android.bluetooth.BluetoothProfile;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.Looper;
|
||||||
import android.support.annotation.Nullable;
|
import android.support.annotation.Nullable;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
@ -38,6 +40,7 @@ import java.util.concurrent.BlockingQueue;
|
|||||||
import java.util.concurrent.CountDownLatch;
|
import java.util.concurrent.CountDownLatch;
|
||||||
import java.util.concurrent.LinkedBlockingQueue;
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
|
|
||||||
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.Logging;
|
import nodomain.freeyourgadget.gadgetbridge.Logging;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice.State;
|
import nodomain.freeyourgadget.gadgetbridge.impl.GBDevice.State;
|
||||||
@ -177,7 +180,11 @@ public final class BtLEQueue {
|
|||||||
BluetoothDevice remoteDevice = mBluetoothAdapter.getRemoteDevice(mGbDevice.getAddress());
|
BluetoothDevice remoteDevice = mBluetoothAdapter.getRemoteDevice(mGbDevice.getAddress());
|
||||||
synchronized (mGattMonitor) {
|
synchronized (mGattMonitor) {
|
||||||
// connectGatt with true doesn't really work ;( too often connection problems
|
// connectGatt with true doesn't really work ;( too often connection problems
|
||||||
mBluetoothGatt = remoteDevice.connectGatt(mContext, false, internalGattCallback);
|
if (GBApplication.isRunningMarshmallowOrLater()) {
|
||||||
|
mBluetoothGatt = remoteDevice.connectGatt(mContext, false, internalGattCallback, BluetoothDevice.TRANSPORT_LE);
|
||||||
|
} else {
|
||||||
|
mBluetoothGatt = remoteDevice.connectGatt(mContext, false, internalGattCallback);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
boolean result = mBluetoothGatt != null;
|
boolean result = mBluetoothGatt != null;
|
||||||
if (result) {
|
if (result) {
|
||||||
@ -371,8 +378,16 @@ public final class BtLEQueue {
|
|||||||
LOG.info("Using cached services, skipping discovery");
|
LOG.info("Using cached services, skipping discovery");
|
||||||
onServicesDiscovered(gatt, BluetoothGatt.GATT_SUCCESS);
|
onServicesDiscovered(gatt, BluetoothGatt.GATT_SUCCESS);
|
||||||
} else {
|
} else {
|
||||||
LOG.info("Attempting to start service discovery:" +
|
LOG.info("Attempting to start service discovery");
|
||||||
gatt.discoverServices());
|
// discover services in the main thread (appears to fix Samsung connection problems)
|
||||||
|
new Handler(Looper.getMainLooper()).post(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (mBluetoothGatt != null) {
|
||||||
|
mBluetoothGatt.discoverServices();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BluetoothProfile.STATE_DISCONNECTED:
|
case BluetoothProfile.STATE_DISCONNECTED:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user