Qt小例子学习59 - WebEngineView 加载qml显示图表

该示例展示了如何使用Qt的WebEngineView组件加载QML文件,并在其中显示Highcharts图表。QML中定义了一个WebEngineView,用于打开本地的HTML文件,HTML文件内包含Highcharts的JavaScript代码来创建图表。当点击图表的某个元素时,通过WebEngineView的`onNewViewRequested`事件创建新的窗口并打开新视图。
摘要由CSDN通过智能技术生成

Qt小例子学习59 - WebEngineView 加载qml显示图表

main.qml

import QtQuick 2.9
import QtQuick.Window 2.2
import QtWebEngine 1.5

Window {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    WebEngineView {
        id: webView
        anchors.fill: parent
        url: "qrc:/html/index.html"
        profile.onDownloadRequested: downloadHelper.onDownloadRequested(download)

        onNewViewRequested: {
            var newWindow = Qt.createQmlObject('import QtQuick.Window 2.2;
                                                import QtWebEngine 1.5;
                                                 Window {
                                                    width: 640; height: 480;
                                                    visible: true;
                                                    property alias wv: wv
                                                    WebEngineView{id:wv; anchors.fill: parent}}',
                                               webView,
                                               "dynamicSnippet1");
            console.log(newWindow.wv)
            request.openIn(newWindow.wv)
        }
    }
}

main.cpp

#include <QApplication>
#include <QFileDialog>
#include <QQmlApplicationEngine>
#include <QQmlEngine>
#include <QtWebEngine>

class DownloadHelper : public QObject
{
    Q_OBJECT
public:
    Q_INVOKABLE void onDownloadRequested(QObject *download)
    {
        const QString &old_path = download->property("path").toString();
        const QString &suffix = QFileInfo(old_path).suffix();
        const QString &path = QFileDialog::getSaveFileName(nullptr, "Save File",
                              old_path, "*." + suffix);
        if (!path.isEmpty())
        {
            download->setProperty("path", path);
            Q_ASSERT(QMetaObject::invokeMethod(download, "accept"));
        }
    }
};

int main(int argc, char *argv[])
{
    QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);

    QApplication app(argc, argv);
    QtWebEngine::initialize();

    QQmlApplicationEngine engine;
    DownloadHelper helper;
    engine.rootContext()->setContextProperty("downloadHelper", &helper);
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
    if (engine.rootObjects().isEmpty())
        return -1;

    return app.exec();
}

#include "main.moc"

index.html

<div id="container" style="width: 100%; min-height: 400px"></div>
<script src="https://code.highcharts.com/highcharts.js"></script>
<script src="https://code.highcharts.com/modules/exporting.js"></script>
<script src="https://code.highcharts.com/modules/offline-exporting.js"></script>
<script src="https://code.highcharts.com/modules/export-data.js"></script>
<script type="text/javascript">
    Highcharts.setOptions({
        navigation: {
            menuItemStyle: {
                padding: '6px 14px'
            }
        }
    });
    var chart = new Highcharts.Chart({
        chart: {
            renderTo: 'container'
        },
        exporting: {
            filename: 'data'
        },
        title: {
            text: 'export file'
        },
        xAxis: {
            categories: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12']
        },
        series: [{
            name: 'test data',
            data: [29.9, 71.5, 106.4, 129.2, 144.0, 176.0, 135.6, 148.5, 216.4, 194.1, 95.6, 54.4]
        }]
    });
</script>

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值