位置: IT常识 - 正文

【小沐学C++】C++ MFC中嵌入web网页控件(WebBrowser、WebView2、CEF3)

编辑:rootadmin
【小沐学C++】C++ MFC中嵌入web网页控件(WebBrowser、WebView2、CEF3) 文章目录1、简介2、WebBrowser2.1 新建测试项目2.2 添加web控件类文件2.3 添加web控件变量2.4 添加窗口事件2.5 添加web控件实例创建代码2.6 编译和运行3、WebView23.1 新建测试项目3.2 下载和安装WebView2包3.3 添加web控件代码3.4 编译和运行4、CEF34.1 下载cef34.2 编译和运行cef3结语1、简介

推荐整理分享【小沐学C++】C++ MFC中嵌入web网页控件(WebBrowser、WebView2、CEF3),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

WebBrowser控件最常见的用途之一是向应用程序添加 Internet 浏览功能。使用 IWebBrowser2 接口,可以浏览到本地文件系统、网络或万维网上的任何位置。可以使用IWebBrowser2::Navigate 方法告知控件要浏览到哪个位置。第一个参数是包含位置名称的字符串。要浏览到本地文件系统或网络上的某个位置,请指定文件系统位置的完整路径或网络上该位置的 UNC 名称。若要浏览到万维网上的某个站点,请指定该站点的 URL。

2、WebBrowser

To add the WebBrowser control to a basic Microsoft Foundation Classes (MFC) application, perform the following steps.

Right-click the Project name, and point to Add, the select Class… from the context menu.Select “MFC Class From ActiveX Control” and click Add.Select “Microsoft Web Browser” from among the classes listed in the registry. Highlight the IWebBrowser2 interface, and click the right arrow to generate a new CWebBrowser2 class.Click Finish.2.1 新建测试项目

选择模板:Visual C++ -> MFC应用程序,如下: 选择:单个文档 创建的项目文件如下:

2.2 添加web控件类文件

在项目“MFCApplication9”上鼠标右键,在菜单里选择“类向导。。。” 在弹窗“类向导”中选择ActiveX控件中的MFC类。 安装如下的提示,选择Microsoft Web Browser<1.0>. 按照如下提示,选择IWebBrowser2。然后点击按钮完成。 然后自动在项目中生成控件的类文件如下:

2.3 添加web控件变量

在文件MFCApplication9View.h中添加代码如下:

#include "CWebBrowser2.h"CWebBrowser2 *m_pBrowser;

2.4 添加窗口事件

对CMFCApplication9View视图类添加窗口事件:WM_CREATE,WM_SIZE

