Qt/C++学习系列之QGroupBox控件的简单使用

前言

最近在练手一个项目,项目中有不同功能的划分,为了功能分区一目了然,我使用到QGroupBox控件,也是在界面排版布局中最常用的控件之一。下面就详细介绍一下项目中的具体使用。


样式使用

在项目初始化的时候,就简单粗暴的使用setStyleSheet对ui界面进行统一的设定。 那么QGroupBox控件可以定义什么的样式呢?

  • 边框样式 border、border-width、border-style、border-color、border-radius
  • 字体样式 font-size、font-family、font-weight、color
  • 背景样式 background-color、background-image、background-repeat、background-position
  • 内边距和外边距 padding、margin
  • 标题样式 QGroupBox 的标题可以通过子控件选择器 QGroupBox::title 来单独设置样式。
  • 指示器样式 QGroupBox 可以添加复选框,也可以用QGroupBox::indicator类设置样式。 复选框可以这样加

代码层面

项目中,我们将一些内容进行分类后,需要根据勾选的QGroupBox做出对应的操作。有时候需要QGroupBox的点击事件。

初始化控件

cpp 复制代码
void MainWindow::QGroupBox_init()
{
    ui->groupBox_1->installEventFilter(this); // 为 groupBox_1 安装事件过滤器
    ui->groupBox_2->installEventFilter(this); // 为 groupBox_2 安装事件过滤器
    GroupBox.append(ui->groupBox_1); // 将 groupBox_1 添加到控件列表
    GroupBox.append(ui->groupBox_2); // 将 groupBox_2 添加到控件列表

    // 默认勾选 QGroupBox1
    if (!GroupBox.isEmpty()) {
        GroupBox.first()->setStyleSheet("XXX");
    }
}
  • installEventFilter:为控件安装事件过滤器,以便捕获鼠标点击事件。
  • GroupBox:一个列表,可以动态改变样式的 QGroupBox 控件。将列表第一个设置默认的样式。

初始化时也可以使用setStyleSheet对控件进行样式定义。举个例子:

cpp 复制代码
this->setStyleSheet(
        "QGroupBox { "
        "border: 2px solid #ccc;font-size: 14px; font-weight: normal; color: black; padding: 20px; border-radius: 20px;"
        "}"
    );
  • 边框为 2 像素宽的浅灰色实线。字体大小为 14 像素,字体颜色为黑色,字体粗细为正常。控件内部的填充间距为 20 像素。边框的四个角为半径 20 像素的圆角。

事件过滤器

在初始化中就使用到事件过滤器,是因为当界面中的QGroupBox过多,而我们只需要对其中某些QGroupBox进行处理时,可以使用事件过滤事件进行处理。这个想法是问了AI后发现的。当时没有使用QGroupBox,而使用QGroupBox后,发现没有比较好的办法进行指定QGroupBox进行选择。在询问AI后,提出使用eventFilter,也就是事件过滤器,将需要的QGroupBox可以使用QList<QGroupBox *> 这样一个列表进行存储。然后再后续的事件中对列表中的QGroupBox进行处理就可以了。

cpp 复制代码
bool MainWindow::eventFilter(QObject *obj, QEvent *event)
{
    if (event->type() == QEvent::MouseButtonPress) { // 检测鼠标点击事件
        QGroupBox *clickedGroupBox = qobject_cast<QGroupBox *>(obj); // 将点击的对象转换为 QGroupBox 类型
        if (设置条件) { // 判断是否为列表中的 QGroupBox
            onGroupBoxClicked(clickedGroupBox); // 调用点击事件处理函数
            return true; // 事件已处理
        }
    }
    return QMainWindow::eventFilter(obj, event); // 调用基类的事件过滤器
}
  • event->type():判断事件类型是否为鼠标点击事件。
  • qobject_cast<QGroupBox *>(obj):将点击的对象转换为 QGroupBox 类型。
  • onGroupBoxClicked:调用点击事件处理函数。

点击事件处理

cpp 复制代码
void MainWindow::onGroupBoxClicked(QGroupBox *clickedGroupBox)
{
    // 获取被点击的 QGroupBox 的名称
    QString groupName = clickedGroupBox->title();
    //接着对点击的QGroupBox进行处理
}
  • 获取标题:通过 clickedGroupBox->title() 获取被点击的 QGroupBox 的标题。

总结

本文根据实际项目出发,介绍了QGroupBox 的相关事件处理方式。在遇到难点时,可以适时求助一下AI,加快编写效率!

相关推荐
AI改变未来1 天前
我们该如何使用DeepSeek帮我们减负?
人工智能·deepseek
太空眼睛1 天前
【LLaMA-Factory】使用LoRa微调训练DeepSeek-R1-Distill-Qwen-7B
lora·微调·sft·训练·deepspeed·llama-factory·deepseek
pedestrian_h1 天前
Spring AI 开发本地deepseek对话快速上手笔记
java·spring boot·笔记·llm·ollama·deepseek
木偶彡1 天前
如何通过http访问ollama接口
大模型·ollama·deepseek
浪淘沙jkp1 天前
AI大模型学习二十、利用Dify+deepseekR1 使用知识库搭建初中英语学习智能客服机器人
人工智能·llm·embedding·agent·知识库·dify·deepseek
-曾牛2 天前
Spring AI 与 Hugging Face 深度集成:打造高效文本生成应用
java·人工智能·后端·spring·搜索引擎·springai·deepseek
全栈技术负责人2 天前
cursor对话关键词技巧
ai编程
大白技术控2 天前
浙江大学 deepseek 公开课 第三季 第3期 - 陈喜群 教授 (附PPT下载) by 突破信息差
人工智能·互联网·deepseek·deepseek公开课·浙大deepseek公开课课件·deepseek公开课ppt·人工智能大模型
奔跑吧邓邓子3 天前
DeepSeek“智”造:解锁旅游行业新玩法
应用·deepseek·旅游行业·旅游攻略
佩奇的技术笔记4 天前
AI编程: 使用Trae1小时做成的音视频工具,提取音频并识别文本
音视频·ai编程