Qt实现跟随侧边栏的按钮控制侧边栏的展开与折叠

效果展示:右侧工具栏宽度是固定的

在这里插入图片描述

方式概述:

一、界面布局方式如图所示:SideToolWidget主体采用水平布局,包含两个QWidget,左侧为用于信息显示的leftWidget,右侧为容纳展开折叠按钮窗口btnWidget与云台工具显示窗口ptzWidget的containerWidget,内部窗体的具体布局如图所示;
在这里插入图片描述
二、实现方式描述,按钮窗口btnWidget与云台工具显示窗口ptzWidget均采用宽度固定,高度自由的布局策略,容器窗口可采取宽度固定或不固定,高度自由,宽度若固定,应为按钮窗口btnWidget与云台工具显示窗口ptzWidget的宽度之和;若宽度不固定,应在布局的左侧放置一个水平弹簧用于将按钮窗口在pztWidget隐藏时挤压至最右侧;记录ptzWidget的宽度,展开折叠按钮showOrHideBtn槽函数中判断用户点击的状态,若隐藏,则containerWidget总宽度与btnWidget相同,若显示,则containerWidget宽度为btnWidget与pztWidget之和;

完整代码:其中资源图片也可自己贴图替换

头文件

#ifndef SIDETOOLWIDGET_H
#define SIDETOOLWIDGET_H

#include <QWidget>
#include <QList>

QT_BEGIN_NAMESPACE
namespace Ui { class SideToolWidget; }
QT_END_NAMESPACE

class SideToolWidget : public QWidget
{
    Q_OBJECT

public:
    SideToolWidget(QWidget *parent = nullptr);
    ~SideToolWidget();
    void initPtzStyle();
private slots:
    void on_showOrHideBtn_clicked();

private:
    Ui::SideToolWidget *ui;
    bool unfold;
    int changeWidth;
};
#endif // SIDETOOLWIDGET_H

源文件


#include "sidetoolwidget.h"
#include "ui_sidetoolwidget.h"
#include <QIcon>

const QString btnStyle = "QPushButton{border-radius:18px; background-position:center; background-color:rgba(245,245,245,250)}"\
                         "QPushButton:pressed{background-color:rgba(255,255,255,255);border-style:inset;}";

SideToolWidget::SideToolWidget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::SideToolWidget)
    , unfold(true)
{
    ui->setupUi(this);
    changeWidth = ui->ptzWidget->width();
    this->setWindowTitle("折叠窗口");
    initPtzStyle();
}

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

void SideToolWidget::initPtzStyle()
{
    // ptzWidget中所有按钮设置统一风格
    QList<QPushButton*> btnList = ui->ptzWidget->findChildren<QPushButton *>();
    for (int i = 0; i < btnList.count(); i++) {
        btnList.at(i)->setStyleSheet(btnStyle);
        btnList.at(i)->setIconSize(QSize(20,20));
    }

    ui->topButton->setIcon(QIcon(":/prefix/image/PTZ_Top.ico"));
    ui->rightTopButton->setIcon(QIcon(":/prefix/image/PTZ_TopRight.ico"));
    ui->rightButton->setIcon(QIcon(":/prefix/image/PTZ_Right.ico"));
    ui->rightBottomButton->setIcon(QIcon(":/prefix/image/PTZ_BottomRight.ico"));
    ui->bottomButton->setIcon(QIcon(":/prefix/image/PTZ_Bottom.ico"));
    ui->bottomLeftButton->setIcon(QIcon(":/prefix/image/PTZ_BottomLeft.ico"));
    ui->leftButton->setIcon(QIcon(":/prefix/image/PTZ_Left.ico"));
    ui->topLeftButton->setIcon(QIcon(":/prefix/image/PTZ_TopLeft.ico"));
    ui->resetButton->setIcon(QIcon(":/prefix/image/PTZ_Recover.ico"));

    ui->zoomInButton->setStyleSheet(btnStyle);
    ui->zoomOutButton->setStyleSheet(btnStyle);
    ui->focusMinButton->setStyleSheet(btnStyle);
    ui->focusMaxButton->setStyleSheet(btnStyle);
    ui->flightOutButton->setStyleSheet(btnStyle);
    ui->flightInButton->setStyleSheet(btnStyle);

    ui->singleCallBtn_1->setIcon(QIcon(":/prefix/image/SingleCall.ico"));
    ui->singleDeleteBtn_1->setIcon(QIcon(":/prefix/image/SingleDelete.ico"));
    ui->singleCallBtn_2->setIcon(QIcon(":/prefix/image/SingleCall.ico"));
    ui->singleDeleteBtn_2->setIcon(QIcon(":/prefix/image/SingleDelete.ico"));
    ui->singleCallBtn_3->setIcon(QIcon(":/prefix/image/SingleCall.ico"));
    ui->singleDeleteBtn_3->setIcon(QIcon(":/prefix/image/SingleDelete.ico"));
    ui->singleCallBtn_4->setIcon(QIcon(":/prefix/image/SingleCall.ico"));
    ui->singleDeleteBtn_4->setIcon(QIcon(":/prefix/image/SingleDelete.ico"));
    ui->singleCallBtn_5->setIcon(QIcon(":/prefix/image/SingleCall.ico"));
    ui->singleDeleteBtn_5->setIcon(QIcon(":/prefix/image/SingleDelete.ico"));
}

void SideToolWidget::on_showOrHideBtn_clicked()
{
    if (unfold) {
        ui->ptzWidget->hide();
        ui->showOrHideBtn->setText("<<");
        ui->containerWdget->setFixedWidth(ui->btnWidget->width()); 
        unfold = false;
    } else {
        ui->ptzWidget->show();
        ui->showOrHideBtn->setText(">>");
        ui->containerWdget->setFixedWidth(ui->btnWidget->width() + changeWidth);
        unfold = true;
    }
}

完整代码及资源文件下载链接

https://download.csdn.net/download/qq_44896246/87212584?spm=1001.2014.3001.5503

  • 4
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值