Qt 中设置窗体(QWidget)透明度的几种方法
创始人
2024-01-25 21:13:20
0

Qt 中设置窗体(QWidget)透明度的几种方法


1. 设置窗体的背景色

在构造函数里添加代码,需要添加头文件qpalette或qgui

QPalette pal = palette(); 
pal.setColor(QPalette::Background, QColor(0x00,0xff,0x00,0x00)); 
setPalette(pal);

通过设置窗体的背景色来实现,将背景色设置为全透。

效果: 窗口整体透明,但窗口控件不透明,QLabel控件只是字显示,控件背景色透明; 窗体客户区完全透明。


2. 使用函数

setWindowFlags(Qt::Dialog | Qt::FramelessWindowHint);//去掉标题栏
setAttribute(Qt::WA_TranslucentBackground, true);//设置窗口背景透明

同样在构造函数中,效果和第一种方法相同。


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

setWindowOpacity(0.7);

这个函数可以分10个等级调整透明度,配合QSlider控件可以做成控制条 效果:窗口及控件都半透明。

自己注释:

直接设置setWindowOpacity函数应该不起作用,需要设置窗体的属性:

this->setAttribute(Qt::WA_WState_WindowOpacitySet);

CSDN QT大纲:Qt开发必备技术栈学习路线和资料

4. 窗口整体不透明,局部透明

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

void TestWindow::paintEvent( QPaintEvent* )
{ QPainter p(this);p.setCompositionMode( QPainter::CompositionMode_Clear );p.fillRect( 10, 10, 300, 300, Qt::SolidPattern ); 
}

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


5. 使用qss样式表设置窗体透明

QWidget* widget = new QWidget();
widget->setObjectName("wid");
widget->setStyleSheet("QWidget#wid{background-color: rgba(255,0,0,0.5);}");
widget->show();

rgba(255,255,255,1)中参数解释:

r【read】 表示:红色,范围:0-255,

g【green】表示:绿色,范围:0-255,

b【blue】 表示:蓝色,范围:0-255,

a【alpha】表示:透明度,范围:0-1,0表示全透明, 1表示不透明;

补充: 如果QWidget 的子类窗口采用setStyleSheet 设置背景色无效,需要加上setAttribute(Qt::WA_StyledBackground);
目的是脱离父窗口的样式。


6. 设置窗体颜色渐变

(1)渐变颜色设置有:qlineargradient(线性渐变颜色设置),qradialgradient(辐射渐变),qconicalgradient(圆锥形渐变)。

渐变方式

解释

QLinearGradient:

显示从起点到终点的渐变。

QRadialGradient:

以圆心为中心显示渐变。

QConicalGradient:

围绕一个中心点显示渐变。

QGradient::PadSpread :

填充区域内最接近的停止颜色。这是默认的。

QGradient::RepeatSpread :

在区域外继续重复填充。

QGradient::ReflectSpread :

在区域外反射填充。

(2)渐变过程:x1->x2 从左向右渐变;y1->y2 从上向下渐变。如果只有x相等,则表示垂直线性渐变,如果只有y相等,则表示平行线性渐变,否则就是斜角线性渐变。

(3)左右渐变

QLabel#label{background-color: qlineargradient(x1:0, y1:0, x2:1, y2:0,stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));}

效果:

(4)上下渐变

QLabel#label{background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));}

效果:

(5)左右上下 渐变

QLabel#label{background-color: qlineargradient(x1:0, y1:0, x2:1, y2:1,stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));}

效果:

 

(6)x1,x2,y1,y2都是设置成0或者1,颜色都一样是红色

QLabel#label{background-color: qlineargradient(x1:1, y1:1, x2:1, y2:1,stop:0 rgba(255,0,0,1),stop:1 rgba(0,255,0,1));}

效果:

(7)增加多个渐变点

QLabel#label{background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:0,stop:0 rgba(255,0,0,1),stop:0.5 rgba(0,255,0,1),stop:1 rgba(0,0,255,1));}

效果:

 

(8)辐射渐变

以圆心为中心显示渐变。(cx, cy)是中点,半径(radius)是以中点为圆心的圆的半径,(fx, fy)是渐变的起点。

QLabel#label{background-color: qradialgradient(spread:pad, cx:0.5, cy:0.5, radius:0.5, fx:0.5, fy:0.5,stop:0 rgba(105, 105, 0, 255),stop:0.19397 rgba(0, 55, 55, 255),stop:0.202312 rgba(80, 80, 0, 255),stop:0.495514 rgba(0, 105, 105, 255),stop:0.504819 rgba(0, 188, 188, 255),stop:0.79 rgba(0, 195, 195, 255),stop:1 rgba(0, 158, 158, 255));
}

效果:

 

(9)圆锥形渐变

在(cx, cy)坐标上以角度(angle)为中心显示渐变。

QLabel#label{background-color: qconicalgradient(cx:0.5, cy:0.5, angle:0,stop:0 rgba(0, 255, 0, 255), stop:0.373979 rgba(0, 255, 0, 255),stop:0.373991 rgba(33, 30, 255, 255), stop:0.624018 rgba(33, 30, 255, 255),stop:0.624043 rgba(255, 0, 0, 255), stop:1 rgba(255, 0, 0, 255));}

效果:


本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QT嵌入式开发,Quick模块等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

相关内容

热门资讯

40个冷门创业项目推荐创业冷门... 40个冷门创业项目推荐现在冷门行业都有什么?能赚钱的小项目有很多,可是选择起来比较烦琐,选项目首先从...
十大冷门创业项目 十大冷门创业... 当下很多看似赚钱的不一定赚到钱,很多看似不乐观的不一定处于寒冬!今天我们就来看看有哪些冷门却很是赚钱...
适合新手创业的项目有哪些? 适... 创业的利润和可观的回报,吸引了很多人走向了创业的道路。对于没有任何创业经验的人来说,就想要知道适合新...
最适合新手创业的20个小项目 ... 最适合新手创业的20个小项目以下是由中国人才网为大家推荐的20个创业新手最适合的创业项目:眼镜店根据...
新手小白也可操作的创业赚钱项目... 第一时间获取热门网赚项目资讯,长按扫码加团队微信领福利项目概述:一直有小韭菜问我,现在什么能做?什么...
年入二十万 大部分人达不到 他... 大家有没有钓过鱼,哪怕是大太阳也抵挡不住钓鱼的心?钓鱼其实是会让人上瘾的,这个隐还不好戒。今天就给大...
创新创业扶持项目 创新创业扶持... 国务院关于大力推进大众创业万众创新若干政策措施的意见国发〔2015〕32号各省、自治区、直辖市人民政...
芜湖市创新创业扶持政策 芜湖市... 八大政策1、众创空间初始奖补。评定为市级众创空间的,给予50万元奖励,评定为市级及以上示范性众创空间...
选择创业项目的理由怎么写 选择... 在市场大环境的影响下,现在有越来越多的大学毕业生踏上了创业的道路。为什么越来越多的大学生走上创业之路...
国家植物园水杉林喷雾暑期增加开... 7月7日,北京青年报记者从国家植物园获悉,为让市民游客感受到更多的夏日清凉,国家植物园樱桃沟水杉林喷...