【QT Tools】软件多语言国际化翻译的方法与步骤
在Qt的项目开发过程中,有时软件要翻译成多语言版本,这就涉及到国际化方面的操作。虽然Qt对这方面集成了很多工具,操作起来比较方便,本文还是总结一下国际化的方法和步骤,用以备忘和参考。
我们通常在写程序时,为了正常显示中文,一般会直接用到类QTextCodec和tr()函数,其实这只是一种临时的做法,方便我们快速完成程序、显示效果。当要真正发布一个程序时,最好的方式是在程序中使用英文字符串,再使用国际化工具进行翻译。
1.软件国际化的方法
在Qt中,所有的输入部件和文本绘制方式对对所有支持的语言都提供了内置支持,Qt内置的字体引擎可以在同一时间正确而精细地绘制不同的文本。在Qt项目开发过程中,我们可以使用Qt Linguist工具来完成应用程序的翻译工作。
在Qt中编写代码时,要对需要显示的字符串调用tr()函数,完成代码编辑后,对这个应用程序的翻译主要分三个步骤:
CMD: 此处代指 Qt Creator [工具] -> [外部] -> [Qt 语言家]
- 在
CMD中运行lupdate工具,从源代码中提取要翻译的文本,这里会生成一个.ts文件,此文件格式是xml格式; - 在
Qt Linguist中打开.ts文件,并完成翻译工作; - 在
CMD中运动lrelease工具,从.ts文件中生成一个.qm文件,它是一个二进制文件,用于程序运行时使用。
其中,.ts文件和.qm文件都是平台无关的 。
2.具体实例实现步骤
- 新建Qt Gui应用,项目名称为
myI18N,类名为MainWindow,基类保持QMainWindow不变。 - 建立完项目后,点击
mainwindow.ui文件进入设计模式,先添加一个&File菜单,再为其添加一个&New子菜单并设置快捷键为Ctrl+N,然后往界面上拖入一个Push Button。 - 下面我们再使用代码添加几个标签,打开
mainwindow.cpp文件,添加头文件#include <QLabel>,然后在构造函数中添加代码:
label = new QLabel(this);
label->setText(tr("helllo QT"));
label->move(100,50);
label2 = new QLabel(this);
label2->setText(tr("password","mainwindow"));
label2->move(100,80);
label3 = new QLabel(this);
int id = 123;
QString name = "wusanlang";
label3->setText(tr("ID is %1, Name is %2").arg(id).arg(name));
label3->resize(180,20);
label3->move(100,120);
这里值得注意的是tr()函数是不止一个参数的,其原型为:
QString QObject::tr(const char *sourceText, const char *disambiguation = Q_NULLPTR, int n = -1)
第一个参数sourceText就是要显示的字符串,tr()函数会返回sourceText的译文;
第二个参数disambiguation是消除歧义字符串,比如这里的password,如果一个程序中需要输入多个不同的密码,那么在没有上下文的情况下,就很难确定这个password到底指哪个密码。这个参数一般使用类名或者部件名,比如这里使用了mainwindow,就说明这个password是在mainwindow上的;
第三个参数n表明是否使用了复数,因为英文单词中复数一般要在单词末尾加“s”,比如“1 message”,复数时为“2 messages”。遇到这种情况,就可以使用这个参数,它可以根据数值来判断是否需要添加“s”。
- 程序运行结果如下图所示。

