Qt圆角窗口的两种实现方案详解

 更新时间:2026年01月11日 09:24:28   作者:郝学胜-神的一滴  
在Qt中设置控件的圆角通常可以通过Qt样式表(QSS)来实现,这是一种非常灵活且强大的方式来定制Qt控件的外观,这篇文章主要介绍了Qt圆角窗口的两种实现方案,需要的朋友可以参考下

前言:圆角之美

圆角窗口,乃现代UI设计之精髓,去棱角之锋芒,添界面之柔和。Qt框架虽未原生提供圆角窗口,然开发者可自辟蹊径,实现此般效果。本文将详述两种主流方案,并辅以代码示例与应用案例,助君掌握此技。

方案一:重写paintEvent之法

原理剖析

🖌️ 重写paintEvent,乃Qt绘图之根本。通过覆写此虚函数,可完全掌控窗口绘制过程,实现任意形状之窗口。

代码实现

void RoundedWidget::paintEvent(QPaintEvent* event)
{
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing);  // 抗锯齿
    painter.setBrush(Qt::white);                   // 背景色
    
    // 绘制圆角矩形
    painter.drawRoundedRect(rect(), 15, 15);       // 15为圆角半径
    
    // 继续绘制其他内容...
}

优劣分析

优势

  • 完全控制绘制过程
  • 可动态调整圆角大小
  • 适用于复杂自定义UI

劣势

  • 需手动处理所有绘制逻辑
  • 性能略低于纯样式表方案

应用案例

📱 音乐播放器界面:需动态改变圆角大小以配合动画效果时,此方案尤为适用。

方案二:Qss和QStyleOption

原理剖析

🎨 QSS(Qt Style Sheets) ,乃Qt之样式表系统,类似CSS。结合QStyleOption,可实现高效圆角效果。

45% 35% 20% 方案二技术组成 QSS样式表 QStyleOption 窗口属性设置

代码实现

// 设置窗口样式
setStyleSheet("QWidget {"
              "background-color: white;"
              "border-radius: 15px;"
              "}");

// 必须设置的窗口标志
setAttribute(Qt::WA_TranslucentBackground);
setWindowFlags(Qt::FramelessWindowHint);

关键点说明

🔑 注意事项

  1. 必须设置WA_TranslucentBackground属性
  2. 需移除窗口边框(FramelessWindowHint)
  3. 样式表可外部文件化,便于维护

性能对比表

特性方案一方案二
实现复杂度
运行性能
可维护性
动态调整能力

应用案例

💻 设置对话框:静态圆角窗口,样式统一且无需频繁更新时,此方案最佳。

进阶技巧

阴影效果

🌑 添加阴影可增强圆角窗口的立体感:

// 方案二的增强版
setStyleSheet("QWidget {"
              "background-color: white;"
              "border-radius: 15px;"
              "border: 1px solid #ccc;"
              "}");
QGraphicsDropShadowEffect* shadow = new QGraphicsDropShadowEffect;
shadow->setBlurRadius(10);
shadow->setOffset(3, 3);
setGraphicsEffect(shadow);

性能优化

减少重绘区域:

// 在方案一中优化
void RoundedWidget::paintEvent(QPaintEvent* event)
{
    if(!event->region().intersected(roundedArea).isEmpty()) {
        // 仅绘制需要更新的圆角部分
    }
}

结语

🛠️ 两种方案,各有所长。重写paintEvent之法,灵活多变;QSS方案,简洁高效。开发者当视具体需求而择。

📚 延伸阅读

  • Qt绘图系统深度解析
  • QSS选择器高级用法
  • 现代UI设计原则

总结

到此这篇关于Qt圆角窗口两种实现方案的文章就介绍到这了,更多相关Qt圆角窗口实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • Qt中常用对话框使用技巧及注意事项

    Qt中常用对话框使用技巧及注意事项

    Qt 为应用程序设计提供了一些常用的标准对话框,如打开文件对话框、选择颜色对话框、信息提示和确认选择对话框、标准输入对话框等,这篇文章主要给大家介绍了关于Qt中常用对话框使用技巧及注意事项的相关资料,需要的朋友可以参考下
    2024-04-04
  • C语言练习之数组中素数交换

    C语言练习之数组中素数交换

    这篇文章主要为大家介绍了C语言数组中素数交换,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助<BR>
    2021-12-12
  • C++短路求值(逻辑与、逻辑或)实例

    C++短路求值(逻辑与、逻辑或)实例

    这篇文章主要介绍了C++短路求值(逻辑与、逻辑或)实例,以实例形式讲述了逻辑或的短路与逻辑与的短路及相应的应用实例,需要的朋友可以参考下
    2014-10-10
  • c++ builder TreeView控件节点遍历代码

    c++ builder TreeView控件节点遍历代码

    这篇文章介绍了c++ builder TreeView控件节点遍历代码,有需要的朋友可以参考一下
    2013-09-09
  • C语言实现合式公式的判断示例

    C语言实现合式公式的判断示例

    这篇文章主要介绍了C语言实现合式公式的判断示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Visual Studio 2022 编译C++20代码的图文步骤

    Visual Studio 2022 编译C++20代码的图文步骤

    在Visual Studio中启用C++20 import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标准库模块,完成后通过Ctrl+F5编译含import的代码,下面就来介绍一下
    2025-06-06
  • C语言数据结构系列队列篇

    C语言数据结构系列队列篇

    本章我们将学习 "队列" ,首先介绍队列的概念和结构,然后我们将着重讲解栈的实现。我们从零开始写队列的接口,并从零开始步步解读。本章将继续巩固画思路草图的能力,只要思路草图画好了,就可以很轻松地将其转换成代码
    2022-02-02
  • C语言实现时区转换函数的实例

    C语言实现时区转换函数的实例

    这篇文章主要介绍了C语言实现时区转换函数的实例的相关资料,这里分析需求并提供实现代码,需要的朋友可以参考下
    2017-08-08
  • 用C语言实现计算器功能

    用C语言实现计算器功能

    这篇文章主要为大家详细介绍了用C语言实现计算器功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • c++实现简单的线程池

    c++实现简单的线程池

    这里给大家介绍了C++中对于pthread线程的一个简单应用以及使用继承CDoit,实现其中的start和end,有需要的小伙伴可以参考下
    2015-11-11

最新评论