QT非UI设计器生成界面的国际化

news2025/3/18 21:29:04

目的

UI设计器生成界面的国际化,比较容易实现些,因为有现成的函数可以调用,基本过程如下:

void MainWindow::on_actLang_CN_triggered()
{//中文界面
    qApp->removeTranslator(trans);
    delete trans;
    trans=new QTranslator;
    trans->load("samp16_1_cn.qm");
    qApp->installTranslator(trans);
    ui->retranslateUi(this);
    QSettings   settings("WWB-Qt","samp16_1"); //注册表键组
    settings.setValue("Language","CN"); //界面语言,汉语
}
void MainWindow::on_actLang_EN_triggered()
{//英文界面
    qApp->removeTranslator(trans);
    delete trans;
    trans=new QTranslator;
    trans->load("samp16_1_en.qm");
    qApp->installTranslator(trans);
    ui->retranslateUi(this);
    QSettings   settings("WWB-Qt","samp16_1"); //注册表键组
    settings.setValue("Language","EN"); //界面语言,英语
}

直接调用相应的函数就可以了。
但手动编写代码的界面如何实现这些呢?
比如这个界面:

Widget::Widget(QWidget *parent)
    : QWidget(parent),trans(nullptr)
{
    QLabel* label = new QLabel(QString::fromUtf8("widget_处理"));
    label->setStyleSheet("QLabel{font:60px}");
    QHBoxLayout* layoutMain = new QHBoxLayout();
    this->setLayout(layoutMain);
    //layoutMain->addWidget(label);
    layoutMain->setContentsMargins(0,0,0,0);
    QFrame *mainFrame = new QFrame();
    layoutMain->addWidget(mainFrame);
    QHBoxLayout* layoutMainFrame = new QHBoxLayout();
    layoutMainFrame->setContentsMargins(0,0,0,0);
    mainFrame->setLayout(layoutMainFrame);
    //帮助
    QFrame *helpFrame = new QFrame();
    QHBoxLayout* layoutHMenu1 = new QHBoxLayout();
    layoutHMenu1->setContentsMargins(0,0,0,0);
    layoutHMenu1->setSpacing(0);
    //1/打开帮助
    m_btnOpenHelp = new QToolButton();
    m_btnOpenHelp->setText(tr("打开帮助"));
    m_btnOpenHelp->setMaximumWidth(60);
    layoutHMenu1->addWidget(m_btnOpenHelp);
    //帮助小分类
    QLabel *lable1_1 = new QLabel(this);
    lable1_1->setText(tr("帮助"));
    lable1_1->setMaximumHeight(20);
    lable1_1->setAlignment(Qt::AlignCenter);
    QVBoxLayout* layoutVMenu1 = new QVBoxLayout();
    layoutVMenu1->setContentsMargins(0,0,0,0);
    layoutVMenu1->setSpacing(0);
    layoutVMenu1->addLayout(layoutHMenu1);
    layoutVMenu1->addWidget(lable1_1);
    helpFrame->setLayout(layoutVMenu1);
    layoutMainFrame->addWidget(helpFrame);
    //关于
    QFrame *aboutFrame = new QFrame();
    QHBoxLayout* layoutHMenu2 = new QHBoxLayout();
    layoutHMenu2->setContentsMargins(0,0,0,0);
    layoutHMenu2->setSpacing(0);
    //1/关于
    m_btnOpenAbout = new QToolButton();
    m_btnOpenAbout->setText(tr("关于"));
    m_btnOpenAbout->setMaximumWidth(60);
    layoutHMenu2->addWidget(m_btnOpenAbout);
    m_btnTranslate = new QToolButton();
    m_btnTranslate->setText(tr("翻译"));
    QObject::connect(m_btnTranslate,SIGNAL(clicked(bool)),this,SLOT(on_btnTranslate_clicked(bool)));
    m_btnTranslate->setMaximumWidth(60);
    layoutHMenu2->addWidget(m_btnTranslate);
    //关于小分类
    m_lable2_1 = new QLabel(this);
    m_lable2_1->setText(tr("关于"));
    m_lable2_1->setMaximumHeight(20);
    m_lable2_1->setAlignment(Qt::AlignCenter);
    QVBoxLayout* layoutVMenu2 = new QVBoxLayout();
    layoutVMenu2->setContentsMargins(0,0,0,0);
    layoutVMenu2->setSpacing(0);
    layoutVMenu2->addLayout(layoutHMenu2);
    layoutVMenu2->addWidget(m_lable2_1);
    aboutFrame->setLayout(layoutVMenu2);
    layoutMainFrame->addWidget(aboutFrame);
    //最后加弹簧
    QSpacerItem *spacer = new QSpacerItem(10, 20,
                               QSizePolicy::Expanding,
                               QSizePolicy::Minimum);
    layoutMainFrame->addItem(spacer);
}

