QT知识集锦

 

qt中关于QWidget的背景颜色和背景图片的设置

首先设置autoFillBackground属性为真

然后定义一个QPalette对象

设置QPalette对象的背景属性(颜色或图片)

最后设置QWidget对象的Palette

实例:

QWidget *widget = new QWidget;

widget->setAutoFillBackground(true);

QPalette palette;

palette.setColor(QPalette::Background, QColor(192,253,123));

//palette.setBrush(QPalette::Background, QBrush(QPixmap(":/background.png")));

widget>setPalette(palette);

qt程序界面怎样把标题栏去掉?

window.setWindowFlags( Qt::FramelessWindowHint);即可

setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint);可前端显示

设置QWidget不可最大化

this->setFixedSize(480, 800);

设置窗体透明

this.setWindowOpacity(0.5);

隐藏qt程序的任务栏条

mainwindow.setWindowFlags( Qt::Tool | Qt::StaysOnTopHint ); //


保持在最前面可选

透明窗体实现

. 背景刷成黑色,前景色设为白色。 方法一、paltette方式,经测试,该方法不会影响到其他控件,推荐使用
QPalette bgpal = palette();

bgpal.setColor (QPalette::Background, QColor (0, 0 , 0, 255));

//bgpal.setColor (QPalette::Background, Qt::transparent);

bgpal.setColor (QPalette::Foreground, QColor (255,255,255,255)); setPalette (bgpal);

方法二、stylesheet方式 影响子控件的方法是:

setStyleSheet ("background-color: rgb(0,0,0);color: rgb(255,255,255);");

不影响子控件的方法是:

setStyleSheet ("venus--TitleBar {background-color: rgb(0,0,0);color: rgb(255,255,255);}");

. 圆角控件 用stylesheet方式

setStyleSheet ("border:2px groove gray;border-radius:10px;padding:2px 4px;");

. 圆角窗口RoundRectWin::RoundRectWin() { QPalette p = palette(); QPixmap img("roundrect.png");

QBitmap mask("roundrect_mask.png");

p.setBrush(QPalette::Window, QBrush(img));

setPalette(p);

setMask(mask);

resize(img.size());

//setWindowFlags(Qt::FramelessWindowHint);//这句会去掉标题栏 } 注意:mask的图多余部分设为白色

. 半透明窗口

1.窗口整体透明,但是窗体上的控件不透明。 通过设置窗体的背景色来实现,将背景色设置为全透。 QPalette pal = palette();

pal.setColor(QPalette::Background, QColor(0x00,0xff,0x00,0x00)); setPalette(pal); 试验效果:

窗体标题栏不透明;

窗体客户区上的控件不透明,QLabel控件只是字显示,控件背景色透明; 窗体客户区完全透明。

另外从网上看到的方法:setAttribute(Qt::WA_TranslucentBackground, true); 试验的结果是类似于上面的方法,但有时候窗体会被一些杂色斑点填充,未找到原因。

2.窗口及其上面的控件都半透明:

setWindowOpacity(0.7)

试验效果:窗口及控件都半透明。注意不能够setWindowFlags(Qt::FramelessWindowHint);要不就不起作用

3.窗口整体不透明,局部透明:

Paint事件中使用Clear模式绘图。

void TestWindow::paintEvent( QPaintEvent* )

{ QPainter p(this);

p.setCompositionMode( QPainter::CompositionMode_Clear ); p.fillRect( 10, 10, 300, 300, Qt::SolidPattern ); }

试验效果:绘制区域全透明。如果绘制区域有控件不会影响控件。

以上实验均是基于DirectfbQte测试。在Linux下及Windows下效果会略有不同。 比如在Windows下第3个实验,绘制区域就是一个黑窟窿,如果Window本身半透,则是Window下面的内容加上半透效果,不是全透明效果。

. 控制QPixmapalpha

QPixmap temp(pixmapTop.size()); temp.fill(Qt::transparent);

QPainter p(&temp);

p.setCompositionMode(QPainter::CompositionMode_Source);

p.drawPixmap(0, 0, pixmapTop);

p.setCompositionMode(QPainter::CompositionMode_DestinationIn);

p.fillRect(temp.rect(), QColor(0, 0, 0, alpha)); //--lable显示前景图片ui->label->setScaledContents(true);

ui->label->setPixmap(temp);

. layout 的边界 layout->setMargin (0);

鼠标移入事件

virtual void enterEvent ( QEvent * event )

 

如何从QML中退出程序

main.cpp

#include <QApplication>
#include <QDeclarativeView>
#include <QDeclarativeEngine>

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

    QDeclarativeView view;
    view.setSource(QUrl("./ui.qml"));
    view.setResizeMode(QDeclarativeView::SizeRootObjectToView);

    QObject::connect((QObject*)view.engine(), SIGNAL(quit()), &app, SLOT(quit()));

#if defined(Q_WS_S60) || defined(Q_WS_MAEMO)
    view.showMaximized();
#else
    view.setGeometry(100,100, 800, 480);
    view.show();
#endif

    return app.exec();
}

ui.qml

import Qt 4.7

Rectangle {
    anchors.fill: parent; color: "black"

    Rectangle {
        anchors.centerIn: parent
        width: 100; height: 40; radius: 5; color: "lightgray"

        Text { anchors.centerIn: parent; text: "Quit"; color: "black" }

        MouseArea {
            anchors.fill: parent
            onClicked: Qt.quit()
        }
    }
}

调用Qt.quit()后会导致发送QDeclarativeEngine::quit()信号,而在main函数中我们已经将QDeclarativeEngine::quit()信号信号与QApplication::quit()槽关联起来,这样便可以实现从QML中退出程序了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值