QCefView初步使用

2024-01-17 13:52
文章标签 使用 初步 qcefview

本文主要是介绍QCefView初步使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

QCefView的简介

QCefView是使用Qt对cef3的简单包装,以使用Qt的开发。具体的参考见:
https://cefview.github.io/QCefView/zh/docs/intros/buiding
https://blog.csdn.net/m0_37251750/article/details/126508912
编译过成依赖Cef的包,Cef有二进制发行包: https://cef-builds.spotifycdn.com/index.html
Cef在linux上使用的时候需要特别注意的是库的加载,libcef.so需要最先加载,cmake设置如下:

target_link_libraries(CefMain PRIVATE"-Wl,--no-as-needed -lcef"QCefViewQt${QT_VERSION_MAJOR}::Widgets
)

JavaScript调用C++

JS调用C++有两种方式, 一种是用invokeMethod,另一种是用CefViewQuery的方式。

invokeMethod的方式调用C++

js使用invokeMethod调用C++,主要是使用window上的桥接对象. 首先需要在C++中连接信号槽, 如下:

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);QCefSetting setting;setting.setBackgroundColor(QColor::fromRgb(200, 200, 200));//    QDir dir = QCoreApplication::applicationDirPath();
//    QString webResourceDir = QDir::toNativeSeparators(dir.filePath("HTML"));
//    qDebug() << webResourceDir;QString webResourceDir = "/home/yinl/CefMain/HTML";QCefContext::instance()->addLocalFolderResource(webResourceDir, URL_ROOT);QString indexUrl = QString("%1/%2").arg(URL_ROOT, "index.html");_pCefView = new QCefView(indexUrl, &setting, this);this->setCentralWidget(_pCefView);connect(_pCefView, &QCefView::invokeMethod, this, &MainWindow::onInvokeMethod);connect(_pCefView, &QCefView::cefQueryRequest, this, &MainWindow::onCefQueryRequest);connect(_pCefView, &QCefView::consoleMessage, this, [&](const QString& message, int level) {qDebug() << "js log, level: " << level << ", msg: " << message;});
}
function onInvokeMethodClicked(name, ...arg) {// invoke C++ codewindow.CallBridge.invokeMethod(name, ...arg);
}

在js中调用invokeMethod的接口, 然后触发C++的槽函数:

void MainWindow::onInvokeMethod(int browserId, qint64 frameId, const QString& method, const QVariantList& arguments)
{if (0 == method.compare("minWindow")) {this->showMinimized();}else if (0 == method.compare("maxWindow")) {this->showMaximized();}else if (0 == method.compare("normalWindow")) {this->showNormal();}else if (0 == method.compare("closeWindow")) {this->close();}else if (0 == method.compare("cppLog")) {qDebug() << "js: " << arguments;}else if (0 == method.compare("requestData")) {QCefEvent event("reqData");event.arguments().append("Hello world! CPP DATA.");_pCefView->broadcastEvent(event);}else {}
}

注意js中的console.log可以使用QCefView的consoleMessage的信号处理。

CefViewQuery的方式调用C++

也可以使用QCefQuery类进行请求和应答模式的调用C++的接口,此方式也是异步的操作方式,通过提供回调函数来处理返回结果。
首先需要连接cefQueryRequest的信号,然后在js中触发信号就可以调用C++接口。

function onCallQuery() {let query = {// id: 1,request: "Hello CPP", // 可以是复杂的json数据onSuccess: function (response) {cppLog("onCallQuery onSuccess: " + response);// window.alert(response);console.log(response);},onFailure: function (error_code, error_message) {cppLog("onCallQuery onFailure error_code: " + error_code + ", error_message: " + error_message);// window.alert(error_message);console.log(response);}};window.CefViewQuery(query);
}

在C++这边可以通过QCefQuery类中的id和请求来判断请求类别,然后进行处理:

void MainWindow::onCefQueryRequest(int browserId, qint64 frameId, const QCefQuery& query)
{QString request = query.request();qDebug() << "js request: " << request;quint64 id = query.id();if (id == 1) {
//        query.setResponseResult(true, "Hello Js");query.setResponseResult(false, "Hello Js", -1);_pCefView->responseQCefQuery(query);}
}

C++调用JavaScript

QCefView调用javaScript是使用事件的方式封装,在js中添加事件监听:

function onLoad() {cppLog("js onLoad init.");window.CallBridge.addEventListener("reqData", function (data) {onReqData(data);cppLog(data);});
}

C++可以通过事件触发来触发js的接口:

  • public bool triggerEvent(const QCefEvent & event)
  • public bool triggerEvent(const QCefEvent & event,int frameId)
  • public bool broadcastEvent(const QCefEvent & event)

以上三个都是异步的操作,如下:

QCefEvent event("reqData");
event.arguments().append("Hello world! CPP DATA.");
_pCefView->broadcastEvent(event);

这篇关于QCefView初步使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/616257

相关文章

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求