当前位置:网站首页>Qt实战案例(54)——利用QPixmap设计图片透明度
Qt实战案例(54)——利用QPixmap设计图片透明度
2022-07-31 15:28:00 【wendy_ya】
一、项目介绍
本文介绍利用QPixmap设计图片透明度,可以看到拖动下方进度条,用于控制上方图片的透明度。
二、项目基本配置
新建一个Qt案例,项目名称为“TransparencyTest”,基类选择“QWidget”,点击选中创建UI界面复选框,完成项目创建。
三、UI界面设置
UI界面如下:
| 序号 | 名称 | 类型 | 属性 |
|---|---|---|---|
| ① | label_photo | QLabel | / |
| ② | slider | QSlider | minimum:0;maximum:255; |
四、主程序实现
4.1 widget.h头文件
头文件中需要声明滑动条移动槽函数:
右键——>滑动条——>sliderMoved:
我这里是:
private slots:
void on_Slider_sliderMoved(int position);
4.2 widget.cpp源文件
源文件中首先在构造函数中设置背景label的图片,然后设置label位置,设置滑动条初始位置位于最右侧:
//设置窗口大小
setFixedSize(800,600);
//设置背景label的图片
QPixmap pix(":/test.jpg");
ui->label_photo->setPixmap(pix);
//设置lable位置
ui->label_photo->setScaledContents(true);
ui->label_photo->setGeometry(10,10,200,150);
ui->label_photo->raise();
ui->label_photo->show();
//设置初始滑动条位置在最右端
ui->Slider->setValue(255);
定义滑动条滑动槽函数:
void Widget::on_Slider_sliderMoved(int position)
{
//设置新的图片的透明度
QPixmap pix1(":/test.jpg");
QPixmap temp(pix1.size());
temp.fill(Qt::transparent);
QPainter p1(&temp);
p1.setCompositionMode(QPainter::CompositionMode_Source);
p1.drawPixmap(0, 0, pix1);
p1.setCompositionMode(QPainter::CompositionMode_DestinationIn);
//根据QColor中第四个参数设置透明度,此处position的取值范围是0~255
p1.fillRect(temp.rect(), QColor(0, 0, 0, position));
p1.end();
pix1 = temp;
ui->label_photo->setPixmap(pix1);
}
五、效果演示
完整效果如下:
如果没有看懂的话,完整代码可以参考:https://download.csdn.net/download/didi_ya/86268287
ok,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~
边栏推荐
猜你喜欢
随机推荐
TRACE32 - Common Operations
【CUDA学习笔记】初识CUDA
leetcode303 Weekly Match Replay
NC | 中国农大草业学院杨高文组揭示发现多因子干扰会降低土壤微生物多样性的积极效应...
为什么毕业季不要表白?
全新宝马3系上市,安全、舒适一个不落
修改SQL语言实现Mysql 多表关联查询优化
实现防抖与节流函数
Ubantu专题4:xshell、xftp连接接虚拟机以及设置xshell复制粘贴快捷键
7、常见面试口语提问问题汇总
名创优品斥资6.95亿购买创始人叶国富所持办公楼股权
删除 状态良好(恢复分区)的磁盘
763.划分字母区间——之打开新世界
Grafana安装后web打开报错
The use of button controls
数据表插入数据insert into
hough变换检测直线原理(opencv霍夫直线检测)
TRACE32 - SNOOPer-based variable logging
华医网冲刺港股:5个月亏2976万 红杉与姚文彬是股东
力扣:56. 合并区间








