このページでは

C

Qt Quick Ultralite instrument_cluster の例

Cアプリケーションからユーザーインターフェース要素を制御する方法を示します。

概要

この例では、Cアプリケーションからユーザー・インターフェース・エレメントを制御する方法を示します。

対象プラットフォーム

プロジェクト構成

instrument_cluster サンプルは以下のファイルで構成されています:

  • src/VehicleStatus.cpp
  • src/VehicleStatus.h
  • CMakeLists.txt
  • mcu_instrument_cluster.qmlproject
  • instrument_cluster.qml

CMakeプロジェクト・ファイルには、アプリケーションのUIを定義する基本的なビルド・スクリプトinstrument_cluster.qml 。プロジェクトのコンフィギュレーションはmcu_instrument_cluster.qmlproject で定義されています。

これらのファイルに加えて、src/simulation フォルダには、AUTOSAR 以外のプラットフォームで計器クラスタの入力データを提供するための簡単なシミュレータが含まれています:

  • src/simulation/baremetal/main.cpp
  • src/simulation/freertos/main.cpp
  • src/simulator.cpp
  • src/simulator.h

fonts フォルダには、アプリケーションのフォントファイルが含まれています:

  • fonts/TitilliumWeb-Light.ttf
  • fonts/TitilliumWeb-SemiBold.ttf
CMakeプロジェクトファイル

注意: シミュレーションファイルは、AUTOSAR非対象の場合のみ追加されます。

# Copyright (C) 2025 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial
cmake_minimum_required (VERSION 3.21.1)

project(instrument_cluster VERSION 0.0.1 LANGUAGES C CXX ASM)
if (NOT TARGET Qul::Core)
    find_package(Qul)
endif()

set(TARGET_SOURCES src/VehicleStatus.cpp)
set(INCLUDE_DIRECTORIES ${CMAKE_CURRENT_SOURCE_DIR}/src)
set(GENERATE_ENTRYPOINT_ARG "")

if(NOT QUL_PLATFORM MATCHES "autosar")
    set(SIMULATOR_DIR src/simulation)
    set(TARGET_SOURCES
        ${TARGET_SOURCES}
        ${SIMULATOR_DIR}/simulator.cpp
        ${SIMULATOR_DIR}/${QUL_OS_LOWERCASE}/main.cpp
    )
    set(INCLUDE_DIRECTORIES
        ${INCLUDE_DIRECTORIES}
        ${CMAKE_CURRENT_SOURCE_DIR}/src/simulation
    )
else()
    set(GENERATE_ENTRYPOINT_ARG GENERATE_ENTRYPOINT)
endif()

qul_add_target(instrument_cluster
    ${TARGET_SOURCES}
    QML_PROJECT mcu_instrument_cluster.qmlproject
    ${GENERATE_ENTRYPOINT_ARG}
)
app_target_setup_os(instrument_cluster)

target_include_directories(instrument_cluster PRIVATE
    ${INCLUDE_DIRECTORIES}
)

if(NOT CMAKE_CROSSCOMPILING AND NOT WIN32)
    add_custom_command(TARGET instrument_cluster
        COMMAND strip instrument_cluster -o instrument_cluster.stripped
        DEPENDS instrument_cluster)
endif()
QmlProjectファイル
import QmlProject 1.3

Project {
    mainFile: "instrument_cluster.qml"

    MCU.Config {
        defaultFontFamily: "Titillium Web"
    }
    FontFiles {
        files: [
            "fonts/TitilliumWeb-Light.ttf",
            "fonts/TitilliumWeb-SemiBold.ttf"
        ]
    }
    QmlFiles {
        files: [
            "instrument_cluster.qml"
        ]
    }
    InterfaceFiles {
        files: ["src/VehicleStatus.h"]
    }
}
VehicleStatusシングルトン

VehicleStatus シングルトンは、ユーザーインターフェースの車両パラメータを格納する役割を担っています。Qul::Singleton を継承し、パブリックシグナルとプロパティを QML に公開しています。また、Qul::EventQueue を継承し、プロパティ値が変更されたときにユーザーインターフェースの更新をトリガーするイベントキューを提供しています。

    ...
    Qul::Property<int> speed;
    Qul::Property<double> tripMeter;
    Qul::Signal<void(bool leftBlinkerState)> leftBlinkerStateChange;
    Qul::Signal<void(bool rightBlinkerState)> rightBlinkerStateChange;
    ...

QMLコードはVehicleStatus シングルトンを介してこれらの値にアクセスします:

    ...
    Text {
        id: speedometer
        color: "#2CDE85"
        anchors.centerIn: parent

        font.weight: Font.DemiBold
        font.pixelSize: 90
        text: VehicleStatus.speed
    }
    ...

インストルメント・クラスターの再描画は、ダミーのevent queue を使ってトリガーされます。イベントハンドリングは、Qt Quick Ultraliteエンジンに更新を要求します。

...
void qul_application_send_value_change_event()
{
    VehicleStatus::instance().postEvent(true);
}
...

実際のイベントハンドラは何もしない:

    ...
    void onEvent(const bool &value)
    {
        // Dummy event queue to trigger UI updates
        (void) value;
    }
    ...

計器クラスタのコンテンツを制御するために、Cリンケージ関数が非GUIコードに公開されます:

...
extern "C" {
void qul_application_set_speed(int speed)
{
    VehicleStatus::instance().speed.setValue(speed);
}
...
AUTOSAR の例

AUTOSARプロジェクトでは、Qt Quick UltraliteComplex Device Driverは以下のようにCリンケージAPIを呼び出します:

#include "VehicleStatus.h"
...
// QUL Complex Device Driver Runnable with a periodic trigger
void Cdd_Qul_Update(void)
{
    int changedValuesCount = 0;

    static int previousSpeed = 0;
    int speed;

    // Read the speed value via the AUTOSAR Interface
    // Rte_Read_Cdd_Qul_Speed(&speed);

    if (speed != previousSpeed) {
        changedValuesCount++;
        qul_application_set_speed(speed);
        previousSpeed = speed;
    }
    ...
    if (changedValuesCount > 0) {
        // Send an event to trigger repainting of the UI
        qul_application_send_value_change_event();
    }

    qul_update_engine(); // Calls Qul::Application::update()
}

ファイル

C++コードとQMLの統合も参照してください

特定の Qt ライセンスの下で利用可能です。
詳細をご覧ください。