mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2024-12-27 11:05:49 +01:00
Drastic rewrite of discovery activity.
- get rid of pre-lollipop BLE discovery (nowadays we support only lollipop and above) and related preference - get rid of the sequenced BT-then-BLE-scan that wasn't working reliably anyway and was causing a recursion - add a caching layer for already processed devices (the same device is found multiple times during discovery) - add a caching layer for device name in GBDeviceCandidate (many coordinators will ask for it, and it's a very expensive operation)
This commit is contained in:
parent
5d78b778e3
commit
7f24ba8ffb
@ -116,7 +116,7 @@ public class GBApplication extends Application {
|
|||||||
private static SharedPreferences sharedPrefs;
|
private static SharedPreferences sharedPrefs;
|
||||||
private static final String PREFS_VERSION = "shared_preferences_version";
|
private static final String PREFS_VERSION = "shared_preferences_version";
|
||||||
//if preferences have to be migrated, increment the following and add the migration logic in migratePrefs below; see http://stackoverflow.com/questions/16397848/how-can-i-migrate-android-preferences-with-a-new-version
|
//if preferences have to be migrated, increment the following and add the migration logic in migratePrefs below; see http://stackoverflow.com/questions/16397848/how-can-i-migrate-android-preferences-with-a-new-version
|
||||||
private static final int CURRENT_PREFS_VERSION = 18;
|
private static final int CURRENT_PREFS_VERSION = 19;
|
||||||
|
|
||||||
private static LimitedQueue mIDSenderLookup = new LimitedQueue(16);
|
private static LimitedQueue mIDSenderLookup = new LimitedQueue(16);
|
||||||
private static Prefs prefs;
|
private static Prefs prefs;
|
||||||
@ -1183,6 +1183,11 @@ public class GBApplication extends Application {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.w(TAG, "error acquiring DB lock");
|
Log.w(TAG, "error acquiring DB lock");
|
||||||
}
|
}
|
||||||
|
if (oldVersion < 19) {
|
||||||
|
//remove old ble scanning prefences, now unsupported
|
||||||
|
editor.remove("disable_new_ble_scanning");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
editor.putString(PREFS_VERSION, Integer.toString(CURRENT_PREFS_VERSION));
|
editor.putString(PREFS_VERSION, Integer.toString(CURRENT_PREFS_VERSION));
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
package nodomain.freeyourgadget.gadgetbridge.activities;
|
package nodomain.freeyourgadget.gadgetbridge.activities;
|
||||||
|
|
||||||
import static nodomain.freeyourgadget.gadgetbridge.util.GB.toast;
|
|
||||||
|
|
||||||
import android.Manifest;
|
import android.Manifest;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
@ -68,11 +66,14 @@ import org.slf4j.Logger;
|
|||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
import nodomain.freeyourgadget.gadgetbridge.GBApplication;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.R;
|
import nodomain.freeyourgadget.gadgetbridge.R;
|
||||||
@ -91,6 +92,8 @@ import nodomain.freeyourgadget.gadgetbridge.util.DeviceHelper;
|
|||||||
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
import nodomain.freeyourgadget.gadgetbridge.util.GB;
|
||||||
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
|
import nodomain.freeyourgadget.gadgetbridge.util.Prefs;
|
||||||
|
|
||||||
|
import static nodomain.freeyourgadget.gadgetbridge.util.GB.toast;
|
||||||
|
|
||||||
|
|
||||||
public class DiscoveryActivity extends AbstractGBActivity implements AdapterView.OnItemClickListener, AdapterView.OnItemLongClickListener, BondingInterface {
|
public class DiscoveryActivity extends AbstractGBActivity implements AdapterView.OnItemClickListener, AdapterView.OnItemLongClickListener, BondingInterface {
|
||||||
private static final Logger LOG = LoggerFactory.getLogger(DiscoveryActivity.class);
|
private static final Logger LOG = LoggerFactory.getLogger(DiscoveryActivity.class);
|
||||||
@ -98,10 +101,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
private final Handler handler = new Handler();
|
private final Handler handler = new Handler();
|
||||||
private final ArrayList<GBDeviceCandidate> deviceCandidates = new ArrayList<>();
|
private final ArrayList<GBDeviceCandidate> deviceCandidates = new ArrayList<>();
|
||||||
private ScanCallback newBLEScanCallback = null;
|
private ScanCallback newBLEScanCallback = null;
|
||||||
/**
|
|
||||||
* Use old BLE scanning
|
|
||||||
**/
|
|
||||||
private boolean oldBleScanning = false;
|
|
||||||
/**
|
/**
|
||||||
* If already bonded devices are to be ignored when scanning
|
* If already bonded devices are to be ignored when scanning
|
||||||
*/
|
*/
|
||||||
@ -111,27 +110,18 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
private ProgressBar bluetoothLEProgress;
|
private ProgressBar bluetoothLEProgress;
|
||||||
private DeviceCandidateAdapter deviceCandidateAdapter;
|
private DeviceCandidateAdapter deviceCandidateAdapter;
|
||||||
private GBDeviceCandidate deviceTarget;
|
private GBDeviceCandidate deviceTarget;
|
||||||
private final BluetoothAdapter.LeScanCallback leScanCallback = new BluetoothAdapter.LeScanCallback() {
|
|
||||||
@Override
|
|
||||||
public void onLeScan(BluetoothDevice device, int rssi, byte[] scanRecord) {
|
|
||||||
//logMessageContent(scanRecord);
|
|
||||||
handleDeviceFound(device, (short) rssi);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
private BluetoothAdapter adapter;
|
private BluetoothAdapter adapter;
|
||||||
|
private BluetoothLeScanner bluetoothLeScanner;
|
||||||
private Button startButton;
|
private Button startButton;
|
||||||
private Scanning isScanning = Scanning.SCANNING_OFF;
|
private boolean scanning;
|
||||||
private long selectedUnsupportedDeviceKey = DebugActivity.SELECT_DEVICE;
|
private long selectedUnsupportedDeviceKey = DebugActivity.SELECT_DEVICE;
|
||||||
|
private Set<BTUUIDPair> foundCandidates = new HashSet<>();
|
||||||
|
|
||||||
private final Runnable stopRunnable = new Runnable() {
|
private final Runnable stopRunnable = new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
if (isScanning == Scanning.SCANNING_BT_NEXT_BLE) {
|
|
||||||
// Start the next scan in the series
|
|
||||||
stopDiscovery();
|
stopDiscovery();
|
||||||
startDiscovery(Scanning.SCANNING_BLE);
|
LOG.info("Discovery stopped by thread timeout.");
|
||||||
} else {
|
|
||||||
stopDiscovery();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
private final BroadcastReceiver bluetoothReceiver = new BroadcastReceiver() {
|
private final BroadcastReceiver bluetoothReceiver = new BroadcastReceiver() {
|
||||||
@ -140,26 +130,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
switch (Objects.requireNonNull(intent.getAction())) {
|
switch (Objects.requireNonNull(intent.getAction())) {
|
||||||
case BluetoothAdapter.ACTION_DISCOVERY_STARTED: {
|
case BluetoothAdapter.ACTION_DISCOVERY_STARTED: {
|
||||||
LOG.debug("ACTION_DISCOVERY_STARTED");
|
LOG.debug("ACTION_DISCOVERY_STARTED");
|
||||||
if (isScanning != Scanning.SCANNING_BLE) {
|
|
||||||
if (isScanning != Scanning.SCANNING_BT_NEXT_BLE) {
|
|
||||||
setIsScanning(Scanning.SCANNING_BT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BluetoothAdapter.ACTION_DISCOVERY_FINISHED: {
|
|
||||||
LOG.debug("ACTION_DISCOVERY_FINISHED");
|
|
||||||
handler.post(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
// Continue with LE scan, if available
|
|
||||||
if (isScanning == Scanning.SCANNING_BT || isScanning == Scanning.SCANNING_BT_NEXT_BLE) {
|
|
||||||
checkAndRequestLocationPermission();
|
|
||||||
stopDiscovery();
|
|
||||||
startDiscovery(Scanning.SCANNING_BLE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case BluetoothAdapter.ACTION_STATE_CHANGED: {
|
case BluetoothAdapter.ACTION_STATE_CHANGED: {
|
||||||
@ -179,7 +149,7 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
short rssi = intent.getShortExtra(BluetoothDevice.EXTRA_RSSI, GBDevice.RSSI_UNKNOWN);
|
short rssi = intent.getShortExtra(BluetoothDevice.EXTRA_RSSI, GBDevice.RSSI_UNKNOWN);
|
||||||
Parcelable[] uuids = intent.getParcelableArrayExtra(BluetoothDevice.EXTRA_UUID);
|
Parcelable[] uuids = intent.getParcelableArrayExtra(BluetoothDevice.EXTRA_UUID);
|
||||||
ParcelUuid[] uuids2 = AndroidUtils.toParcelUuids(uuids);
|
ParcelUuid[] uuids2 = AndroidUtils.toParcelUuids(uuids);
|
||||||
handleDeviceFound(device, rssi, uuids2);
|
addToCandidateListIfNotAlreadyProcessed(device, rssi, uuids2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case BluetoothDevice.ACTION_BOND_STATE_CHANGED: {
|
case BluetoothDevice.ACTION_BOND_STATE_CHANGED: {
|
||||||
@ -246,7 +216,8 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
}
|
}
|
||||||
LOG.warn(result.getDevice().getName() + ": " +
|
LOG.warn(result.getDevice().getName() + ": " +
|
||||||
((scanRecord != null) ? scanRecord.getBytes().length : -1));
|
((scanRecord != null) ? scanRecord.getBytes().length : -1));
|
||||||
handleDeviceFound(result.getDevice(), (short) result.getRssi(), uuids);
|
addToCandidateListIfNotAlreadyProcessed(result.getDevice(), (short) result.getRssi(), uuids);
|
||||||
|
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
LOG.warn("Error handling scan result", e);
|
LOG.warn("Error handling scan result", e);
|
||||||
}
|
}
|
||||||
@ -299,7 +270,7 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
|
|
||||||
checkAndRequestLocationPermission();
|
checkAndRequestLocationPermission();
|
||||||
|
|
||||||
startDiscovery(Scanning.SCANNING_BT_NEXT_BLE);
|
startDiscovery();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onStartButtonClick(View button) {
|
public void onStartButtonClick(View button) {
|
||||||
@ -309,11 +280,7 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
} else {
|
} else {
|
||||||
deviceCandidates.clear();
|
deviceCandidates.clear();
|
||||||
deviceCandidateAdapter.notifyDataSetChanged();
|
deviceCandidateAdapter.notifyDataSetChanged();
|
||||||
if (GB.supportsBluetoothLE()) {
|
startDiscovery();
|
||||||
startDiscovery(Scanning.SCANNING_BT_NEXT_BLE);
|
|
||||||
} else {
|
|
||||||
startDiscovery(Scanning.SCANNING_BT);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -338,21 +305,21 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
@Override
|
@Override
|
||||||
protected void onDestroy() {
|
protected void onDestroy() {
|
||||||
unregisterBroadcastReceivers();
|
unregisterBroadcastReceivers();
|
||||||
stopAllDiscovery();
|
stopDiscovery();
|
||||||
super.onDestroy();
|
super.onDestroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onStop() {
|
protected void onStop() {
|
||||||
unregisterBroadcastReceivers();
|
unregisterBroadcastReceivers();
|
||||||
stopAllDiscovery();
|
stopDiscovery();
|
||||||
super.onStop();
|
super.onStop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onPause() {
|
protected void onPause() {
|
||||||
unregisterBroadcastReceivers();
|
unregisterBroadcastReceivers();
|
||||||
stopAllDiscovery();
|
stopDiscovery();
|
||||||
super.onPause();
|
super.onPause();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,19 +330,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
super.onResume();
|
super.onResume();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stopAllDiscovery() {
|
|
||||||
try {
|
|
||||||
stopBTDiscovery();
|
|
||||||
if (oldBleScanning) {
|
|
||||||
stopOldBLEDiscovery();
|
|
||||||
} else {
|
|
||||||
stopBLEDiscovery();
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
LOG.warn("Error stopping discovery", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void handleDeviceFound(BluetoothDevice device, short rssi) {
|
private void handleDeviceFound(BluetoothDevice device, short rssi) {
|
||||||
if (device.getName() != null) {
|
if (device.getName() != null) {
|
||||||
if (handleDeviceFound(device, rssi, null)) {
|
if (handleDeviceFound(device, rssi, null)) {
|
||||||
@ -390,7 +344,20 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
handleDeviceFound(device, rssi, uuids);
|
addToCandidateListIfNotAlreadyProcessed(device, rssi, uuids);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addToCandidateListIfNotAlreadyProcessed(BluetoothDevice device, short rssi, ParcelUuid[] uuids) {
|
||||||
|
BTUUIDPair btuuidPair = new BTUUIDPair(device, uuids);
|
||||||
|
if(foundCandidates.contains(btuuidPair)) {
|
||||||
|
// LOG.info("candidate already processed, skipping");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (handleDeviceFound(device, rssi, uuids)) {
|
||||||
|
//device was considered a candidate, do not process it again unless something changed
|
||||||
|
foundCandidates.add(btuuidPair);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean handleDeviceFound(BluetoothDevice device, short rssi, ParcelUuid[] uuids) {
|
private boolean handleDeviceFound(BluetoothDevice device, short rssi, ParcelUuid[] uuids) {
|
||||||
@ -424,85 +391,39 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startDiscovery(Scanning what) {
|
private void startDiscovery() {
|
||||||
if (isScanning()) {
|
if (isScanning()) {
|
||||||
LOG.warn("Not starting discovery, because already scanning.");
|
LOG.warn("Not starting discovery, because already scanning.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG.info("Starting discovery: " + what);
|
LOG.info("Starting discovery");
|
||||||
startButton.setText(getString(R.string.discovery_stop_scanning));
|
startButton.setText(getString(R.string.discovery_stop_scanning));
|
||||||
if (ensureBluetoothReady() && isScanning == Scanning.SCANNING_OFF) {
|
if (ensureBluetoothReady()) {
|
||||||
if (what == Scanning.SCANNING_BT || what == Scanning.SCANNING_BT_NEXT_BLE) {
|
if (GB.supportsBluetoothLE()) {
|
||||||
startBTDiscovery(what);
|
|
||||||
} else if (what == Scanning.SCANNING_BLE && GB.supportsBluetoothLE()) {
|
|
||||||
if (oldBleScanning) {
|
|
||||||
startOldBTLEDiscovery();
|
|
||||||
} else {
|
|
||||||
startBTLEDiscovery();
|
startBTLEDiscovery();
|
||||||
}
|
startBTDiscovery();
|
||||||
} else {
|
} else {
|
||||||
discoveryFinished();
|
startBTDiscovery();
|
||||||
toast(DiscoveryActivity.this, getString(R.string.discovery_enable_bluetooth), Toast.LENGTH_SHORT, GB.ERROR);
|
|
||||||
}
|
}
|
||||||
|
setScanning(true);
|
||||||
} else {
|
} else {
|
||||||
discoveryFinished();
|
|
||||||
toast(DiscoveryActivity.this, getString(R.string.discovery_enable_bluetooth), Toast.LENGTH_SHORT, GB.ERROR);
|
toast(DiscoveryActivity.this, getString(R.string.discovery_enable_bluetooth), Toast.LENGTH_SHORT, GB.ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stopDiscovery() {
|
private void stopDiscovery() {
|
||||||
LOG.info("Stopping discovery");
|
LOG.info("Stopping discovery");
|
||||||
if (isScanning()) {
|
|
||||||
Scanning wasScanning = isScanning;
|
|
||||||
if (wasScanning == Scanning.SCANNING_BT || wasScanning == Scanning.SCANNING_BT_NEXT_BLE) {
|
|
||||||
stopBTDiscovery();
|
stopBTDiscovery();
|
||||||
} else if (wasScanning == Scanning.SCANNING_BLE) {
|
|
||||||
if (oldBleScanning) {
|
|
||||||
stopOldBLEDiscovery();
|
|
||||||
} else {
|
|
||||||
stopBLEDiscovery();
|
stopBLEDiscovery();
|
||||||
}
|
setScanning(false);
|
||||||
}
|
|
||||||
|
|
||||||
discoveryFinished();
|
|
||||||
handler.removeMessages(0, stopRunnable);
|
handler.removeMessages(0, stopRunnable);
|
||||||
} else {
|
|
||||||
discoveryFinished();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isScanning() {
|
private boolean isScanning() {
|
||||||
return isScanning != Scanning.SCANNING_OFF;
|
return scanning ;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startOldBTLEDiscovery() {
|
|
||||||
LOG.info("Starting old BLE discovery");
|
|
||||||
|
|
||||||
handler.removeMessages(0, stopRunnable);
|
|
||||||
handler.sendMessageDelayed(getPostMessage(stopRunnable), SCAN_DURATION);
|
|
||||||
if (adapter.startLeScan(leScanCallback)) {
|
|
||||||
LOG.info("Old Bluetooth LE scan started successfully");
|
|
||||||
bluetoothLEProgress.setVisibility(View.VISIBLE);
|
|
||||||
setIsScanning(Scanning.SCANNING_BLE);
|
|
||||||
} else {
|
|
||||||
LOG.info("Old Bluetooth LE scan starting failed");
|
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void stopOldBLEDiscovery() {
|
|
||||||
if (adapter != null) {
|
|
||||||
adapter.stopLeScan(leScanCallback);
|
|
||||||
LOG.info("Stopped old BLE discovery");
|
|
||||||
}
|
|
||||||
|
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* New BTLE Discovery uses startScan (List<ScanFilter> filters,
|
|
||||||
ScanSettings settings,
|
|
||||||
ScanCallback callback) */
|
|
||||||
private void startBTLEDiscovery() {
|
private void startBTLEDiscovery() {
|
||||||
LOG.info("Starting BLE discovery");
|
LOG.info("Starting BLE discovery");
|
||||||
|
|
||||||
@ -515,7 +436,7 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
|
|
||||||
LOG.debug("Bluetooth LE discovery started successfully");
|
LOG.debug("Bluetooth LE discovery started successfully");
|
||||||
bluetoothLEProgress.setVisibility(View.VISIBLE);
|
bluetoothLEProgress.setVisibility(View.VISIBLE);
|
||||||
setIsScanning(Scanning.SCANNING_BLE);
|
setScanning(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stopBLEDiscovery() {
|
private void stopBLEDiscovery() {
|
||||||
@ -540,15 +461,13 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
}
|
}
|
||||||
|
|
||||||
LOG.debug("Stopped BLE discovery");
|
LOG.debug("Stopped BLE discovery");
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts a regular Bluetooth scan
|
* Starts a regular Bluetooth scan
|
||||||
*
|
*
|
||||||
* @param what The scan type, only either SCANNING_BT or SCANNING_BT_NEXT_BLE!
|
|
||||||
*/
|
*/
|
||||||
private void startBTDiscovery(Scanning what) {
|
private void startBTDiscovery() {
|
||||||
LOG.info("Starting BT discovery");
|
LOG.info("Starting BT discovery");
|
||||||
try {
|
try {
|
||||||
// LineageOS quirk, can't start scan properly,
|
// LineageOS quirk, can't start scan properly,
|
||||||
@ -561,10 +480,8 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
if (adapter.startDiscovery()) {
|
if (adapter.startDiscovery()) {
|
||||||
LOG.debug("Discovery started successfully");
|
LOG.debug("Discovery started successfully");
|
||||||
bluetoothProgress.setVisibility(View.VISIBLE);
|
bluetoothProgress.setVisibility(View.VISIBLE);
|
||||||
setIsScanning(what);
|
|
||||||
} else {
|
} else {
|
||||||
LOG.error("Discovery starting failed");
|
LOG.error("Discovery starting failed");
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -573,26 +490,16 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
adapter.cancelDiscovery();
|
adapter.cancelDiscovery();
|
||||||
LOG.info("Stopped BT discovery");
|
LOG.info("Stopped BT discovery");
|
||||||
}
|
}
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void discoveryFinished() {
|
public void setScanning(boolean scanning) {
|
||||||
if (isScanning != Scanning.SCANNING_OFF) {
|
this.scanning = scanning;
|
||||||
LOG.warn("Scan was not properly stopped: " + isScanning);
|
if (scanning) {
|
||||||
}
|
startButton.setText(getString(R.string.discovery_stop_scanning));
|
||||||
|
} else {
|
||||||
setIsScanning(Scanning.SCANNING_OFF);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setIsScanning(Scanning to) {
|
|
||||||
this.isScanning = to;
|
|
||||||
|
|
||||||
if (isScanning == Scanning.SCANNING_OFF) {
|
|
||||||
startButton.setText(getString(R.string.discovery_start_scanning));
|
startButton.setText(getString(R.string.discovery_start_scanning));
|
||||||
bluetoothProgress.setVisibility(View.GONE);
|
bluetoothProgress.setVisibility(View.GONE);
|
||||||
bluetoothLEProgress.setVisibility(View.GONE);
|
bluetoothLEProgress.setVisibility(View.GONE);
|
||||||
} else {
|
|
||||||
startButton.setText(getString(R.string.discovery_stop_scanning));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -606,8 +513,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
bluetoothProgress.setVisibility(View.GONE);
|
bluetoothProgress.setVisibility(View.GONE);
|
||||||
bluetoothLEProgress.setVisibility(View.GONE);
|
bluetoothLEProgress.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
discoveryFinished();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean checkBluetoothAvailable() {
|
private boolean checkBluetoothAvailable() {
|
||||||
@ -631,6 +536,8 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
this.adapter = adapter;
|
this.adapter = adapter;
|
||||||
|
if(GB.supportsBluetoothLE())
|
||||||
|
this.bluetoothLeScanner = adapter.getBluetoothLeScanner();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -717,7 +624,7 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
} catch (Exception ex) {
|
} catch (Exception ex) {
|
||||||
LOG.error("Exception when checking location status: ", ex);
|
LOG.error("Exception when checking location status: ", ex);
|
||||||
}
|
}
|
||||||
LOG.error("Problem with permissions, returning");
|
LOG.info("Permissions seems to be fine for scanning");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -896,7 +803,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
bluetoothIntents.addAction(BluetoothDevice.ACTION_UUID);
|
bluetoothIntents.addAction(BluetoothDevice.ACTION_UUID);
|
||||||
bluetoothIntents.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
|
bluetoothIntents.addAction(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
|
||||||
bluetoothIntents.addAction(BluetoothAdapter.ACTION_DISCOVERY_STARTED);
|
bluetoothIntents.addAction(BluetoothAdapter.ACTION_DISCOVERY_STARTED);
|
||||||
bluetoothIntents.addAction(BluetoothAdapter.ACTION_DISCOVERY_FINISHED);
|
|
||||||
bluetoothIntents.addAction(BluetoothAdapter.ACTION_STATE_CHANGED);
|
bluetoothIntents.addAction(BluetoothAdapter.ACTION_STATE_CHANGED);
|
||||||
|
|
||||||
registerReceiver(bluetoothReceiver, bluetoothIntents);
|
registerReceiver(bluetoothReceiver, bluetoothIntents);
|
||||||
@ -906,10 +812,6 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
Prefs prefs = GBApplication.getPrefs();
|
Prefs prefs = GBApplication.getPrefs();
|
||||||
ignoreBonded = prefs.getBoolean("ignore_bonded_devices", true);
|
ignoreBonded = prefs.getBoolean("ignore_bonded_devices", true);
|
||||||
discoverUnsupported = prefs.getBoolean("discover_unsupported_devices", false);
|
discoverUnsupported = prefs.getBoolean("discover_unsupported_devices", false);
|
||||||
oldBleScanning = prefs.getBoolean("disable_new_ble_scanning", false);
|
|
||||||
if (oldBleScanning) {
|
|
||||||
LOG.info("New BLE scanning disabled via settings, using old method");
|
|
||||||
}
|
|
||||||
int level = prefs.getInt("scanning_intensity", 1);
|
int level = prefs.getInt("scanning_intensity", 1);
|
||||||
switch (level) {
|
switch (level) {
|
||||||
case 0:
|
case 0:
|
||||||
@ -937,22 +839,28 @@ public class DiscoveryActivity extends AbstractGBActivity implements AdapterView
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
private enum Scanning {
|
private class BTUUIDPair {
|
||||||
/**
|
private final BluetoothDevice bluetoothDevice;
|
||||||
* Regular Bluetooth scan
|
private final ParcelUuid[] parcelUuid;
|
||||||
*/
|
|
||||||
SCANNING_BT,
|
public BTUUIDPair(BluetoothDevice bluetoothDevice, ParcelUuid[] parcelUuid) {
|
||||||
/**
|
this.bluetoothDevice = bluetoothDevice;
|
||||||
* Regular Bluetooth scan but when ends, start BLE scan
|
this.parcelUuid = parcelUuid;
|
||||||
*/
|
}
|
||||||
SCANNING_BT_NEXT_BLE,
|
|
||||||
/**
|
@Override
|
||||||
* Regular BLE scan
|
public boolean equals(Object o) {
|
||||||
*/
|
if (this == o) return true;
|
||||||
SCANNING_BLE,
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
/**
|
BTUUIDPair that = (BTUUIDPair) o;
|
||||||
* Scanning has ended or hasn't been started
|
return bluetoothDevice.equals(that.bluetoothDevice) && Arrays.equals(parcelUuid, that.parcelUuid);
|
||||||
*/
|
}
|
||||||
SCANNING_OFF
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
int result = Objects.hash(bluetoothDevice);
|
||||||
|
result = 31 * result + Arrays.hashCode(parcelUuid);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,6 +50,7 @@ public class GBDeviceCandidate implements Parcelable {
|
|||||||
private final short rssi;
|
private final short rssi;
|
||||||
private final ParcelUuid[] serviceUuids;
|
private final ParcelUuid[] serviceUuids;
|
||||||
private DeviceType deviceType = DeviceType.UNKNOWN;
|
private DeviceType deviceType = DeviceType.UNKNOWN;
|
||||||
|
private String deviceName;
|
||||||
|
|
||||||
public GBDeviceCandidate(BluetoothDevice device, short rssi, ParcelUuid[] serviceUuids) {
|
public GBDeviceCandidate(BluetoothDevice device, short rssi, ParcelUuid[] serviceUuids) {
|
||||||
this.device = device;
|
this.device = device;
|
||||||
@ -137,7 +138,9 @@ public class GBDeviceCandidate implements Parcelable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
String deviceName = null;
|
if (this.deviceName != null ) {
|
||||||
|
return this.deviceName;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
Method method = device.getClass().getMethod("getAliasName");
|
Method method = device.getClass().getMethod("getAliasName");
|
||||||
if (method != null) {
|
if (method != null) {
|
||||||
|
@ -10,12 +10,6 @@
|
|||||||
android:layout="@layout/preference_checkbox"
|
android:layout="@layout/preference_checkbox"
|
||||||
android:summary="@string/ignore_bonded_devices_description"
|
android:summary="@string/ignore_bonded_devices_description"
|
||||||
android:title="@string/ignore_bonded_devices" />
|
android:title="@string/ignore_bonded_devices" />
|
||||||
<CheckBoxPreference
|
|
||||||
android:defaultValue="false"
|
|
||||||
android:key="disable_new_ble_scanning"
|
|
||||||
android:layout="@layout/preference_checkbox"
|
|
||||||
android:summary="@string/pref_summary_disable_new_ble_scanning"
|
|
||||||
android:title="@string/pref_disable_new_ble_scanning" />
|
|
||||||
<CheckBoxPreference
|
<CheckBoxPreference
|
||||||
android:defaultValue="false"
|
android:defaultValue="false"
|
||||||
android:key="enable_companiondevice_pairing"
|
android:key="enable_companiondevice_pairing"
|
||||||
|
Loading…
Reference in New Issue
Block a user