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

相关文章

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java 正则表达式的使用实战案例

《Java正则表达式的使用实战案例》本文详细介绍了Java正则表达式的使用方法,涵盖语法细节、核心类方法、高级特性及实战案例,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、正则表达式语法详解1. 基础字符匹配2. 字符类([]定义)3. 量词(控制匹配次数)4. 边

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案