【QT进阶】Qt Web混合编程之VS2019 CEF的编译与使用(图文并茂超详细介绍)

往期回顾

【QT入门】Qt自定义控件与样式设计之自定义QLineEdit实现搜索编辑框-CSDN博客

【QT入门】Qt自定义控件与样式设计之自定义QTabWidget实现tab在左,文本水平的效果-CSDN博客【QT进阶】Qt Web混合编程之CEF、QCefView简单介绍-CSDN博客

 【QT进阶】Qt Web混合编程之VS2019 CEF的编译与使用(图文并茂超详细介绍)

一、CEF的下载

官方网址:上面有很详细的讲解,有时间可以多看看

https://bitbucket.org/chromiumembedded/cef/src/master/

下载网址:官网往下翻到Quick Links ->Downloads  

https://cef-builds.spotifycdn.com/index.html

下载之后放在D盘合适位置,简单修改下名字,加两个文件夹

build_vs2019_x64产生vs解决方案的目录
cef102_x64_sdk放提取的各种库

二、cmake的下载和通过cmake进行CEF配置

 1、cmake的下载

下载官网:

https://cmake.org/download/#older

 这里cmake的下载就不跟大家细说了,大家可以参考这位博主的文章

Windows下Cmake安装步骤详解(图文)_windows终端安装cmake-CSDN博客

2、打开cmake的gui进行配置 

 2.1、配置cef路径

2.2、配置产生vs解决方案目录的路径 

2.3、点击configure,选择x64后finish 

注意,这里一定把vs版本选择正确,否则一直报错 

我最开始选成了vs2022的,一直报错,找不到错误在哪,因为他已经写入一部分文件,第二次就不会弹出这个配置窗口了,我还是看的截图找到的问题

如何让他再次弹出这个配置界面呢?先进入build文件夹,把写入的文件全部删除,再重启cmake,重新配置,此时他就会弹出该界面,我们再设置为vs2019即可

2.4然后修改CMAKE_INSTALL_PREFIX 

修改为我们新建的另一个文件夹sdk的,主要是怕C盘他没有访问权限,很多东西放不进去

2.5配置好以后点击Generate 

看见出现Generating done,就是成功了

3、项目文件配置

3.1、点击Open Project打开项目

 进入到cmake配置成功的项目中去,当然哦我们也可以打开之前新建的build文件夹,双击打开sln文件,一样的

3.2、进入后先编译项目

 进来以后,先编译看有无报错,然后将cefsimple设置为启动项目,打开里面的simple_app.cc文件,大概在代码105行左右位置,修改默认打开的网址。

因为默认是谷歌,但是没有合理上网方式,是用不了谷歌的,我们先改成百度的

 3.3、运行项目

最后运行项目,如果成功弹出百度网页,并能实现上网功能,说明完全ok了


以上就是vs2019环境下,CEF编译与使用的简单介绍。

都看到这里了,点个赞再走呗朋友~

加油吧,预祝大家变得更强!

  • 25
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: QtCEF可以实现混合开发,即将两种技术和优点结合起来,开发出高效、高可靠性的应用程序。下面我们来看一个Qt CEF混合开发应用实例。 以开发一个简单的浏览器为例,首先使用QtQtWebEngine模块创建浏览器框架,然后使用CEF库来加载HTML页面。具体步骤如下: 1.创建Qt浏览器框架:使用QtWebEngine模块创建一个基本的浏览器窗口,该窗口可以包含地址栏、前进/后退、刷新等基本浏览器功能。 2.集成CEF:将CEF库与Qt框架集成。CEF库是一个基于Chromium开发的框架,可以用于加载HTML、JavaScript、CSS等Web技术。CEF库提供了强大的JavaScript和UI交互能力,可以通过CEF实现更多更复杂的功能。 3.在Qt使用CEF:通过Qt的QWindow类和CEFCefWindowHandle类实现QWindow和CEF窗口之间的交互。可以使用Qt的信号/槽机制来处理CEF窗口的事件。 4.加载HTML页面:通过CEF加载HTML页面,通过QtWebView控件在浏览器框架中显示页面内容。 通过以上步骤,我们可以创建一个基于QtCEF混合开发的浏览器应用程序。这种混合开发方式可以充分利用QtCEF提供的各自的优势,开发出高效、高可靠性的应用程序。同时也可以在UI和交互方面更加灵活地实现各种功能。 ### 回答2: QtCEF(Chromium Embedded Framework)混合开发应用可以使你开发跨平台的、具有Web前端组件的应用,为用户提供更好的用户体验和更丰富的交互特性,下面是一个实例。 我们可以使用Qt作为应用程序框架,同时使用CEF作为嵌入的Web浏览器来呈现Web内容。这个应用程序使用Qt的GUI组件、CEFWeb组件和C++的普通类和函数来实现。 具体实现过程如下: 1. 下载和安装CEFCEF是一个本地Web浏览器框架,支持Windows、macOS和Linux系统。它允许你使用Chromium浏览器内核来呈现Web内容。CEF提供了一系列的API和工具来支持应用与Web内容直接的交互。 2. 使用Qt Creator创建一个新的Qt Widgets应用程序。在项目设置中配置如下: a. 加入CEF运行时库文件和头文件。 b. 对于Windows平台,在项目属性中配置QtCEF的链接库。 c. 添加一个Qt Form作为主界面。 3. 在Qt代码中使用CEF组件,在主界面中添加一个QVBoxLayout。将CEF Widget直接放在这个Layout中,从而实现与其他Qt Widgets的混合。 4. 在C++代码中创建一个CEF浏览器对象。这个对象负责加载和解析Web页面,和处理浏览器事件。在开始时CEF浏览器会调用on_loading_state_change()回调函数,它表示CEF正在加载Web页面。 5. 当CEF浏览器加载Web页面时,处理web页面中的事件,例如提交表单、点击按钮等。CEF JavaScript Binding桥接机制可以让你在C++代码中注册JavaScript回调,让Web侧能够调用本地功能。CEF也允许你从Web页面中注入JavaScript脚本,以实现与本地代码的通信。 总结:使用QtCEF混合开发应用,可以开发出具有极佳用户体验的跨平台应用程序,一方面,可以充分利用CEF提供的强大的Web交互能力,另一方面,可以使用Qt的GUI组件来构建应用程序框架,并使其与Web组件混合。对于开发者而言,这意味着更轻松的应用程序开发和更高效的应用程序交互方式。 ### 回答3: qtcef混合开发应用是通过将QT的界面与CEFweb浏览器引擎相结合,实现了一种可支持Web技术的应用程序的开发方式。 比如在一个桌面应用程序中,用户可以在QT界面中使用CEF作为内置浏览器来浏览Web页面或连接Web服务。 一种实例是使用QT中的QWebEngineView来加载CEF中的Web页面,可以通过QWebChannel来实现QTCEF两者之间的通信,例如把QT中的JavaScript对象传递到CEF中,或者把CEF中的事件传递到QT中进行处理。这样可以实现在QT应用程序中嵌入Web浏览器,同时利用QT的强大框架和CEF的强大Web渲染技术为应用程序添加更多的功能。 另外,QT中还提供了QtWebEngineWidgets来支持类似于CEFWeb浏览器功能,同时可以与QT的界面框架无缝整合,用于创建具有丰富Web功能的桌面应用程序。 总之,QTCEF混合开发应用可以扩展应用程序的Web功能,从而提供更加丰富、更加强大的用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值