前言
目前客户端引用了cef sharp
库来嵌入web页面cef sharp
是对cef
(chromium embed framework)的c#封装cef
是对chromium内核
的c++封装
什么是chromium
?chromium
是google 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打钩,否则后面创建解决方案会失败
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后,生成成功后
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低压,估计也要不少时间,
等编译完成了再来更新第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了
功能通过
2.可以播放视频音频
打开bilibili播放一个视频
功能通过
结语
我的电脑cpu是i7 低压,内存24GB
编译过程其实(两三个小时)*2就结束了
主要过程还是在拉代码
在编译的过程中内存有几次用光过
所以内存朋友小的朋友编译之前应该把虚拟内存设置多一点
编译完32位和64位,文件夹大小为
所以编译前至少留100GB左右的存储空间吧