http://qt-project.org/wiki/How_to_do_dynamic_translation_in_QML
qml internationalization 步骤 一、对需要国际化的地方加上qsTr eg. text: qsTr("Welcome to china!"); 二、生成ts文件: ts文件生成方法: 在Qt Command Prompt命令行中使用lrelease生成 eg. lupdate main.qml -ts t1_fr.ts 可以同时对qml文件生成多种语言的ts文件 eg. lupdate main.qml text.qml button.qml -ts t1_fr.ts t1_en_ts note: ts不会覆盖,可以多次lupdate更新 三、使用Qt自带的Linguist工具翻译为目标语言 四、生成qm文件,既是我们需要的语言转换文件 可以使用两种方法生成: 1、命令行中使用lrelease生成qm文件 eg. lrelease t1_fr.ts 2、使用Linguist自带的工具, 点击 文件->发布(release)既可生成qm文件 五、使用Translator类load qm文件 再install Translator eg. QTranslator * translator; = new QTranslator(this); translator->load("t1_fr", "."); qApp->installTranslator(translator); 六、动态切换语言时需要notifiy每个qsTr的string来刷新显示 方法如下: Q_PROPERTY(QString emptyString READ getEmptyString NOTIFY languageChanged) languageChanged为信号 可以用qsTr("Welcome to china!") + emptyString的方法 (note: emptyString 需要暴露给qml,具体方法查看qt文档)。 七、关于国际化 ListElement中的数据方法有两种: 举例说明: 1、ListElement使用QT_TR_NOOP进行标记,在使用时用qsTr翻译 eg1. ListModel { id: listModel ListElement {title: QT_TR_NOOP("Math");} ListElement {title: QT_TR_NOOP("Chinese");} ListElement {title: QT_TR_NOOP("English");} ListElement {title: QT_TR_NOOP("Sports);} } delegate: { text: qsTr(title); } 2、在ListElement中用js function进行返回 ListModel { id: listModel_2 ListElement {} ListElement {} ListElement {} ListElement {} function title(index) { if ( title[ "text" ] === undefined) { title.text = [ qsTr( "Math" ) , qsTr( "Chinese" ) , qsTr( "English" ) , qsTr( "Sports" ) ] } return title.text[index] } } delegate: { text: title(index); }