QML文件加载的几种方式

959 阅读2分钟

阅读本文大概需要4分钟

Qt

整理下QML过程,看到好多方式加载QML文件,这里参考网上总结整理下.

QQmlApplicationEngine加载QML

查看帮助文档,可以看出QQmlApplicationEngine继承自QQmlEngine->QObject.

这种方式属于QQmlApplicationEngine搭配Window

main.cpp

#include <QGuiApplication>
#include <QQmlApplicationEngine>

int main(int argc, char *argv[])
{
    QGuiApplication app(argc, argv);

    QQmlApplicationEngine engine;
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));

    return app.exec();
}

对应QML文件内容: main.qml

import QtQuick 2.7
import QtQuick.Window 2.2

Window {
    visible: true
    width: 460
    height: 320
    title: qsTr("QQmlApplicationEngine方式加载")

    Text {
        text: qsTr("Hello World")
        anchors.centerIn: parent
    }
}

效果

以上方式加载以Window为根对象的QML文件,这个时候QML就完全拥有了控制权,可以直接设置窗体的标题、尺寸等信息.

QQuickView加载QML

main.cpp

#include <QGuiApplication>
#include <QQmlApplicationEngine>

#include <QQuickView>

int main(int argc, char *argv[])
{
    QGuiApplication app(argc, argv);

    QQuickView view;
    view.setResizeMode (QQuickView::SizeRootObjectToView);
    view.setSource (QUrl("qrc:/main.qml"));
    view.show ();

    return app.exec();
}

这个时候需要修改QML文件中的内容了,如果不修改,直接运行,则会出现2个窗体,并且会输出警告:

error

QQuickView does not support using windows as a root item. 

If you wish to create your root window from QML, consider using QQmlApplicationEngine instead. 

错误很明显,提示不能使用windows作为根.

这里需要将window替换成Rectangle.替换后直接运行,你就会发现提示qrc:/main.qml:8:5: Cannot assign to non-existent property "title".意思很明确了,这里不能通过QML来设置窗口的标题了.

使用这种方式时,对窗口的控制权在C++代码中要实现,QML文件是以Item作为根对象的.

main.qml

import QtQuick 2.7
import QtQuick.Window 2.2

Rectangle {
    visible: true
    width: 460
    height: 320
    //title: qsTr("QQmlApplicationEngine方式加载")

    Text {
        text: qsTr("Hello World")
        anchors.centerIn: parent
    }
}

需要设置标题时可以在C++中来实现,只需要在main.cpp中添加一行:

view.setTitle ("QQuickView方式加载");

QQuickWidget加载QML

官网自带的说明例子.一般用来在QWidget界面上加载QML界面,不过我觉得一般人是不会这么干的,况且这样使用不觉得累么!

    QQuickWidget *view = new QQuickWidget;
    view->setSource(QUrl::fromLocalFile("myqmlfile.qml"));
    view->show();