12.2 macOS 下的 GMT 中文支持¶
本文介绍如何让 GMT 在 macOS 下支持中文。
12.2.1 ghostscript的中文支持¶
首先需要使 ghostscript 支持中文,这可以通过 cjk-gs-support 项目提供的脚本 cjk-gs-integrate.pl 实现。
下载脚本 cjk-gs-integrate.pl
cjk-gs-integrate.pl
脚本的执行依赖于命令kpsewhich
,该命令由 TeXLive 提供。执行kpsewhich --version
检查kpsewhich
这个命令是否存在。若不存在,则需要单独安装。使用homebrew安装 basictex 或 mactex-no-gui:# 以下二选一即可,第一个更小,第二个更完整 brew cask install basictex brew cask install mactex-no-gui
执行脚本:
$ sudo perl cjk-gs-integrate.pl
该脚本会自动搜索系统中自带的中文字体,并生成gs支持中文所需的配置文件。
12.2.2 GMT的中文支持¶
在 ~/.gmt
(若无该文件夹,请自行新建)下创建字体配置文件:
$ touch ~/.gmt/PSL_custom_fonts.txt
$ open ~/.gmt/PSL_custom_fonts.txt
打开 GMT 字体配置文件,在文件中加入如下语句:
STSong-Light-UniGB-UTF8-H 0.700 1
STFangsong-Light-UniGB-UTF8-H 0.700 1
STHeiti-Regular-UniGB-UTF8-H 0.700 1
STKaiti-Regular-UniGB-UTF8-H 0.700 1
STSong-Light-UniGB-UTF8-V 0.700 1
STFangsong-Light-UniGB-UTF8-V 0.700 1
STHeiti-Regular-UniGB-UTF8-V 0.700 1
STKaiti-Regular-UniGB-UTF8-V 0.700 1
这几句话分别添加了宋体、仿宋、黑体和楷体四种字体的横排和竖排两种方式。
用 gmt pstext -L
命令查看 GMT 当前的字体配置:
$ gmt pstext -L
Font # Font Name
------------------------------------
0 Helvetica
1 Helvetica-Bold
... ......
39 STSong-Light-UniGB-UTF8-H
40 STFangsong-Light-UniGB-UTF8-H
41 STHeiti-Regular-UniGB-UTF8-H
42 STKaiti-Regular-UniGB-UTF8-H
43 STSong-Light-UniGB-UTF8-V
44 STFangsong-Light-UniGB-UTF8-V
45 STHeiti-Regular-UniGB-UTF8-V
46 STKaiti-Regular-UniGB-UTF8-V
其中 39-46 号字体为新添加的中文字体。以后要用中文字体时,需要用这些编号来指定字体,也许你的机器上的编号和这里不同。
12.2.3 GMT 中文测试¶
注解
请自行确认你的中文字体编号。如果编号不是39到46,请自行修改以下测试脚本。
#!/bin/bash
gmt set FONT_TITLE 25p,41,black
gmt set FONT_LABEL 15p,39,black
gmt pstext -R0/8/0/4 -JX12c/4c -Bxaf+l"X轴" -Byaf+l"Y轴" \
-BWSen+t"中文标题" -F+f -P > GMT_Chinese.ps << EOF
2 3.5 25p,39,black 宋体横排
2 2.5 25p,40,blue 仿宋横排
2 1.5 25p,41,red 黑体横排
2 0.5 25p,42,green 楷体横排
4 3.5 25p,43,black 宋体竖排
5 3.5 25p,44,blue 仿宋竖排
6 3.5 25p,45,red 黑体竖排
7 3.5 25p,46,green 楷体竖排
EOF
gmt psconvert -A -P -Tf GMT_Chinese.ps
gmt psconvert -A -P -Tg GMT_Chinese.ps
rm gmt.*
成图效果如下:
注解
生成的 PNG、JPG格式的图片中可直接显示中文,而生成的 PDF 文件用 macOS 自带的 PDF 预览工具打开无法显示中文,使用 Adobe Reader 打开则可以正常显示中文。