当前位置: 首页 > news >正文

Qt 实现抽屉效果

1、实现效果和UI设计界面
在这里插入图片描述
在这里插入图片描述
2、工程目录
在这里插入图片描述
3、mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include <QToolButton>
#include <QPushButton>
#include <vector>
using namespace std;QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();private:Ui::MainWindow *ui;/*** @brief 初始化 UI*/void initUI();// 要折叠的内容vector<QWidget*> widgetBodys;// 要用到的 toolButtonvector<QToolButton*> toolButtons;// 折叠按钮 pushButtonvector<QPushButton*> pushButtons;private slots:// 点击打开和关闭抽屉按钮void on_btns_clicked();
};
#endif // MAINWINDOW_H

4、mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);// 初始化 UIinitUI();
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::initUI()
{// 要折叠的内容widgetBodys.push_back(ui->widgetOneBody);widgetBodys.push_back(ui->widgetTwoBody);widgetBodys.push_back(ui->widgetThreeBody);// 要用到的 toolButtontoolButtons.push_back(ui->toolButtonOne);toolButtons.push_back(ui->toolButtonTwo);toolButtons.push_back(ui->toolButtonThree);// 折叠按钮 pushButtonpushButtons.push_back(ui->pushButtonOne);pushButtons.push_back(ui->pushButtonTwo);pushButtons.push_back(ui->pushButtonThree);for(size_t i = 0;i < widgetBodys.size();++i){// 设置 ToolButton 的样式toolButtons[i]->setToolButtonStyle(Qt::ToolButtonTextBesideIcon);toolButtons[i]->setIcon(QIcon(QPixmap(":/res/functions.png")));toolButtons[i]->setText(QString::fromLocal8Bit("常用功能"));// 设置抽屉按钮的样式,抽屉默认折叠pushButtons[i]->setIcon(QIcon(QPixmap(":/res/close.png")));// 设置抽屉默认折叠,一定记得在 UI 设计界面将 layoutTopMargin 和 layoutBottomMargin 设置为0widgetBodys[i]->hide();// 方便后面点击按钮时获取点击的哪个按钮pushButtons[i]->setProperty("index",i);connect(pushButtons[i],&QPushButton::clicked,this,&MainWindow::on_btns_clicked);}
}void MainWindow::on_btns_clicked()
{// 获取点击的按钮QPushButton *pushButton = qobject_cast<QPushButton*>(sender());if(pushButton){int index = pushButton->property("index").toInt();if(widgetBodys[index]->isVisible()){// 当前抽屉是展开的// 关闭抽屉widgetBodys[index]->hide();// 按钮变为关闭状态pushButton->setIcon(QIcon(QPixmap(":/res/close.png")));}else{// 当前抽屉是关闭的// 打开抽屉widgetBodys[index]->show();// 按钮变为打开状态pushButton->setIcon(QIcon(QPixmap(":/res/open.png")));}}
}
http://www.lryc.cn/news/409743.html

相关文章:

  • windows上启动Kafka
  • 贪心系列专题篇三
  • Java中两个集合取差集
  • flask mysql数据迁移
  • Kylin系列(一)入门
  • pmp学习交流组队~
  • 公司常用的监控软件有哪些?2024年六大公司监控软件良心推荐!
  • DNS解析异常--排查验证
  • OpenCV库学习之Canny边缘检测模块
  • Python 教程(七):match...case 模式匹配
  • Python小项目实战:杨辉三角
  • java注解与反射(非常详细, 带有很多样例)
  • 模拟实现短信登录功能 (session 和 Redis 两种代码实例) 带前端演示
  • C# Parallel设置最大并发度
  • 【java】力扣 反转字符串中的单词
  • 科学设计程序员面试内容,破解“八股文”之弊
  • 蓝牙BlueZ验证使用记录
  • 【从0制作自己的ros导航小车:上位机篇】02、ros1多机通讯与坐标变换可视化
  • JumpServer关闭admin mfa验证
  • Kafka知识总结(选举机制+控制器+幂等性)
  • 2024非常全的接口测试面试题及参考答案-软件测试工程师没有碰到算我输!
  • python 写一个年会抽奖的demo
  • C++ OpenCV 实现多张图片叠加 叠加文字
  • 用 apifox cli 命令行运行本地接口出现TypeError:Invalid IP address: undefined
  • PyQt6简易案例代码GUI界面小工具——实现增、删、查、改(练手正合适)
  • JavaScript快速入门指南
  • Esbuild介绍
  • UnityShaderUI编辑器扩展
  • 分布式事务——2PC 代码示例
  • vue实现简易的全局加载动画效果