LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 12987|回复: 16

Arch Linux 中文化-字体设置

[复制链接]
发表于 2006-4-25 22:24:42 | 显示全部楼层 |阅读模式
前言 :

Arch Linux 是一个定制性很强的发行版,其设计的哲学决定了Arch Linux 不太可能像SUSE、Fedora、Mandriva等发行版一样预设了一套完善的字体配置。Arch Linux需要用户进行一定的定制,用户在定制、配置过程中能学到更多的知识,这也是Arch Linux的设计哲学之一。

一 .字体相关库的简介

1 . LibXft

    libXft库是为了给X应用程序提供一个能访问FreeType字体光栅化引擎和X渲染扩展的、便于使用的接口,鉴于FreeType没有提供配置和定制 字体的功能,Xft也担负了这一任务。Xft提供了新的字体命名约定、复杂而精密的字体匹配和选择机制,并对相关功能进行充分的抽象,从而使得一般应用程 序既能够从使用X渲染扩展的文本输出获得益处,又能在不支持这一扩展的X服务器上正常工作。

    libXft 是画字函数库, 它使用 Fontconfig match 到了所要的字型之后, 来决定该如何画这些字。libXft 会看情况而决定要不要使用 core protocol 或 XRender 来画字。libXft 主要作GTK 2 (GTK < 2.8.0)程序,QT 程序的画字函数库。  

2 .Cairo

    一个支持多种输出的向量图形库,也就是说,cairo是种画图的工具库,他可以向多种设备上画图.可以输出到pdf,ps,xlib,XCB,win32,svg。基于GTK ( = >  2.8.0)的程序用cairo 画字而不再使用libXft 。

3 .Fontconfig

    Fontconfig 包含两个基本的模块,即读取XML文件并建立内部配置的配置模块和接受请求的字体样板并返回最接近所需字体的匹配模块。

4 .Freetype

    Freetype FreeType库是一个完全免费 ( 开源 ) 的、高质量的且可移植的字体
引擎,它提供统一的接口来访问多种字体格式文件,包括TrueType, OpenType, Type1, CID, CFF, Windows FON/FNT,X11 PCF 等。支持单色位图 (homochromous bitmap) 、反走样位图( anti-alias bitmap )的渲染。 Freetype 是高度模块化设计的程序库。Freetype 提供 libXft/cairo 如何画字的信息,包括处理 anti-aliasing 或 hinting. 因此 freetype 的改变会影响到 libXft/cairo 画出来的字,而 Fontconfig 的改变会影响到 libXft/cario 如何去选字来画。

5 .Pango

Pango 是个开源的整合到GTK+2的渲染国际化文本文件的库,pango 的名字是由 希腊语 "an" (Παν; lit. all) + 日语 "Go" (語; lit. language)组合成。也就是All language,Pango负责多国语言文本(如一个文本文件中由英文,日文,中文等不同的语系组成)的渲染。


二 .基本概念

1. 点阵字体 与 矢量字体

        点阵字体也叫位图字体,其中每个字形都以一组二维像素 信息表示。由于位图的原故,点阵字体很难进行缩放,特定的点阵字体只能清晰地显示在相应的字号下。但对于 12-16px 这样小的汉字,点阵字体常常比其它类型的字体在屏幕上更好的显示效果。常见的点阵字体有 bdf,pcf,fnt,hbf 等格式。
    对于常见的计算机操作系统,字体的显示算法需要一些字体的信息来优化屏幕显示效果,英文称为 hinting。汉字由于笔画复杂,所以 hinting 的方式与西文截然不同。使用在汉字字体中嵌入预先制作的点阵位图既可以有效地避免 hinting 算法带来的计算开销,同时屏幕上显示的汉字边缘清晰,易于阅读。下面就是使用点阵显示和不使用点阵显示的两个例子:

未使用点阵中文的显示效果                     


使用点阵中文的显效果  


    矢量字体中每一个字形是通过数学曲线来描述的,它包含了字形边界上的关键点,连线的导数信息等,字体的渲染引擎通过读取这些数学矢量,然后 进行一定的数学运算来进行渲染。这类字体的好处是字体可以无限放大而不产生变形。矢量字体主要包括 Type1 和 TrueType 等几类。

