diff options
-rw-r--r-- | core/btdiscovery.cpp | 22 | ||||
-rw-r--r-- | desktop-widgets/btdeviceselectiondialog.cpp | 18 | ||||
-rw-r--r-- | desktop-widgets/btdeviceselectiondialog.ui | 166 |
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/> |