C++ Qt 学习(五):Qt Web 编程
1. Chrome 技术介绍
- 大多数 web 技术都是基于 chrome,例如 CEF、QCefView 以及 QWebEngineView,这些都是在 native 界面里用来显示 html 网页,并且可以与 web 交互
- 例如常见的登录窗口、优酷的视频区域、WPS 的稻壳商城等,这些都是用 web 技术实现的
- 而 native 端,只需要把把网页展示出来,实现交互即可
2. VS2019 编译与使用 CEF
2.1 CEF 下载与编译
-
CEF 下载链接

-
下载上图箭头所指链接,解压后按下图重命名文件夹,并新建 build 和 sdk 两个文件夹

-
用 CMake 工具编译上述 CEF 包,按下图配置
- 基于Windows的Cmake安装教程

- 基于Windows的Cmake安装教程
-
编译成后点击上图中的 Open Project 进入 VS2019 中
- F7 生成解决方案后报错如下,修改箭头处代码如图所示,保存后再次 F7 生成解决方案

- F7 生成解决方案后报错如下,修改箭头处代码如图所示,保存后再次 F7 生成解决方案
2.2 CEF 案例运行
- 将 cefsimple 设置为启动项目,启动本地调试器,出现百度搜索界面
- 注意修改下图代码中 url 链接为百度

- 注意修改下图代码中 url 链接为百度

3. QWebEngineView 基本用法
-
Widget 提升为 QWebEngineView

-
.pro 中添加头文件
QT += core gui webenginewidgets -
widget.cpp
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);ui->web_widget->setUrl(QUrl("http://www.baidu.com"));ui->web_widget->show(); }Widget::~Widget() {delete ui; }

4. Qt html js 交互
- qt 除了可以显示网页,还可以和网页交互,互相发消息,调用函数

- QtWebDemo.h
#pragma once#include <QtWidgets/QWidget>
#include "ui_QtWebDemo.h"
#include "WebObject.h"class QtWebDemo : public QWidget {Q_OBJECTpublic:QtWebDemo(QWidget *parent = Q_NULLPTR);~QtWebDemo();public slots:void on_btnSend_clicked();void update_text(const QString& htmltext);private:Ui::QtWebDemoClass ui;WebObject* m_pWebObj = nullptr;
};
- QtWebDemo.cpp
#include "QtWebDemo.h"
#include <QWebChannel>
#include <QWebEnginePage>QtWebDemo::QtWebDemo(QWidget *parent) : QWidget(parent) {ui.setupUi(this);QString path = QApplication::applicationDirPath() + "/WebPage/index.html";ui.webEngineView->setUrl(QUrl(path));m_pWebObj = new WebObject();QWebEnginePage* pPage = ui.webEngineView->page();// Qt 和 html js 的桥梁:QWebChannelQWebChannel* channel = new QWebChannel(this);// 注册 html 对象// 第二个参数需要是 QObject 的派生类channel->registerObject(QStringLiteral("content"), m_pWebObj); pPage->setWebChannel(channel);connect(m_pWebObj, &WebObject::sig_SendToUI, this, &QtWebDemo::update_text);
}void QtWebDemo::on_btnSend_clicked() {QString text = ui.lineEdit->text();m_pWebObj->SendTextToHtml(text);
}QtWebDemo::~QtWebDemo() {delete m_pWebObj;
}void QtWebDemo::update_text(const QString& htmltext) {ui.plainTextEdit->appendPlainText(htmltext);
}
- WebObject.h
#pragma once#include <QObject>class WebObject : public QObject {Q_OBJECTpublic:WebObject(QObject* parent = nullptr) :QObject(parent) {}~WebObject();void SendTextToHtml(const QString& text);// 接收来自 html 发来的内容,必须要加 Q_INVOKABLE,不然收不到Q_INVOKABLE void receiveTextFromHtml(const QString& r_text);signals:void sig_sendTextToHtml(const QString& text);void sig_SendToUI(const QString& htmltext);
};
- WebObject.cpp
#include "WebObject.h"WebObject::~WebObject() {}void WebObject::SendTextToHtml(const QString& text) {emit sig_sendTextToHtml(text);
}void WebObject::receiveTextFromHtml(const QString& htmltext) {emit sig_SendToUI(htmltext);
}
5. Qt ECharts 使用详解
- ECharts:比 QCustomPlot、QWT、QCharts 更好的开源图表曲线组件

