Windows下从源码编译CEF

本文详细记录了在Windows系统下从源码编译CEF以获取PPAPI C++接口所需的库,包括安装Python,设置环境变量,解决locale问题,安装VS2013和Windows 10 SDK,以及使用automate-git.py脚本进行编译的过程。编译过程中可能出现的错误及解决办法也进行了说明。
部署运行你感兴趣的模型镜像

PPAPI提供了C和C++两种插件开发接口。要使用C++版本的接口,需要ppapi_cpp.lib和ppapi_cpp_objects.lib这两个静态库,然而CEF的SDK里没有这两个库,只能编译CEF的源码来得到。所以,我就编译了CEF的源码。

花了几天时间,反复编译几次,过程比较艰辛,记录一下。如果你参考我的过程编译,请看完这篇文章再动手。

foruok原创,如需转载请关注foruok的微信订阅号“程序视界”联系foruok。

https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding这里描述了怎么从源码编译CEF,这是主要的参考资料。

CEF支持自动、手动两种编译方法,我们使用基于git的自动构建流程。

注意,必须在无墙状态下来编译。

编译步骤

Windows系统必须是Windows 7 x64 或更高版本,x86的不支持哦。

保证已经安装了python,并设置了环境变量。

e:/sources/CEF是我的编译目录,以后都以此为例来说明。

安装过程参考了http://www.chromium.org/developers/how-tos/build-instructions-windowshttps://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding,我试验了几次,出了一些错。现在,按我下面的步骤来即可:

  1. 设置系统locale为English,否则可能遇到类似下图的错误:
    error_unicode
  2. 安装VS 2013 Update 4,其他版本的VS都歇菜。安装过程中确保选择MFC组件(Microsoft Foundation Classes for C++)
  3. Windows 10 SDK,安装到默认路径下。
  4. 配置环境变量,使用Ninja编译、使用VS 2013调试,按下面的命令设置环境变量(在cmd.exe内):
    set DEPOT_TOOLS_WIN_TOOLCHAIN=0
    set GYP_GENERATORS=ninja,msvs-ninja
    set GYP_MSVS_VERSION=2013
  5. 下载automate-git.py脚本文件。
  6. 自动构建版本为2526的分支,用下面的命令:
    python e:/sources/CEF/automate-git.py –download-dir=e:/sources/CEF/2526 –branch=2526

提一下,automate-git.py会自动下载depot_tools、Chromium和CEF源码、构建CEF的调试和发布版本、创建SDK包。SDK包在e:/sources/CEF/2526/chromium/src/cef/binary_distrib目录下。

特别说明

  • 如果你因为系统locale出错,再次执行automate-git.py时,可能会遇见下面的错误(红线所示):

error_out_exsit

此时删除e:/sources/CEF/2526/chromium/src/out目录,再来一遍即可。

  • VS 2013如果没有安装到默认目录,也会出错(我就是酱紫的):
    error_vcvars

我编译了一天多,出了上面的错误。

沿着上图出错信息回溯,发现已经执行到automate-git.py的975行,这是最后一步了,所有中间编译已完成,就剩打包生成发行包了。

错误原因如图上标注的,找不到vcvars32.bat。跟到msvs_env.bat文件里去看,发现其中通过硬编码的VS路径来引用vcvars32.bat,对于VS2013,它用”%PROGRAMFILES(X86)%\Microsoft Visual Studio 12.0\VC\bin\vcvars32.bat”,我安装到别的地方去了……还好,有一个CEF_VCVARS变量,设置一下就好了。使用下列命令:

set CEF_VCVARS=E:\software\VS2013_64_update4\VC\bin\vcvars32.bat

然后我需要研究如何只生成SDK,执行“python e:/sources/CEF/automate-git.py –help”,查看帮助,发现有一个–no-build选项还有一个–force-distrib选项,还有很多,最后用下面的命令生成了SDK发行包:

python e:/sources/CEF/automate-git.py --download-dir=e:/sources/CEF/2526 --branch=2526 --no-build --no-update --force-distrib

编译成功后,生成的CEF SDK发行包在chromium\src\cef\binary_distrib目录下,我这里是cef_binary_3.2526.1364.gf6bf57b_windows32.zip。 注意,这里面没有PPAPI C++接口对应的静态库……但它们确实生成了,ppapi_cpp.lib和ppapi_cpp_objects.lib,在chromium\src\out\Release\obj\ppapi目录下,拷贝到你的SDK里就可以用了。

opengl库libGLESv2.dll和libEGL.dll也在编译过程生成了,DLL和对应的lib文件都在chromium\src\out\Release下,也可以拷贝到SDK目录下,PPAPI的有些示例会用到。

chromium\src\out\Release目录下还有cefclient.exe,就是CEF SDK里那个示例,可以运行。运行后效果如下图:

