gpt4 book ai didi

Qt中CQGUI框架之阴影圆角窗口实现

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Qt中CQGUI框架之阴影圆角窗口实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

大家好,我是IT文艺男,来自一线大厂的一线程序员 。

今天给大家讲解基于C++/Qt的CQGUI框架的阴影圆角窗口实现,实现效果如下图所示::

Qt中CQGUI框架之阴影圆角窗口实现

CQGUI开发环境::

  • Microsoft Visual Studio 2019
  • Qt5.15.1

步骤如下:

1、继承关系 。

?
1
class LoginPanel : public QDialog

2、窗口属性 。

?
1
2
3
setAttribute(Qt::WA_TranslucentBackground); //设置顶层面板背景透明
setWindowFlags(Qt::FramelessWindowHint); //设置无边框
setContentsMargins(10, 10, 10, 10);

Qt::WA_TranslucentBackground Indicates that the widget should have a translucent background, i.e., any non-opaque regions of the widgets will be translucent because the widget will have an alpha channel. Setting this flag causes WA_NoSystemBackground to be set. On Windows the widget also needs the Qt::FramelessWindowHint window flag to be set. This flag is set or cleared by the widget's author. 。

3、设置阴影效果 。

?
1
2
3
4
5
auto *defaultShadow = new QGraphicsDropShadowEffect();
defaultShadow->setBlurRadius(10.0);
defaultShadow->setColor(QColor(0, 0, 0, 160));
defaultShadow->setOffset(0, 0);
_loginMainFrm->setGraphicsEffect(defaultShadow);

4、设置样式 。

?
1
2
3
4
5
6
7
QFrame#loginMainFrm>QFrame#leftFrame{
  background:rgba(255,255,255,0.9);
  border-top-left-radius:6px;
   border-top-right-radius:0px;
   border-bottom-right-radius:0px;
   border-bottom-left-radius:6px;
}

5、事件响应 。

?
1
2
3
4
5
6
7
8
protected :
   void mousePressEvent(QMouseEvent *e) override ;
   void mouseReleaseEvent(QMouseEvent *e) override ;
   void mouseMoveEvent(QMouseEvent *e) override ;
   void closeEvent(QCloseEvent *e) override ;
   bool event(QEvent* e) override ;
protected :
   bool eventFilter(QObject* o, QEvent* e) override;

到此这篇关于Qt中CQGUI框架之阴影圆角窗口实现的文章就介绍到这了,更多相关CQGUI阴影圆角窗口内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://www.cnblogs.com/appsucc/p/14587599.html 。

最后此篇关于Qt中CQGUI框架之阴影圆角窗口实现的文章就讲到这里了,如果你想了解更多关于Qt中CQGUI框架之阴影圆角窗口实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com