summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Jan Mulder <jlmulder@xs4all.nl>2017-06-02 14:06:11 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-06-02 11:31:00 -0700
commitdbd1d1f41a84f1cdb48367087f1372ca7612e9c9 (patch)
tree56568f0364f15e65bbfe3b15a7398a562cd8aa11
parent3b4091a0b9fd8d2e0486390c90971e69e0a4749c (diff)
downloadsubsurface-dbd1d1f41a84f1cdb48367087f1372ca7612e9c9.tar.gz
Android BT: generalize pairing data
This adds a list of paired BT devices to the QMLManager class. In addition, a very simple implementation is made of getting the paired BT devices on Linux, so that we can test further processing of selecting the proper devices, in a mobile-on-desktop situation. Signed-off-by: Jan Mulder <jlmulder@xs4all.nl>
-rw-r--r--mobile-widgets/qmlmanager.cpp53
-rw-r--r--mobile-widgets/qmlmanager.h7
2 files changed, 38 insertions, 22 deletions
diff --git a/mobile-widgets/qmlmanager.cpp b/mobile-widgets/qmlmanager.cpp
index 10b72d9f9..005c5cfb3 100644
--- a/mobile-widgets/qmlmanager.cpp
+++ b/mobile-widgets/qmlmanager.cpp
@@ -96,17 +96,23 @@ QMLManager::QMLManager() : m_locationServiceEnabled(false),
#if defined(BT_SUPPORT)
if (localBtDevice.isValid() &&
localBtDevice.hostMode() == QBluetoothLocalDevice::HostConnectable) {
- QStringList pairedBT = getBluetoothDevices();
-
- for (int i = 0; i < pairedBT.length(); i++) {
- qDebug() << "Paired = " << pairedBT[i];
- }
-
+ btPairedDevices.clear();
QString localDeviceName = "localDevice " + localBtDevice.name() + " is valid, starting discovery";
appendTextToLog(localDeviceName.toUtf8().data());
+#if defined(Q_OS_LINUX)
discoveryAgent = new QBluetoothDeviceDiscoveryAgent(this);
connect(discoveryAgent, &QBluetoothDeviceDiscoveryAgent::deviceDiscovered, this, &QMLManager::btDeviceDiscovered);
discoveryAgent->start();
+#endif
+#if defined(Q_OS_ANDROID)
+ getBluetoothDevices();
+#endif
+ for (int i = 0; i < btPairedDevices.length(); i++) {
+ qDebug() << "Paired =" << btPairedDevices[i].name << btPairedDevices[i].address.toString();
+ }
+#if defined(Q_OS_LINUX)
+ discoveryAgent->stop();
+#endif
} else {
appendTextToLog("localBtDevice isn't valid");
}
@@ -219,7 +225,13 @@ extern void addBtUuid(QBluetoothUuid uuid);
void QMLManager::btDeviceDiscovered(const QBluetoothDeviceInfo &device)
{
+ btPairedDevice this_d;
+ this_d.address = device.address();
+ this_d.name = device.name();
+ btPairedDevices.append(this_d);
+
QString newDevice = device.name();
+
// all the HW OSTC BT computers show up as "OSTC" + some other text, depending on model
if (newDevice.startsWith("OSTC"))
newDevice = "OSTC 3";
@@ -1608,29 +1620,27 @@ QStringList QMLManager::getDCListFromVendor(const QString& vendor)
return productList[vendor];
}
-//
-// As Qt is not able to pull the pairing data from a device, a lengthy
-// discovery process is needed to see what devices are paired. On
+// Android: As Qt is not able to pull the pairing data from a device, i
+// a lengthy discovery process is needed to see what devices are paired. On
// https://forum.qt.io/topic/46075/solved-bluetooth-list-paired-devices
// user s.frings74 does, however, present a solution to this using JNI.
// Currently, this code is taken "as is".
-//
-QStringList QMLManager::getBluetoothDevices()
+
+void QMLManager::getBluetoothDevices()
{
- QStringList result;
-#if defined(Q_OS_ANDROID)
- QString fmt("%1 %2");
+#if defined(Q_OS_ANDROID) && defined(BT_SUPPORT)
+ struct QMLManager::btPairedDevice result;
// Query via Android Java API.
// returns a BluetoothAdapter
QAndroidJniObject adapter=QAndroidJniObject::callStaticObjectMethod("android/bluetooth/BluetoothAdapter","getDefaultAdapter","()Landroid/bluetooth/BluetoothAdapter;");
if (checkException("BluetoothAdapter.getDefaultAdapter()", &adapter)) {
- return result;
+ return;
}
// returns a Set<BluetoothDevice>
QAndroidJniObject pairedDevicesSet=adapter.callObjectMethod("getBondedDevices","()Ljava/util/Set;");
if (checkException("BluetoothAdapter.getBondedDevices()", &pairedDevicesSet)) {
- return result;
+ return;
}
jint size=pairedDevicesSet.callMethod<jint>("size");
checkException("Set<BluetoothDevice>.size()", &pairedDevicesSet);
@@ -1638,7 +1648,7 @@ QStringList QMLManager::getBluetoothDevices()
// returns an Iterator<BluetoothDevice>
QAndroidJniObject iterator=pairedDevicesSet.callObjectMethod("iterator","()Ljava/util/Iterator;");
if (checkException("Set<BluetoothDevice>.iterator()", &iterator)) {
- return result;
+ return;
}
for (int i = 0; i < size; i++) {
// returns a BluetoothDevice
@@ -1646,13 +1656,14 @@ QStringList QMLManager::getBluetoothDevices()
if (checkException("Iterator<BluetoothDevice>.next()", &dev)) {
continue;
}
- QString address=dev.callObjectMethod("getAddress","()Ljava/lang/String;").toString(); // returns a String
- QString name=dev.callObjectMethod("getName", "()Ljava/lang/String;").toString(); // returns a String
- result.append(fmt.arg(address).arg(name));
+
+ result.address = QBluetoothAddress(dev.callObjectMethod("getAddress","()Ljava/lang/String;").toString());
+ result.name = dev.callObjectMethod("getName", "()Ljava/lang/String;").toString();
+
+ btPairedDevices.append(result);
}
}
#endif
- return result;
}
#if defined(Q_OS_ANDROID)
diff --git a/mobile-widgets/qmlmanager.h b/mobile-widgets/qmlmanager.h
index bc2cc1fbf..b10ae9af2 100644
--- a/mobile-widgets/qmlmanager.h
+++ b/mobile-widgets/qmlmanager.h
@@ -126,9 +126,13 @@ public:
Q_INVOKABLE int getProductIndex();
Q_INVOKABLE QString getBtAddress();
#if defined(BT_SUPPORT)
+ struct btPairedDevice {
+ QBluetoothAddress address;
+ QString name;
+ };
void btDeviceDiscovered(const QBluetoothDeviceInfo &device);
+ void getBluetoothDevices();
#endif
- QStringList getBluetoothDevices();
public slots:
void applicationStateChanged(Qt::ApplicationState state);
@@ -217,6 +221,7 @@ private:
#endif
#if defined(BT_SUPPORT)
+ QList<struct btPairedDevice> btPairedDevices;
QBluetoothLocalDevice localBtDevice;
QBluetoothDeviceDiscoveryAgent *discoveryAgent;
struct btVendorProduct {