A basic example of a QML file that makes use of controls is shown here:
import QtQuick 2.12 import QtQuick.Controls 2.12 ApplicationWindow { title: "My Application" width: 640 height: 480 visible: true Button { text: "Push Me" anchors.centerIn: parent } }
尽管 QQuickView has traditionally been used to display QML files in a C++ application, doing this means you can only set window properties from C++.
With Qt Quick Controls 2, declare an ApplicationWindow as the root item of your application and launch it by using QQmlApplicationEngine instead. This ensures that you can control top level window properties from QML.
A basic example of a source file that makes use of controls is shown here:
#include <QGuiApplication> #include <QQmlApplicationEngine> int main(int argc, char *argv[]) { QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling); QGuiApplication app(argc, argv); QQmlApplicationEngine engine; engine.load(QUrl(QStringLiteral("qrc:/main.qml"))); return app.exec(); }
If you need to register a C++ class to use from QML, you can call qmlRegisterType () before declaring your QQmlApplicationEngine 。见 从 C++ 定义 QML 类型 了解更多信息。
If you need to expose data to QML components, you need to make them available to the context of the current QML engine. See QQmlContext 了解更多信息。