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使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本