当前位置:
首页 >
Qt自定义对话框中边框阴影实现
发布时间:2023/11/30
59
豆豆
生活随笔
收集整理的这篇文章主要介绍了
Qt自定义对话框中边框阴影实现
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
1. 对于Window系统或者Unix系统,QDialog有一个默认的边框(样式看起来有点复古),不过Qt可以提供自定义的边框设计,通过设置对话框相关属性:
setWindowFlags(Qt::Dialog | Qt:: FramelessWindowHint); //设置不适应默认边框 setAttribute(Qt::WA_TranslucentBackground); //设置半透明的背景2. 设计一个layout容器,放置相关的控件:
QVBoxLayout *mainLayout = new QVBoxLayout(this); mainLayout->setMargin(0); QFrame *contentFrame = new QFrame(this); //添加相关组件 mainLayout->addWidget(contentFrame);QGraphicsDropShadowEffect *effect = new QGraphicsDropShadowEffect(this); //添加阴影 effect->setOffset(2,2); effect->setColor(QColor("#A5A6A5")); effect->setBlurRadius(5); m_contentFrame->setGraphicsEffect(effect);setContentsMargins(0, 0, 5, 5); //在下面和右边添加阴影3.如果还需要设置阴影部分的其他效果(添加相关细线),可以重写相关PaintEvent函数
void paintEvent(QPaintEvent *event) {QPainter painter(this);painter.setRenderHint(QPainter::Antialiasing, true);QColor color(165, 165, 165);for (int i = 0; i < 5; i++) {color.setAlpha(200 - 100 *sqrt(i));painter.setPen(QPen(color, 1 * sqrt(i + 0.1)));painter.drawLine(geometry().x() + 1, height() - (4 -i),width() -(4 - i), height() - (4 - i));painter.drawLine(width() - (4 - i), geometry().y() + 1,width() - (4 - i), height() - (4 - i));}}4. 设计效果图:
总结
以上是生活随笔为你收集整理的Qt自定义对话框中边框阴影实现的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 属羊的女人剧情介绍
- 下一篇: Qt自定义数据类型注册meta-obje