Qt 实现抽屉效果

1、实现效果和UI设计界面

2、工程目录

3、mainwindow.h

cpp 复制代码
#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_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT
    
public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
    
private:
    Ui::MainWindow *ui;
    
    /**
     * @brief 初始化 UI
     */
    void initUI();
    
    // 要折叠的内容
    vector<QWidget*> widgetBodys;
    
    // 要用到的 toolButton
    vector<QToolButton*> toolButtons;
    
    // 折叠按钮 pushButton
    vector<QPushButton*> pushButtons;

private slots:
    // 点击打开和关闭抽屉按钮
    void on_btns_clicked();
};
#endif // MAINWINDOW_H

4、mainwindow.cpp

cpp 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    // 初始化 UI
    initUI();
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::initUI()
{
    // 要折叠的内容
    widgetBodys.push_back(ui->widgetOneBody);
    widgetBodys.push_back(ui->widgetTwoBody);
    widgetBodys.push_back(ui->widgetThreeBody);
    
    // 要用到的 toolButton
    toolButtons.push_back(ui->toolButtonOne);
    toolButtons.push_back(ui->toolButtonTwo);
    toolButtons.push_back(ui->toolButtonThree);
    
    // 折叠按钮 pushButton
    pushButtons.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 设置为0
        widgetBodys[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")));
        }
    }
}
相关推荐
长源Gingko20 分钟前
Windows中在QTCreator中调试,提示缺少debug information files问题的解决
windows·qt
SundayBear2 小时前
Qt 开发修炼指南:从入门到通透的实战心法
开发语言·qt·嵌入式
ajassi20002 小时前
开源 C++ QT QML 开发(十)通讯--串口
c++·qt·开源
BingeBlog3 小时前
[01] Qt的UI框架选择和对比
开发语言·c++·笔记·qt·ui·开源软件
扶尔魔ocy7 小时前
【QT常用技术讲解】opencv实现摄像头图像检测并裁剪物体
开发语言·qt·opencv
ajassi200015 小时前
开源 C++ QT QML 开发(二)工程结构
linux·qt·qml
楼田莉子16 小时前
Qt开发学习——QtCreator深度介绍/程序运行/开发规范/对象树
开发语言·前端·c++·qt·学习
W.D.小糊涂20 小时前
Qt 5.14.2+Mysql5.7 64位开发环境下无法连接数据库
开发语言·qt
ajassi200021 小时前
开源 C++ QT QML 开发(六)自定义控件--波形图
c++·qt·开源
无敌最俊朗@21 小时前
Qt 多线程与并发编程详解
linux·开发语言·qt