青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

千張筆記

Email:rain_qian830@163.com
posts - 28, comments - 42, trackbacks - 0, articles - 0
  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

QT筆記(3)-Qt中添加背景圖片的方法

Posted on 2010-07-25 14:07 千張 閱讀(30910) 評(píng)論(16)  編輯 收藏 引用 所屬分類(lèi): QT學(xué)習(xí)
工作似乎走上正軌了,上周五的工作是做一個(gè)界面,用到QFrame和QPushButton,QFrame做主面板,QPushButton為其子控件,需要在主面板上貼背景圖片,還需要在QPushButton上貼上相應(yīng)的圖標(biāo),弄了一天,再加上今天一小會(huì),終于有一點(diǎn)點(diǎn)結(jié)果了。

通過(guò)從Google上搜索各種方法(現(xiàn)在才知道Google比Baidu強(qiáng)大很多啊),最后都試了一些,主要有下面幾種方法:
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文件夾中。
存在問(wèn)題:圖片可以顯示出來(lái),但是圖片大小不能和frame大小一致,顯示效果不好,具體怎樣調(diào)整大小,以后再補(bǔ)充,效果如下(設(shè)置了透明的,好像很漂亮~透明部分將我的桌面顯示出來(lái)了~_~):


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();
}
效果如下:

注意:很漂亮的效果吧~~注意代碼中紅線(xiàn)的部分噢,設(shè)置ObjectName后,才能保證setStyleSheet只作用在我們的frame上,不影響其子控件的背景設(shè)置。之所以用border-image而不用background-image,還是上面的問(wèn)題,用background-image不能保證圖片大小和控件大小一致,圖片不能完全顯示,這個(gè)以后再補(bǔ)充了,現(xiàn)在還沒(méi)有找到方法。

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();
}
效果如下:

注:跟前面一樣的效果吧,與前面的差別就是這個(gè)背景圖片不隨著窗口的大小而變化,因?yàn)樗墓潭ù笮”辉O(shè)置成(400,700)了。重寫(xiě)QWidget的paintEvent事件,當(dāng)控件發(fā)生重繪事件,比如show()時(shí),系統(tǒng)就會(huì)自動(dòng)調(diào)用paintEvent函數(shù)。


好了,上面是三種設(shè)置背景圖片的方法,下面我要說(shuō)一個(gè)設(shè)置QPushButton的背景圖片的方法,用的是setIcon方法(其實(shí)QPushButton設(shè)置背景圖片也可以用前面三種方法的,不過(guò)現(xiàn)在這種Icon方法的看起來(lái)也不錯(cuò))
#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();
}
效果如下:

注:圖標(biāo)效果不錯(cuò)吧~_~

好了,今天就寫(xiě)到這里,以后有新的內(nèi)容再補(bǔ)充。
補(bǔ)充,這樣就可以讓圖片跟窗口一樣大小了。
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();
}


Feedback

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-07-25 21:07 by guofu
不錯(cuò) 不錯(cuò)

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-07-26 11:09 by 孔雀
哥們你這個(gè)模擬器是symbian的還是android的?
看到你的貼圖我都困惑了

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-07-26 13:06 by qianqian
@孔雀
I am a girl.
No symbian or android.
Just Linux and QT(Qt creator).
The phone frame is just a picture, not a simulator.

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-07-31 14:10 by QT fans
@qianqian
very good !! I like it!

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-07-31 14:12 by QT fans
可以留個(gè) QQ一起交流嗎?我q的是522190051 。

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-08-05 16:32 by qianqian
4、設(shè)置字體大小、粗體、斜體、顏色、背景的時(shí)候要注意:setFont可以設(shè)置,但是前提是沒(méi)有用setStyleSheet函數(shù)  否則 setFont不起作用,同時(shí)還可以用html腳步<font></font>這樣設(shè)置?! tyleSheet方法:textEdit->setStyleSheet("font-size:18px;""background-color:black;"   "border-style:solid;""font-style:italic;""font-weight:bold;""color:white");   setFont方法: QFont font;  font.setFamily("Bitstream Charter");  font.setPixelSize(16);  font.setBold(true);   font.setItalic(true);  textEdit->setFont(font);  html方法:textEdit->setText("<font color=red>abc</font>")  

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-09-28 10:44 by pacco
果斷被忽悠了,竟然是個(gè)圖,不是個(gè)模擬器?

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-09-28 11:24 by qianqian
@pacco
請(qǐng)你看清楚行么,我從來(lái)沒(méi)說(shuō)這是模擬器,我說(shuō)了是qt添加背景圖片的代碼,而且我代碼都貼出來(lái)了,你看得懂就該知道是怎么回事,看不懂不要在這亂說(shuō)我忽悠誰(shuí),大哥,拜托你看清楚了再說(shuō)話(huà),我學(xué)習(xí)記筆記不算忽悠誰(shuí)吧。

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-10-21 08:13 by 王文靖
很喜歡你的博客,簡(jiǎn)明得體,美觀大方。以后小弟會(huì)多多參閱學(xué)習(xí)的。

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-11-01 17:39 by Hanmei
是在QVFB下還是直接環(huán)境下

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2010-11-08 15:18 by dou8615
我換了張圖片試了一下程序,出現(xiàn)了QFrame和frame沒(méi)有聲明的問(wèn)題,不知道怎么回事呢

