FreeBSD系统中使用clang/clang++编译Skia源码的方法

FreeBSD系统中使用clang/clang++编译Skia源码的方法

  • 修改日期:2026-02-10
  • 操作系统:FreeBSD
  • 编译器:clang/clang++
  • 说明1:本文档介绍FreeBSD系统中使用clang/clang++编译Skia源码的方法
  • 说明2:该编译Skia源码的方法,是为了适配nim_duilib项目使用Skia库,如果用于其他库使用,可能需要修改编译参数
  • 说明3:获取skia源码后,需要更新部分源码(更新方法见后续文档),否则编译无法通过。(使用了三个第三方库:expat,freetype2,fontconfig)
  • 说明4:操作过程中,假设源码的根目录是~/develop目录,如果使用其他目录,可替换为实际的目录。

一、准备工作:安装必备的软件

复制代码
sudo pkg install git unzip python3 cmake ninja gn llvm fontconfig freetype2

二、使用脚本自动编译(推荐)

该脚本自动完成相关源码下载和编译工作。

选定一个工作目录,创建一个脚本build.sh,将下面已经整理好脚本复制进去,保存文件。

然后在控制台,为脚本文件添加可执行权限,最后运行该脚本:

复制代码
chmod +x build.sh
./build.sh

脚本文件内容如下:

复制代码
#!/usr/bin/env bash

git clone https://github.com/rhett-lee/skia_compile
chmod +x ./skia_compile/freebsd/build_skia_all_in_one.sh
./skia_compile/freebsd/build_skia_all_in_one.sh

编译时如果获取skia_compile代码失败,可以多重试几次。

编译完成的库文件在工作目录的skia/out子目录中,按编译选项放在相应的子目录。

三、手动编译过程

第1步:获取skia源码并更新修改代码

  1. 获取skia源码:

    #!/usr/bin/env bash
    cd ~/develop
    git clone https://github.com/google/skia.git
    git -C ./skia checkout 34aa71b8bee4648a442b7125680232d803374f19

  2. 下载源码和文档,并更新skia的修改代码:

    #!/usr/bin/env bash
    cd ~/develop
    git clone https://github.com/rhett-lee/skia_compile
    unzip -o ./skia_compile/skia.2026-02-10.src.zip -d ./skia/

更新完成后,可以到skia目录中确认一下是否更新成功

复制代码
#!/usr/bin/env bash
cd ~/develop/
git -C ./skia status

第2步:编译skia(编译器:LLVM)

  1. 进入skia源码目录:

    cd ~/develop/skia

确定fontconfig和freetype2头文件和库文件在下面的路径中

复制代码
/usr/local/include/freetype2 
/usr/local/include
/usr/local/lib 

否则修改参数的实际路径

复制代码
extra_ldflags = [ \"-L/usr/local/lib\" ]
extra_cflags=[\"-DSK_DISABLE_LEGACY_PNG_WRITEBUFFER\", \"-I/usr/local/include/freetype2\", \"-I/usr/local/include\"]
  1. 编译skia静态库(llvm.arm64.Release)
  • gn gen out/llvm.arm64.release --args="target_cpu=\"arm64\" ar=\"llvm-ar\" skia_enable_fontmgr_fontconfig=true skia_use_freetype=true extra_ldflags = [ \"-L/usr/local/lib\" ] cc=\"clang\" cxx=\"clang++\" is_trivial_abi=false is_official_build=true skia_use_libwebp_encode=false skia_use_libwebp_decode=false skia_use_libpng_encode=false skia_use_libpng_decode=false skia_use_zlib=false skia_use_libjpeg_turbo_encode=false skia_use_libjpeg_turbo_decode=false skia_enable_fontmgr_win_gdi=false skia_use_icu=false skia_use_expat=false skia_use_xps=false skia_enable_pdf=false skia_use_wuffs=false skia_enable_svg=true skia_use_expat=true skia_use_system_expat=false is_debug=false extra_cflags=[\"-DSK_DISABLE_LEGACY_PNG_WRITEBUFFER\", \"-I/usr/local/include/freetype2\", \"-I/usr/local/include\"]"
  • ninja -C out/llvm.arm64.release
  1. 编译skia静态库(llvm.x64.Release)
  • gn gen out/llvm.x64.release --args="target_cpu=\"x64\" ar=\"llvm-ar\" skia_enable_fontmgr_fontconfig=true skia_use_freetype=true extra_ldflags = [ \"-L/usr/local/lib\" ] cc=\"clang\" cxx=\"clang++\" is_trivial_abi=false is_official_build=true skia_use_libwebp_encode=false skia_use_libwebp_decode=false skia_use_libpng_encode=false skia_use_libpng_decode=false skia_use_zlib=false skia_use_libjpeg_turbo_encode=false skia_use_libjpeg_turbo_decode=false skia_enable_fontmgr_win_gdi=false skia_use_icu=false skia_use_expat=false skia_use_xps=false skia_enable_pdf=false skia_use_wuffs=false skia_enable_svg=true skia_use_expat=true skia_use_system_expat=false is_debug=false extra_cflags=[\"-DSK_DISABLE_LEGACY_PNG_WRITEBUFFER\", \"-I/usr/local/include/freetype2\", \"-I/usr/local/include\"]"
  • ninja -C out/llvm.x64.release

四、资源链接

  1. Skia的编译文档库,如需获取最新版本的文档,请点击访问:skia_compile
  2. nim_duilib界面库的代码库,请点击访问:nim_duilib
    nim_duilib 是一款基于C++开发的跨平台界面库,源于经典的 duilib 界面库并进行了深度优化与功能扩展,支持Windows/Linux/macOS/FreeBSD平台,支持的Linux系统包括OpenEuler、OpenKylin、UbuntuKylin、统信UOS、中科方德、Ubuntu、Fedora、Debian等,专注于简化桌面应用的高效开发。其设计融合了DirectUI理念,通过XML描述界面布局,实现视觉与逻辑的分离,显著提升开发灵活性与维护性。
相关推荐
charlie11451419115 分钟前
嵌入式C++工程实践——第13篇:第一次重构 —— enum class取代宏,类型安全的开始
开发语言·c++·vscode·stm32·安全·重构·现代c++
CHANG_THE_WORLD23 分钟前
C++ 文件读取函数完全指南
开发语言·c++
6Hzlia23 分钟前
【Hot 100 刷题计划】 LeetCode 300. 最长递增子序列 | C++ 动态规划 & 贪心二分
c++·leetcode·动态规划
阿正的梦工坊26 分钟前
JavaScript 闭包 × C++ 类比:彻底搞懂闭包
开发语言·javascript·c++
6Hzlia28 分钟前
【Hot 100 刷题计划】 LeetCode 72. 编辑距离 | C++ 经典 DP 增删改状态转移
c++·算法·leetcode
无限进步_38 分钟前
【C++】寻找字符串中第一个只出现一次的字符
开发语言·c++·ide·windows·git·github·visual studio
螺丝钉code1 小时前
设计系统 showdown:Awesome DESIGN.md vs UI UX Pro Max - AI 时代的设计规范新范式
人工智能·ui·ux
楼田莉子1 小时前
Linux网络:IP协议
linux·服务器·网络·c++·学习·tcp/ip
wuminyu1 小时前
专家视角看JVM_StartThread
java·linux·c语言·jvm·c++
敲上瘾1 小时前
高并发内存池(三):PageCache(页缓存)的实现
linux·c++·缓存·高并发内存池·池化技术