Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
bluetooth-index.qdoc
Go to the documentation of this file.
1
// Copyright (C) 2022 The Qt Company Ltd.
2
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GFDL-1.3-no-invariants-only
3
4
/*!
5
\page qtbluetooth-index.html
6
\title Qt Bluetooth
7
\brief Qt Bluetooth enables connectivity between Bluetooth enabled devices.
8
\ingroup technology-apis
9
10
The Bluetooth API provides connectivity between Bluetooth enabled devices.
11
12
Currently, the API is supported on the following platforms:
13
14
\table
15
\header
16
\li API Feature
17
\li \l {Qt for Android}{Android}
18
\li \l {Qt for iOS}{iOS}
19
\li \l {Qt for Linux/X11}{Linux (BlueZ 5.x)}
20
\li \l \macos
21
\li \l {Qt for Windows}{Windows}
22
\row
23
\li Classic Bluetooth
24
\li x
25
\li
26
\li x
27
\li x
28
\li x
29
\row
30
\li Bluetooth LE Central
31
\li x
32
\li x
33
\li x
34
\li x
35
\li x
36
\row
37
\li Bluetooth LE Peripheral
38
\li x
39
\li x
40
\li x
41
\li x
42
\li
43
\endtable
44
45
\section1 Overview
46
47
Bluetooth is a short-range (less than 100 meters) wireless technology. It
48
has a data transfer rate of 2.1 Mbps, which makes it ideal
49
for transferring data between devices. Bluetooth connectivity is based on
50
basic device management, such as scanning for devices, gathering information
51
about them, and exchanging data between them.
52
53
Qt Bluetooth supports Bluetooth Low Energy development for client/central role
54
use cases. Further details can be found in the
55
\l {Bluetooth Low Energy Overview}{Bluetooth Low Energy Overview} section.
56
57
\section1 Using the Module
58
59
\include {module-use.qdocinc} {using the c++ api}
60
61
\section2 Building with CMake
62
63
\include {module-use.qdocinc} {building with cmake} {Bluetooth}
64
65
\section2 Building with qmake
66
67
\include {module-use.qdocinc} {building_with_qmake} {bluetooth}
68
69
\section1 Permissions
70
71
Starting from Qt 6.6, the Qt Bluetooth module uses new \l QPermission API
72
to handle \l {QBluetoothPermission}{Bluetooth} permissions. This means that Qt
73
itself no longer queries for these permissions, so this needs to be done
74
directly from the client application.
75
76
Please refer to the \l {Application Permissions} page for an example of how
77
to integrate the new \l QPermission API into the application.
78
79
\section1 Related Information
80
81
\section2 Building Qt Bluetooth
82
83
Even though the module can be built for all Qt platforms, the module is not
84
ported to all of them. Non-supported platforms employ a dummy backend that is
85
automatically selected when the platform is not supported. The dummy backend
86
reports appropriate error messages and values, which enables you to detect at
87
runtime that the current platform is not supported. The dummy backend is also
88
selected on Linux if BlueZ development headers are not found during build time
89
or Qt was built without Qt D-Bus support.
90
91
The usage of the dummy backend is highlighted via an appropriate warning while building and running.
92
93
\section3 Linux Specific
94
95
Since Qt 6.5 the Linux peripheral support has two backend alternatives:
96
BlueZ DBus and Bluetooth Kernel API. The DBus backend is the default
97
backend since Qt 6.7.
98
99
BlueZ DBus is the newer BlueZ stack and possibly the eventual successor of the
100
older Kernel API. It is a bit more limited in terms of features, but in a
101
typical usage this should not matter. One notable benefit of using the DBus
102
backend is that the user process no longer needs to have the
103
\e CAP_NET_ADMIN capability (for example by running as \c root user).
104
105
The DBus backend requires BlueZ version 5.56 or higher, and that it provides
106
the needed DBus APIs. If these requirements are not met, Qt automatically
107
falls back to the Bluetooth Kernel API backend.
108
109
The older kernel backend can also be selected manually by setting the
110
\e QT_BLUETOOTH_USE_KERNEL_PERIPHERAL environment variable.
111
112
\section3 \macos Specific
113
The Bluetooth API on \macos requires a certain type of event dispatcher
114
that in Qt causes a dependency to \l QGuiApplication. However, you can set the
115
environment variable \c {QT_EVENT_DISPATCHER_CORE_FOUNDATION=1} to circumvent
116
this issue.
117
118
Applications that don't use Classic Bluetooth will find a subset of QtBluetooth
119
is available, as CoreBluetooth (Bluetooth LE) don't require \l QApplication or
120
\l QGuiApplication.
121
122
\section2 Articles and Guides
123
\list
124
\li \l {Qt Bluetooth Overview}{Classic Bluetooth Overview}
125
\li \l {Bluetooth Low Energy Overview}
126
\endlist
127
128
\section2 Reference
129
\list
130
\li \l {Qt Bluetooth C++ Classes}{C++ Classes}
131
\endlist
132
133
\section2 Logging Categories
134
135
The \l QtBluetooth module exports the following
136
\l {Configuring Categories}{logging categories}:
137
138
\table
139
\header
140
\li Logging Category
141
\li Description
142
\row
143
\li qt.bluetooth
144
\li Enables logging of cross platform code path in QtBluetooth
145
\row
146
\li qt.bluetooth.android
147
\li Enables logging of the \l {Qt for Android} {Android} implementation
148
\row
149
\li qt.bluetooth.bluez
150
\li Enables logging of the BLuez/Linux implementation
151
\row
152
\li qt.bluetooth.ios
153
\li Enables logging of the \l {Qt for iOS} {iOS} implementation
154
\row
155
\li qt.bluetooth.osx
156
\li Enables logging of the \l {Qt for macOS} {macOS} implementation
157
\row
158
\li qt.bluetooth.windows
159
\li Enables logging of the \l {Qt for Windows} {Windows} implementation
160
\endtable
161
162
Logging categories enable additional warning and debug output for QtBluetooth.
163
More detailed information about logging is found in \l QLoggingCategory. A
164
quick way to enable all QtBluetooth logging is to add the following line to the
165
\c main() function:
166
167
\code
168
QLoggingCategory::setFilterRules(QStringLiteral("qt.bluetooth* = true"));
169
\endcode
170
171
\section2 Examples
172
\list
173
\li QML
174
\list
175
\li \l {heartrate-game}{Bluetooth Low Energy Heart Rate Game}
176
\li \l {heartrate-server}{Bluetooth Low Energy Heart Rate Server}
177
\li \l {lowenergyscanner}{Bluetooth Low Energy Scanner}
178
\endlist
179
\li C++
180
\list
181
\li \l {btchat}{Bluetooth Chat}
182
\endlist
183
\endlist
184
185
\section1 Module Evolution
186
187
\l{Changes to Qt Bluetooth} lists important changes in the module
188
API and functionality that were done for the Qt 6 series of Qt.
189
190
\section1 Licenses and Attributions
191
192
Qt Bluetooth is available under commercial licenses from \l{The Qt Company}.
193
In addition, it is available under the
194
\l{GNU Lesser General Public License, version 3}, or
195
the \l{GNU General Public License, version 2}.
196
See \l{Qt Licensing} for further details.
197
198
On Linux, Qt Bluetooth uses a separate executable, \c sdpscanner,
199
to integrate with the official Linux bluetooth protocol stack
200
BlueZ. BlueZ is available under the \l{GNU General Public License,
201
version 2}.
202
203
\annotatedlist attributions-qtbluetooth
204
*/
qtconnectivity
src
bluetooth
doc
src
bluetooth-index.qdoc
Generated on
for Qt by
1.14.0