这个界面是没有retranslateUi()这个函数的。
说说QT国际化的概念:
QT国际化(Internationalization,简称I18N)是指将一个软件应用程序的界面、文本、日期、数字等元素转化为不同的语言和文化习惯的过程。
这使得软件能够在不同的国家和地区使用,并且可以根据用户的语言和地区提供本地化的使用体验。
QT是一种跨平台的应用程序开发框架,提供了很多工具和功能来支持国际化。

过程

先看看,ui的这个函数到底做了什么,我们可以模仿这一个函数实现相应的功能,充分利用QT框架的东西:
在这里插入图片描述

原来是重新设置了一下文本相关的东西。
这让我们可以知道,执行了这段代码后:

qApp->removeTranslator(trans);
    delete trans;
    trans=new QTranslator;
    trans->load("samp16_1_cn.qm");
    qApp->installTranslator(trans);

语言已经翻译完了,但需要把翻译的结果,再放到界面上去,如果放到界面上去,就是需要手动的设置这些控件的文本,感觉有些笨似的,然而,却只能这样;如果用Ui设置器的话,Qt界面设计器会为我们自动生成这些代码,但我们没有用Qt界面设计器,所以也没有这些函数,只有我们自己去实现这些函数。
先看实现的效果:
在这里插入图片描述
在这里插入图片描述
我们是这样实现的:
首先是“翻译”按钮的实现逻辑:

void Widget::on_btnTranslate_clicked(bool checked)
{
    static bool isChinese = true;
    if(isChinese)
    {
        qDebug()<<"isChinese="<<isChinese;
        if(trans)
        {
            qApp->removeTranslator(trans);
            delete trans;
        }
        QString appDirPath = QCoreApplication::applicationDirPath();
        //QString fileName = appDirPath+"//translate1_cn.qm";
        QString fileName = QString(":/translate/translate1_cn.qm");
        trans=new QTranslator;
        trans->load(fileName);
        qApp->installTranslator(trans);
        qApp->processEvents();
        //this->update();
        isChinese = false;
    }
    else
    {
        qDebug()<<"isChinese="<<isChinese;
        if(trans)
        {
            qApp->removeTranslator(trans);
            delete trans;
        }
        QString appDirPath = QCoreApplication::applicationDirPath();
        QString fileName = QString(":/translate/translate1_en.qm");
        //QString fileName = appDirPath+"//translate1_en.qm";
        trans=new QTranslator;
        trans->load(fileName);
        qApp->installTranslator(trans);
        qApp->processEvents();
        isChinese = true;
    }
    //ui->retranslateUi(this);
}

这个逻辑很简单,就是利用QT的函数实现了翻译工作,但是少了retranslateUi()函数的实现,如何实现这一个函数呢?
先定义一个事件:

void Widget::changeEvent(QEvent *event)
{
    if (event->type() == QEvent::LanguageChange) {
           retranslateUi();  // 语言变化时更新界面
       }
    QWidget::changeEvent(event);
}

再实现retranslateUi()函数:

void Widget::retranslateUi()
{
     m_btnOpenAbout->setText(tr("关于"));
     m_btnOpenHelp->setText(tr("打开帮助"));
     m_lable2_1->setText(tr("关于"));
     m_btnTranslate->setText(tr("翻译"));
}

这样就实现了翻译工作。
效果如下:

Qt界面国际化1

总结

用QT开发多语言界面程序,主要包括以下几个步骤
1)在程序设计阶段,程序代码中每一个用户可见的字符串都有tr()函数封装
2)在项目配置文件(.pro文件)中设置需要导出的翻译文件(.ts文件),使用lupdate工具扫描项目文件 中需要翻译的字符串,并生成翻译文件
3)使用Qt的Linguist程序打开后成的翻译文件,将程序中的字符串翻译为需要的语言,如将所中文字符串翻译为英文
4)使用lrelease工具编译翻译好的翻译文件,生成更为紧凑的".qm"文件。
5)在应用程序中用QTranslator调用不两年的".qm"文件,实现不同的语言界面。
关于手写代码界面的翻译,有如下关键部分:
翻译事件:

[virtual protected] void QWidget::changeEvent(QEvent *event)
This event handler can be reimplemented to handle state changes.
The state being changed in this event can be retrieved through the event supplied.
Change events include: QEvent::ToolBarChange, QEvent::ActivationChange, QEvent::EnabledChange, QEvent::FontChange, 
QEvent::StyleChange, QEvent::PaletteChange, QEvent::WindowTitleChange, QEvent::IconTextChange, QEvent::ModifiedChange, 
QEvent::MouseTrackingChange, QEvent::ParentChange,
 QEvent::WindowStateChange, QEvent::LanguageChange, QEvent::LocaleChange, QEvent::LayoutDirectionChange, QEvent::ReadOnlyChange.

这个过程体现了QT事件的灵活应用:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2317430.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python | 输入日期,判断这一天是这一年的第几天

题目&#xff1a; 使用 python 编程&#xff0c;实现输入日期&#xff0c;判断这一天是这一年的第几天? 具体实现代码如下&#xff1a; import datetime year input(请输入年份&#xff1a;) month input(请输入月份&#xff1a;) day input(请输入天&#xff1a;) date…

单片机开发资源分析的实战——以STM32F103C8T6为例子的单片机资源分析

目录 第一点&#xff1a;为什么叫STM32F103C8T6 从资源手册拿到我们的对STM32F103C8T6的资源描述 第二件事情&#xff0c;关心我们的GPIO引脚输出 第三件事情&#xff1a;去找对应外设的说明部分 前言 本文章隶属于项目&#xff1a; Charliechen114514/BetterATK: This is…

Maven | 站在初学者的角度配置

目录 Maven 是什么 概述 常见错误 创建错误代码示例 正确代码示例 Maven 的下载 Maven 依赖源 Maven 环境 环境变量 CMD测试 Maven 文件配置 本地仓库 远程仓库 Maven 工程创建 IDEA配置Maven IDEA Maven插件 Maven 是什么 概述 Maven是一个项目管理和构建自…

【css酷炫效果】纯CSS实现3D翻转卡片动画

【css酷炫效果】纯CSS实现3D翻转卡片动画 缘创作背景html结构css样式完整代码效果图 想直接拿走的老板&#xff0c;链接放在这里&#xff1a;https://download.csdn.net/download/u011561335/90490472 缘 创作随缘&#xff0c;不定时更新。 创作背景 刚看到csdn出活动了&am…

并发编程面试题二

1、java线程常见的基本状态有哪些&#xff0c;这些状态分别是做什么的 &#xff08;1&#xff09;创建&#xff08;New&#xff09;&#xff1a;new Thread()&#xff0c;生成线程对象。 &#xff08;2&#xff09;就绪&#xff08;Runnable&#xff09;:当调用线程对象的sta…

Spring Cloud Stream - 构建高可靠消息驱动与事件溯源架构

一、引言 在分布式系统中&#xff0c;传统的 REST 调用模式往往导致耦合&#xff0c;难以满足高并发和异步解耦的需求。消息驱动架构&#xff08;EDA, Event-Driven Architecture&#xff09;通过异步通信、事件溯源等模式&#xff0c;提高了系统的扩展性与可观测性。 作为 S…

突破连接边界!O9201PM Wi-Fi 6 + 蓝牙 5.4 模块重新定义笔记本无线体验

在当今数字化时代&#xff0c;笔记本电脑已成为人们工作、学习和娱乐的必备工具。而无线连接技术&#xff0c;作为笔记本电脑与外界交互的关键桥梁&#xff0c;其性能的优劣直接关乎用户体验的好坏。当下&#xff0c;笔记本电脑无线连接领域存在诸多痛点&#xff0c;严重影响着…

Python----计算机视觉处理(Opencv:图像颜色替换)

一、开运算 开运算就是对图像先进行腐蚀操作&#xff0c; 然后进行膨胀操作。开运算可以去除二值化图中的小的噪点&#xff0c;并分离相连的物体。 其主要目的就是消除那些小白点 在开运算组件中&#xff0c;有一个叫做kernel的参数&#xff0c;指的是核的大小&#xff0c;通常…

一周学会Flask3 Python Web开发-SQLAlchemy查询所有数据操作-班级模块

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 我们来新建一个的蓝图模块-班级模块&#xff0c;后面可以和学生模块&#xff0c;实现一对多的数据库操作。 blueprint下新建g…

Matlab 风力发电机磁悬浮轴承模型pid控制

