QML文件加载的几种方式

整理下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
    }
}

效果

image

以上方式加载以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();


作者:devstone
链接:https://www.jianshu.com/p/b330dd65a787
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 

posted @   imxiangzi  阅读(202)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示