Qt Quick パブリケーション

Qt Quick Controls を使用して、MQTT トピックに発行できるアプリケーションを作成します。

Qt Quick Publicationでは、QMqttClient を QML タイプとして登録し、Qt Quick アプリケーションで使用する方法を説明します。

Qt MQTTは現在のバージョンでは QML API を提供していません。しかし、モジュールの C++ クラスを QML で利用できるようにすることは可能です。

クライアントの作成

QMqttClient をメンバとするラッパークラスQmlMqttClient を作成します:

private:
    Q_DISABLE_COPY(QmlMqttClient)
    QMqttClient m_client;
};

コンストラクタでラッパーメソッドをQMqttClient のメソッドに接続します:

QmlMqttClient::QmlMqttClient(QObject *parent)
    : QObject(parent)
{
    connect(&m_client, &QMqttClient::hostnameChanged, this, &QmlMqttClient::hostnameChanged);
    connect(&m_client, &QMqttClient::portChanged, this, &QmlMqttClient::portChanged);
    connect(&m_client, &QMqttClient::stateChanged, this, &QmlMqttClient::stateChanged);
}

ラッパー・メソッドはラップされたメソッドと同じ名前を持ちます。最も単純なケースでは、単一のメソッド呼び出しだけです:

void QmlMqttClient::connectToHost()
{
    m_client.connectToHost();
}

ラッパー・メソッドをカスタマイズすることも可能です:

void QmlMqttClient::setPort(int newPort)
{
    if (newPort < 0 || newPort > std::numeric_limits<quint16>::max()) {
        qWarning() << "Trying to set invalid port number";
        return;
    }
    m_client.setPort(static_cast<quint16>(newPort));

QMLでクラスを登録する

main.cpp 、モジュール・パブリケーションからQMLのMain型を読み込みます:

    QGuiApplication app(argc, argv);
    QQmlApplicationEngine engine;

    QObject::connect(
            &engine, &QQmlApplicationEngine::objectCreationFailed, &app,
            []() { QCoreApplication::exit(EXIT_FAILURE); }, Qt::QueuedConnection);

    engine.loadFromModule(u"publication"_s, u"Main"_s);

次に、Main.qml ファイルの MqttClient タイプを使って MQTT クライアントを作成します:

    MqttClient {
        id: client
        hostname: hostnameField.text
        port: portField.text
    }

ファイル

本ドキュメントに含まれる文書の著作権は、それぞれの所有者に帰属します 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。