2 .内嵌点阵字的字体

    由于CJK字体的结构复杂,在小号字体只有使用点阵才能有清晰的显示效果,但是点阵字体很难进行缩,而且线条单一,在大号字体显示时就显得苍白无力。把点阵字体内嵌到矢量字体就能发挥两者的优点,并且也弥补了两者的不足。小号字体时清晰明朗,大号字体时字型饱满,形态丰富。常见的内嵌点阵字的字体有:北京中易电子公司宋体SimSun 、方正宋体(FZSongti)、文鼎PL上海宋(Uming)、Firefly的文鼎PL新宋(AR PL New Sung)等。

3 . Hinting 与 Autohinter

    Hinting 用来最佳化字型显示的方法。由于屏幕的像素有限,向量字型的缩放需要有更多的考虑, 例如当一条线位在两个像素格子中间时, 该取左边的格子还是右边的格子? 如果这方面的控制没有做好,就常常会出现字型的衬线没有对齐,或是小字歪七扭八的情况。 Hinting 是额外的信息, 它告诉 renderer 该如何处理这些细节的部份,使得向量字在小字的时候能够好看。也因此 Hinting 是非常费时费人力的工作,TrueType 字型很多,但是有良好 Hinting 的字型不多。拙劣的 Hinting 就会让字变得很难看。

    为了稍微改善这个问题,freetype 有 autohint 的功能,可以自动为没有 hint 的字型做 hinting 的工作。另外由于 TrueType 的 hinting 是有专利的,不能完全自由地使用, autohint 就不受这个限制。autohint 自然无法做得像人力的 hint 一样好,不过至少比没有 hint 要好些。话虽如此,对于许多笔划复杂的文字 (如中文) 目前 freetype 的 autohint 还做得不甚完美,而因为建立完整的 hinting 的难度,即使是英文字,原本就很高,内建有 hinting 的中文字型就少之又少了。所以常常有人抱怨中文字在屏幕上很难看,就是没有理想 hinting, 或者是使用了 autohinter 所造成的一些反效果。

4 . AA(Antialiasing)

    Antialiasing 是将字体在后台先以数倍的大小来绘画,然后再缩成想要的大小,未满一格的格子用灰阶补点。

     Antialiasing 会给人一种朦胧的感觉,习惯了Windows XP 下清晰,锐利的字体显示时,Antialiasing 会让人不太适应,会让用户觉得Linux下的字体显示不如Windows XP。但是,其实 Anti-aliasing是一种很先进的显示技术 ,当长时间显示器上阅读的时候,Windows XP 下的锐利的字体显示风格,会让眼睛更加容易疲劳,使用Antialiasing,字体的显示更加柔和,更加适合长时间的在显示器上阅读文档,减少眼睛的疲劳。

    微软的下一代OS Windows Vista 也将用ClearType 作为默认的显示效果,来取传统的黑白,锐利的英文字体显示和点阵CJK 显示。看!ClearType是不是和Linux下的 Anti-aliasing 效果很相似。:-D




                     Autohint+antialiasing

三 .字体简介

1 自由(free)的英文字体
    Bitstream vera fonts,DejaVu fonts[community repo],MS True Type core fonts 等,DejaVu fonts是在Bitstream vera fonts release 1.10 的基础上进行不断扩充的字体。 MS True Type core fonts包含了Arial, Courier New, Times New Roman, Verdana等系列字体的总称。 MS True Type core fonts 的licence 是EULA,可以合法的免费使用。

2 自由中文字体

ttf-arphic-ukai
ttf-arphic-uming
ttf-fireflysung

3 不合版权的字体

LingSong :Tahoma+Simsun的“杂交”字体,Tahoma版权属于微软,Simsun字体的版权属于 北京中易电子公司。

Vera Sans YuanTi:Bitstream Vera+simsun点阵+方正准圆+方正粗圆的“杂交”字体。

四 .设置实例

