summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/btdiscovery.cpp22
-rw-r--r--desktop-widgets/btdeviceselectiondialog.cpp18
-rw-r--r--desktop-widgets/btdeviceselectiondialog.ui166
3 files changed, 125 insertions, 81 deletions
diff --git a/core/btdiscovery.cpp b/core/btdiscovery.cpp
index b764098ef..f51a62b23 100644
--- a/core/btdiscovery.cpp
+++ b/core/btdiscovery.cpp
@@ -132,18 +132,20 @@ extern void addBtUuid(QBluetoothUuid uuid);
extern QHash<QString, QStringList> productList;
extern QStringList vendorList;
+QString btDeviceAddress(const QBluetoothDeviceInfo *device, bool isBle)
+{
+ QString address = device->address().isNull() ?
+ device->deviceUuid().toString() : device->address().toString();
+ const char *prefix = isBle ? "LE:" : "";
+ return prefix + address;
+}
+
QString markBLEAddress(const QBluetoothDeviceInfo *device)
{
- QBluetoothDeviceInfo::CoreConfigurations flags;
- QString prefix = "";
-
- flags = device->coreConfigurations();
- if (flags == QBluetoothDeviceInfo::LowEnergyCoreConfiguration)
- prefix = "LE:";
- if (device->address().isNull())
- return prefix + device->deviceUuid().toString();
- else
- return prefix + device->address().toString();
+ QBluetoothDeviceInfo::CoreConfigurations flags = device->coreConfigurations();
+ bool isBle = flags == QBluetoothDeviceInfo::LowEnergyCoreConfiguration;
+
+ return btDeviceAddress(device, isBle);
}
void BTDiscovery::btDeviceDiscovered(const QBluetoothDeviceInfo &device)
diff --git a/desktop-widgets/btdeviceselectiondialog.cpp b/desktop-widgets/btdeviceselectiondialog.cpp
index de3e383c5..fc7b2e86f 100644
--- a/desktop-widgets/btdeviceselectiondialog.cpp
+++ b/desktop-widgets/btdeviceselectiondialog.cpp
@@ -449,13 +449,25 @@ void BtDeviceSelectionDialog::deviceDiscoveryError(QBluetoothDeviceDiscoveryAgen
}
extern QString markBLEAddress(const QBluetoothDeviceInfo *device);
+extern QString btDeviceAddress(const QBluetoothDeviceInfo *device, bool isBle);
QString BtDeviceSelectionDialog::getSelectedDeviceAddress()
{
- if (selectedRemoteDeviceInfo)
- return markBLEAddress(selectedRemoteDeviceInfo.data());
+ if (!selectedRemoteDeviceInfo)
+ return QString();
- return QString();
+ int btMode = ui->btMode->currentIndex();
+ QBluetoothDeviceInfo *device = selectedRemoteDeviceInfo.data();
+
+ switch (btMode) {
+ case 0: // Auto
+ default:
+ return markBLEAddress(device);
+ case 1: // Force LE
+ return btDeviceAddress(device, true);
+ case 2: // Force classical
+ return btDeviceAddress(device, false);
+ }
}
QString BtDeviceSelectionDialog::getSelectedDeviceName()
diff --git a/desktop-widgets/btdeviceselectiondialog.ui b/desktop-widgets/btdeviceselectiondialog.ui
index 4aa83cf1c..be63b4160 100644
--- a/desktop-widgets/btdeviceselectiondialog.ui
+++ b/desktop-widgets/btdeviceselectiondialog.ui
@@ -14,25 +14,6 @@
<string>Remote Bluetooth device selection</string>
</property>
<layout class="QGridLayout" name="gridLayout">
- <item row="0" column="0">
- <widget class="QLabel" name="discoveredDevicesLabel">
- <property name="sizePolicy">
- <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="font">
- <font>
- <weight>75</weight>
- <bold>true</bold>
- </font>
- </property>
- <property name="text">
- <string>Discovered devices</string>
- </property>
- </widget>
- </item>
<item row="3" column="1">
<layout class="QHBoxLayout" name="dialogControls">
<item>
@@ -57,49 +38,15 @@
</item>
</layout>
</item>
- <item row="1" column="0" rowspan="2">
- <layout class="QVBoxLayout" name="remoteDevicesSection">
- <item>
- <widget class="QListWidget" name="discoveredDevicesList">
- <property name="sizePolicy">
- <sizepolicy hsizetype="MinimumExpanding" vsizetype="Expanding">
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- </widget>
- </item>
- <item>
- <layout class="QVBoxLayout" name="scanningControls">
- <item>
- <widget class="QPushButton" name="scan">
- <property name="sizePolicy">
- <sizepolicy hsizetype="Minimum" vsizetype="Minimum">
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>Scan</string>
- </property>
- </widget>
- </item>
- <item>
- <widget class="QPushButton" name="clear">
- <property name="sizePolicy">
- <sizepolicy hsizetype="Minimum" vsizetype="Minimum">
- <horstretch>0</horstretch>
- <verstretch>0</verstretch>
- </sizepolicy>
- </property>
- <property name="text">
- <string>Clear</string>
- </property>
- </widget>
- </item>
- </layout>
- </item>
- </layout>
+ <item row="3" column="0">
+ <widget class="QLabel" name="dialogStatus">
+ <property name="text">
+ <string/>
+ </property>
+ <property name="wordWrap">
+ <bool>true</bool>
+ </property>
+ </widget>
</item>
<item row="1" column="1">
<widget class="QGroupBox" name="localDeviceDetails">
@@ -207,16 +154,99 @@
</layout>
</widget>
</item>
- <item row="3" column="0">
- <widget class="QLabel" name="dialogStatus">
- <property name="text">
- <string/>
+ <item row="0" column="0">
+ <widget class="QLabel" name="discoveredDevicesLabel">
+ <property name="sizePolicy">
+ <sizepolicy hsizetype="Fixed" vsizetype="Fixed">
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
</property>
- <property name="wordWrap">
- <bool>true</bool>
+ <property name="font">
+ <font>
+ <weight>75</weight>
+ <bold>true</bold>
+ </font>
+ </property>
+ <property name="text">
+ <string>Discovered devices</string>
</property>
</widget>
</item>
+ <item row="1" column="0" rowspan="2">
+ <layout class="QVBoxLayout" name="remoteDevicesSection">
+ <item>
+ <widget class="QListWidget" name="discoveredDevicesList">
+ <property name="sizePolicy">
+ <sizepolicy hsizetype="MinimumExpanding" vsizetype="Expanding">
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
+ </property>
+ </widget>
+ </item>
+ <item>
+ <layout class="QHBoxLayout" name="btModeSection">
+ <item>
+ <widget class="QLabel" name="btModeLabel">
+ <property name="text">
+ <string>Bluetooth mode</string>
+ </property>
+ </widget>
+ </item>
+ <item>
+ <widget class="QComboBox" name="btMode">
+ <item>
+ <property name="text">
+ <string>Auto</string>
+ </property>
+ </item>
+ <item>
+ <property name="text">
+ <string>Force LE</string>
+ </property>
+ </item>
+ <item>
+ <property name="text">
+ <string>Force classical</string>
+ </property>
+ </item>
+ </widget>
+ </item>
+ </layout>
+ </item>
+ <item>
+ <layout class="QVBoxLayout" name="scanningControls">
+ <item>
+ <widget class="QPushButton" name="scan">
+ <property name="sizePolicy">
+ <sizepolicy hsizetype="Minimum" vsizetype="Minimum">
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
+ </property>
+ <property name="text">
+ <string>Scan</string>
+ </property>
+ </widget>
+ </item>
+ <item>
+ <widget class="QPushButton" name="clear">
+ <property name="sizePolicy">
+ <sizepolicy hsizetype="Minimum" vsizetype="Minimum">
+ <horstretch>0</horstretch>
+ <verstretch>0</verstretch>
+ </sizepolicy>
+ </property>
+ <property name="text">
+ <string>Clear</string>
+ </property>
+ </widget>
+ </item>
+ </layout>
+ </item>
+ </layout>
+ </item>
</layout>
</widget>
<resources/>