位置: 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字符串转换为数字类型)

  • 华为freebudspro2怎么开启高清音质(华为freebudspro2怎么看激活时间)

    华为freebudspro2怎么开启高清音质(华为freebudspro2怎么看激活时间)

  • 苹果13备忘录怎么设置密码(苹果13备忘录怎么发送给微信好友)

    苹果13备忘录怎么设置密码(苹果13备忘录怎么发送给微信好友)

  • 淘宝退货规则有哪些(2020淘宝退款退货规则)

    淘宝退货规则有哪些(2020淘宝退款退货规则)

  • 惠普笔记本u盘启动快捷键(惠普笔记本u盘插上找不到怎么办)

    惠普笔记本u盘启动快捷键(惠普笔记本u盘插上找不到怎么办)

  • 12123实名认证人脸识别不了(12123实名认证人脸识别不了怎么办)

    12123实名认证人脸识别不了(12123实名认证人脸识别不了怎么办)

  • iphone11是双卡槽吗(苹果11双卡是什么样的卡槽)

    iphone11是双卡槽吗(苹果11双卡是什么样的卡槽)

  • 5mhz等于多少hz(1.5mhz等于多少hz)

    5mhz等于多少hz(1.5mhz等于多少hz)

  • 手机号和微信号不一致怎么办(手机号和微信号都搜索不到人怎么办)

    手机号和微信号不一致怎么办(手机号和微信号都搜索不到人怎么办)

  • 戴尔g模式可以一直开吗(戴尔g模式持续多久)

    戴尔g模式可以一直开吗(戴尔g模式持续多久)

  • qq匿名怎么弄(qq匿名提问在哪里打开)

    qq匿名怎么弄(qq匿名提问在哪里打开)

  • 手机格式化后会变快吗(手机格式化后会怎样)

    手机格式化后会变快吗(手机格式化后会怎样)

  • 魅族手机怎么解锁(魅族手机怎么解锁 忘记密码)

    魅族手机怎么解锁(魅族手机怎么解锁 忘记密码)

  • qq潜水怎么改(qq的潜水是什么意思)

    qq潜水怎么改(qq的潜水是什么意思)

  • 不知道qq密码怎么登录(不知道qq密码怎么办)

    不知道qq密码怎么登录(不知道qq密码怎么办)

  • 苹果7支持nfc功能吗(苹果7支持nfc功能怎么打开)

    苹果7支持nfc功能吗(苹果7支持nfc功能怎么打开)

  • ip协议的两个版本(ip协议种类)

    ip协议的两个版本(ip协议种类)

  • 实际存储数据的对象是(实际存储在数据库中的表是什么)

    实际存储数据的对象是(实际存储在数据库中的表是什么)

  • iphone11支持双4g吗(iphone11支持双4g待机)

    iphone11支持双4g吗(iphone11支持双4g待机)

  • vivo手机字体变成空心(vivo手机字体变大)

    vivo手机字体变成空心(vivo手机字体变大)

  • vivo全屏手机怎么截图(vivo手机怎么把返回键显示出来)

    vivo全屏手机怎么截图(vivo手机怎么把返回键显示出来)

  • 拼多多小程序在哪(拼多多小程序在哪里改收货地址)

    拼多多小程序在哪(拼多多小程序在哪里改收货地址)

  • 苹果x有指纹解锁吗(苹果x指纹解锁在哪里设置)

    苹果x有指纹解锁吗(苹果x指纹解锁在哪里设置)

  • 怎么查三星手机是不是原装(怎么查三星手机是不是原装正品)

    怎么查三星手机是不是原装(怎么查三星手机是不是原装正品)

  • crr-ul00是什么型号(crr-ul20)

    crr-ul00是什么型号(crr-ul20)

  • ps如何打圈内环形文字(ps如何打圈内环形文字怎么调间距)

    ps如何打圈内环形文字(ps如何打圈内环形文字怎么调间距)

  • 聊聊计算机中的寄存器(计算机中的意思和含义)

    聊聊计算机中的寄存器(计算机中的意思和含义)

  • 帝国CMS如何实现会员登陆赠送积分(帝国cms如何使用)

    帝国CMS如何实现会员登陆赠送积分(帝国cms如何使用)

  • 个体户定期定额征收标准
  • 营业执照是怎么样子的
  • 居民个税和非居民个税哪个高
  • 定期定额不开票违法吗
  • 企业大额融资贷款
  • 已经确认收入的售出商品发生销售退回时
  • 冲销暂估入账原材料的会计分录
  • 银行扣除的贴现利息怎么算
  • 企业计提福利费时,贷记应付职工薪酬
  • 物管费开票可以开公司名称吗
  • 收回债权会计分录
  • 预收美元和发票的关系
  • 滞纳金账务处理
  • 无形资产怎么衡量
  • 中小企业工会经费怎么算
  • 持有至到期投资科目被取消了吗
  • 支付税点是什么意思
  • 员工高温补贴奖励怎么写
  • 腾讯电脑管家开机加速在哪里
  • 跨年度暂估成本入账冲回如何会计分录
  • 设备的折旧率是什么意思
  • 小规模购进商品只收到记账联专票
  • linux中不能使用的shell
  • win10 ltsc版
  • bboy.exe进程是病毒吗 bboy进程安全吗
  • PHP:proc_terminate()的用法_命令行函数
  • 结转出租包装物因不能使用而报废的残料价值
  • 企业为员工提供服务要交增值税吗
  • 担保公司代偿账户是什么
  • 资产减值损失如何录入
  • php dao
  • 超像素和markpage的区别
  • apdl命令流手册下载
  • 增值税普通发票有什么用
  • 《开具红字增值税专用发票信息表》纸质
  • 销售鸡蛋免税怎么交税
  • 购汽车能抵扣进项吗
  • 增值税发票如何作废流程
  • 上市公司收购其他股票
  • db2获取当前年月日
  • mysql数据库访问速度慢的解决方法
  • 下列行为免征增值税的有
  • 开票明细是食品类吗
  • 补发以前年度工资怎么做账
  • 小规模纳税人报哪些税
  • 利润分配账务处理例题
  • 借管理费用贷应交税费个人所得税
  • 以前年度的银行流水可以补进来做账嘛
  • 工资代发户怎么开
  • 公司市场部门有什么职位
  • 低值易耗品和物料用品的区别
  • 应收账款期初余额错了怎么调整
  • 如何进行税前扣除
  • 交易性金融资产包括哪些项目
  • 发票红冲后原票是什么状态
  • 购入固定资产怎么折旧
  • 小企业持有的不良资产
  • 存储过程失效怎么办
  • sqlserver获取表结构
  • 如何解开win10电脑密码
  • 电脑怎么改xp系统
  • ubuntu中如何设置克隆屏
  • 恢复已删除的聊天记录微信
  • sessmgr.exe - sessmgr是什么进程 有什么用
  • linux012
  • shell脚本echo输出变量
  • dos 浏览器
  • js function的this指向
  • jquery教程chm
  • js弹出div出现遮罩层
  • javascript基础编程
  • python日志类
  • 常用的javascript对象
  • 打印缴纳社保电子缴税凭证
  • 增值税纳税申报表附列资料(三)
  • 安徽省国家税务局通用定额发票
  • 手工税票
  • 湖南长沙税务局上班时间
  • 国税局和地税局分别征收什么税种
  • 社保交五百多
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设