# re: QT筆記(3)-Qt中添加背景圖片的方法[未登錄](méi)  回復(fù)  更多評(píng)論   

2011-01-03 19:06 by yy
QPushButton 這里為什么不用layout呢?

# re: QT筆記(3)-Qt中添加背景圖片的方法[未登錄](méi)  回復(fù)  更多評(píng)論   

2011-01-03 19:07 by yy
QPushButton為什么不用layout呢?

# re: QT筆記(3)-Qt中添加背景圖片的方法  回復(fù)  更多評(píng)論   

2011-01-07 09:53 by 曾華山
QFrame是不是也可以用layout呢?沒(méi)試過(guò),有空在琢磨琢磨。。

# re: QT筆記(3)-Qt中添加背景圖片的方法[未登錄](méi)  回復(fù)  更多評(píng)論   

2012-04-06 09:24 by
你好,我用3個(gè)button添加背景圖,然而第三個(gè)button的圖標(biāo)老是顯示不對(duì),是第二個(gè)的圖標(biāo),請(qǐng)問(wèn)怎么改呀?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人小视频| 欧美日韩国产不卡| 亚洲高清一区二| 午夜精品福利在线观看| 亚洲午夜在线| 亚洲欧美一区二区三区在线| 欧美专区福利在线| 欧美一级日韩一级| 麻豆精品视频在线观看视频| 欧美激情中文不卡| 99精品国产高清一区二区| 日韩视频―中文字幕| 午夜电影亚洲| 久久午夜影视| 欧美日韩一区二区高清| 国产欧美日韩精品丝袜高跟鞋| 国产农村妇女毛片精品久久麻豆| 激情视频一区二区| 99视频在线精品国自产拍免费观看| 亚洲欧美日韩在线一区| 欧美成人有码| 亚洲欧美视频| 欧美黑人一区二区三区| 国产欧美视频一区二区| 日韩视频免费在线观看| 正在播放日韩| 亚洲人成网站在线播| 激情文学综合丁香| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲午夜免费福利视频| 免费在线国产精品| 亚洲一区二区视频| 欧美成年人视频网站| 国产精品日韩一区| 日韩天堂在线视频| 欧美高清在线播放| 久久精品一区二区三区不卡牛牛| 欧美日韩午夜在线| 亚洲人成网站在线观看播放| 久久精品视频va| 日韩亚洲欧美成人一区| 农村妇女精品| 亚洲第一页在线| 葵司免费一区二区三区四区五区| 亚洲主播在线| 欧美日本在线视频| 亚洲激情欧美激情| 老司机亚洲精品| 欧美在线观看一二区| 国产精品日韩久久久| 亚洲深夜激情| 亚洲美女区一区| 欧美成人精品不卡视频在线观看 | 欧美成人日韩| 一区二区三区在线观看视频| 久久久久久伊人| 午夜精品美女自拍福到在线| 欧美视频手机在线| 亚洲一区二区三区四区在线观看| 亚洲人成啪啪网站| 欧美日韩国产精品一卡| 99国产精品久久久| 日韩亚洲欧美高清| 国产精品久久999| 亚洲欧美日韩精品在线| 亚洲一区二三| 今天的高清视频免费播放成人| 久久精品国产免费观看| 久久99在线观看| 亚洲国产日韩综合一区| 亚洲国产欧美在线人成| 欧美四级伦理在线| 小辣椒精品导航| 久久精品女人| 一本色道久久综合| 午夜精品视频网站| 亚洲国产专区校园欧美| 99re66热这里只有精品3直播| 国产精品久久久久久久app| 久久精品国产2020观看福利| 久久精品国产久精国产一老狼| 在线成人激情黄色| 亚洲国产欧美国产综合一区| 欧美特黄a级高清免费大片a级| 亚洲精品国产日韩| 亚洲一区二区免费看| 欧美在线视频播放| 在线观看的日韩av| 亚洲欧洲日韩女同| 国产精品乱子乱xxxx| 另类成人小视频在线| 欧美国产日韩xxxxx| 午夜精品久久久久久久久久久久 | 欧美午夜一区二区| 久久激情五月丁香伊人| 欧美电影专区| 久久久久**毛片大全| 欧美激情性爽国产精品17p| 欧美一级理论性理论a| 欧美成人首页| 久久国产精品高清| 欧美美女bb生活片| 老司机精品视频一区二区三区| 欧美日本在线| 欧美黑人多人双交| 国产在线精品二区| 亚洲视频一二| 一本色道久久综合亚洲精品婷婷 | 欧美日韩一区自拍| 美女国内精品自产拍在线播放| 欧美日韩国产首页| 欧美激情精品久久久久久黑人 | 欧美日韩小视频| 欧美~级网站不卡| 国产精品理论片在线观看| 91久久极品少妇xxxxⅹ软件| 影音先锋在线一区| 亚洲已满18点击进入久久 | 久久久久久久综合色一本| 欧美日韩国产综合网| 免费在线亚洲| 精品1区2区| 久久久久久有精品国产| 久久爱另类一区二区小说| 欧美色图麻豆| 日韩视频在线播放| 日韩一级欧洲| 欧美人与性禽动交情品| 亚洲国产精品久久久久久女王| 国产拍揄自揄精品视频麻豆| 亚洲欧美成人一区二区三区| 亚洲欧美另类在线观看| 欧美午夜免费| 一片黄亚洲嫩模| 亚洲一二三区精品| 国产精品久久久久久久久久尿| 一区二区三区日韩精品视频| 亚洲综合999| 国产偷国产偷亚洲高清97cao | 欧美在现视频| 一本色道久久综合精品竹菊| 亚洲精品一级| 欧美美女bbbb| 中文久久精品| 欧美亚洲一区二区三区| 国产精品视频yy9099| 午夜精品久久久久久| 久久一区二区三区四区| 亚洲高清一区二| 免费观看一区| 日韩午夜激情av| 欧美一级久久| 激情六月婷婷久久| 噜噜噜在线观看免费视频日韩| 欧美成人综合网站| 99精品视频免费在线观看| 欧美色播在线播放| 午夜精品三级视频福利| 欧美高清一区二区| 亚洲色图综合久久| 国内精品国语自产拍在线观看| 久久久久国色av免费看影院| 亚洲激情黄色| 久久成人18免费网站| 极品少妇一区二区三区精品视频| 浪潮色综合久久天堂| 99re热精品| 毛片一区二区| 亚洲一区二区三区免费观看 | 国产综合婷婷| 欧美精品三区| 欧美一区91| 亚洲日本免费| 欧美在线在线| 99精品国产一区二区青青牛奶| 国产精品影音先锋| 麻豆精品在线视频| 亚洲免费一区二区| 亚洲韩日在线| 久久亚洲风情| 亚洲一区二区精品在线观看| 黄色亚洲网站| 国产精品qvod| 欧美成人午夜激情在线| 欧美一区国产二区| 一区二区日韩免费看| 欧美高清视频www夜色资源网| 欧美亚洲综合在线| 99精品热6080yy久久| 亚洲高清视频在线观看| 国产午夜亚洲精品羞羞网站| 欧美日韩亚洲一区在线观看| 久久综合狠狠| 久久精品在线观看| 午夜精品久久久久久久99水蜜桃 | 欧美成年人网站| 久久精品国产亚洲一区二区| 亚洲欧美成人| 亚洲一区影音先锋| 一区二区三区欧美激情|