【QT】自定义QWidget设置圆角+边框(重绘paintEvent)

目录

0.背景

1.详细代码

.h头文件

.cpp实现

构造函数设置样式


0.背景

windows + qt5.12 + c++
我有一个自定义的 QWidget ,名为 BCI_MessageBox ,继承自QWidget,想实现它的圆角+边框

实现图如下(里面都是自定义的按钮,不重要)

实现思路:重写保护函数 【paintEvent】,通过位图遮罩将窗口裁剪为圆角矩形;然后再加一些样式设置边框即可;

1.详细代码

.h头文件

cpp 复制代码
protected:
    void paintEvent(QPaintEvent *event);

.cpp实现

cpp 复制代码
void BCI_MessageBox::paintEvent(QPaintEvent *event)
{
    QStyleOption opt;
    opt.initFrom(this);
    QPainter p(this);
    style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);//绘制样式

    QBitmap bmp(this->size());
    bmp.fill();
    QPainter painter(&bmp);

    painter.setPen(Qt::NoPen);
    painter.setBrush(Qt::black);
    painter.setRenderHint(QPainter::Antialiasing);
    //设置边框为圆角12px
    painter.drawRoundedRect(bmp.rect(), 10, 10);
    setMask(bmp);
    QWidget::paintEvent(event);
}

构造函数设置样式

【隐藏标题栏 + 白色边框、圆角】

cpp 复制代码
    this->setWindowFlags(Qt::Widget|Qt::FramelessWindowHint);
    setStyleSheet("BCI_MessageBox{border:1px solid #FFFFFF;background:#242424;border-radius:10px;}");

--END--

相关推荐
誰能久伴不乏6 小时前
【Qt实战】工业级多线程串口通信:从底层协议设计到完美收发闭环
linux·c++·qt
liu****6 小时前
4.Qt窗口开发全解析:菜单栏、工具栏、状态栏及对话框实战
数据库·c++·qt·系统架构
从此不归路11 小时前
Qt5 进阶【11】图形视图框架:用 QGraphicsView 搭一个流程图编辑器
开发语言·c++·qt
凯子坚持 c12 小时前
Qt常用控件指南(7)
服务器·数据库·qt
wkd_00714 小时前
【Qt | QTableWidget】QTableWidget 类的详细解析与代码实践
开发语言·qt·qtablewidget·qt5.12.12·qt表格
残梦531415 小时前
Qt6.9.1起一个图片服务器(支持前端跨域请求,不支持上传,可扩展)
运维·服务器·开发语言·c++·qt
mengzhi啊15 小时前
QT的语言家使用方法示范
qt
Henry Zhu12315 小时前
Qt网络编程详解(下):项目实战
网络·qt
轩情吖16 小时前
Qt布局管理器
开发语言·c++·qt·布局管理器·桌面级·qvboxlayout·qhboxlayout
CSDN_RTKLIB16 小时前
Qt Creator中修改源文件编码
qt