百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Qt 设置窗体透明

bigegpt 2025-01-04 17:23 6 浏览

一、前言

  在音频开发中,窗体多半为半透明、圆角窗体,如下为Qt 5.5 VS2013实现半透明方法总结。

二、半透明方法设置

  1、窗体及子控件都设置为半透明

  1)setWindowOpacity(0.8);//参数范围为0-1.0,通过QSlider控件做成透明度控制条

Qt资料领取→「链接」

  2)无边框设置

  setWindowFlags(Qt::FramelessWindowHint);

  3)窗体圆角设置

  setAttribute(Qt::WA_TranslucentBackground);
  通过paintEvent绘制窗体背景色与圆角
  void Widget::paintEvent(QPaintEvent *event)
  {
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing); // 反锯齿;
    painter.setBrush(QBrush(QColor("#616F76")));  //窗体背景色
    painter.setPen(Qt::transparent);
    QRect rect = this->rect();        //rect为绘制大小
    rect.setWidth(rect.width() - 1);
    rect.setHeight(rect.height() - 1);
    painter.drawRoundedRect(rect, 15, 15);  //15为圆角角度
    //也可用QPainterPath 绘制代替 painter.drawRoundedRect(rect, 15, 15);
    //QPainterPath painterPath;
    //painterPath.addRoundedRect(rect, 15, 15);//15为圆角角度
    //painter.drawPath(painterPath);
    QWidget::paintEvent(event);
  }

