summaryrefslogtreecommitdiffstats
path: root/tests/manual/examples/ble/doc/src/ble.qdoc
blob: 44e82bce5a9eea057adaa953e272ff55f863b19d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GFDL-1.3-no-invariants-only

/*!
    \example ble
    \title QtRemoteObjects Bluetooth LE Example
    \examplecategory {Connectivity}
    \brief Using QtBluetooth Low Energy (BT LE or BLE for short) as a transport medium with
           Qt Remote Objects.
    \ingroup qtremoteobjects-examples

    This is achieved by wrapping the bluetooth low energy transport logic in a \l QIODevice.

    The example consists of a client and server application which communicate over the bluetooth
    low energy radio.

    The server-side is a simple heater object which is either turned ON (heats) or OFF (cools).
    The temperature changes periodically and this temperature is shown by the client-side GUI.
    This changing temperature value flows from the server to client as remote object property.
    The client-side can control the ON/OFF status of the server-side heater object. This data
    flows similarly as a remote object property.

    \section1 Overview

    Bluetooth Low Energy is inherently a client/server architecture, where server
    advertises its services and client discovers them, after which the data can be
    transferred.

    The following Figure illustrates the main steps when running the example:

    \image ble_example_flow.png "Main phases when starting the example"

    \section1 Data flow

    The data flows over the Bluetooth Low Energy medium. This is implemented with
    two GATT characteristics, one for each direction. This is illustrated by the following Figure:

    \image ble_example_iodevice.png "BT LE IO Device"

    \section1 Known limitations

    The example relies on \l QLowEnergyController::connected() and
    \l QLowEnergyController::disconnected() signals to detect client connection and
    disconnection. These signals are not always reliable on the server (peripheral) side
    on all platforms. This is typically not a problem when connecting for
    the first time, but may be an issue on subsequent reconnections if the server is not
    restarted.

*/