实现 Qt 统一风格与换肤实例是本文介绍的内容,不多说,进图内容。QT既然作为一个成功的跨平台GUI库,当然会想到界面风格统一,本地化与换肤都做了考虑,网上有多种换肤的方法,自己也习惯于用简单的方法,总结了一下自己心得,与大家分享
一、改变与装饰界面:
通常使用设置Widget的背景,边界,子对象的图片,颜色来进行装饰QWidget,
1、改变被景图片:
较常用办法是
- QWidget.setAutoFillBackground(true);
- QPalette palette= QWidget.Palette();
- QPixmap pic("xxx.png"); palette.setBrush(QPalette::Window, new Brush(pic));
- palette.setBrush(QPalette::Base, new Brush(pic));
- palette.setBrush(QPalette::Button, new Brush(pic));
- QWidget.setPalette(palette);
但不同的控件还是要区别对待,比如对待QPushButton简单用此方法就不行,还要设置为QPushButton.setFlat(true),也可以用QPushButton的setImage方法,还有对待 QTabWidget不仅要改变背景图片,还要改变Tab的图片,Tab还要区别改变被选中的Tab与没被选中的Tab图片,QTreeWidget,QTreeView中还要针对树装结节的图片,还有标题栏等,都要用不同的方法来设置,QT有一种更方便的解决方案,就是设置StyleSheet被称为QSS方法,类似网页设计中的CSS, 语法也几乎相同Idential,比如要设置QPushButton的背景图,鼠标over,及按下的图片切换,可以用如下方法:
- const char* normal = “bg.png";
- const char* pressed = "pressed.png;
- const char* over = "over.png";
- char str[512] = {0};
- sprintf(str,"QPushButton{background-image:url(%s);border-style.:flat;} QPushButton:hover:pressed{background-image:url(%s);border-
- style.:flat;}QPushButton:hover:!pressed{background-image:url(%s);border-style.:flat;}", normal, pressed, over);
- w->setStyleSheet(QString(str));
2、改变颜色:
常用:QWidget->setBackgroundColor();来改变,当然也可以用Style. Sheet方法。
二、全局统一风格:
上面提到了QSS,QT还可以通过设置QApplication的StyleSheet来改变程序中所有控件的风格。比如:
QApplication.setStyleSheet(QString("QPushButton{background-image:url(bg.png); border-style.:flat;}")); 这样的话,所有QPushButton的实例对象的背景图片缺省情况下都是bg.png,当然,如果你重新设置某个QPushButton实例对象的 StyleSheet,那个实例对象的风格以当前设置的为准。
这样对界面的风格统一提供了一个简单有效的解决方案。
三、简单介绍QSS:
google_protectAndRun("render_ads.js::google_render_ad", google_handleError, google_render_ad);
小结:实现 Qt 统一风格与换肤的内容实例的内容介绍完了,希望本文对你有所帮助!