什么是glibc?glibc是什么?什么是freetype?freetype是什么?什么是?Xlib是什么?什么是locale?
说说EasyWine的乱码问题
EW是个好东西,有了它,wine一下子就从鸡肋变成鸡大腿了,好多软件都可以顺利安装,而不需要去研究wine的配置了。当然,暂时还是鸡大腿,希望以后能吃出鸡翅的味道:-)
不过呢,好多朋友下载了EW之后,确实乘兴而来,败兴而归,为啥?看不懂,中文全都是乱码。若说是老外写的程序,不支持中文,乱码也还情有可原,可是EW分明是咱们的民族软件,为啥会乱码呢?而且,这个乱码还特别的难缠,任你费九牛二虎之力,它还是我行我素。怎么办呢?
先来说说乱码产生的原因。要说乱码,这个话就长了,咱们先看看linux下面的字体解决方案。
EasyWineLumaQQ
Xdialogfirefox-1.0kde
xmmszenityfirefox-1.5qterm
||||
||||
||||
gtk+-1.0gtk+-2.0gtk+-2.8qt
||||
||||
||||
|pangocario|
||||
||||
||||
|freetypefreetypefreetype
XlibfontconfigfontconfiglibXft
freetypelibXft||
||||
||||
|__________________|______________________|___________________|
|
|
glibc
上面这个图简单的说明了一下Xwindow下面最常见的几种自己解决方案。
最早最原始的方法就是调用Xlib里面的字体函数显示文字,很多早期的应用程序都使用这种方式,比如xterm什么的,当然也是最难用的,效果不佳,效率也差。gtk+1.0版本就是用xlib来显示文字,所以所有基于gtk+1.0的程序也就跟着使用x核心字体了。X核心字体,顾名思义,就是x内建的文字显示功能。Xwindow启动的时候,从配置文件得到字体所在路径,从字体目录里面的fonts.dirfonts.scaleencodings.dir等文件得到具体的字体信息,通过freetypetype1等字体模块来读取字体文件。这种方式使用起来不是很灵活,而且字体显示效率也不高,已经逐渐被淘汰了。
现在最常见字体系统就是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_CNgb2312utf-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.-elarge
mkfontdir-e.-elarge
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。Howaboutzh_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,里面加上
exportLANG=zh_CN.UTF-8
exportLC_ALL=zh_CN.UTF-8
夜深了,明早还要上班,不说了,以后有空再说吧。
BTW:Deman还是趁早换到zenity吧,不要用Xdialog了,这样就没这么多乱码问题了。呵呵,不过俺这篇文章也没价值了
--------------------------------------------------------------------------------
作者:deman时间:2006-1-310:40
好文章,不过zenity在kde下很有问题啊.我在kde下都编译不成功啊.n次都失败.
--------------------------------------------------------------------------------
作者:peaker时间:2006-1-2122:32
楼主的方法对于2.65版可能行不通了:
我原来用2.6beta版的时候,用这种方法在debian中,UTF8下可以很好地显示窗口中的文字,可是桌面菜单和程序菜单中全是乱码,没办法只好自己改。
可是升级到2.65版后,原来的方法都不行了,用这些方法都是乱码。于是我把\usr\bin下的easywine(可执行文件)用kwrite打开,另存为gbk编码的,覆盖原文件。然后运行easywine。窗口可以正常显示汉字了(晕,utf8下必须使用非utf8的编码才可以正常显示?),但是桌面菜单和程序菜单还是乱码。
easywine改成了gbk编码是不是影响了桌面菜单和程序菜单的编码啊?
--------------------------------------------------------------------------------
作者:deman时间:2006-1-2122:42
http://www.easywine.org/bbs/view...&extra=page%3D1
这里答了你问题,另外问问题的话,最好新开一贴
--------------------------------------------------------------------------------
作者:pinuocao时间:2006-4-2816:06
我运行了vim/etc/X11/xorg.conf
却没有FontPath显示
--------------------------------------------------------------------------------
作者:deman时间:2006-4-2817:11
你的是什么系统?
--------------------------------------------------------------------------------
作者:pinuocao时间:2006-4-2817:51
我装的是redhatlinux9.0的
--------------------------------------------------------------------------------
作者:deman时间:2006-4-2817:57
LOCALE是什么?
--------------------------------------------------------------------------------
作者:pinuocao时间:2006-4-2818:19
GB18030
--------------------------------------------------------------------------------
作者:pinuocao时间:2006-4-2818:34
utf8
--------------------------------------------------------------------------------
作者:deman时间:2006-4-2818:53
那尝试使用非utf8