Windows下从源码编译CEF

xingyun86 2018-4-18 2328

原文地址:https://www.kancloud.cn/digest/cef-ppapi/119488


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 字符集。

相关文章参考:


×
打赏作者
最新回复 (0)
查看全部
全部楼主
返回