int CMFCApplication9View::OnCreate(LPCREATESTRUCT lpCreateStruct){if (CView::OnCreate(lpCreateStruct) == -1)return -1;// TODO: 在此添加您专用的创建代码return 0;}void CMFCApplication9View::OnSize(UINT nType, int cx, int cy){CView::OnSize(nType, cx, cy);// TODO: 在此处添加消息处理程序代码}

2.5 添加web控件实例创建代码

在上面的两个事件函数里添加对应的代码:

void CMFCApplication9View::OnSize(UINT nType, int cx, int cy){CView::OnSize(nType, cx, cy);if (m_pBrowser) {m_pBrowser->MoveWindow(0, 0, cx, cy);}// TODO: 在此处添加消息处理程序代码}int CMFCApplication9View::OnCreate(LPCREATESTRUCT lpCreateStruct){if (CView::OnCreate(lpCreateStruct) == -1)return -1;// TODO: 在此添加您专用的创建代码// Create the control.m_pBrowser = new CWebBrowser2;ASSERT(m_pBrowser);if (!m_pBrowser->Create(NULL, NULL, WS_VISIBLE, CRect(0, 0, 0, 0), this, NULL)){TRACE("failed to create browser/n");delete m_pBrowser;m_pBrowser = NULL;return 0;}// Initialize the first URL.COleVariant noArg;CString strURL("https://image.baidu.com/");//CString strURL("https://cn.bing.com/");m_pBrowser->Navigate(strURL, &noArg, &noArg, &noArg, &noArg);return 0;}2.6 编译和运行

3、WebView2

Microsoft Edge WebView2 控件允许在本机应用中嵌入 web 技术(HTML、CSS 以及 JavaScript)。 WebView2 控件使用 Microsoft Edge 作为绘制引擎,以在本机应用中显示 web 内容。

支持以下编程环境:

Win32 C/C++.NET Framework 4.5 或更高版本.NET Core 3.1 或更高版本.NET 5.NET 6WinUI 2.0WinUI 3.03.1 新建测试项目

新建一个MFC的项目如上。

3.2 下载和安装WebView2包【小沐学C++】C++ MFC中嵌入web网页控件(WebBrowser、WebView2、CEF3)

通过菜单“项目”-“管理NuGet程序包”,下载相关包。 在“浏览”分页的左上角的搜索栏中,键入 Microsoft.Web.WebView2。 或者,复制并粘贴下面的单行代码块。 然后选择“ Microsoft.Web.WebView2”。以及在右侧选择对应的版本,然后点击按钮安装。 自动弹窗下载提示框,点击确定按钮。 输出下载的日志信息。 在项目的代码文件夹里会自动创建子文件夹packages,里面保存了下载的相关包文件夹:Microsoft.Web.WebView2.1.0.902.49 再下另一个包:Microsoft.Windows.ImplementationLibrary。

稍后,你将安装 Windows 实现库 (WIL) - 仅限标头的 C++ 库,通过适用于 Windows COM 编码模式的可读、类型安全的 C++ 接口,使 Windows 上的开发人员的生活更加轻松。 可通过 Visual Studio 中的 解决方案资源管理器 为项目安装此 Microsoft.Windows.ImplementationLibrary 包。

在 “NuGet” 窗口中,单击“ 浏览 ”选项卡。在左上角的搜索栏中,键入 Microsoft.Windows.ImplementationLibrary。 或者,复制并粘贴下面的单行代码块。 然后选择 “Microsoft.Windows.ImplementationLibrary”。 同样在项目文件夹里会下载子文件夹:Microsoft.Windows.ImplementationLibrary.1.0.191107.2 项目文件夹的文件packages.config:

<?xml version="1.0" encoding="utf-8"?><packages> <package id="Microsoft.Web.WebView2" version="1.0.902.49" targetFramework="native" /> <package id="Microsoft.Windows.ImplementationLibrary" version="1.0.191107.2" targetFramework="native" /></packages>3.3 添加web控件代码

(1)添加变量和头文件

#include <iostream>#include <wrl.h>#include <wil/com.h>#include "WebView2.h"using namespace Microsoft::WRL;// Pointer to WebViewControllerstatic wil::com_ptr<ICoreWebView2Controller> webviewController;// Pointer to WebView windowstatic wil::com_ptr<ICoreWebView2> webview;

(2)在OnCreate事件函数中添加代码:

int CMFCApplication9View::OnCreate(LPCREATESTRUCT lpCreateStruct){if (CView::OnCreate(lpCreateStruct) == -1)return -1;HWND hWnd = this->m_hWnd;// TODO: 在此添加您专用的创建代码// <-- WebView2 sample code starts here -->// Step 3 - Create a single WebView within the parent window// Locate the browser and set up the environment for WebViewCreateCoreWebView2EnvironmentWithOptions(nullptr, nullptr, nullptr,Callback<ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler>([hWnd](HRESULT result, ICoreWebView2Environment* env) -> HRESULT {// Create a CoreWebView2Controller and get the associated CoreWebView2 whose parent is the main window hWndenv->CreateCoreWebView2Controller(hWnd, Callback<ICoreWebView2CreateCoreWebView2ControllerCompletedHandler>([hWnd](HRESULT result, ICoreWebView2Controller* controller) -> HRESULT {if (controller != nullptr) {webviewController = controller;webviewController->get_CoreWebView2(&webview);}// Add a few settings for the webview// The demo step is redundant since the values are the default settingswil::com_ptr<ICoreWebView2Settings> settings;webview->get_Settings(&settings);settings->put_IsScriptEnabled(TRUE);settings->put_AreDefaultScriptDialogsEnabled(TRUE);settings->put_IsWebMessageEnabled(TRUE);// Resize WebView to fit the bounds of the parent windowRECT bounds;::GetClientRect(hWnd, &bounds);webviewController->put_Bounds(bounds);// Schedule an async task to navigate to Bingwebview->Navigate(L"https://www.bing.com/");// <NavigationEvents>// Step 4 - Navigation events// register an ICoreWebView2NavigationStartingEventHandler to cancel any non-https navigationEventRegistrationToken token;webview->add_NavigationStarting(Callback<ICoreWebView2NavigationStartingEventHandler>([](ICoreWebView2* webview, ICoreWebView2NavigationStartingEventArgs* args) -> HRESULT {wil::unique_cotaskmem_string uri;args->get_Uri(&uri);std::wstring source(uri.get());if (source.substr(0, 5) != L"https") {args->put_Cancel(true);}return S_OK;}).Get(), &token);// </NavigationEvents>// <Scripting>// Step 5 - Scripting// Schedule an async task to add initialization script that freezes the Object objectwebview->AddScriptToExecuteOnDocumentCreated(L"Object.freeze(Object);", nullptr);// Schedule an async task to get the document URLwebview->ExecuteScript(L"window.document.URL;", Callback<ICoreWebView2ExecuteScriptCompletedHandler>([](HRESULT errorCode, LPCWSTR resultObjectAsJson) -> HRESULT {LPCWSTR URL = resultObjectAsJson;//doSomethingWithURL(URL);return S_OK;}).Get());// </Scripting>// <CommunicationHostWeb>// Step 6 - Communication between host and web content// Set an event handler for the host to return received message back to the web contentwebview->add_WebMessageReceived(Callback<ICoreWebView2WebMessageReceivedEventHandler>([](ICoreWebView2* webview, ICoreWebView2WebMessageReceivedEventArgs* args) -> HRESULT {wil::unique_cotaskmem_string message;args->TryGetWebMessageAsString(&message);// processMessage(&message);webview->PostWebMessageAsString(message.get());return S_OK;}).Get(), &token);// Schedule an async task to add initialization script that// 1) Add an listener to print message from the host// 2) Post document URL to the hostwebview->AddScriptToExecuteOnDocumentCreated(L"window.chrome.webview.addEventListener(\'message\', event => alert(event.data));" \L"window.chrome.webview.postMessage(window.document.URL);",nullptr);// </CommunicationHostWeb>return S_OK;}).Get());return S_OK;}).Get());// <-- WebView2 sample code ends here -->return 0;}

(3)在OnSize事件函数中添加代码:

void CMFCApplication9View::OnSize(UINT nType, int cx, int cy){CView::OnSize(nType, cx, cy);// TODO: 在此处添加消息处理程序代码if (webviewController != nullptr) {RECT bounds;GetClientRect(&bounds);webviewController->put_Bounds(bounds);};}3.4 编译和运行

最后运行的测试程序的界面如下:

4、CEF3

CEF全称Chromium Embedded Framework,是一个基于Google Chromium 的开源项目。Google Chromium项目主要是为Google Chrome应用开发的,而CEF的目标则是为第三方应用提供可嵌入浏览器支持。CEF隔离底层Chromium和Blink的复杂代码,并提供一套产品级稳定的API,发布跟踪具体Chromium版本的分支,以及二进制包。CEF的大部分特性都提供了丰富的默认实现,让使用者做尽量少的定制即可满足需求。

4.1 下载cef3

https://cef-builds.spotifycdn.com/index.html 浏览器直接搜索关键词「CEF Automated Builds」找到新的下载站点。

4.2 编译和运行cef3

对于cef来说,只需要把编译出来的libcef_dll_wrapper.lib拿来使用即可,其他文件直接包里的即可。

cef_binary_3.3578.1860.g36610bd_windows32或 cef_binary_88.2.9+g5c8711a+chromium-88.0.4324.182_windows32_minimal

VisualStudio2017、2019编译非常快速,使用CMake对相关代码为例,使用CMake-gui转换,默认是64位版本(如果需要使用32位版本,转换的时候注意选择Win32),转换后的vs工程默认就是Unicode字符集MTd(MT)的,直接编译libcef_dll_wrapper即可,生成的lib拷走,其他的lib直接使用现成的。

创建成功后只编译libcef_dll_wrapper即可,其他lib和资源使用编译好的即可。 尽量链接release版本的,要链接:libcef.lib、cef_sandbox.lib、libcef_dll_wrapper 字符串要传递的时候,需转换为Unicode,可使用std::wstring转换。 cefinitialize崩溃:说明exe执行路径下缺少相关文件导致初始化失败,可以把Resources目录下的locales文件夹、icudtl.dat、cef*.pak等文件复制过来。

通过cmake构建cef的vs工程。

依次点击按钮:“Configure” -> “Generate” -> “Open Project”

生成vs工程文件:

用vs2017打开解决方案文件cef.sln,如下: 其中cefsimple和cefclient是基于win32的实现cef3浏览器的简单示例代码,相对而言,cefsimple比较简单,代码量比较少,mfc中也主要是用这个工程中的文件。 编译和运行,其中cefclient.exe运行如下:

D:\cef_binary88\Release\libcef.libD:\cef_binary88\Release\cef_sandbox.libD:\cef_binary88\Release\libcef_dll_wrapper.lib结语

如果您觉得该方法或代码有一点点用处,可以给作者点个赞,或打赏杯咖啡;╮( ̄▽ ̄)╭ 如果您感觉方法或代码不咋地//(ㄒoㄒ)//,就在评论处留言,作者继续改进;o_O??? 如果您需要相关功能的代码定制化开发,可以留言私信作者;(✿◡‿◡) 感谢各位大佬童鞋们的支持!( ´ ▽´ )ノ ( ´ ▽´)っ!!!

本文链接地址:https://www.jiuchutong.com/zhishi/297741.html 转载请保留说明!

上一篇:【Linux】rm 命令:删除文件/文件夹(linux rm 命令)

下一篇:js字符串转换为对象格式的3种方法(js字符串转换为数字类型)

  • 网店推广方式有哪些(网店推广方式有几种具体是哪些)

    网店推广方式有哪些(网店推广方式有几种具体是哪些)

  • 网速不稳定是什么原因(网速不稳定)(网速不稳定是什么原因?手机)

    网速不稳定是什么原因(网速不稳定)(网速不稳定是什么原因?手机)

  • iphone13pro怎么打开5g(iphone13pro怎么打开nfc)

    iphone13pro怎么打开5g(iphone13pro怎么打开nfc)

  • 支付宝城市服务在哪里(支付宝城市服务随手拍举报在哪里)

    支付宝城市服务在哪里(支付宝城市服务随手拍举报在哪里)

  • 华为荣耀9x是不是5g双模手机(华为荣耀9x是不是很重)

    华为荣耀9x是不是5g双模手机(华为荣耀9x是不是很重)

  • belete键盘是什么意思

    belete键盘是什么意思

  • 步步高家教机可以自己下载吗(步步高家教机可以下载QQ吗)

    步步高家教机可以自己下载吗(步步高家教机可以下载QQ吗)

  • kindle需要贴膜吗(kindle需不需要贴膜)

    kindle需要贴膜吗(kindle需不需要贴膜)

  • 华为mate30长度多少厘米(华为mate 30手机长多少厘米)

    华为mate30长度多少厘米(华为mate 30手机长多少厘米)

  • 抖音显示的音浪是累计的吗(抖音显示音浪旧版本)

    抖音显示的音浪是累计的吗(抖音显示音浪旧版本)

  • word首字下沉点不了(word首字下沉点不动)

    word首字下沉点不了(word首字下沉点不动)

  • 华为mate30来电铃声渐强怎么关闭(华为mate30来电铃声本地音乐怎么删除)

    华为mate30来电铃声渐强怎么关闭(华为mate30来电铃声本地音乐怎么删除)

  • feed流和信息流区别(feed流的表现形式)

    feed流和信息流区别(feed流的表现形式)

  • ipad盒子上的序列号在哪里(ipad盒子上的序列号w开头)

    ipad盒子上的序列号在哪里(ipad盒子上的序列号w开头)

  • win10怎么查看双通道(怎样在win10看到安装的双系统)

    win10怎么查看双通道(怎样在win10看到安装的双系统)

  • ios系统用什么编程(苹果系统用什么写的)

    ios系统用什么编程(苹果系统用什么写的)

  • 苹果手机4g网速慢怎么办(苹果手机4G网速突然变慢)

    苹果手机4g网速慢怎么办(苹果手机4G网速突然变慢)

  • Wifi出现感叹号怎么解决(wifi出现感叹号上不了网怎么办)

    Wifi出现感叹号怎么解决(wifi出现感叹号上不了网怎么办)

  • windows无法验证此文件的数字签名解决方法(windows无法验证显卡驱动的数字签名)

    windows无法验证此文件的数字签名解决方法(windows无法验证显卡驱动的数字签名)

  • Wat Chaloem Phra Kiat Phrachomklao Rachanusorn的浮庙,泰国南邦 (© pa_YON/Getty Images)

    Wat Chaloem Phra Kiat Phrachomklao Rachanusorn的浮庙,泰国南邦 (© pa_YON/Getty Images)

  • 前端白屏出现的原因及一些解决方式(页面白屏可能原因前端)

    前端白屏出现的原因及一些解决方式(页面白屏可能原因前端)

  • PHPCMS漏洞之authkey生成算法问题导致authkey泄露(php网站漏洞)

    PHPCMS漏洞之authkey生成算法问题导致authkey泄露(php网站漏洞)

  • java默认访问修饰符的使用(java默认访问权限修饰符)

    java默认访问修饰符的使用(java默认访问权限修饰符)

  • 股权分配利润应该怎么做账
  • 会计工资标准
  • 自来水开出发票的税率是多少
  • 企业残疾金的基数是多少
  • 会费要交增值税吗
  • 财务报表提示未审计
  • 广告公司会议记录内容
  • 建筑简易征收的合同怎么写
  • 通过应交税费核算的
  • 不交住房公积金了能提取出来吗
  • 跨年度发现的差错
  • 新成立的公司银行存款如何入账
  • 展会门票费计入什么科目
  • 公司法人信息变更是先去税务局还是先去银行
  • 变更办税人需要原办税人去吗
  • 转账支票可不可以挂失止付
  • 年底进项税和销项税怎么记
  • 拿到省级奖有什么用
  • 广告代理服务计入什么费用
  • 分类所得申报要申报吗
  • 购入材料的应付账款包括商业折扣吗
  • 经营范围外的业务可以开发票吗
  • 合同银行账户与开票信息不一致会计如何处理
  • 应付账款是贵公司欠还是欠贵公司
  • kali linux安装kde桌面
  • 电商第三方平台规则的特点
  • 会计差错及账项调整
  • 深红玫瑰鹦鹉多钱一个
  • yii2入门
  • nginx同一个端口设置两个网站
  • 国有控股公司改制
  • 软件企业认定好处
  • 抖音是如何成功的
  • 轻量级网络设计
  • 机器学习分类算法之XGBoost(集成学习算法)
  • golang和php
  • 增值税发票打印出格了能用吗
  • 物权转移的几种情形
  • 应付利息怎么计算
  • 发放年终奖的会议纪要
  • redis的
  • 图文详解塘鲺、鲶鱼的区别介绍
  • 发票临时增量好难
  • 电子承兑逾期超过30天怎么办
  • 保险公司的奖励制度
  • 施工企业期间费用 企业管理费会计分录
  • 可供出售金融资产新准则叫什么
  • 个人承担的个税是公司的成本费用吗
  • 申报个人所得税的软件叫什么
  • 绩效工资定义及标准
  • 自然人可以申请一般纳税人吗
  • 费用票成本票有哪些
  • 什么是企业合并的具体动因之一
  • 冲减以前年度未开票收入开票如何申报小规模纳税人
  • 应付账款预付账款期末余额怎么算
  • 企业办理土地证需要哪些资料
  • 固定资产盘盈盘亏的会计科目
  • doc怎么使用
  • windows10 硬件
  • Win10预览版拆弹
  • win8的应用商店
  • 直接玩鬼泣4
  • aspnet_admin.exe进程是安全的吗 aspnet_admin进程信息查询
  • win1020h2正式版
  • SCHDPL32.EXE - SCHDPL32是什么进程 有什么用
  • linux 用户进程
  • react用什么ui
  • ant编译工具
  • java调用curl命令
  • unity3d怎么样
  • 举例讲解生产可能性曲线
  • android 内部存储
  • 云南税务查询系统
  • 江苏省发票查询电话
  • 广东省地方税务局
  • 地税发票怎么开 步骤
  • 跨县调动工作流程
  • 单位轿车出售怎么处理
  • 小船载重多少
  • 昱铭这个公司名字怎么样
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设