QT 在label上透明绘图

先看效果,点击《添加图片》按钮,显示图片(在红色背景label控件上再添加一层label显示图像,这个label显示的图像是透明的),调节doublespinbox,透明度可以调节。

一、新建TransparentDemo工程

二、在界面上添加label,修改样式表,将底色置为红色,作为北京

三、新建一个TransparentLabel类,继承自QLabel

此时,工程包括文件

五、在transparentlabel.h中添加

头文件

cpp 复制代码
#include <QLabel>
#include <QPainter>

添加构造函数

cpp 复制代码
TransparentLabel(QWidget *parent=nullptr);

添加重绘函数paintEvent

cpp 复制代码
void paintEvent(QPaintEvent *) override;

如下图

cpp 复制代码
#ifndef TRANSPARENTLABEL_H
#define TRANSPARENTLABEL_H

#include <QLabel>
#include <QPainter>
class TransparentLabel : public QLabel
{
public:
    TransparentLabel();
    TransparentLabel(QWidget *parent=nullptr);
protected:
    void paintEvent(QPaintEvent *) override;
};

#endif // TRANSPARENTLABEL_H

六、在transparentlabel.cpp中实现构造函数和重绘函数,如下

cpp 复制代码
#include "transparentlabel.h"

TransparentLabel::TransparentLabel()
{

}
TransparentLabel::TransparentLabel(QWidget* parent):QLabel(parent){

}

void TransparentLabel::paintEvent(QPaintEvent *){
    //读取图片路径
    QString imagePath= "D:\\picture\\ming3.png";
    //读取图片
    QPixmap pixmap(imagePath);
    //获取当前label的大小
    QRect rect=this->geometry();
    //将图像大小缩放适合label
    QPixmap scaledPixmap = pixmap.scaled(QSize(rect.width(),rect.height()));
    //在label上绘图
    QPainter painter(this);
    //设置透明度
    painter.setOpacity(0.4);
    //绘图
    painter.drawPixmap(0, 0,scaledPixmap);
    //将此label放在最上层
    this->raise();
}

七、在ui文件中添加 "添加图片" 按钮

八、在mainwindow.h中添加头文件和transparentlabel成员、添加图片按钮槽函数

cpp 复制代码
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <transparentlabel.h>
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:
    void on_pushButton_clicked();

private:
    Ui::MainWindow *ui;
    TransparentLabel *transparentLabel;
};
#endif // MAINWINDOW_H

九、在mainwindow.cpp中实现按钮槽函数,并且在构造函数中初始化transparentLabel变量,隐藏

cpp 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    transparentLabel = new TransparentLabel(this);
    transparentLabel->hide();
}

MainWindow::~MainWindow()
{
    delete ui;
}


void MainWindow::on_pushButton_clicked()
{
    QRect label_geometry=ui->label->geometry();//获取label大小
    transparentLabel->setGeometry(label_geometry);//设置透明label的位置
    transparentLabel->show();//显示
}

十、运行效果,点击之后在红色背景label上显示透明的图像

20230801_155459

PS:添加doublespinbox调节透明度很简单,参见下一篇
QT在label上透明绘图(二)

相关推荐
晨旭缘几秒前
后端日常启动及常用命令(Java)
java·开发语言
星辰_mya8 分钟前
RockerMQ之commitlog与consumequeue
java·开发语言
꧁Q༒ོγ꧂9 分钟前
C++ 入门完全指南(六)--指针与动态内存
开发语言·c++
IT=>小脑虎12 分钟前
2026版 Go语言零基础衔接进阶知识点【详解版】
开发语言·后端·golang
ChangYan.13 分钟前
ffi-napi运行失败,报错:No native build was found,解决办法
开发语言
专注VB编程开发20年13 分钟前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
say_fall18 分钟前
C++ 类与对象易错点:初始化列表顺序 / 静态成员访问 / 隐式类型转换
android·java·开发语言·c++
热爱专研AI的学妹19 分钟前
2026世界杯观赛工具自制指南:实时比分推送机器人搭建思路
开发语言·人工智能·python·业界资讯
Dev7z26 分钟前
基于MATLAB图像处理的苹果品质自动分级系统设计与实现
开发语言·图像处理·matlab
源代码•宸31 分钟前
Golang基础语法(go语言指针、go语言方法、go语言接口、go语言断言)
开发语言·经验分享·后端·golang·接口·指针·方法