qdialog 圆角_Qt 的一些心得(背景设置,圆角,半透明)

本文介绍了如何在Qt中设置QDialog的背景颜色、实现圆角效果、以及创建半透明窗口。通过QPalette和样式表(stylesheet)设置背景和前景色,使用样式表实现圆角效果,利用QPixmap和QBitmap制作圆角窗口,并通过调整窗口属性实现不同类型的透明效果,包括窗口整体透明、控件透明和局部透明。同时,文章还涉及了QPixmap的alpha通道控制以及Qt窗口嵌入桌面并实现半透明。
摘要由CSDN通过智能技术生成

一. 背景刷成黑色,前景色设为白色。 方法一、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: #000000;color: #ffffff;");

不影响子控件的方法是:

setStyleSheet ("venus--TitleBar {background-color: #000000;color: #ffffff;}");

二. 圆角控件 用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 ); }

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

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

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
设置QDialog背景透明可以通过以下几个步骤实现。首先,将QDialog的样式设置透明,可以使用CSS来设置。然后,对QDialog内部的控件进行圆角设置。 步骤如下: 1. 在构造函数或初始化函数中,使用`setStyleSheet`方法设置QDialog的样式为透明。可以使用CSS的`background-color`属性将背景设置透明。 2. 针对QDialog内部的控件,可以使用`QSS`(Qt样式表)来设置圆角效果。使用`border-radius`属性来设置圆角的半径。 示例代码如下: ```python from PyQt5.QtWidgets import QDialog from PyQt5.QtCore import Qt class MyDialog(QDialog): def __init__(self): super().__init__() # 设置QDialog的样式为透明 self.setStyleSheet("background-color: transparent;") # 对QDialog内部的控件设置圆角 self.setStyleSheet(''' QPushButton { background-color: red; border-radius: 10px; } ''') ``` 这样就可以实现QDialog背景透明和控件的圆角效果了。请根据需要进行相应的设置。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [QT QDialog 圆角实现](https://download.csdn.net/download/xiezhongyuan07/10322255)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Dialog 设置透明背景去掉蒙层)状态栏颜色不改变](https://blog.csdn.net/weixin_44158429/article/details/125779566)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [不错的QDialog示例](https://download.csdn.net/download/guoyflotus/12303359)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值