1 开启/关闭 AA ,Autohint 与 Hinting

AA 与 Autohint/Hinting配搭的效果示范图:

Hinting-only


Autohint-only


Hinting+Antialiasing


Autohint+Antialiasing



下面的配置表示:全部的字体使用autohint 和 antialiasing,渲染度为 hintfull ,通常这是一个很好的全局默认设置。也可以根据个人喜好使用渲染度为hintslight。

  1.        <match target="font">
  2.                 <edit name="autohint">
  3.                         <bool>true</bool>
  4.                 </edit>
  5.                 <edit name="hintstyle">
  6.                         <const>hintfull</const>
  7.                 </edit>
  8.                 <edit name="antialias">
  9.                         <bool>true</bool>
  10.                 </edit>
  11.         </match>
复制代码

下面的配置就是代表的是:小于16号的MS core fonts,关闭Antialiasing 和  Autohint,(使用hinting) 。可以根据个人喜欢调节字号的大小。

  1.         <match target="font">
  2.                 <test name="family">
  3.                         <string>Andale Mono</string>
  4.                         <string>Arial</string>
  5.                         <string>Comic Sans MS</string>
  6.                         <string>Georgia</string>
  7.                         <string>Impact</string>
  8.                         <string>Trebuchet MS</string>
  9.                         <string>Verdana</string>
  10.                         <string>Courier New</string>
  11.                         <string>Times New Roman</string>
  12.                         <string>Tahoma</string>
  13.                         <string>Webdings</string>
  14.                         <string>Albany AMT</string>
  15.                         <string>Thorndale AMT</string>
  16.                         <string>Cumberland AMT</string>
  17.                         <string>Andale Sans</string>
  18.                         <string>Andy MT</string>
  19.                         <string>Bell MT</string>
  20.                         <string>Monotype Sorts</string>
  21.                 </test>
  22.                 <test name="pixelsize" compare="less_eq">
  23.                                 <double>16</double>
  24.                 </test>
  25.                 <edit name="autohint">
  26.                         <bool>false</bool>
  27.                 </edit>
  28.                 <edit name="antialias">
  29.                         <bool>false</bool>
  30.                 </edit>
  31.         </match>
复制代码


2 英文字和中文字等宽

TrueType 字体分成两种,一种是可变字距,也就是每个字符宽度不一样,比如 "x" 与 "i",这两个字符就不等宽,它是在每个字符中记录该字符的宽度,大多数的 TrueType 字体都是这种格式。

  另一种就是固定字距。也就是每个字符宽度都一样,这样显示或打印時,用会有对齐效果,比较美观,在英语环境中,不会有任何问题,但是CJK 的等宽字体,包含『半角英数字符』与『全角 CJK 字符』,字体引擎会把全角字宽度套用在半角字上,造成半宽字看起来间距太大。
       

  1.         <match target="font">
  2.                 <test target="pattern" name="lang" compare="contains">
  3.                         <string>zh</string>
  4.                         <string>ja</string>
  5.                         <string>ko</string>
  6.                 </test>
  7.                 <edit name="spacing">
  8.                         <const>proportional</const>
  9.                 </edit>
  10.                 <edit name="globaladvance">
  11.                                 <bool>false</bool>
  12.                 </edit>
  13.         </match>
复制代码

这个配置表示:让字体引擎(FreeType)取消CJK字体的指定宽度。

3 字体替换

一些网页编写时候,对使用的字体预先设定,(如英文部分使用了simsun,使得英文显示很不美观)所以可以使用字体替换使得字体显示更美观。

把Simsun , SimSun-18030 , AR PL ShanHeiSun Uni等这个几个中文字体的英文部分,用 Tahoma,Arial 等替换。


  1.         <match target="pattern">
  2.                 <test name="family">
  3.                         <string>SimSun</string>
  4.                         <string>SimSun-18030</string>
  5.                         <string>AR PL ShanHeiSun Uni</string>
  6.                         <string>AR PL New Sung</string>
  7.                         <string>MingLiU</string>
  8.                 </test>
  9.                 <edit binding="strong" mode="prepend" name="family">
  10.                         <string>Tahoma</string>
  11.                         <string>Arial</string>
  12.                         <string>Verdana</string>
  13.                         <string>DejaVu Sans</string>
  14.                         <string>Bitstream Vera Sans</string>
  15.                 </edit>
  16.         </match>
