说起Skia,熟悉的人会非常熟悉,陌生的人也会相当陌生。为什么这么说呢?做Android原生开发的人来,Android的2D绘图引擎就是Skia,你所看到的Canvas、Bitmap、Drawable等概念都是Skia的内部抽象结构,整个Android的原生界面就是使用Skia来绘制的。
Skia的官方网站为https://skia.org,但不要努力了,你打不开的。它在github上有个自动同步的镜像仓库https://github.com/google/skia,这是在大天朝里没有梯子可用时能找到Skia的地方了。打开这个仓库后尴尬又接踵而至,这个仓库除了能让你下载源码和翻阅demo外,没有任何文档可以给你参考,甚至连个编译指导都没有,ReadMe里唯一的一句话就是:
Skia is a complete 2D graphic library for drawing Text, Geometries, and Images. See full details, and build instructions, at https://skia.org.
OK, fine~
我亲自来给大家做个接受,顺便接下来把它搬到树莓派上来跑跑看在~
Skia图形库
Skia是个开源2D矢量图形库,它为多种软硬件平台提供了通用的绘图API。Google的Android、Chrome浏览器、Chrome OS、Firefox浏览器、Firefox OS等都以它为自身的图形渲染引擎。
Skia目前是由Google来管理的,任何人都可以基于BSD免费软件许可来使用Skia。Skia的开发团队致力于开发其核心部分,并广泛采纳各方对Skia的开源贡献。
Skia目前能够支持一下绘制特性:
- CPU软绘制
- 离屏渲染
- OpenGL/GLES硬件加速
- Vulkan硬件加速
- X11支持
- GDI+支持
源码下载
安装depot_tools和git
下面的介绍会告诉你如何下载Skia的编译工具包depot_tools(包括gclient、git-cl、Ninja)。我已Linux(Debian)为例来介绍整个步骤吧,按照以下步骤开始:
下载git
sudo apt-get install git
下载python2
Skia的编译工具还在使用python2,你可以在python官网去下载https://www.python.org/downloads/
下载depot_tools工具包
git clone "https://chromium.googlesource.com/chromium/tools/depot_tools.git"
export PATH="${PWD}/depot_tools:${PATH}"
下载Skia源码并同步依赖库
git clone https://github.com/google/skia.git
cd skia
python2 tools/git-sync-deps
编译Skia
Skia使用GN来配置其编译参数。编译工具包就已经包含了GN,当然你可以在https://chromium.googlesource.com/chromium/src/tools/gn/下载独立的版本。
编译模式is_official_build和三方依赖库
大部分用户都应该设置is_official_build=true,同时大部分开发者都应该设置is_official_build=false,它默认为false。
这个编译模式是用来把Skia的编译配置为更适用于工程化后的环境下使用的,这样编译出来的版本会去除所有的调试符号(debug
symbols),在常规的搜索路径下动态链接依赖的三方库。但对于开发者而言,携带所有的调试符号,并把所有的三方依赖库都编译并嵌入到Skia中会更便于开发调试和自动化测试。
Skia提供了多种可选特性可以在编译时使用skia_use_XXX开关去配置GN启动这些特性。这些特性包含如用于解码图片的libpng、libwebp、libjpeg-turbo和映射字符子集的ICU、sftnly。
如果skia_use_XXX启用了,则同时启用skia_use_system_XXX则会把此特性对应的编译为单独的库并在运行时到系统路径下去链接。(is_official_build=true本质上就是把所有的skia_use_system_XXX都默认启用了)
同时你也可以使用extra_cflags和extra_ldflags这两个编译开关去配置独立的依赖库头文件路径和库文件链接路径。
编译器后端性能优化
Skia专门针对Clang做了性能上面的优化,但如果你使用GCC、MSVC或其他编译器来编译Skia并将其用于软渲染、图片解码或颜色控件转换,你可能会发现它的性能反倒变得更差。
这只是一些编译优先级策略带来的问题,并不是对其他编译器编译水土不服产生的bug,所有如果你遇到麻烦,请在mailing list里告知Skia开发团队,他们会协助处理。
开始编译
配置生成构建文件
生成ninja编译所使用的静态库构建目录/动态库构建目录及其构建文件:
bin/gn gen out/Static --args='is_official_build=true'
bin/gn gen out/Shared --args='is_official_build=true is_component_build=true'
Skia还可以配置为如下几种常见的构建方案:
bin/gn gen out/Debug
bin/gn gen out/Release --args='is_debug=false'
bin/gn gen out/Clang --args='cc="clang" cxx="clang++"'
bin/gn gen out/Cached --args='cc_wrapper="ccache"'
bin/gn gen out/RTTI --args='extra_cflags_cc=["-frtti"]'
你可以使用下面的命令查看所有的编译参数:
bin/gn args out/Debug --list
编译和链接
当你已经生成了构建文件及目录后,你可以使用以下命令来编译并链接Skia:
ninja -C out/Static
ninja -C out/Shared
对于上述几种常见的构建方案来说,要编译链接Skia也是使用同样的方法:
ninja -C out/Debug
ninja -C out/Release
ninja -C out/Clang
ninja -C out/Cached
ninja -C out/RTTI
如果在编译的过程中发现一些头文件丢失了,可以使用以下命令来安装依赖库:
tools/install_dependencies.sh
遗留问题
- 如何编译树莓派版本的Skia?