Qt中添加背景图片的方法

来源:互联网 发布:淘宝双11活动规则 编辑:程序博客网 时间:2024/06/09 05:29
工作似乎走上正轨了,上周五的工作是做一个界面,用到QFrame和QPushButton,QFrame做主面板,QPushButton为其子控件,需要在主面板上贴背景图片,还需要在QPushButton上贴上相应的图标,弄了一天,再加上今天一小会,终于有一点点结果了

通过从Google上搜索各种方法(现在才知道Google比Baidu强大很多啊),最后都试了一些,主要有下面几种方法:

1. QPalette的方法

#include <QApplication>#include <QtGui>int main(int argc, char *argv[]){    QApplication app(argc,argv);        QFrame *frame = new QFrame;    frame->resize(400,700);    QPixmap pixmap("images/frame.png");    QPalette   palette;    palette.setBrush(frame->backgroundRole(),QBrush(pixmap));    frame->setPalette(palette);    frame->setMask(pixmap.mask());  //可以将图片中透明部分显示为透明的    frame->setAutoFillBackground(true);    frame->show();    return app.exec();}

注意图片路径怎么表示,我的图片放在该工程下的images文件夹中。
存在问题:图片可以显示出来,但是图片大小不能和frame大小一致,显示效果不好,具体怎样调整大小,以后再补充,效果如下(设置了透明的,好像很漂亮~透明部分将我的桌面显示出来了~_~):



2.setStyleSheet方法(非常好用的方法)

#include <QApplication>#include <QtGui>int main(int argc, char *argv[]){    QApplication app(argc,argv);    QFrame *frame = new QFrame;    frame->setObjectName("myframe");    frame->resize(400,700);    frame->setStyleSheet("QFrame#myframe{border-image:url(images/frame.png)}" );    frame->show();    return app.exec();}

效果如下:


注意:很漂亮的效果吧~~注意代码中红线的部分噢,设置ObjectName后,才能保证setStyleSheet只作用在我们的frame上,不影响其子控件的背景设置。之所以用border-image而不用background-image,还是上面的问题,用background-image不能保证图片大小和控件大小一致,图片不能完全显示,这个以后再补充了,现在还没有找到方法。

3.paintEvent事件方法

//myframe.h文件#ifndef MYFRAME_H#define MYFRAME_H#include <QWidget>#include <QtGui>class MyFrame : public QWidget{public:    MyFrame();    void paintEvent(QPaintEvent *event);};#endif // MYFRAME_H//myframe.cpp文件#include "myframe.h"MyFrame::MyFrame(){}void MyFrame::paintEvent(QPaintEvent *event){    QPainter painter(this);    painter.drawPixmap(0,0,400,700,QPixmap("images/frame.png"));}//main.cpp文件#include <QApplication>#include <QtGui>#include "myframe.h"int main(int argc, char *argv[]){    QApplication app(argc,argv);        MyFrame *frame = new MyFrame;    frame->resize(400,700);    frame->show();    return app.exec();}

效果如下:


注:跟前面一样的效果吧,与前面的差别就是这个背景图片不随着窗口的大小而变化,因为它的固定大小被设置成(400,700)了。重写QWidget的paintEvent事件,当控件发生重绘事件,比如show()时,系统就会自动调用paintEvent函数。