zoukankan      html  css  js  c++  java
  • Qt中添加背景图片的方法

    Qt中添加背景图片的方法

     
    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函数。


    好了,上面是三种设置背景图片的方法,下面我要说一个设置QPushButton的背景图片的方法,用的是setIcon方法(其实QPushButton设置背景图片也可以用前面三种方法的,不过现在这种Icon方法的看起来也不错)
    #include <QApplication>
    #include <QtGui>

    int main(int argc, char *argv[])
    {
        QApplication app(argc,argv);

        QFrame *frame = new QFrame;
        QPushButton * button0 = new QPushButton(frame);
        QPushButton * button1 = new QPushButton(frame);
        QPushButton * button2 = new QPushButton(frame);
        QPushButton * button3 = new QPushButton(frame);
        QPushButton * button4 = new QPushButton(frame);
        QPushButton * button5 = new QPushButton(frame);

        frame->setObjectName("myframe");
        frame->resize(400,700);
        frame->setStyleSheet("QFrame#myframe{border-image:url(images/frame.png)}" );

        button0->setGeometry(60,150,68,68);
        button1->setGeometry(160,150,68,68);
        button2->setGeometry(260,150,68,68);
        button3->setGeometry(60,280,68,68);
        button4->setGeometry(160,280,68,68);
        button5->setGeometry(260,280,68,68);

        QIcon icon;
        QPixmap pixmap0("images/SMS.png");
        icon.addPixmap(pixmap0);
        button0->setIcon(icon);
        button0->setIconSize(QSize(68,68));
        button0->setFixedSize(pixmap0.size());
        button0->setMask(pixmap0.mask());


        QPixmap pixmap1("images/EMail.png");
        icon.addPixmap(pixmap1);
        button1->setIcon(icon);
        button1->setIconSize(QSize(68,68));
        button1->setFixedSize(pixmap1.size());
        button1->setMask(pixmap1.mask());


        QPixmap pixmap2("images/Contacts.png");
        icon.addPixmap(pixmap2);
        button2->setIcon(icon);
        button2->setIconSize(QSize(68,68));
        button2->setFixedSize(pixmap2.size());
        button2->setMask(pixmap2.mask());

        QPixmap pixmap3("images/Calendar.png");
        icon.addPixmap(pixmap3);
        button3->setIcon(icon);
        button3->setIconSize(QSize(68,68));
        button3->setFixedSize(pixmap3.size());
        button3->setMask(pixmap3.mask());


        QPixmap pixmap4("images/GoogleVoice.png");
        icon.addPixmap(pixmap4);
        button4->setIcon(icon);
        button4->setIconSize(QSize(68,68));
        button4->setFixedSize(pixmap4.size());
        button4->setMask(pixmap4.mask());


        QPixmap pixmap5("images/AndroidMarket.png");
        icon.addPixmap(pixmap5);
        button5->setIcon(icon);
        button5->setIconSize(QSize(68,68));
        button5->setFixedSize(pixmap5.size());
        button5->setMask(pixmap5.mask());


        frame->show();

        return app.exec();
    }
    效果如下:

    注:图标效果不错吧~_~

    好了,今天就写到这里,以后有新的内容再补充。
    补充,这样就可以让图片跟窗口一样大小了。
    int main(int argc, char *argv[])
    {
        QApplication app(argc,argv);
        
        QFrame *frame = new QFrame;
        frame->resize(400,700);

        QImage image1;
        image1.load("images/frame1.jpg");
        QImage image2 = image1.scaled(400,700);

        QPalette   palette;
        palette.setBrush(frame->backgroundRole(),QBrush(image2));
        frame->setPalette(palette);
        frame->setMask(pixmap.mask());  //可以将图片中透明部分显示为透明的
        frame->setAutoFillBackground(true);
        frame->show();

        return app.exec();
    }
  • 相关阅读:
    java里如何使用输入流和输出流实现读取本地文件里内容和写出到本地文件里
    Windows 命令行基础(博主推荐)
    Python2.7编程基础(博主推荐)
    27 个Jupyter Notebook的小提示与技巧
    java里如何实现循环打印出字符或字符数组里的内容
    [转]angularjs之ui-grid 使用详解
    [转]AngularJS 实现 Table的一些操作(示例大于实际)
    [转]js 回车转成TAB(利用tabindex)
    [转] Entity Framework添加记录时获取自增ID值
    [转]使用依赖关系注入在 ASP.NET Core 中编写干净代码
  • 原文地址:https://www.cnblogs.com/ggggyj/p/4040140.html
Copyright © 2011-2022 走看看