2、通过图片贴图,设置局部透明

  1)窗体设置

  setAttribute(Qt::WA_TranslucentBackground);//背景半透明属性设置
  setWindowFlags(Qt::FramelessWindowHint);//无边框窗体设置

  2)采用样式加载图片

  ui->m_BgWidget->setStyleSheet("background-image:url(:/images/bg.png);");

  注意:m_BgWidget为窗体对象的子窗体,不能直接设置QWidget

  3)效果图如下(录制gif时刷新有点延时)

  3、通过paintEvent重绘背景色透明度

  1)窗体属性设置

  setAttribute(Qt::WA_TranslucentBackground);//背景半透明属性设置
  setWindowFlags(Qt::FramelessWindowHint);//无边框窗体设置
  m_BgColor = QColor("#616F76");//默认背景色
  m_BgColor.setAlphaF(0.8);
  this->setContextMenuPolicy(Qt::CustomContextMenu);
  connect(this, SIGNAL(customContextMenuRequested(const QPoint &)),
      this, SLOT(showContextMenuSlot(const QPoint &)));//右击出现菜单

  2)右击出现菜单

  void Widget::showContextMenuSlot(const QPoint &pos)
  {
    QAction *act = NULL;
    if(NULL == m_Menu)
    {
      m_Menu = new QMenu();//菜单
      m_Actions.clear();//记录所有Action
      act = m_Menu->addAction("1.0", this, SLOT(funcSlot()));
      m_Actions << act;
      act->setCheckable(true);
      act = m_Menu->addAction("0.8", this, SLOT(funcSlot()));
      m_Actions << act;
      act->setCheckable(true);  //设置可选中
      act->setChecked(true);  //设置被选中
      act = m_Menu->addAction("0.5", this, SLOT(funcSlot()));
      m_Actions << act;
      act->setCheckable(true);
      act = m_Menu->addAction("0.3", this, SLOT(funcSlot()));
      m_Actions << act;
      act->setCheckable(true);
      act = m_Menu->addAction("0.1", this, SLOT(funcSlot()));
      m_Actions << act;
      act->setCheckable(true);
    }
    m_Menu->exec(mapToGlobal(pos));//弹出菜单
  }

  3)选择菜单Action,修改背景颜色透明度

  void Widget::funcSlot()
  {
    QAction *act = qobject_cast<QAction *>(sender());//获取选中的Action
    if(act)
    {
      double alpha = act->text().toDouble();
      m_BgColor.setAlphaF(alpha);//背景色透明度修改
      foreach(QAction *action, m_Actions)//去除其余选中,互斥
      {
        if(act != action)
          action->setChecked(false);
      }
      this->update();//刷新界面
    }
  }

  4)通过paintEvent重绘背景色

  void Widget::paintEvent(QPaintEvent *event)
  {
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing); // 反锯齿;
    painter.setBrush(QBrush(m_BgColor));//修改后的背景色
    painter.setPen(Qt::transparent);
    QRect rect = this->rect();      //rect为绘制窗体大小
    rect.setWidth(rect.width() - 1);
    rect.setHeight(rect.height() - 1);
    painter.drawRoundedRect(rect, 15, 15);//15为圆角角度
    //也可用QPainterPath 绘制代替 painter.drawRoundedRect(rect, 15, 15);
    //QPainterPath painterPath;
    //painterPath.addRoundedRect(rect, 15, 15);
    //painter.drawPath(painterPath);
    QWidget::paintEvent(event);
  }

  5)效果如下(录频有点重影)

  4、通过paintEvent采用Clear模式绘图,实现局部透明

  1)窗体属性设置

  m_Margin = 60;//各个绘制图形与边框的距离
  m_BgColor = QColor("#00BFFF");//窗体背景色
  installEventFilter(this);//事件过滤器,用于鼠标按下后界面移动
  setWindowFlags(Qt::FramelessWindowHint);//无边框窗体设置
  setAttribute(Qt::WA_TranslucentBackground);//背景半透明属性设置

  2)画笔属性设置

  void Widget::paintEvent(QPaintEvent *)
  {
    QPainter painter(this);
    painter.setPen(Qt::NoPen);
    painter.setBrush(m_BgColor);
    painter.drawRoundedRect(this->rect(), 15, 15);//设置整体窗体圆角为15°
    painter.setCompositionMode(QPainter::CompositionMode_Clear);//设置Clear绘图模式
    //绘制三角形
    drawTriangle(&painter);
    //绘制圆
    drawCircular(&painter);
    //绘制矩形
    drawRectangle(&painter);
  }

  3)绘制三角形

  void Widget::drawTriangle(QPainter *painter)
  {
    QPainterPath path;
    int width = this->width() / 2;
    int height = this->height() / 2;
    //顶点
    int topX = width / 2;
    int topY = m_Margin;
    //左下顶点
    int leftX = m_Margin;
    int leftY = height - m_Margin;
    //右下顶点
    int rightX = width - m_Margin;
    int rightY = height - m_Margin;
    path.moveTo(topX, topY);//起点
    path.lineTo(leftX, leftY);//画线段1
    path.lineTo(rightX, rightY);//画线段2
    path.lineTo(topX, topY);//画线段3
    painter->fillPath(path, QBrush(m_BgColor));//绘制三角形
  }

  4)绘制圆

  void Widget::drawCircular(QPainter *painter)
  {
    int width = this->width() / 2;
    int height = this->height() / 2;
    int x = width + width / 2;//X向坐标
    int y = height / 2; //Y向坐标
    int r = width / 2 - m_Margin;
    //第一个参数为中心点,r为x向、y向长度(不一致时可绘制椭圆)
    painter->drawEllipse(QPoint(x, y), r, r);
  }

  5)绘制矩形

  void Widget::drawRectangle(QPainter *painter)
  {
    int width = this->width() / 2;
    int height = this->height() / 2;
    int rectWidth = width - 2 * m_Margin;//矩形宽度
    int rectHeight = height - 2 * m_Margin;//矩形高度
    int rectX = width - rectWidth / 2;//矩形X向长度
    int rectY = height + m_Margin;//矩形Y向长度
    painter->drawRect(QRect(rectX, rectY, rectWidth, rectHeight));
  }

  6)运行效果

文章转自博客园(凉天满月):https://www.cnblogs.com/liangtianmanyue/p/14758177.html

Qt资料领取(视频教程+文档+代码+项目实战)

相关推荐

ActiveAndroid使用(对象化数据库)

