什么是glibc?glibc是什么?什么是freetype?freetype是什么?什么是?Xlib是什么?什么是lo

07-01

什么是glibc?glibc是什么?什么是freetype?freetype是什么?什么是?Xlib是什么?什么是locale?
说说EasyWine的乱码问题
EW是个好东西,有了它,wine一下子就从鸡肋变成鸡大腿了,好多软件都可以顺利安装,而不需要去研究wine的配置了。当然,暂时还是鸡大腿,希望以后能吃出鸡翅的味道:-)
不过呢,好多朋友下载了EW之后,确实乘兴而来,败兴而归,为啥?看不懂,中文全都是乱码。若说是老外写的程序,不支持中文,乱码也还情有可原,可是EW分明是咱们的民族软件,为啥会乱码呢?而且,这个乱码还特别的难缠,任你费九牛二虎之力,它还是我行我素。怎么办呢?
先来说说乱码产生的原因。要说乱码,这个话就长了,咱们先看看linux下面的字体解决方案。
EasyWine LumaQQ
Xdialog firefox-1.0 kde
xmms zenity firefox-1.5 qterm
| | | |
| | | |
| | | |
gtk+-1.0 gtk+-2.0 gtk+-2.8 qt
| | | |
| | | |
| | | |
| pango cario |
| | | |
| | | |
| | | |
| freetype freetype freetype
Xlib fontconfig fontconfig libXft
freetype libXft | |
| | | |
| | | |
|__________________|______________________|___________________|
|
|
glibc
上面这个图简单的说明了一下Xwindow下面最常见的几种自己解决方案。
最早最原始的方法就是调用Xlib里面的字体函数显示文字,很多早期的应用程序都使用这种方式,比如xterm什么的,当然也是最难用的,效果不佳,效率也差。gtk+ 1.0版本就是用xlib来显示文字,所以所有基于gtk+1.0的程序也就跟着使用x核心字体了。X核心字体,顾名思义,就是x内建的文字显示功能。Xwindow启动的时候,从配置文件得到字体所在路径,从字体目录里面的fonts.dir fonts.scale encodings.dir等文件得到具体的字体信息,通过freetype type1等字体模块来读取字体文件。这种方式使用起来不是很灵活,而且字体显示效率也不高,已经逐渐被淘汰了。
现在最常见字体系统就是libxft2+fontconfig+freetype的组合了,libxft2是字体绘制引擎,负责文字显示;fontconfig负责字体的选择控制;freetype用来读取字体文件。cario是gtk+2.8最新引进来的图形引擎,有自己的文字绘制引擎。这里面,对于配置系统字体最重要的就是fontconfig了,fontconfig负责管理系统内所有的字体文件,给他们建立fonts.cache,并根据fonts.conf的配置选取合适的字体进行显示。
最后还有glibc,glibc是什么?即使c的运行库,这个是出了内核意外所有程序都要用到的。glibc跟字体有什么关系?没关系!不过跟locale有关系。什么是locale? 我也不知道,方正就是一大堆的东西,告诉你文字用什么编码啊,时间用什么格式等等,基本上就相当于一个语言环境。在程序里面,一段文字,可能是用unicode存储的,但是我们的运行环境是gb2312,怎么把unicode的文字变成gb2312编码的文字,这个就要靠glibc了。所以想要正常使用中文,还要保证glibc也支持中文。
好了,关于字体系统就说这么多了。fontconfig是很先进的解决方案,非常灵活,配置也很方便,网上资料也比较多。通常大家的中文解决方案,都是基于fontconfig的,这对于绝大多数应用来说,都足够了,可以获得非常完美中文显示效果。事情坏就坏在还有很多老的程序不支持fontconfig,尤其是很多gtk+1.0的应用,比如xmms这种常用的程序。
长话短说了,上面废话太多,还是说说具体怎么配置吧。
首先,glibc。运行locale -a,看看你的系统支持zh_CN gb2312 utf-8什么的不。支持 ---> ok。 不支持 ---》 想办法吧(呵呵,比较罕见的)。
然后就要看看我们的字体文件都在哪里了。通常,字体文件会放在/usr/share/fonts或者/usr/X11R6/lib/fonts里面。里面还有很多目录,存放了各种字体文件。假设我们从windows下面考了个simsun.ttc放在/usr/share/fonts/local里面。
vim /etc/X11/xorg.conf
看看FontPath对不对,记住把/usr/share/fonts/local加进去,还有module里面不要忘记加载freetype模块。
Ok, 各位看官注意了,下面一步很关键,而且很少有人注意到,很多乱码无法解决都是它引起的。
cd /usr/share/fonts/encodings
mkfontscale -e . -e large
mkfontdir -e . -e large
cd ..
ln -snf /encodings
干什么?生成encodings.dir这个字体编码文件。xlib需要根据这个文件里面的配置来正确解读不同的文字编码。如果这个xlib找不到这个配置,就会无法正确显示中文了,比如乱码,部分乱码什么的。
好了,现在重新启动X ---为了使这个encodings.dir生效,很重要的。
cd /usr/share/fonts/local
mkfontscale
mkfontdir
再次重启X, 这样simsun就可以正常使用了。运行xfontsel,因该可以看到simsun了。
现在配置gtkrc来控制gtk+按照我们的意愿选择字体,比如英文用verdana, 中文用simsun。(verdana哪里来?windows下面找去)
/etc/gtk/这个目录里面有很多gtkrc.xxx,分别控制不同locale时的字体方案。我们主要关心gtkrc.zh_CN和gtkrc.utf-8这两个文件,分别对应zh_CN和UTF-8这两个locale。比如zh_CN.GB2312就使用gtkrc.zh_CN,en_US.UTF-8就使用gtkrc.utf-8。How about zh_CN.UTF-8?呵呵,这个用的是gtkrc.utf-8。
/etc/gtk/gtkrc.zh_CN
style "gtk-default-zh_CN" {
fontset = "-*-verdana-medium-r-normal--12-*-*-*-*-*-iso8859-1,/
-*-simsun-medium-r-normal--12-*-*-*-*-*-iso10646-1,/
*-r-*"
}
class "GtkWidget" style "gtk-default-zh_CN"
意思就是当系统语言是中文,显示文字时,首先找verdana这个字体,如果能显示,ok;如果不能,继续,看看simsun行不,行,ok;还不行,随便找啦,找到能用就ok啦。
可以把/etc/gtk/gtkrc.utf-8做成gtkrc.zh_CN的一个链接。
ln -snf /etc/gtk/gtkrc.zh_CN /etc/gtk/gtkrc.utf-8
Ok. Now, type
EasyWine
看看还是不是乱码了?还乱码?跟我说,呵呵,咱们继续研究。
怎么看当前的locale?
locale
就可以了。
怎么设置locale?修改~/.profile,里面加上
export LANG=zh_CN.UTF-8
export LC_ALL=zh_CN.UTF-8
夜深了,明早还要上班,不说了,以后有空再说吧。
BTW: Deman还是趁早换到zenity吧,不要用Xdialog了,这样就没这么多乱码问题了。呵呵,不过俺这篇文章也没价值了
--------------------------------------------------------------------------------
作者: deman 时间: 2006-1-3 10:40
好文章,不过zenity在kde下很有问题啊.我在kde下都编译不成功啊.n次都失败.
--------------------------------------------------------------------------------
作者: peaker 时间: 2006-1-21 22:32
楼主的方法对于2.65版可能行不通了:
我原来用2.6 beta版的时候,用这种方法在debian中,UTF8下可以很好地显示窗口中的文字,可是桌面菜单和程序菜单中全是乱码,没办法只好自己改。
可是升级到2.65版后,原来的方法都不行了,用这些方法都是乱码。于是我把/usr/bin下的easywine(可执行文件)用kwrite打开,另存为gbk编码的,覆盖原文件。 然后运行easywine。窗口可以正常显示汉字了(晕,utf8下必须使用非utf8的编码才可以正常显示?), 但是桌面菜单和程序菜单还是乱码。
easywine改成了gbk编码是不是影响了桌面菜单和程序菜单的编码啊?
--------------------------------------------------------------------------------
作者: deman 时间: 2006-1-21 22:42
http://www.easywine.org/bbs/view ... &extra=page%3D1
这里答了你问题,另外问问题的话,最好新开一贴
--------------------------------------------------------------------------------
作者: pinuocao 时间: 2006-4-28 16:06
我运行了vim /etc/X11/xorg.conf
却没有FontPath显示
--------------------------------------------------------------------------------
作者: deman 时间: 2006-4-28 17:11
你的是什么系统?
--------------------------------------------------------------------------------
作者: pinuocao 时间: 2006-4-28 17:51
我装的是 red hat linux9.0的
--------------------------------------------------------------------------------
作者: deman 时间: 2006-4-28 17:57
LOCALE 是什么?
--------------------------------------------------------------------------------
作者: pinuocao 时间: 2006-4-28 18:19
GB18030
--------------------------------------------------------------------------------
作者: pinuocao 时间: 2006-4-28 18:34
utf8
--------------------------------------------------------------------------------
作者: deman 时间: 2006-4-28 18:53
那尝试使用非utf8