Qt Creator中使用qss对界面美化没有作用(效果)的问题

Posted 少壮不努力,老大徒伤悲!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Qt Creator中使用qss对界面美化没有作用(效果)的问题相关的知识,希望对你有一定的参考价值。

  最近在研究qt界面开发,发现使用qss对界面进行美化后效果不错,要比mfc效率高很多,美化效果也很出色。但是在使用qss文件对界面控件进行美化的过程中遇到了个很奇葩的问题,困惑了我好久,今晚又遇到了,感觉整个人都不好了,问题症状如下:

  (1)我在Qt Creator中新建了一个工程,添加qss文件及内容后运行,加载qss文件并运行程序,qss美化效果死活出不来(经检查,qss内容及加载过程都正确);

  (2)在Qt Creator中打开一个现有项目,该项目中含有qss文件,能正确加载,在别的电脑上也验证过美化效果能出来,在我电脑上直接运行也有效果,但是我更改了qss文件的内容后,再运行,所有qss美化效果都没了。

  通过从网上查询,最终参考别人的意见并自己测试,最终解决,基本确定是qss编码问题造成的,解决方案如下:

  (1)在项目中选中qss文件,右击/用...打开/System Editor。如下图:

    

  (2)文件/另存为/编码方式选择ANSI/保存

    

  (3)提示框问是否替换?/是

  

  (4)Qt Creator/工具/选项/文本编辑器/行为/UTF-8 BOM选择“总是删除”。

     

  (5)重新qmake/构建/运行程序,解决了,qss美化效果出来了。

原因分析:

  感觉是由于qss编码问题造成的,我的qss文件是通过在工程目录下建一个txt文件,然后改为qss文件,再加到工程里来的,怀疑这个过程中有编码不统一问题。在网上搜索了半天只搜到一篇于此相关的文章,感觉对我帮助很大,在此表示感谢!网址为:http://www.vbgudu.com/html/20160628/53209.html。怕以后找不到,特将内容直接贴在下面:

【qss功能需要正确设置编码才能起作用】

   QT这个库,无非使用OO对跨平台做了绝佳的封装,这其中的主要工作也就是比较繁琐而已,但并不多么了不起。唯独其中提供的QSS功能,让我感到十分神奇,做出来的效果实在很惊艳,而使用代码却又是如此简单,而且是在长期以来中规中冷冰冰的C++编译器上提供这些功能,实在是刮过业界一个新风。也让我认识到,不是什么功能都是编译器提供的,编写库的人,在普通的编译器规则上,照样可以做出各种惊艳的效果来。

  但是最近碰到一个问题,就是我的QSS设置效果在开发机上好好的,并且自己开的虚拟机上也是好好的,但是公司同事机上死活没有效果。这个问题疑惑了很久了,今天终于灵光一闪,解决了这个问题。原因还是出在QSS文件编码格式上。出于跨平台和多语言考虑,我把项目所有源文件都改成了UTF8+BOM格式,这个QSS文件也不例外(我的QSS文件里不含有中文字符)。读取QSS的代码在main函数里这样写:

        

QFile qss(":/qss/myfile");
qss.open(QFile::ReadOnly); // qss 也要讲究是什么格式的文件读取
qApp->setStyleSheet(qss.readAll()); 
qss.close();

  我是在中文环境下开发的,于是它按照ANSI格式去读取QSS文件了,也不知道为什么就没问题。估计是文件头上的三个字节EF BB BF都被当作中文读出来了,然后试图去匹配QSS自带关键字,都对不上,然后就被忽略了,后面继续读取的话,那都是正确的。但是同一个文件同样的代码,到西文环境下,可能成功匹配几个字母,后面的却再也对不上号,于是就全部忽略了。这就是为什么我的程序QSS效果在同事机子上始终没有效果的原因。解决方案是把QSS文件转成为ANSI,或者不带BOM的UTF8格式,重新编译,然后效果就又重新出现啦。哦,原来这样啊,QSS文件就不能和ts语言文件一样做的更内置一点呢?

  另外就是QT对它自己的错误控制的很好,不轻易报错,这里QSS读不出来、对不上号不报错,SIGNAL对SLOT对不上号也不报错,这到底是优点还是缺点呢?我感觉是方便了初级开发者,复杂了对运行时的深度控制判断。

 

以上是关于Qt Creator中使用qss对界面美化没有作用(效果)的问题的主要内容,如果未能解决你的问题,请参考以下文章

QSS文件美化界面无效

QSS-qt样式表

qt 布局

QScrollArea qss样式表,美化滚动条

QScrollArea qss样式表,美化滚动条

Qt ui 界面如何更加好看,漂亮