- widget.cpp
#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);QString exe_path = qApp->applicationDirPath();QString _klinePath = exe_path + "/myecharts/candlestick-simple.html";ui->web_widget->setUrl(QUrl(_klinePath));connect(ui->radioButton_kline, &QRadioButton::toggled, [=](bool checked){if(checked) {ui->web_widget->setUrl(QUrl(_klinePath));}});connect(ui->radioButton_line, &QRadioButton::toggled, [=](bool checked){if(checked) {QString _linePath = exe_path + "/myecharts/line-smooth.html";ui->web_widget->setUrl(QUrl(_linePath));}});
}Widget::~Widget() {delete ui;
}
相关文章:
C++ Qt 学习(五):Qt Web 编程
1. Chrome 技术介绍 大多数 web 技术都是基于 chrome,例如 CEF、QCefView 以及 QWebEngineView,这些都是在 native 界面里用来显示 html 网页,并且可以与 web 交互 例如常见的登录窗口、优酷的视频区域、WPS 的稻壳商城等,这些都…...
基于arm-gcc 工具链开发mcu程序时,怎么便捷查看内存映像
目录 一、背景 arm-none-eabi-size 二、脚本实现 2.1. 源码2.2. 效果呈现 三、实现说明 3.1 基本思路3.2 涉及到的shell 相关知识 3.2.1 sed 实现只打印第二行3.2.2 cut 截取某一行数据的第n个字段3.2.3 使用bc 计算器,实现浮点运算 一、背景 arm-gcc 工具链…...
亚马逊云科技Zero ETL集成全面可用,可运行近乎实时的分析和机器学习
亚马逊云科技数据库、数据分析和机器学习全球副总裁Swami Sivasubramanian曾指出:“数据是应用、流程和商业决策的核心。”如今,客户常用的数据传输模式是建立从Amazon Aurora到Amazon Redshift的数据管道。这些解决方案能够帮助客户获得新的见解&#x…...
Java 设计模式——访问者模式
目录 1.概述2.结构3.案例实现3.1.抽象访问者类3.2.抽象元素类3.3.具体元素类3.4.具体访问者类3.5.对象结构类3.6.测试 4.优缺点5.使用场景6.扩展6.1.分派6.2.动态分配6.3.静态分配6.4.双分派 1.概述 访问者模式 (Visitor Pattern) 是一种行为型设计模式,它用于将数…...
Mysql联合查询
Mysql联合查询 T1表结构(用户名,密码) useridusernamepassword1jackpwd12owenpwd2 T2表结构(用户名,密码) useridjifendengji12033506 第一:内联(inner join) 如果想把用户信息、积分、等…...
响应式婴幼儿早教启蒙网站模板源码
模板信息: 模板编号:6830 模板编码:UTF8 模板颜色:红色 模板分类:学校、教育、培训、科研 适合行业:培训机构类企业 模板介绍: 本模板自带eyoucms内核,无需再下载eyou系统…...
ChatGPT付费创作系统V2.4.9独立版 +WEB端+ H5端 + 小程序端系统测试安装教程
播资源提供的GPT付费体验系统最新版系统是一款基于ThinkPHP框架开发的AI问答小程序,是基于国外很火的ChatGPT进行开发的Ai智能问答小程序。当前全民热议ChatGPT,流量超级大,引流不要太简单!一键下单即可拥有自己的GPT!…...
react 修改less文件后保存,内存溢出,项目崩溃问题解决
一、完整报错 一个很老的react项目,因为没有package-lock.json版本锁,导致拉下来的时候,安装的依赖版本冲突,好不容易启动起来,修改less文件后只要一保存,项目就会崩溃,需要重启,报…...
Lib文件和netlist的关系,DDC文件和netlist的区别
今天来说一说两个基础的概念: 1:综合用的Lib文件和netlist网表的关系 在数字IC设计中,Lib和网表都是非常重要的文件,但它们的作用和用途有很大的区别。 Lib文件,也称为库文件,主要包含单元级的信息&…...
万宾科技智能井盖,实现对井盖的监测
随着人工智能和物联网技术的不断变化,各种适用于市政府提高管理能力和公共服务水平的高科技产品不断更新。在道路基础设施建设过程中,智能井盖传感器的出现时刻保护着城市地下生命线,而且可以对地下水道井盖进行实时的监测并完成数据上传等工…...
使用Python从零实现多分类SVM
前言 本文将首先简要概述支持向量机及其训练和推理方程,然后将其转换为代码以开发支持向量机模型。之后然后将其扩展成多分类的场景,并通过使用Sci-kit Learn测试我们的模型来结束。 SVM概述 支持向量机的目标是拟合获得最大边缘的超平面(两个类中最近…...
WPF ToggleButton 主题切换动画按钮
WPF ToggleButton 主题切换动画按钮 仿造最近看到的html中的一个效果,大致思路是文章这样,感觉还可以再雕琢一下。 代码如下 XAML: <UserControl x:Class"WPFSwitch.AnimationSwitch"xmlns"http://schemas.microsoft.com/winfx/200…...
centerOS下docker 搭建IotDB集群
一、准备3台机器,IP地址依次为IP1,IP2,IP3,找一个目录下建立文件夹如下: ./data/confignode ./logs/confignode ./data/datanode ./logs/datanode二、在当前目录下建立docker-compose.yml文件,3台都要 1、…...
Vue3-Composition-API-学习笔记
01.Setup函数的体验 App.vue <template><div><h2>当前计数:{{ counter }}</h2><button click"increment">1</button><button click"decrement">-1</button></div> </template>&…...
NSS [HUBUCTF 2022 新生赛]checkin
NSS [HUBUCTF 2022 新生赛]checkin 判断条件是if ($data_unserialize[username]$username&&$data_unserialize[password]$password),满足则给我们flag。正常思路来说,我们要使序列化传入的username和password等于代码中的两个同名变量࿰…...
免费小程序HTTPS证书
随着互联网的快速发展,小程序已经成为人们日常生活中不可或缺的一部分。然而,在小程序的开发和使用过程中,安全问题一直是开发者们关注的重点。其中,HTTPS 证书是保障小程序安全的重要工具之一。在这方面,免费的小程序…...
Linux arm64异常简介和系统调用过程
文章目录 一、异常简介1.1 Exception levels1.2 异常类型 二、系统调用简介2.1 SVC指令2.2 VBAR2.3 系统调用保存现场2.4 系统调用返回 三、Linux 内核分析参考资料 一、异常简介 在ARM64体系架构中,异常是处理器在执行指令时可能遇到的不寻常情况或事件。这些异常…...
我遇到的最蠢的bug,竟然是因为这个原因……
bug的背景 我是一个Python开发者,我最近在做一个数据分析的项目,需要用到pandas库,来处理和分析一些表格数据我的功能需求是,根据用户输入的一些条件,从一个大的数据表中筛选出符合条件的数据,并生成一个新…...
【Mysql】查询mysql的版本
目录 cmd命令查询 mysql -- help(命令) mysql -u root -p(命令) 数据库管理工具查询 select version(); cmd命令查询 mysql -- help(命令) mysql -u root -p(命令) 执行该命令并且输入数据库密码 数据库管理工具查询 selec…...
广州华锐互动:VR互动实训内容编辑器助力教育创新升级
随着科技的飞速发展,教育领域也正在经历一场深刻的变革。其中,虚拟现实(VR)技术为教学活动提供了前所未有的便利和可能性。在诸多的VR应用中,VR互动实训内容编辑器无疑是最具潜力和创新性的一种。广州华锐互动开发的这款编辑器以其独特的功能…...
技术装饰器中的功能添加与行为扩展
技术装饰器中的功能添加与行为扩展 在现代编程中,装饰器(Decorator)作为一种强大的设计模式,被广泛应用于功能增强和行为扩展。它通过在不修改原始代码的情况下,动态地为函数或类添加新功能,从而提升代码的…...
头歌(educoder)机器学习实战:Apriori算法解析与超市购物篮智能挖掘
1. 从购物小票到商业洞察:Apriori算法入门 每次逛超市结账时,收银台打印的那张长长的小票背后,藏着无数有趣的消费秘密。你可能听说过那个经典的"啤酒与尿布"故事——超市发现年轻爸爸们经常同时购买这两样商品,于是调整…...
告别第三方API:SpringBoot项目集成ip2region离线IP库的完整配置流程(附工具类)
SpringBoot深度整合ip2region:从离线IP定位到微服务架构实践 在Web应用开发中,获取用户地理位置信息是常见的需求场景。无论是内容分发、风控系统还是数据分析,IP属地信息都能为业务决策提供重要参考。传统方案通常依赖第三方API服务…...
如何用键盘完全替代鼠标?Mouseable终极指南让你效率翻倍
如何用键盘完全替代鼠标?Mouseable终极指南让你效率翻倍 【免费下载链接】mouseable Mouseable is intended to replace a mouse or trackpad. 项目地址: https://gitcode.com/gh_mirrors/mo/mouseable 你是否曾经因为长时间使用鼠标而感到手腕酸痛ÿ…...
抖音无水印下载器完整指南:如何高效批量下载抖音视频
抖音无水印下载器完整指南:如何高效批量下载抖音视频 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback suppor…...
一文学会Excel条件格式:让数据自己“开口说话“
🏷️ 标签:Excel | 条件格式 | 数据可视化 | Excel技巧 | 办公效率 | 数据分析 前言:你的表格,为什么"不会说话"? 先看一个场景。 你的领导让你整理一份销售月报,数据如下: 姓名 销售额 是否达标 张三 48000 否 李四 52000 是 王五 31000 否 赵六 65000 是…...
[特殊字符] 复杂条件下非饱和非均质土坡三维稳定性极限分析 MATLAB 代码介绍
Matlab代码源码实现:复杂条件下非饱和非均质土坡三维稳定性极限分析 MATLAB 代码的功能介绍文章,涵盖了代码的整体目标、结构、功能模块及其在工程与科研中的应用价值。 一、项目背景与研究目标 本 MATLAB 程序集旨在实现 复杂条件下非饱和非均质土坡的…...
OPC DA远程连接总失败?可能是Windows认证和DCOM设置没搞对
OPC DA远程连接故障排查:Windows认证与DCOM配置全指南 当你在深夜的工厂车间里,面对闪烁的报警灯和停滞的生产线,OPC DA远程连接却突然罢工——这种场景对工控工程师来说再熟悉不过。常规的IP设置和ProgID核对往往只是冰山一角,真…...
告别硬编码!用TwinCAT 3 XML-Server实现设备配方与参数动态加载
工业自动化参数管理的革命:TwinCAT 3 XML-Server实战指南 在一条24小时运转的汽车零部件生产线上,工程师小王正面临一个典型困境——每次切换产品型号时,都需要手动修改PLC程序中的200多个参数,包括冲压压力、传送带速度、机械臂位…...
cv_unet_image-colorization多图批量处理扩展教程:Python脚本自动化上色
cv_unet_image-colorization多图批量处理扩展教程:Python脚本自动化上色 1. 引言:从手动到自动,解放你的生产力 你是不是也遇到过这样的场景?手头有一堆黑白老照片,想用AI工具给它们上色,但每次只能上传一…...
