加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

QT显示中文

发布时间:2020-12-15 06:57:04 所属栏目:百科 来源:网络整理
导读:?原文地址:http://www.voidcn.com/article/p-wtcjrqgx-nz.html ? 首先要显示中文要在定义的环境变量下面有字库文件 QWS_FONTDIR=/usr/local/xxx/fons ?Qt可以支持以下四种形态的字体格式:TrueType (TTF),Postscript Type(PFA/PFB),Bitmap Distribution F

?原文地址:http://www.voidcn.com/article/p-wtcjrqgx-nz.html

?

首先要显示中文要在定义的环境变量下面有字库文件

QWS_FONTDIR=/usr/local/xxx/fons

?Qt可以支持以下四种形态的字体格式:TrueType (TTF),Postscript Type(PFA/PFB),Bitmap Distribution Format fonts(BDF),Qt Prerendered Font(QPF)。
如果直接使用TTF或PFA/PFB。即让应用程序在显示的时候再计算点阵,最终的效果并不理想,会发现有些字大,有些字小,而且需要占用非常多的FLASH和内存,速度也有点慢,如果直接使用BDF,速度非常慢,而且需要占用比较多的FLASH和内存;使用QPF,速度和占用其它资源是最小的,因此我们的嵌入式产品中的QT软件都是采用QPF格式的。
另一方面,嵌入式应用中,QT界面在LCD中可能是采用旋转的形式显示,如7寸屏,而QT中旋转显示时,需要旋转字体库的支持,否则将无法正常显示文字。

?现在可以自己制作,制作需要工具是makeqpf

这个工具可以到对应源码目录下的tools/makeqpf下make得到

?如 cd qt-x11-xxx/tools/makeqpf/

make

?制作的话就直接 makeqpf xxx.ttf 就可以了

?cd $(QTDIR)/lib/fonts
打开fontdir,加入如下信息:
wenquanyi wqy-zenhei.ttf FT n 75 160 u
wenquanyi wqy-zenhei.ttf FT n 50 160 u
wenquanyi wqy-zenhei.ttf FT n 50 180 u
wenquanyi wqy-zenhei.ttf FT n 75 180 u
这些信息的含义如下:
name1: 任意名
wqy-zenhei.ttf 文件名
FT: 表示是ttf文件
n : y表示是斜体,n表示正常
50: 表示是正常,75表示是粗体
160:表示是16点大小的字体,可根据需要修改
u:表示是unicode的
4)字库生成
首先,执行qvfb,然后执行makeqpf.你会在 qvfb的显示窗内看到fontdir中每一行的信息。
在makeqpf界面中,点击要转换的字库,生成的新的.qpf文件就会存放到$(QTDIR)/lib/fonts/下了
5)旋转字体库的制作
使用带参数的方式执行makeqpf,如
./makeqpf -display Transformed:Rot90
以上指令用于制作翻转90度的字库文件,制作其它的字库文件只需将270改为90,180,0等
注:在$(QTDIR)/lib/fonts/ 目录下的qpf字体文件中,文件名中带有t5,t10,t15等后缀的为旋转字体库,t5为旋转90度,t10为旋转180度,t15为旋转270度。如wenquanyi_160_50_t5.qpf

?有字库并把它拷到根文件系统的对应位置(由环境变量指定)后

在QT源程序的main.cpp中的main中加入

?QTextCodec::setCodecForTr(QTextCodec::codecForName("utf8"));
? QTextCodec::setCodecForCStrings(QTextCodec::codecForName("utf8"));

?QFont font("wenquanyi",12,QFont::Bold); //使用wenquanyi字体
? this->setFont(font);

?

一般默认使用的是unifont

?

为了尊重源作者的劳动成果,再次注明这是转载的,源地址为:http://www.voidcn.com/article/p-wtcjrqgx-nz.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读