配置模块的build.gradlerepositories{mavenCentral()mavenLocal()maven{url"https://oss.sonatype.org/conte...

AndroidStudio下的依赖管理(android app依赖外部jar包)

在开发中用第三方库是很常见的事,如何在AndroidStudio下管理这些依赖呢?这就是这篇文章的目的。目录Maven/Ivy仓库依赖Module依赖aar文件依赖jar文件依赖例子完整代码一、Mav...

Android Studio之gradle的配置与介绍

1、gradle的简单介绍Gradle是可以用于Android开发的新一代的BuildSystem,也是AndroidStudio默认的build工具。其实Gradle脚本是基于一种JVM语言—...

Android中的run-as命令带来的安全问题

一、前言最近一周比较忙,没时间写东西了,今天继续开始我们今天的话题:run-as命令,在上周的开发中,遇到一个问题,就是在使用run-as命令的时候出现了一个错误,不过当时因为工作进度的问题,这问题就...

Android系统级深入开发——input驱动程序

1、Input驱动程序是Linux输入设备的驱动程序,分成游戏杆(joystick)、鼠标(mouse和mice)和事件设备(Eventqueue)3种驱动程序。其中事件驱动程序是目前通用的驱动程序...

Android项目中如何用好构建神器Gradle?

CSDN移动将持续为您优选移动开发的精华内容,共同探讨移动开发的技术热点话题,涵盖移动应用、开发工具、移动游戏及引擎、智能硬件、物联网等方方面面。如果您想投稿、参与内容翻译工作,或寻求近匠报道,请发送...

Android Studio自定义文件类头(android studio自定义标题栏)

--简书作者谢恩铭转载请注明出处今天给大家介绍一个很简单的"小"技巧。平时,我们在AndroidStudio中开发Android时,总免不了要创建新的文件,也许是Java文件,也许是C...

C语言#include头文件真的是插入代码吗?

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!编译器理论和实作既是又不是。从编译器理论理解,#include头文件"相当于"插入了头文件的代码,以供源代码引用(宏定...

Android 系统核心机制binder(03)binder C++层实现

本章关键点总结&说明:这里主要关注BinderC++部分即可,看到,也是本章节的核心内容,主要就是以C++封装的框架为主来解读binder。之前主要针对于底层驱动binder的数据交互以及...

Java对象序列化与反序列化的那些事

Java对象序列化与反序列化的那些事在Java的世界里,对象序列化和反序列化就像一对孪生兄弟,它们共同构成了Java对象存储和传输的基础。如果你曾经尝试将对象保存到文件中,或者在网络中传输对象,那么你...

Java对象序列化剖析(java 对象序列化)

对象序列化的目的1)希望将Java对象持久化在文件中2)将Java对象用于网络传输实现方式如果希望一个类的对象可以被序列化/反序列化,那该类必须实现java.io.Serializable接口或jav...

C++模板 - 16(SFINAE)(c++模板编程)

C++支持函数重载,同一个函数名,只要它的签名不一样,可以声明若干个版本(这个特性也是必须的,不然构造函数就只能有一个了)。现在函数的重载集合中又加入了新的成员-函数模板,事情就变得越发有趣起来,...

NewtoSoft.Json相关使用技巧(newtosoft.json相关使用技巧有哪些)

  本篇将为大家介绍Newtonsoft.Json的一些高级用法,可以修改很少的代码解决上述问题。Newtonsoft.Json介绍  在做开发的时候,很多数据交换都是以json格式传输的。而使用Js...

C#调用DeepSeek API(c#调用deepseek api 流式输出)

一、官方网站二、DeepSeek测试DeepSeek三大适用模式:基础模型(V3)、深度思考(R1)、联网搜索。基础模型(V3)深度思考(R1)联网搜索三、C#调用DeepSeekAPI核心代码//...

.NET性能系列文章二:Newtonsoft.Json vs System.Text.Json

微软终于追上了?图片来自GlennCarstens-Peters[1]Unsplash[2]欢迎来到.NET性能系列的另一章。这个系列的特点是对.NET世界中许多不同的主题进行研究、基准和比较...