【Qt】剪切图片左上角是直角,其他三个角是圆角

先看效果图

直接上代码:

QPixmap Widget::round(const QPixmap &img_in, int radius)
{
    if (img_in.isNull())
    {
        return QPixmap();
    }
    QSize size(img_in.size());
    QBitmap mask(size);
    QPainter painter(&mask);
    painter.setRenderHints(QPainter::Antialiasing | QPainter::SmoothPixmapTransform);
    painter.fillRect(mask.rect(), Qt::white);
    painter.setBrush(QColor(0, 0, 0));
    QPainterPath path;
    path.lineTo(0, size.height() - radius);
    path.arcTo(0, size.height() - radius, radius, radius, 180, 90);
    path.lineTo(size.width() - radius, size.height());
    path.arcTo(size.width() - radius, size.height() - radius, radius, radius, 270, 90);
    path.lineTo(size.width(), radius);
    path.arcTo(size.width() - radius, 0, radius, radius, 0, 90);
    path.lineTo(0, 0);
    painter.drawPath(path);
//    painter.drawEllipse(mask.rect());
//    painter.drawRoundedRect(mask.rect(), radius, radius);
    QPixmap image = img_in;// .scaled(size);
    image.setMask(mask);
    return image;
}

原理就是在Pixmap加上一个对应形状的遮罩,所想要的形状就出来了。

就是通过绘制直线和圆弧,生成一个对应图形的path。画圆弧的用法另外查看吧

通过这个原来就可以显示自己想要的任何形状,只要你自己能够把这个形状画出来

比如

painter.drawEllipse(mask.rect());

就是形状就是圆形的

比如

painter.drawRoundedRect(mask.rect(), radius, radius);

就是四个圆角的形状

添加了

painter.setRenderHints(QPainter::Antialiasing | QPainter::SmoothPixmapTransform);

还是会有锯齿,我也不晓得为啥

当然这个效果使用样式表也是可以实现的,样式表做出来的效果也是有锯齿的。

有无锯齿的效果的做法可以互相交流一下

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值