【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--

相关推荐
机器视觉知识推荐、就业指导3 小时前
Qt6 + QCustomPlot 实时曲线 Demo ,适合串口与上位机项目
qt
YY&DS5 小时前
Qt 嵌入 CEF 在 Linux 下必须设置 `QT_XCB_GL_INTEGRATION=xcb_egl才能加载网页
linux·开发语言·qt
秋田君8 小时前
Qt 5.12.8 下载与安装教程(附网盘资源)
开发语言·qt
郝学胜-神的一滴9 小时前
Qt 高级开发 019:从零定制登录窗口按钮、Logo 样式与交互悬浮效果
开发语言·c++·qt·程序人生·交互·用户界面
YY&DS10 小时前
Qt Designer 自定义控件已提升后,如何修改提升类
开发语言·qt
爱吃生蚝的于勒11 小时前
QT开发第二章——信号和槽
c语言·开发语言·c++·qt
宏笋14 小时前
qss/css 样式中margin和padding的作用和区别
css·qt
雪的季节14 小时前
qt实现线程方式有哪些
qt
读书札记20221 天前
Qt界面卡死问题探讨及解决方法
qt
bug和崩溃我都要1 天前
Qt 封装 libmpv 全功能视频播放器开发指南
开发语言·qt·音视频