Qt Quick Controls - 連絡先リスト

Qt Quick Controls とシンプルな連絡先リストを実装する C++ クラスを使用した QML アプリです。

連絡先リストの例では、Qt Quick Designer と互換性のある方法で C++ バックエンドを統合する方法を示します。UI の宣言的な部分には、Qt Quick Designer で視覚的に編集できる .ui.qml ファイルが使用されています。

C++ バックエンド

連絡先リストアプリケーションでは、ユーザーが連絡先を追加、編集、削除できます。実際の実装は C++ で行われ、QAbstractListModel として公開されます。

ContactModel C++ クラスは名前空間の下に登録され、後にMainForm.ui.qml によってインポートされ、インスタンス化されます。C++ クラスを QML 型として登録する方法については、C++ から QML 型を定義する を参照してください。

#include <QtQml/qqml.h>
...
qmlRegisterType<ContactModel>("Backend", 1, 0, "ContactModel");
...

デザイナーのサポート

designer サブディレクトリに、Qt Quick Designer の ContactModel を置き換えるプラグインを作成します。これを動作させるために、contactlist.pro に以下の行を追加します。

QML_DESIGNER_IMPORT_PATH = $$PWD/designer

Qt Quick Designer は ContactModel C++ クラスをインスタンス化できないため、ListModel を使用してモックアップを定義します。 これにより、モデルを使用したListView が Qt Quick Designer に表示されるようになります。

例の実行

Qt Creator からサンプルを実行するには、Welcome モードを開き、Examples からサンプルを選択します。詳細については、Building and Running an Example を参照してください。

サンプルプロジェクト @ code.qt.io

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