源程序编写完成后,我们在.pro文件中指定生成.ts文件的名字,即在文件中添加语句:
TRANSLATIONS = myI18N_zh_CN.ts //文件名可以随意,但要注意区分
- 在
CMD中执行lupdate.exe程序,生成.ts文件。 - 这时使用
Qt Linguist打开.ts文件进行翻译 ,翻译完成后保存。 - 翻译完成后,使用
lrelease.exe程序,生成.qm文件。
- 在项目程序中,添加
.qm文件来改变程序的语言。
在使用qm文件时,要用到QTranslator类,其使用方法为:
int main(int argc, char *argv[])
{
QApplication a(argc, argv); //全局对象指针是宏qApp
QTranslator translator;
translator.load("../myI18N_zh_CN.qm");
a.installTranslator(&translator);
MainWindow w;
w.show();
return a.exec();
}
本测试项目中,我自己制作了,通过点击按钮来实现中英文的切换,其按钮槽函数为实现如下:
void MainWindow::on_pushButton_clicked()
{
QTranslator translator;
if(m_bTranslator) //翻译成中文
{
translator.load("../myI18N_zh_CN.qm");
qApp->installTranslator(&translator);
ui->retranslateUi(this);
//自己添加非ui控件的动态翻译
label->setText(QApplication::translate("MainWindow", "helllo QT", Q_NULLPTR));
label2->setText(QApplication::translate("MainWindow", "password", Q_NULLPTR));
label3->setText(QApplication::translate("MainWindow", "ID is %1, Name is %2", Q_NULLPTR));
}
else
{
qApp->removeTranslator(&translator);
ui->retranslateUi(this);
//自己添加的非ui控件的动态翻译
label->setText(QApplication::translate("MainWindow", "hello QT", Q_NULLPTR));
label2->setText(QApplication::translate("MainWindow", "password", Q_NULLPTR));
label3->setText(QApplication::translate("MainWindow", "ID is %1, Name is %2", Q_NULLPTR));
}
m_bTranslator = !m_bTranslator;
}
Qt国际化翻译并不难,本文主要总结归纳一下,以便备忘和后期参考。
【QT Tools】软件多语言国际化翻译的方法与步骤的更多相关文章
- jquery/vue/react前端多语言国际化翻译方案指南
❝ 本文章共3470字,预计阅读时间5-10分钟. ❞ 国际化-前言 每个开发者能希望编写的程序可以让全世界的用户使用,它要求从产品中抽离所有地域语言,国家/地区和文化相关的元素.换种说法,「应用程序 ...
- 使用 PySide2 开发 Maya 插件系列三:qt语言国际化(internationalization)
使用 PySide2 开发 Maya 插件系列三:qt语言国际化(internationalization) 前言: 这是 qt for python 的语言国际化,基于 UI 的,python 也有 ...
- (三)Qt语言国际化
Vs 2010+ Qt5 实现语言国际化 创建一个工程,cpp代码如下: 1.创建工程 #include "languageinternationalized.h" #includ ...
- Qt 国际化翻译
简介 Qt Linguist 提供了一套加速应用程序翻译和国际化的工具.Qt 使用单一的源码树和单一的应用程序二进制包就可同时支持多个语言和书写系统. 使用 QTranslator 来加载生成的 qm ...
- Zend_Frameowrk中进行多语言国际化的相关的配置和使用
在使用Zend_Framework建立网站,若网站在以后的使用中面向国际,这时就需要实现网站的多语言国际化问题.使用Zend_Framework开发的网站需要进行多语言的开发时,就需要用到了Zend_ ...
- Qt学习之路(34): 国际化(下)
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://devbean.blog.51cto.com/448512/245063 上次 ...
- Ios国际化翻译工具
IOS Translation Tool(IOS国际化翻译工具) 介绍 当IOS项目国际化的时候,手工去翻译每一个字符串是一件非常痛苦的事情.尤其是当项目中存在N多种语言.而且又很难保证,手工翻译的准 ...
- win10+anaconda环境下pyqt5+qt tools+eric6.18安装及汉化过程
最近需要用python编写一个小程序的界面,选择了pyqt5+eric6的配套组合,安装过程中遇到一些坑,特此记录.参考书籍是电子工业出版社的<PyQt5快速开发与实战>. 因为我使用an ...
- 给iview项目加一个i18n国际化翻译
看了上一篇博客吗?我们就根据那一篇博客来,用里面的项目,进行我们接下来国际化翻译项目. 我们安装vue-i18n和js-cookie npm install vue-i18n npm install ...
- 用Qt写软件系列三:一个简单的系统工具(上)
导言 继上篇<用Qt写软件系列二:QIECookieViewer>之后,有一段时间没有更新博客了.这次要写的是一个简单的系统工具,需求来自一个内部项目.功能其实很简单,就是查看当前当前系统 ...
随机推荐
- SPI扩展点在业务中的使用及原理分析
1 什么是SPI SPI 全称Service Provider Interface.面向接口编程中,我们会根据不同的业务抽象出不同的接口,然后根据不同的业务实现建立不同规则的类,因此一个接口会实现多个 ...
- 简易的git命令行入门教程
一.Git 全局设置 git config --global user.name "用户名" git config --global user.email "邮件地址@1 ...
- [QOJ4815] Flower's Land
简要题意:给出一个 \(n\) 个点的树,对某个点 \(i\) 求包含某一个点的大小为 \(k\) 的权值最大的连通块,一个连通块的权值是其所有点的权值之和. \(n\le 40000,k\le \m ...
- Head First Java学习:第八章-接口和抽象类
第八章:接口和抽象类 深入多态 1.抽象类:有些类不应该被初始化 在类声明前面加上抽象类的关键字,abstract. 防止类被初始化,即不能被"new"创建该类的实例(要求) 还是 ...
- Redis 学习笔记1:数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及 zset(sorted set:有序集合). 一.Redis 数据类型-STRING 1.常用 ...
- 【低代码】低代码平台协同&敏捷场景下的并行开发解决方案探索
低代码开发平台的出现,大大地提高的产品交付效率,但是在协同开发.敏捷迭代的场景下,也暴露出了一些问题. 例如: 多人同时对项目进行修改,相互影响甚至修改内容被互相覆盖: 同一项目下多个需求同步开发,但 ...
- 多维数组、Arrays类、稀疏数组、冒泡排序
多维数组 多维数组可以看成是数组的数组 比如二维数组就是一个特殊的一堆数组 其中每个元素就是一个数组. 二维数组: int a[][] = new int[2][5]; 解析:二维数组a可以看成一个两 ...
- ubuntu 20.0.4 LTS 配置国内apt-get源
https://blog.csdn.net/wangyijieonline/article/details/105360138 更换阿里源 要知道当前系统的代号,可以用以下命令: lsb_releas ...
- Ubuntu系统 安装 Zabbix Server 6.0
Zabbix6.0简介: zabbix6.0新特性 1.开箱即用的Zabbix server高可用群集 Zabbix server高可用防止硬件故障或计划维护期的停机: 原生选择加入HA群集配置 定义 ...
- 踩坑ffmpeg录制的mp4无法在浏览器上播放
前言 使用ffmpeg编译好的程序在电脑上进行音视频转换,可以参考这篇:<windows电脑FFmpeg安装教程手把手详解_windows安装ffmpeg>,而我们要做的是在游戏引擎中集成 ...