【QT进阶】Qt Web混合编程之实现ECharts数据交互动态修改

往期回顾:

【QT进阶】Qt Web混合编程之CMake VS2019编译并使用QCefView(图文并茂超详细版本)-CSDN博客
【QT进阶】Qt Web混合编程之html、 js的简单交互-CSDN博客
【QT进阶】Qt Web混合编程之使用ECharts显示各类折线图等-CSDN博客

【QT进阶】Qt Web混合编程之实现ECharts数据交互动态修改

一、QWebEngineView

再次复习:

QWebEngineView是Qt框架中的一个类,用于显示Web内容。它基于Chromium引擎,可以加载和显示Web页面,并支持与Web页面交互。我们可以使用QWebEngineView来在Qt应用程序中集成Web内容,实现丰富的Web功能和交互体验。

1.四个重载函数runJavaScript

QWebEngineView类的四个重载函数runJavaScript

|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| void runJavaScript(const QString& scriptSource); . | 在当前页面中执行JavaScript代码,传入的参数为要执行的JavaScript代码的字符串。 |
| void runJavaScript(const QString& scriptSource, quint32 worldId); | 在指定的世界(world)中执行JavaScript代码,worldId参数指定了要在哪个世界中执行JavaScript代码。 |
| void runJavaScript(const QString& scriptSource, const QWebEngineCallback<const QVariant &> &resultCallback); | 用于在当前页面中执行JavaScript代码,并在执行完毕后调用resultCallback回调函数,将执行结果作为参数传递给回调函数。 |
| void runJavaScript(const QString& scriptSource, quint32 worldId, const QWebEngineCallback<const QVariant &> &resultCallback); | 用于在指定的世界中执行JavaScript代码,并在执行完毕后调用resultCallback回调函数,将执行结果作为参数传递给回调函数。 |

二、具体示例

1、显示echarts图表

在Widget类的构造函数中,通过设置echarts图表的HTML文件路径,将该路径传递给QWebEngineView组件,以显示echarts图表。

复制代码
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    QString path = qApp->applicationDirPath() + "/echarts/line-simple.html";
    ui->widget->setUrl(QUrl(path));
}

2、信号槽链接初始化函数

on_btnDefault_clicked()槽函数在按钮被点击时会调用JavaScript函数init(),用于初始化echarts图表并展示默认数据。

复制代码
void Widget::on_btnDefault_clicked()
{
    ui->widget->page()->runJavaScript("init()");
}

init(): 初始化echarts图表并展示默认数据。

复制代码
            function init(){
                var app = {};

                var option;

                option = {
                    xAxis: {
                        type: 'category',
                        data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
                    },
                    yAxis: {
                        type: 'value'
                    },
                    series: [{
                        data: [150, 230, 224, 218, 135, 147, 260],
                        type: 'line'
                    }]
                };

                if (option && typeof option === 'object') {
                    myChart.setOption(option);
                }
            }

3、转换json格式并重新定义数据

on_btnReDefine_clicked()槽函数在另一个按钮被点击时会生成一个包含x轴和y轴数据的JSON对象,将该对象转换为JSON字符串,然后调用JavaScript函数load_data(),用于重新定义echarts图表的数据。

复制代码
void Widget::on_btnReDefine_clicked()
{
    QJsonObject seriesData;

    //设置x轴数据
    QJsonArray dataX = {1, 5, 10, 15, 20, 25, 30, 35, 40};
    seriesData.insert("data_xAxis", dataX);

    //设置y轴数据
    QJsonArray dataY = {100, 70, 1230, 110, 50, 890, 79, 128, 256};
    seriesData.insert("data_yAxis", dataY);

    QString optionStr = QJsonDocument(seriesData).toJson();
    QString js = QString("load_data(%1)").arg(optionStr);

    //C++调用js方法
    ui->widget->page()->runJavaScript(js);
}

load_data(arg_json): 根据传入的JSON数据重新定义echarts图表的数据。

复制代码
function load_data(arg_json) {
                var app = {};

                var option;

                option = {
                    backgroundColor: '#1b1b1b', //背景色

                    xAxis: {
                        type: 'category',
                        //data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
                        data:arg_json["data_xAxis"]
                    },
                    yAxis: {
                        type: 'value'
                    },
                    series: [{
                        //data: [150, 230, 224, 218, 135, 147, 260],
                        data:arg_json["data_yAxis"],
                        type: 'line'
                        
                    }]
                };

HTML部分就是包含一个div元素用于显示echarts图表,引入了echarts库的JavaScript文件,并定义了两个JavaScript函数


以上就是Qt里实现ECharts数据交互动态修改的简单介绍。

都看到这里了,点个赞再走呗朋友~

加油吧,预祝大家变得更强!

相关推荐
郑州光合科技余经理21 小时前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1231 天前
matlab画图工具
开发语言·matlab
dustcell.1 天前
haproxy七层代理
java·开发语言·前端
norlan_jame1 天前
C-PHY与D-PHY差异
c语言·开发语言
多恩Stone1 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc
QQ4022054961 天前
Python+django+vue3预制菜半成品配菜平台
开发语言·python·django
遥遥江上月1 天前
Node.js + Stagehand + Python 部署
开发语言·python·node.js
B站_计算机毕业设计之家1 天前
电影知识图谱推荐问答系统 | Python Django系统 Neo4j MySQL Echarts 协同过滤 大数据 人工智能 毕业设计源码(建议收藏)✅
人工智能·python·机器学习·django·毕业设计·echarts·知识图谱
m0_531237171 天前
C语言-数组练习进阶
c语言·开发语言·算法
Railshiqian1 天前
给android源码下的模拟器添加两个后排屏的修改
android·开发语言·javascript