Qt 国际化——创建中英文翻译步骤

发布时间:2023年12月20日

Qt 国际化——创建中英文翻译步骤

说明:之前我的csdn博客,第一篇文章发表的就是Qt国际化的文章(点击打开),写的也过于简单了:

今天,这篇文章再详细的记录下,中英文翻译的步骤。

一、环境介绍

本片以Qt 5.12.2(编译器MinGW),Qt Creator 4.8.2为例:

操作系统为Win 11 64位:

二、Qt Linguist

Qt对于多语言切换模块提供了专门的工具,Qt Linguist(Qt语言家),我们可以在安装Qt的目录下看到这个工具,它分为32位和64位,如果你的编译器是32位的你翻译的时候就是用32位的Linguist,64位的编译器就对应64位的Linguist。

?

打开Qt Linguist,如下所示:

使用Qt Linguist打开一个文件的时候,我们可以看到它支持的文件类型,如下图所示:

其中一个文件类型是.ts类型,.ts类型就是存储程序翻译的内容信息,有了这一个文件,才可以生成.qm的二进制文件(相应的语言文件),供Qt程序加载,从而实现多语言的切换。

三、配置生成ts文件

我们知道了需要先生成ts文件,才能实现接下来的步骤。ts文件生成,需要在pro文件中配置,比如需要中英文切换,这时在pro文件中添加的代码如下:

TRANSLATIONS += Language_CN.ts\
                Language_EN.ts
Language_CN.ts表示中文ts文件,Language_EN.ts表示英文ts文件。

在pro文件中,添加完成后,通过Qt Creator,菜单栏“工具->外部(E)->Qt语言家->更新翻译(lupdate)”,即可生成.ts文件。

ts文件内容格式大致如下所示:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE TS>
<TS version="2.1">
<context>
    <name>MainWindow</name>
    <message>
        <location filename="mainwindow.ui" line="14"/>
        <source>MainWindow</source>
        <translation type="unfinished"></translation>
    </message>
    <message>
        <location filename="mainwindow.ui" line="27"/>
        <source>PushButton</source>
        <translation type="unfinished"></translation>
    </message>
    <message>
        <location filename="mainwindow.ui" line="40"/>
        <source>中文</source>
        <translation type="unfinished"></translation>
    </message>
    <message>
        <location filename="mainwindow.cpp" line="11"/>
        <source>lange</source>
        <translation type="unfinished"></translation>
    </message>
    <message>
        <location filename="mainwindow.cpp" line="16"/>
        <source>English</source>
        <translation type="unfinished"></translation>
    </message>
    <message>
        <location filename="mainwindow.cpp" line="18"/>
        <source>Chinese</source>
        <translation type="unfinished"></translation>
    </message>
</context>
</TS>

其实就是xml形式的文本文件。这一步操作对应的命令是:

lupdate xxxx.pro

如果是界面操作就不用管这个命令生成。

四、tr函数

在上一步中我们生成ts文件之前,需要把我们需要翻译的内容使用tr函数进行包裹,tr函数的原型是:

static QString tr(const char *sourceText, const char * = nullptr, int = -1)

被tr处理的字符串可以使用工具提取出来翻译成其他语言。

如图:代码中tr的使用

也可以看到和ts文件对应的内容:

五、qm文件

在经过上面的步骤之后我们需要把ts文件翻译成中文并编译生成qm文件,才能被Qt加载。

打开Qt 中安装的Linguist软件,选择我们上面生成的ts文件,如下图所示:

选择需要翻译的项,输入需要翻译的内容,然后点击工具栏中的够好即可(上面是翻译成中文的ts,英文的步骤一样)。

然后点击“文件->发布(R)”,既可生成对应的qm文件。

可以看到qm文件的生成。

这一步,如果使用命令行的生成的话,代码如下:

lrelease xxx.pro

六、qm文件的加载

编译生成qm文件后,我们就可以调用我们的翻译文件了。

1、首先在界面上创建可以切换中英文的菜单栏,你可以通过其他的控件来控制这一步操作:

2、main函数中调用

    QTranslator translator;
    //translator.load(":/qm/Language_EN.qm");
    a.installTranslator( &translator );

    MainWindow w;
    w.setTranslator(&translator);
    w.showMaximized();

3、Mainwindow中调用

class MainWindow : public QWidget
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:
 

    void languageCNActionClickedSlot();
    void languageENActionClickedSlot();

protected:

    void changeEvent(QEvent* event);

public:
    void setTranslator(QTranslator* translator);

private:
    void initMenuData();
    void translatorUI();

private:
    Ui::MainWindow *ui;


    QMenu* mMenu = nullptr;
    QAction *mLanguageCNAction = nullptr;
    QAction *mLanguageENAction = nullptr;

    QTranslator* mTranslator = nullptr;
};
void MainWindow::setTranslator(QTranslator *translator)
{
    mTranslator = translator;
}

void MainWindow::changeEvent(QEvent *event)
{
    switch (event->type())
    {
    case QEvent::LanguageChange:
        translatorUI();
        break;
    default:
        QWidget::changeEvent(event);
    }
}


void MainWindow::languageCNActionClickedSlot()
{
    mTranslator->load(":/qm/Language_CN.qm");
}

void MainWindow::languageENActionClickedSlot()
{
    mTranslator->load(":/qm/Language_EN.qm");
}

void MainWindow::translatorUI()
{
    mLanguageCNAction->setText(tr("Chinese"));
    mLanguageENAction->setText(tr("English"));
    mHelpAction->setText(tr("Help"));
    mAboutAction->setText(tr("About"));

    ui->retranslateUi(this);
}

以上的代码,我们通过LanguageEvent事件来实现动态切换中英文。

本文原创作者:冯一川(ifeng12358@163.com),未经作者授权同意,请勿转载。

文章来源:https://blog.csdn.net/ifeng12358/article/details/134973722
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。