Qt中添加背景图片的方法(改)

工作似乎走上正轨了,上周五的工作是做一个界面,用到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大小一致,显示效果不好,具体怎样调整大小,以后再补充,效果如下(设置了透明的,好像很漂亮~透明部分将我的桌面显示出来了~_~):
QT笔记(3)-Qt中添加背景图片的方法

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();
}

效果如下:
QT笔记(3)-Qt中添加背景图片的方法
注意:很漂亮的效果吧~~注意代码中红线的部分噢,设置ObjectName 后,才能保证set
StyleSheet只作用在我们的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();
}

效果如下:
QT笔记(3)-Qt中添加背景图片的方法
注:跟前面一样的效果吧,与前面的差别就是这个背景图片不随着窗口的大小而变化,因为它的固定大小被设置成 (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();
}

效果如下:
QT笔记(3)-Qt中添加背景图片的方法
注:图标效果不错吧~_~

好了,今天就写到这里,以后有新的内容再补充。
补充,这样就可以让图片跟窗口一样大小了。

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();
}
 
 
 
我的补充:
              给widget加上背景图   -----关键是使用widget的palette的brush
              QWidget *widget = new QWidget;
              widget->setAutoFillBackground(true);
              QPalette palette = widget->palette();
             palette.setBrush(QPalette::window,QBrush(QPixmap("1.png').scaled(widget->size(),Qt::IgnoreAdpectRatio,Qt::SmoothFransFormation)));//使用平滑缩放
             widget->setpalette(palette);
### 回答1: 在Qt,可以使用QPixmap类来设置button背景图片。首先,需要准备好要设置的背景图片文件。然后,通过QPixmap类将图片文件加载进来。接下来,将加载好的背景图片设置给QPushButton的样式表属性。这将使按钮的背景图片被设置为所加载的图片。 以下是实现该功能的示例代码: ```c++ // 创建一个QPushButton对象 QPushButton* button = new QPushButton(this); // 加载背景图片 QPixmap pixmap(":/images/background.jpg"); // 设置按钮的样式表属性,将背景图片设置为按钮的背景 button->setStyleSheet(QString("border-image: url(%1)").arg(pixmap.scaled(button->size()).toImage())); // 将按钮添加到父窗口 // ... ``` 在代码,`":/images/background.jpg"` 是背景图片文件的路径,可以根据实际的文件路径进行修。`border-image` 是样式表属性,用于设置按钮的背景图片。 注意,使用这种方法设置按钮背景图片时,按钮的大小应该已经确定,否则可能导致图片拉伸变形。 ### 回答2: 在Qt,可以使用QSS(Qt Style Sheets)样式表来为Button动态添加背景图片。 首先,确保你已经将背景图片添加Qt项目,可以是本地的文件路径或者是资源文件。然后,在代码创建一个QPushButton实例,例如: ```cpp QPushButton *button = new QPushButton("按钮"); ``` 接下来,为按钮设置样式表。可以通过调用QPushButton的setStyleSheet函数来实现。样式表可以使用类似CSS的语法。例如,如果你要添加背景图片,可以使用background-image属性来指定背景图片的路径。代码如下: ```cpp button->setStyleSheet("QPushButton { background-image: url(:/images/background.jpg); }"); ``` 其url(:/images/background.jpg)是图片的路径,可以根据实际情况进行修。 最后,将按钮添加到父容器,例如一个QWidget或QMainWindow。例如: ```cpp QWidget *widget = new QWidget(); QVBoxLayout *layout = new QVBoxLayout(); layout->addWidget(button); widget->setLayout(layout); widget->show(); ``` 这样,就能够看到按钮上成功添加背景图片。当然,你也可以根据需要进一步调整样式表,如设置背景图片的位置、大小等。 需要注意的是,如果图片路径是相对路径,需要确保图片文件存在于正确的路径下;如果图片路径是资源路径,则需要在.pro文件添加相应的资源文件声明。 希望这个回答能够帮助到您。 ### 回答3: 在Qt,可以通过QPixmap和QPalette两个类来实现动态添加背景图片到QPushButton上。 首先,我们首先创建一个QPixmap对象,加载要作为背景的图片,例如: ``` QPixmap pixmap("background.jpg"); ``` 然后,我们创建一个QPushButton对象,并设置其大小和位置: ``` QPushButton *button = new QPushButton(this); button->setGeometry(100, 100, 200, 50); ``` 接下来,我们创建一个QPalette对象,并将加载的图片作为其背景设置: ``` QPalette palette; palette.setBrush(QPalette::Button, pixmap); ``` 最后,我们将这个QPalette对象应用到QPushButton上: ``` button->setFlat(true); // 设置按钮为扁平样式,以显示背景图片 button->setAutoFillBackground(true); // 设置按钮自动填充背景 button->setPalette(palette); // 将QPalette应用到按钮上 ``` 通过上述方法,我们便实现了动态添加背景图片到QPushButton上。当然,我们也可以将上述代码封装到一个函数,方便将来重复使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值