dvisvgm – 一款快速的 DVI 到 SVG 转换器
描述
dvisvgm 是一款面向 TeX/LaTeX 用户的实用工具。它可以将 DVI、EPS 和 PDF 文件转换为基于 XML 的可缩放矢量图形格式 SVG。最新版本支持标准 DVI 文件(版本 2)以及由 pTeX 在垂直模式下创建的 DVI 输出(版本 3),以及 XeTeX(版本 5 至 7,也称为 XDV)。
要了解转换效果,可以查看使用 dvisvgm 创建的示例。
主要特性概述:
- 完整的字体支持,包括虚拟字体、字体编码评估、CMap 文件、子字体定义和字体映射。
- 所有必需字体的字形轮廓都嵌入到生成的 SVG 文件中。
- 字体数据可以以 SVG、TrueType、WOFF 或 WOFF2 格式嵌入。
- 对于没有矢量格式的字体,通过矢量化 METAFONT 的位图输出来即时生成字形轮廓。
- dvisvgm 允许用路径替换字体元素,使不支持 SVG 字体的应用程序能够正确渲染 dvisvgm 的输出。
- 为生成的图形计算紧密的边界框,同时也支持常见的纸张格式和任意用户定义的尺寸。
--eps
选项允许将 EPS 文件转换为 SVG。--pdf
选项允许将 PDF 文档转换为 SVG。- 可以直接计算裁剪路径的交集,而不是将此任务委托给 SVG 渲染器,从而提高生成的 SVG 文件的兼容性。
- 近似 SVG 1.1 不直接支持的 PostScript 颜色渐变填充。
- 使用内置的 SVG 优化器可以改进生成的 SVG 结构和数据。
- 可选择创建压缩的 SVGZ 文件。
- 提供应用页面变换的选项,如平移、旋转、缩放和倾斜。
- 评估多种特殊命令,包括颜色、emTeX、tpic、hyperref/HyperTeX、papersize、PDF 超链接和 mapfile,以及 PostScript 特殊命令。
- 转换器已在各种 Linux(TeX Live)和 Windows(MiKTeX、TeX Live)系统上成功测试。
- dvisvgm 已被添加到 TeX Live、MiKTeX 和 MacPorts 中。因此,它可用于多种操作系统。
使用方法
有关 dvisvgm 命令行界面和所有可用选项的详细信息,请参阅手册页。
依赖项
dvisvgm 依赖以下免费库:
-
Clipper
为计算两条曲线路径的交集,dvisvgm 将路径展平为多边形,使用略微修改的 Clipper 版本进行交集计算,然后重建曲线。源代码中包含了略微修改的 Clipper 版本。 -
FreeType 2
该库用于从矢量字体(PFB、OTF、TTF)中提取字形轮廓。 -
Ghostscript
PostScript 特殊处理程序需要安装 Ghostscript 共享库libgs.so.N
(Linux)或gsdll32.dll
/gsdll64.dll
(Windows)。如果配置脚本在系统上找到相应的 Ghostscript 开发文件,它会直接链接到libgs.so.N
,其中 N 是库的 ABI 版本。否则,程序会在运行时查找库,只有在找到共享库的情况下才启用 PostScript 支持。由于 Ghostscript API 的不兼容变化,dvisvgm 需要 Ghostscript 8.31 或更高版本。 -
Kpathsea 这个库是Web2C软件包的一部分,通常与TeX发行版一起安装。Kpathsea提供了在大型
texmf
树中搜索文件的功能。请确保使用与您的TeX系统一起提供或匹配的kpathsea版本。 -
potracelib Peter Selinger的位图追踪库用于将Metafont的位图输出矢量化。它也与_dvisvgm_源代码一起捆绑。
-
ttfautohint _dvisvgm_可以选择性地构建ttfautohint支持,以允许对生成的TrueType、WOFF和WOFF2字体进行自动微调。由于这仍是一个实验性功能,默认情况下禁用ttfautohint支持。要启用它,请使用
--with-ttfautohint
选项运行configure
。 -
woff2和brotli 这些Google库与_dvisvgm_源代码一起捆绑。它们用于从TrueType字体创建WOFF2文件。
-
xxHash xxHash库提供了一种快速的哈希算法。_dvisvgm_使用它从PostScript字符名称创建唯一的整数值,以便将它们与Unicode码点一起以紧凑的方式存储。_dvisvgm_源代码中捆绑了xxHash的最新版本。
从源代码构建dvisvgm
_dvisvgm_用C++11编写(ISO C++标准2011),需要适当的编译器,如GCC 4.9、Clang 3.3或更高版本。配置脚本会检查C++11支持的可用性,并在必要时添加适当的编译器选项。
快速安装说明:
- 确保安装了上述所有库的开发包
- 如果_dvisvgm_根文件夹中没有
configure
,请输入autoreconf -fi
- 如果不想使用捆绑的_brotli_、potrace、_woff2_和_xxHash_库,而是链接到相应的系统库,请输入
./configure
- 或者输入
./configure --enable-bundled-libs
以构建并静态链接捆绑的库 - 输入
make
- 以root身份输入
make install
(或sudo make install
)
有关通用配置说明,请参阅INSTALL文件。
配置脚本应该能识别所有必要的参数。如果某个库已安装但未被检测到,请在configure的命令行参数中指定其位置,例如:
./configure --with-freetype=/usr/local/freetype
(可以通过./configure --help
显示所有可用选项)
当缺少TFM或PFB文件时,跟踪器模块会通过系统调用来调用Metafont。请确保已安装Metafont,并且可以通过系统的搜索路径找到它。
如果您不想自己编译源代码,可以从项目网站下载Windows和MiKTeX的预编译二进制文件。
附加信息
该软件包可从CTAN获得,也可以从项目网站下载。在那里您可以找到源代码、预编译二进制文件、手册页、常见问题以及有关转换器和相关主题的更多信息。
如果您发现了bug,请告诉我。您可以给我发电子邮件,或者最好使用GitHub上的bug跟踪器。
版权
版权所有 © 2005–2024 Martin Gieseking
本程序是自由软件;您可以根据自由软件基金会发布的GNU通用公共许可证的条款重新分发和/或修改它;可以使用许可证的第3版,或(随您选择)任何更高版本。
分发本程序是希望它能有用,但不提供任何保证;甚至不提供对适销性或特定用途适用性的暗示保证。有关更多详细信息,请参阅GNU通用公共许可证。