cef chromium 编译

时间:2023-03-09 15:33:38
cef chromium 编译

前言

目前客户端引用了cef sharp库来嵌入web页面

cef sharp是对cef (chromium embed framework)的c#封装

cef是对chromium内核的c++封装

什么是chromium?

chromiumgoogle chrome内核的开源库

google chrome上开发的功能都会先放到chromium上实验

成功了才会合并到google chrome发布

所以chromium可以视为google chrome的预览版

由于专利原因

chromium的发布版不支持mp3, h264(视频编码

如果需要这些功能,需要自己重新编译

为了解决这个禅道bug(chromium离屏渲染下的鼠标滚轮bug,google chrome不是离屏渲染,wpf客户端上使用的cefsharp是),我打算重新编译cef,,顺便编译chromium内核以支持mp3和h264.

编译注意事项

1.官方编译文档

2.执行官方文档上的步骤需要禾斗学上网,(https, git,和DNS)

3.按照官方文档编译出来的chromium内核是不支持mp3 ,h264的,需要手动加一些编译变量

4.chromium内核分支版本不指定的话拉取到master的代码

编译步骤

1.安装vs2017

$PATH_TO_INSTALLER.EXE ^
--add Microsoft.VisualStudio.Workload.NativeDesktop ^
--add Microsoft.VisualStudio.Component.VC.ATLMFC ^
--add Microsoft.VisualStudio.Component.VC.Tools.ARM64 ^
--add Microsoft.VisualStudio.Component.VC.MFC.ARM64 ^
--includeRecommended

安装完后,到应用程序里找到windows sdk 右键修改,先change,下一步,

把debugging tools for windows打钩,否则后面创建解决方案会失败

cef chromium 编译

2.创建以下目录

c:\code\automate
c:\code\chromium_git
c:\code\depot_tools

3.depot_tools

下载 depot_tools.zip,解压到depot_tools文件夹

4.automate-git.py

下载 automate-git.py 放到 automate文件夹

5.设置系统环境变量

1.Path 新增一个路径c:\code\depot_tools
2.创建一个系统变量DEPOT_TOOLS_WIN_TOOLCHAIN 值0

6.拉取代码

C:\Code\chromium_git创建update.bat,内容如下

set GN_DEFINES=use_jumbo_build=true ffmpeg_branding=Chrome proprietary_codecs=true
set GN_ARGUMENTS=--ide=vs2017 --sln=cef --filters=//cef/*
python ..\automate\automate-git.py --download-dir=c:\code\chromium_git --depot-tools-dir=c:\code\depot_tools --no-distrib --no-build --branch=3770

设置好代理后 执行脚本,会自动拉取cef和chromium的源码

总共20G左右

7.为源码创建解决方案

拉取代码后

切换到目录 C:\Code\chromium_git\chromium\src\cef

创建create.bat 内容如下

set GN_DEFINES=use_jumbo_build=true ffmpeg_branding=Chrome proprietary_codecs=true is_component_build=false

set GN_ARGUMENTS=--ide=vs2017 --sln=cef --filters=//cef/*

call cef_create_projects.bat

发布时记得设置is_component_build = false

编译时可能会出现找不到LASTCHANGE.committime这一文件,

C:\code\chromium_git\chromium\src\build\util

执行

python lastchange.py -o LASTCHANGE

即可生成

运行create.bat后,生成成功后

cef chromium 编译

8.执行编译

编译之前,我先把cef的代码加一些洗发水(特效),解决一下鼠标滚轮关闭select元素的bug

切换到C:\Code\chromium_git\chromium\src 编译chromium内核

执行编译x64

python -m pip install pywin32 安装pywin32库
gn args out\Release_GN_x64 可用来配置编译参数
gclient runhooks 更新编译时需要的依赖 ninja -C out\Release_GN_x64 cef

编译x86如法炮制

编译时间如果用机械硬盘硬盘要4小时左右

建议使用固态硬盘,我用我自己的笔记本 i7低压,估计也要不少时间,

cef chromium 编译

等编译完成了再来更新第9步

9. 测试编译后的chromium 内核

1.osr渲染模式下滚动鼠标不应该关闭html select element

命令行传参 开启离屏渲染(osr)打开cefclient,

C:\Code\chromium_git\chromium\src\out\Release_GN_x64> cefclient --multi-threaded-message-loop --off-screen-rendering-enabled --enable-gpu

鼠标滚动不会关闭select了

cef chromium 编译

功能通过

2.可以播放视频音频

打开bilibili播放一个视频

cef chromium 编译

功能通过

结语

我的电脑cpu是i7 低压,内存24GB

编译过程其实(两三个小时)*2就结束了

主要过程还是在拉代码

在编译的过程中内存有几次用光过

所以内存朋友小的朋友编译之前应该把虚拟内存设置多一点

编译完32位和64位,文件夹大小为

cef chromium 编译

所以编译前至少留100GB左右的存储空间吧