复制代码



把 AR PL ShanHeiSun Uni , AR PL New Sung 字体中12~16号的中文字用 WenQuanYi Bitmap Song 点阵字替换, WenQuanYi Bitmap Song 比  AR PL ShanHeiSun Uni , AR PL New Sung中的内嵌点阵更加完善,美观。



  1.         <match target="pattern">
  2.                 <test name="family" qual="any">
  3.                         <string>AR PL ShanHeiSun Uni</string>
  4.                         <string>AR PL New Sung</string>
  5.                 </test>
  6.                 <test compare="more_eq" name="pixelsize" >
  7.                         <double>12</double>
  8.                 </test>
  9.                 <test compare="less_eq" name="pixelsize" >
  10.                         <double>16</double>
  11.                 </test>
  12.                 <edit name="family" mode="prepend" binding="strong">
  13.                         <string>WenQuanYi Bitmap Song</string>
  14.                 </edit>
  15.         </match>
复制代码



4 使用内嵌字体。

  1.         <match target="font">
  2.                 <edit name="embeddedbitmap" mode="assign">
  3.                         <bool>true</bool>
  4.                 </edit>
  5.         </match>
复制代码

内嵌点阵字当字体有内嵌字体时,优先使用内嵌字体。
注意:libXft 还没有embeddedbitmap选项的支持。可以到这里https://bugzilla.redhat.com/bugzilla/attachment.cgi?id=124032
得到libXft2.1.8.2的embeddedbitmap patch,通过ABS重新编译安装libXft 。


5 必须使用hinting的字体

    有些 CJK 字体要the byte code interpreter (hinting)才能正确的显示,因为这些字体使用了hinting的一些技术制作的。常见的MingLiu 就是这类字体。

  1.         <match target="font">
  2.                 <test name="family">
  3.                         <string>MingLiU</string>
  4.                         <string>PMingLiU</string>
  5.                 </test>
  6.                 <edit name="autohint">
  7.                         <bool>false</bool>
  8.                 </edit>
  9.                 <edit name="hinting">
  10.                         <bool>true</bool>
  11.                 </edit>
  12.         </match>
复制代码



附:

Arch WiKi 的连接:

http://wiki.archlinux.org/index.php/字体设置


配置范例:
一. Windows(R)-Like 显示效果的字体参考范例
二. Anti-aliasing效果的字体参考范例

http://wiki.archlinux.org/index.php/中文字体配置范例
发表于 2006-4-25 23:17:40 | 显示全部楼层
好贴,赞一个
回复 支持 反对

使用道具 举报

发表于 2006-4-26 07:17:23 | 显示全部楼层
总结的不错,希望以后别的方面也有这种总结性强/内容完整/水平较高的帖子出现!
回复 支持 反对

使用道具 举报

发表于 2006-4-26 07:44:23 | 显示全部楼层
谢楼主分享,又长见识了。
回复 支持 反对

使用道具 举报

发表于 2006-4-26 09:20:43 | 显示全部楼层
好贴,顶顶顶顶顶!!!
回复 支持 反对

使用道具 举报

发表于 2006-4-26 10:09:53 | 显示全部楼层
好贴,加精!
回复 支持 反对

使用道具 举报

发表于 2006-4-26 11:20:13 | 显示全部楼层
哈哈,又见zerolin,非常棒的帖子。赞一个
回复 支持 反对

使用道具 举报

发表于 2006-4-26 12:05:52 | 显示全部楼层
Damn great, have to be sticky on the top.
回复 支持 反对

使用道具 举报

发表于 2006-4-26 12:33:24 | 显示全部楼层
好东西啊楼主

呵呵
谢谢
回复 支持 反对

使用道具 举报

发表于 2006-4-27 12:19:29 | 显示全部楼层
好贴,收藏。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表