Qt使用时遇到的问题。

在QWidge页面中,背景图片通过#systemset样式无法显示,需使用paintEvent重绘。同时,尝试通过QTranslator加载英文语言包以切换到英文界面,但遇到判断问题和调试困难。在不同的Qt版本和编译环境(ARM与Desktop)下,调试结果有差异,导致问题难以解决。
摘要由CSDN通过智能技术生成

1.在QWidge页面无法显示背景图片#systemset{border-image: url(:/image/qwidgetbg.png);}。

需要使用paintEvent重绘页面。

void systemset::paintEvent(QPaintEvent *)//重绘后界面不会只显示stackedWidget,背景可显示出来
{
    QStyleOption opt;
    opt.init(this);
    QPainter p(this);
    style()->drawPrimitive(QStyle::PE_Widget,&opt,&p,this);

}

在mian.cpp中调用其他文件中参数作判断来显示英文界面,想直接显示英文界面不成功

SettingFile *setFile_1 = new SettingFile();
Calibration cal = setFile_1->readFile_unit(); 

cal.languageType == LanguageEN;

    if(cal.languageType == LanguageEN)
    {
        QTranslator *tran = new QTranslator(qApp);
        tran->load("/home/build-test-Arm64-Debug/language_en.qm");

        qApp->installTranslator(tran);
    }

一开始以为是路径错误,找不到这个路径下的qm文件,后来想可能是判断后没有进来,找到这里给CH赋值了,EH没赋值。可能是没赋值系统自己给值给的不一样判断不对吧。

enum LanguageType{
    LanguageCH =0,
    LanguageEN
};

然后调试Debug的时候,调不出来,可被恶心到了,换了个老版的Qt在另一套虚拟机上弄,ARM好像没法显示,然后选Desktop编译才能Debug出来。为啥为啥呢。

 

使用Qt操作MySQL数据库遇到莫名其妙的问题,可能是由于多种原因造成的,下面是一些常见的问题及其解决方法: 1. 连接问题:确保MySQL服务已经启动,并且Qt应用程序有权访问MySQL服务。你可以使用Qt提供的数据库驱动(如QMYSQL)进行连接测试。如果连接失败,检查数据库服务器的地址、端口、用户名和密码是否正确。 2. 编码问题:在创建数据库或表,要确保使用的是UTF-8编码,以避免字符集不一致导致的数据乱码问题。在Qt中执行SQL命令,也可以指定字符集,例如: ```sql SET NAMES 'utf8'; SET CHARACTER SET utf8; ``` 3. SQL语句错误:检查你的SQL语句是否有语法错误或者逻辑错误。在Qt中可以通过捕获`QSqlError`异常来获取错误信息,并据此调试SQL语句。 4. 权限问题:确保你的MySQL用户有足够的权限去执行特定的数据库操作。如果权限不够,需要联系数据库管理员调整权限设置。 5.Qt与MySQL驱动:确保你的Qt环境已经正确安装并配置了MySQL驱动。你可以使用Qt的插件机制来加载MySQL驱动。 6. 资源泄露或线程问题:如果你在非主线程中操作数据库,确保正确管理数据库连接的生命周期,避免资源泄露。同,确保数据库操作的线程安全性,防止多个线程同操作数据库导致的问题。 解决这些问题通常需要细致地检查代码、数据库设置以及运行环境。如果上述方法都不能解决你的问题,可能需要提供更详细的错误信息,例如错误代码、日志信息或者具体的异常描述,以便进一步诊断问题
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值