Qt标准对话框按钮显示中文解决方案(原创)

从网上搜了一堆解决方法,大多是考来考去,也没有解决我的问题;

基本的方法是

在窗口实例化之前,加载和安装QTranslator;

加载的qm文件从qt源文件中的ts文件中发布而来;

例如:C:\Qt\Qt5.13.0\5.13.0\Src\qttranslations\translations\qt_zh_CN.ts

使用Linguist 5.13.0 (MinGW 7.3.0 64-bit)打开后发布(文件-另外发布)qt_zh_CN.qm

添加到资源中地址是:/labels/qt_zh_CN.qm

在main.cpp中添加代码

#include <QApplication>
#include <QTranslator>
#include <QTextCodec>
#include <QFont>
#include "mainwindow.h"

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    //QApplication::setStyle(QStyleFactory::create("fusion"));

    QTextCodec * textCodec = QTextCodec::codecForName("utf8");
    QTextCodec::setCodecForLocale(textCodec);
    QTranslator * translator = new QTranslator();
    bool isLoad = translator->load(":/labels/qt_zh_CN.qm");
    if(isLoad)
        a.installTranslator(translator);
    qDebug() << "tanslator load " << isLoad;
    //设置全局文字大小,非必需,根据自身情况使用
    QFont font  = QFont("SimHei",10);
    a.setFont(font);
    MainWindow w;
    w.show();
    return a.exec();
}

返回True证明加载成功但是,

没有效果!仍然是OK Cancel Yes

从5.13源文件中找到繁体中文版qtbase_zh_TW.ts后生成qtbase_zh_TW.qm可以显示繁体中文!

后来在github上对比了一下后期版本qtbase_zh_CN.ts文件,格式确实不太一样;

因此从github上下载新版本的qtbase_zh_CN.ts重新发布后可以了qt_zh_CN.qm

从这里下载:https://download.csdn.net/download/li4692625/65475445

来源:Qt的翻译文件QTranslator不能使用问题总结(原) - 北山愚公* - 博客园

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮你解决这个问题。 首先,你需要在Qt Creator中创建一个新的窗口或对话框,然后在该窗口中添加一个QListWidget控件,用于显示列表数据。 接下来,你需要设置QListWidget的属性,以便它能够在每页中显示10行数据,并且能够支持翻页操作。你可以通过以下代码来实现: ```cpp // 设置每页显示的行数 int pageSize = 10; ui->listWidget->setBatchSize(pageSize); // 显示第一页的数据 ui->listWidget->setCurrentRow(0); // 添加翻页按钮 QHBoxLayout *pageLayout = new QHBoxLayout(); QPushButton *prevButton = new QPushButton("上一页"); QPushButton *nextButton = new QPushButton("下一页"); pageLayout->addWidget(prevButton); pageLayout->addWidget(nextButton); ui->verticalLayout->addLayout(pageLayout); // 连接翻页按钮的槽函数 connect(prevButton, &QPushButton::clicked, ui->listWidget, &QListWidget::scrollToPreviousPage); connect(nextButton, &QPushButton::clicked, ui->listWidget, &QListWidget::scrollToNextPage); ``` 上面的代码中,我们首先通过`setBatchSize`函数设置每页显示的行数为10。然后,我们使用`setCurrentRow`函数将列表的当前行设置为第1行,以便显示第一页的数据。 接下来,我们创建了一个水平布局,并在其中添加了上一页和下一页按钮。最后,我们通过`connect`函数将翻页按钮的`clicked`信号连接到列表控件的`scrollToPreviousPage`和`scrollToNextPage`槽函数上,以实现翻页功能。 希望这个解决方案能够对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值