您当前的位置: 首页 >  qt

wendy_ya

暂无认证

  • 1浏览

    0关注

    342博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Qt实战案例(54)——利用QPixmap设计图片透明度

wendy_ya 发布时间:2022-07-31 11:17:29 ,浏览量:1

目录
    • 一、项目介绍
    • 二、项目基本配置
    • 三、UI界面设置
    • 四、主程序实现
      • 4.1 widget.h头文件
      • 4.2 widget.cpp源文件
    • 五、效果演示

一、项目介绍

本文介绍利用QPixmap设计图片透明度,可以看到拖动下方进度条,用于控制上方图片的透明度。

二、项目基本配置

新建一个Qt案例,项目名称为“TransparencyTest”,基类选择“QWidget”,点击选中创建UI界面复选框,完成项目创建。

三、UI界面设置

UI界面如下: 在这里插入图片描述

序号名称类型属性①label_photoQLabel/②sliderQSliderminimum: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,以上便是本文的全部内容了,如果对你有所帮助,记得点个赞哟~

关注
打赏
1659256378
查看更多评论
立即登录/注册

微信扫码登录

0.0421s