windows平台编译CEF支持H264(MP3、MP4)超详细

编译目标(如何确定目标定版本请查看:BranchesAndBuilding

CEF Branch:4664 CEF Commit:fe551e4 Chromium Version:96.0.4664.110

编译环境准备

1 安装或修改VS2019

VS版本和SDK版本可查看:BranchesAndBuilding

1)在在工作负荷勾选使用C++的桌面开发

windows平台编译CEF支持H264(MP3、MP4)超详细

 2)在“单个组件”勾选“Windows 10 SDK (10.0.19014.0)”

windows平台编译CEF支持H264(MP3、MP4)超详细

3)安装或修改完成后在“控制面板”/“程序”/“卸载程序”中找到刚才对应的SDK,“右键”/“更改”

windows平台编译CEF支持H264(MP3、MP4)超详细

4)找到“Debgging Tools for Windows”,然后勾选

windows平台编译CEF支持H264(MP3、MP4)超详细

2 网络代理工具和代理配置

1)一个稳定的代理, 比如: V2free

2)配置git 代理(v2rayN本地服务地址为http://127.0.0.1:10809)

::设置代理(执行一次即可) git config --global http.proxy http://127.0.0.1:10809 git config --global https.proxy http://127.0.0.1:10809 ::取消代理 git config --global --unset http.proxy git config --global --unset https.proxy

CEF 源码编译流程

1 创建工作目录

md C:Codecef md C:Codechromiumsrc md C:Codedepot_tools

windows平台编译CEF支持H264(MP3、MP4)超详细

2 添加环境变量

:: 代理 setx HTTP_PROXY "http://127.0.0.1:10809" setx HTTPS_PROXY "http://127.0.0.1:10809"  :: 禁止depot_tools自动更新 setx DEPOT_TOOLS_UPDATE "0"  :: 使用本地安装的 Visual Studio 版本 setx DEPOT_TOOLS_WIN_TOOLCHAIN "0"  :: GN 构建工具 setx CEF_USE_GN "1"  :: 使用 VS2019 创建项目 setx GN_ARGUMENTS "--ide=vs2019 --sln=cef --filters=//cef/*"  :: 使用官方构建并添加ffmpeg音视频解码 setx GN_DEFINES "is_official_build=true proprietary_codecs=true ffmpeg_branding=Chrome"  :: 将depot_tools路径("C:Codedepot_tools)添加到用户环境变量Path for /f "tokens=3,*" %i in ('reg query HKCUEnvironment /v Path') do setx Path "C:Codedepot_tools;%i%j"

执行以上命令即可在系统中创建环境变量 (记得不用的时候把这些环境变量删除了)

windows平台编译CEF支持H264(MP3、MP4)超详细

3 下载源码

1)下载cef

cd C:Code  :: clone源码并切换至4664分支 git clone https://bitbucket.org/chromiumembedded/cef.git -b 4664

2)下载chromium

cd C:Codechromium  :: clone指定tag(96.0.4664.110)的源码, (cef 4664分支 对应chromiun tag: 96.0.4664.110) :: "--depth 1": 只下载当前版本不需要历史提交记录, 否则耗时严重且浪费储存空间或者意外中断 git clone https://chromium.googlesource.com/chromium/src.git -b 96.0.4664.110 --depth 1

3)下载depot_tools

cd C:Code  :: clone depot_tools工具 git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git  cd C:Codedepot_tools  :: 临时允许更新 set DEPOT_TOOLS_UPDATE=1 :: 执行update_depot_tools.bat下载内部工具 update_depot_tools.bat :; 禁止更新 set DEPOT_TOOLS_UPDATE=0  :: checkout, (cef 4664分支 对应depot_tools commit id: e023d44820) checkout e023d44820

注意: cef, chromium, depot_tools对应版本关系在"cefCHROMIUM_BUILD_COMPATIBILITY.txt"

windows平台编译CEF支持H264(MP3、MP4)超详细

4 gclient 同步chromium依赖项目

1)创建.gclient文件

cd C:Codechromium  :: 通过命令创建.gclient文件 gclient config  https://chromium.googlesource.com/chromium/src.git --unmanaged

2)执行gclient sync

cd C:Codechromium  gclient sync --nohooks --no-history

此命令执行过程中可能会中途暂停或失败,耐心等待或重复执行此命令直到成功为止

3)执行gclient runhooks

cd C:Codechromium  :: 如果前面已经设置了此环境变量, 可以不用执行 set DEPOT_TOOLS_WIN_TOOLCHAIN=0  gclient runhooks

此命令执行过程中可能会中途暂停或失败,耐心等待或重复执行此命令直到成功为止

5 构建项目

1)复制 C:Codecef 到 C:Codechromiumsrc

xcopy "C:Codecef" "C:Codechromiumsrccef" /e

2)构建项目

cd C:Codechromiumsrccef  :: 如果前面已经设置了这些环境变量则可以跳过这3条命令 set CEF_USE_GN=1 set GN_ARGUMENTS=--ide=vs2019 --sln=cef --filters=//cef/* set GN_DEFINES=is_official_build=true proprietary_codecs=true ffmpeg_branding=Chrome  :: 构建项目 call cef_create_projects.bat

6 编译

cd C:Codechromiumsrc  ninja -C out/Release_GN_x86 cef

7 打包

cd C:Codechromiumsrcceftools  make_distrib.bat --ninja-build --client

在 C:Codechromiumsrccefbinary_distrib 目录下就可以看到打包过的文件了

8 其他

1)如果在构建或编译过程中遇到python gbk编码错误, 找到报错的代码添加 utf-8 编码即可, 比如:

      if (environment_block_name != ''):         env_block = _FormatAsEnvironmentBlock(env)         with open(environment_block_name, 'w', encoding='utf-8') as f:           f.write(env_block)

 

发表评论

评论已关闭。

相关文章

当前内容话题
  • 0