cefclient

一点总结

编译是个漫长的过程,可能遇到各种错误,基本找不到中文资料,Google猛搜吧……

闲言碎语:

  1. automate-git.py默认会构建debug和release两个版本,很耗时,得十几个小时。其实可以执行python e:/sources/CEF/automate-git.py –help查看帮助,–no-debug-build选项可以不编译Debug版本,–no-release-build可以不编译Release版本,只编译一个版本,会快很多。
  2. 编译过程中出错,再次编译时,可以指定 –no-update选项,跳过源码更新
  3. CEF编译时链接的运行库为MT(多线程)。如果你要编译CEF或PPAPI示例,也要在“配置属性–>C/C++–>代码生成–>运行库”中设置为MT。
  4. CEF编译时定义了UNICODE和_UNICODE宏。编译示例时最好也使用 Unicode 字符集。

相关文章参考:

您可能感兴趣的与本文相关的镜像

Python3.10

Python3.10

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

Windows 系统下编译 CEFChromium Embedded Framework)源码是一个较为复杂的流程,涉及多个步骤和依赖项的配置。以下是详细的编译方法和步骤: ### ### 环境准备 在开始编译之前,需要确保系统满足以下要求: - 安装 **Windows 10 或更高版本**。 - 安装 **Python 2.7.x**,因为 CEF 的构建脚本依赖于 Python。 - 安装 **Visual Studio 2019 或更高版本**,推荐使用 VS2019 以确保兼容性。 - 安装 **depot_tools**,这是 Chromium 的构建工具集,可以通过以下命令克隆: ```bash git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git ``` 将 `depot_tools` 添加到系统环境变量 `PATH` 中。 ### ### 目录结构 按照 CEF 的官方推荐,构建目录结构如下: ``` code/ ├── automate/ │ └── automate-git.py <-- CEF 构建脚本 ├── chromium_git/ │ └── cef/ <-- CEF 源码目录 ├── chromium/ │ └── src/ <-- Chromium 源码目录 ├── update.bat <-- 启动脚本 └── depot_tools/ <-- Chromium 构建工具 ``` ### ### 下载 CEF 源码 使用 `automate-git.py` 脚本下载 CEFChromium 源码。执行以下命令: ```bash python automate-git.py --download-dir C:\path\to\code --branch 4949 --force-clean ``` - `--branch` 参数指定 CEF 的版本分支,例如 `4949` 是 CEF 的一个稳定版本。 - `--download-dir` 指定下载目录。 - 使用 `--no-update` 参数可以跳过源码更新阶段,加快重复构建的速度。 - 使用 `--no-debug-build` 或 `--no-release-build` 可以避免构建不必要的版本,节省时间[^4]。 ### ### 配置构建参数 在 `chromium/src/cef/` 目录下,编辑 `cef_build.bat` 文件,配置构建参数: - `CEF_USE_SANDBOX=0`:禁用沙箱(可选)。 - `GYP_DEFINES="buildtype=Official"`:设置构建类型为发布版本。 - `--parallel`:启用并行构建,加快编译速度。 ### ### 使用 CMake 生成构建文件 进入 `CEF3` 源码目录,创建构建目录 `build2010`,然后使用 CMake 生成 Visual Studio 项目文件: ```bash mkdir build2010 cd build2010 cmake -G "Visual Studio 16 2019" -A Win32 .. ``` - `-G` 指定生成器,这里使用的是 Visual Studio 2019。 - `-A` 指定目标架构,例如 `Win32` 表示 32 位构建。 ### ### 编译项目 打开生成的 `.sln` 文件(例如 `build2010/cef.sln`),选择构建配置(如 Release),然后进行编译编译完成后,`lib_cef_wrapper.lib` 文件将生成在 `binary_distrib` 目录中[^2]。 ### ### 测试编译结果 编译完成后,在 `chromium/src/out` 目录下找到 `cefclient.exe` 文件,运行该文件并访问以下网站以测试功能: - [http://html5test.com](http://html5test.com):用于测试 HTML5 功能支持情况。 - [https://woolyss.com/media-test/](https://woolyss.com/media-test/):用于测试音频和视频格式的支持情况[^5]。 ### ### 常见问题处理 - **构建失败**:如果构建过程中出现错误,可以尝试使用 `--no-update` 参数跳过源码更新步骤,重新执行构建。 - **运行库设置**:确保在编译时将运行库设置为 **MT(多线程)**,否则会导致链接错误。可以在 Visual Studio 的“配置属性 -> C/C++ -> 代码生成”中设置运行库为 MT[^4]。 - **Unicode 支持**:编译 CEF 时定义了 `UNICODE` 和 `_UNICODE` 宏,建议在项目中也启用 Unicode 字符集以确保兼容性[^4]。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

foruok

你可以选择打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值