当前位置: 首页 > news >正文

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安装教程
      在这里插入图片描述
  • 编译成后点击上图中的 Open Project 进入 VS2019 中

    • F7 生成解决方案后报错如下,修改箭头处代码如图所示,保存后再次 F7 生成解决方案
      在这里插入图片描述

2.2 CEF 案例运行

  • 将 cefsimple 设置为启动项目,启动本地调试器,出现百度搜索界面
    • 注意修改下图代码中 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;
}
http://www.xdnf.cn/news/852841.html

相关文章:

  • Java 调用 WebService 服务的 3 种方式
  • MaxDOS v5.8s U盘版 / U盘版制作教程=(强力打造)
  • 【传奇服务器爱好者】-IGE引擎M2笔记-卧龙脚本
  • 传奇服务端Mirserver功能讲解
  • 毕业设计基于php玩酷(玩具)网站的设计与实现
  • coreplayer n79下载_coreplayer
  • 服务器lsass系统错误,电脑开机提示lsass.exe系统错误,安全帐户管理器初始化失败该怎么办?...
  • 广州华锐互动城市三维地图线上导航应用
  • new兼职网app v1.0.1
  • DeskScapes 8破解过期时间问题
  • android 市场 pad,91桌面Android Pad HD版发布 进军安卓平板市场
  • fckEditor的使用以及图片上传不显示解决
  • iPhone / iPad iOS 5.0.1完美 越狱 教程 A4/A5处理器
  • [2011-04-30]返现网排行榜
  • 热血江湖按键精灵游戏脚本!
  • 【转载】DC的逻辑综合与优化
  • 于娟的忠告----生命只有一次,活着才是王道啊!!!
  • Windows下的MS17-010(永恒之蓝)漏洞分析与复现
  • 10款精选的后台管理系统,收藏吧!
  • <网络>初识计算机网络
  • 测度定义_测度论整理(一)
  • 一套非常完整的机房装修方案
  • [内网渗透]内网基础知识
  • JailbreakMe.com-最新浏览器模式破解iPhones,iPads和iPod Touches方法
  • Html中Label标记的作用和使用介绍
  • 计算机软硬件介绍
  • JSP中 forward() 与redirect()的区别?
  • Aptana Studio 3的安装配置和使用教程
  • (转)25款实用的桌面版博客编辑器
  • Tomcat服务部署、虚拟主机配置及参数优化