QT5实现语言国际化(中英文界面动态切换,超详细)

一、实现效果演示:

效果图

二、实现步骤

1、新建工程language_change工程,过程略,目录如下图:

工程目录

、 

2、点击打开language_change.pro文件,在文件中添加

TRANSLATIONS = english.ts chinese.ts

工程目录下生成“.ts文件”

3、点击工具->外部->Qt语言更新翻译(lupdate),生成english.ts和chinese.ts文件,生成的文件在工程目录下,在。pro文件里会增加 “RESOURCES += \
    qt_language.qrc” ,具体如下图:

RESOURCES += \
    qt_language.qrc

4、利用和工程对应版本32bit或64bit的Linguist版 软件打开.ts文件,并对文件进行翻译,翻译完毕点击左上角的文件,发布会生产对应的.qm文件,具体如下图:

注意:UI设计时默认是英文,则只需翻译对应的cn.ts,点击发布会生产对应的qm文件

 4、工程添加源文件

新建.qrc源文件

5、把上面生成的qm文件添加到该qt_language.qrc目录下,

注意:引用时不需要包含qt_language,相对路径为:":/trans/cn.qm"对应的路径结构如下图:

右击源文件Resources
选择生成的qm文件

 6、在mainwindow.ui文件中添加,QLabel和combox控件如下图:

mainwindow.ui界面

7、mainwindow.h文件如下所示:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#define combox_index
#include <QMainWindow>
#include <QComboBox>
#include <QTranslator>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE
class MainWindow : public QMainWindow
{
    Q_OBJECT
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
    static int aa;//全局变量声明
private slots:
    void on_comboBox_activated(const QString &arg1);//combox槽函数声明
    void changeEvent(QEvent *e);//changeEvent槽函数声明
private:
    QComboBox *combo;//
    QTranslator tran;//翻译器
    QApplication *qApp;//
private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

8、mainwondow.cpp代码如下:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QDebug>
int MainWindow::aa = 0;//全局变量初始化
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    this->resize(400,600);
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_comboBox_activated(const QString &arg1)
{
    aa = ui->comboBox->currentIndex();
    if(aa==0){
        qDebug()<<"下标为0";//调试用
        tran.load(":/english");

    }else if(aa==1){
        qDebug()<<"下标为1";//调试用
        tran.load(":/chinese");
    }else{
        qDebug()<<"下标为其他";//调试用
    }
    qApp->installTranslator(&tran);
}

//调用installTranslator后,系统会给窗体发送信号将产生了changeEvent槽产生event
void MainWindow::changeEvent(QEvent *e)
{
    QWidget::changeEvent(e);
    switch (e->type()) {
        case QEvent::LanguageChange:
            ui->retranslateUi(this);
            break;
        default:
            break;
    }
}
调试时的输出显示

OK,完成了基本的Demo实验,可以应用到我的项目了

容易忽略的细节:

1、槽函数changeEvent(QEvent *e)的在mainwindow.h的添加,否在不会出现预期效果

2、使用QTranslator时,头文件的添加#include添加等

  • 10
    点赞
  • 60
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
使用Qt实现仪器控制开发中的图形化控制界面,可以大大提高开发效率和用户体验。下面是一些步骤,可以帮助你实现这个目标: 1. 安装Qt:首先,需要安装Qt开发环境。可以从Qt官网下载最新的Qt安装包,并按照安装向导进行安装。安装完成后,可以打开Qt Creator,创建一个新的Qt项目。 2. 设计界面:在Qt Creator中,可以使用Qt Designer来设计界面。可以选择各种控件并拖放到界面上,然后设置控件的属性和布局。可以使用布局管理器来自动调整控件的位置和大小,以适应不同的窗口大小。 3. 添加代码:在Qt Creator中,可以使用C++代码来实现控制逻辑。可以在界面中选择控件,并添加相应的槽函数,用于响应用户的操作。可以使用Qt提供的信号和槽机制,实现控件之间的交互和数据传输。可以使用Qt提供的API,实现与仪器之间的通信和控制。 4. 编译和测试:在代码编写完成后,可以使用Qt Creator中的编译器来编译代码,并生成可执行文件。可以在开发环境中进行测试和调试,确保程序能够正常运行。 通过以上步骤,可以快速地实现一个图形化的仪器控制界面。需要注意的是,在实际开发中,还需要考虑很多其他的因素,例如安全性、稳定性、性能等。因此,需要综合考虑各种因素,并进行充分的测试和验证,确保程序的质量和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值