1、内容简介 略 Matlab 174-风力发电机磁悬浮轴承模型pid控制 可以交流、咨询、答疑 2、内容说明 磁悬浮轴承具有无接触、无摩擦、高速度、高精度、能耗低、不需要需润滑无油污染、可靠性高、寿命长和密封等一系列显著的优点。将磁悬浮技术应用于风力发电机中可以降低风机切入…

FPGA中级项目1——IP核(ROM 与 RAM)

FPGA中级项目1——IP核&#xff08;ROM 与 RAM&#xff09; IP核简介 在 FPGA&#xff08;现场可编程门阵列&#xff09;设计中&#xff0c;IP 核&#xff08;Intellectual Property Core&#xff0c;知识产权核&#xff09;是预先设计好的、可重用的电路模块&#xff0c;用于实…

Matlab 基于专家pid控制的时滞系统

1、内容简介 Matlab 185-基于专家pid控制的时滞系统 可以交流、咨询、答疑 2、内容说明 略 在处理时滞系统&#xff08;Time Delay Systems&#xff09;时&#xff0c;使用传统的PID控制可能会面临挑战&#xff0c;因为时滞会导致系统的不稳定或性能下降。专家PID控制通过结…

Unity 笔记:在EditorWindow中绘制 Sorting Layer

在Unity开发过程中&#xff0c;可能会对旧资源进行批量修改&#xff0c;一个个手动修改费人费事&#xff0c;所以催生出了一堆批量工具。 分享一下在此过程中绘制 Sorting Layer 面板的代码脚本。 示意图&#xff1a; 在 EditorGUI 和 EditorGUILayer 中内置了 SortingLayerF…

2024浙江大学计算机考研上机真题

2024浙江大学计算机考研上机真题 2024浙江大学计算机考研复试上机真题 2024浙江大学计算机考研机试真题 2024浙江大学计算机考研复试机试真题 历年浙江大学计算机复试上机真题 历年浙江大学计算机复试机试真题 2024浙江大学计算机复试上机真题 2024浙江大学计算机复试机试真题 …

蓝桥杯嵌入式赛道复习笔记2(按键控制LED灯,双击按键,单击按键,长按按键)

硬件原理解释 这张图展示了一个简单的按键电路原理图&#xff0c;其中包含四个按键&#xff08;PB0、PB1、PB2、PB3、PA0&#xff09;&#xff0c;每个按键通过一个10kΩ的上拉电阻连接到VDD&#xff08;电源电压&#xff09;&#xff0c;并接地&#xff08;GND&#xff09;。 …

每天五分钟深度学习PyTorch:循环神经网络RNN的计算以及维度信息

本文重点 前面我们学习了RNN从何而来,以及它的一些优点,我们也知道了它的模型的大概情况,本文我们将学习它的计算,我们来看一下RNN模型的每一个时间步在计算什么? RNN的计算 ht-1是上一时刻的输出,xt是本时刻的输入,然后二者共同计算得到了ht,然后yt通过ht计算得到,…

Ubuntu docker安装milvusdb

一、安装docker 1.更新软件包 sudo apt update sudo apt upgrade sudo apt-get install docker-ce docker-ce-cli containerd.io查看是否安装成功 docker -v二、使用国内的镜像下载 milvusdb Docker中国区官方镜像: https://registry.docker-cn.com milvusdb/milvus - Doc…

【优选算法篇】--深度解析之滑动窗口篇

滑动窗口 一、长度最小的子数组二、无重复字符的最长子串三、最大连续1的个数III四、水果成篮 一、长度最小的子数组 长度最小的子数组 解析&#xff1a; 首先看到这题 我们首先想到的是暴力枚举&#xff0c;就是暴力枚举所有子数组和。时间复杂度是O(n^3)。 我们这里用解法…

[STM32]新建工程||一个工程文件应该有哪些基本内容?

目录 一 、开发方法 1.直接使用程序来配置寄存器 2.基于库函数的方式 3.基于HAL库的方式 二 、常规的工程文件分类 STM32芯片型号分类以及缩写 ​三 步骤总结 四 工程架构 五 调用外设基本通用步骤 一 、开发方法 1.直接使用程序来配置寄存器 底层&#xff0c;直接&…

python编写的一个打砖块小游戏

游戏介绍 打砖块是一款经典的街机游戏&#xff0c;玩家控制底部的挡板&#xff0c;使球反弹以击碎上方的砖块。当球击中砖块时&#xff0c;砖块消失&#xff0c;球反弹&#xff1b;若球碰到挡板&#xff0c;则改变方向继续运动&#xff1b;若球掉出屏幕底部&#xff0c;玩家失…