QT自定义标题栏

效果

1、自定义标题栏
在这里插入图片描述
2、QT自带标题栏
在这里插入图片描述

自定义标题栏类的代码

1、ui界面
在这里插入图片描述
2、.h

#include <QWidget>
#include <QEvent>
#include <QDockWidget>
#include <QMouseEvent>

namespace Ui {
class mTitleBar;
}

class mTitleBar : public QWidget
{
    //Q_OBJECT
public:
    explicit mTitleBar(QString title,QWidget *parent = nullptr);
    ~mTitleBar();
    void mousePressEvent(QMouseEvent *event);
    void mouseMoveEvent(QMouseEvent *event);
    void mouseReleaseEvent(QMouseEvent *event);

private:
    Ui::mTitleBar *ui;
    bool            mPressBool;
    QPoint          mouseStartPoint;
    QPoint          mwindowTopLeftPoint;
    QDockWidget*    mpDockMouse;

};

3、.cpp

#include "mtitlebar.h"
#include "ui_mtitlebar.h"
#include <QDockWidget>
#include <QWidget>
//构造函数
mTitleBar::mTitleBar(QString title,QWidget *parent) :
    QWidget(parent),
    ui(new Ui::mTitleBar)
{
 	ui->setupUi(this);
    mpDockMouse = new QDockWidget(this);
    mpDockMouse->hide();
    ui->label->setText(title);
    //囗:最大化/恢复
    connect(ui->pushButton, &QPushButton::clicked, [=]
    {
        mpDockMouse = qobject_cast<QDockWidget*>(parentWidget());
        if (mpDockMouse != nullptr)
        {
            if(mpDockMouse->isMaximized())  //显示原来的大小
            {
                mpDockMouse->showNormal();
            }
            else //最大化
            {
                mpDockMouse->showMaximized();
            }

        }
    });
    //× 关闭
    connect(ui->pushButton2, &QPushButton::clicked, [=]
    {
        mpDockMouse = qobject_cast<QDockWidget*>(parentWidget());
        if (mpDockMouse != nullptr)
        {
            mpDockMouse->close();
        }
    });
    //- 最小化
    connect(ui->pushButton3, &QPushButton::clicked, [=]
    {
        mpDockMouse = qobject_cast<QDockWidget*>(parentWidget());
//        mpDockMouse->showMinimized();
        mpDockMouse->hide();


    });
}
//鼠标事件
void mTitleBar::mousePressEvent(QMouseEvent *event)
{

    if(event->button() == Qt::LeftButton)
    {
        mPressBool = true;
        //获得鼠标的初始位置
        mouseStartPoint = event->globalPos();
        //获得窗口的初始位置
        mpDockMouse = qobject_cast<QDockWidget*>(parentWidget());
        mwindowTopLeftPoint = mpDockMouse->frameGeometry().topLeft();

    }
}

void mTitleBar::mouseMoveEvent(QMouseEvent *event)
{
    if(mPressBool)
    {
        //获得鼠标移动的距离
        QPoint distance = event->globalPos() - mouseStartPoint;
        //改变窗口的位置
        mpDockMouse = qobject_cast<QDockWidget*>(parentWidget());
        mpDockMouse->move(mwindowTopLeftPoint + distance);
    }
}

void mTitleBar::mouseReleaseEvent(QMouseEvent *event)
{
    if(event->button() == Qt::LeftButton)
    {
        mPressBool = false;
    }
}

类设置自定义标题栏

this->setTitleBarWidget(new mTitleBar("Cap",this));

百度网盘链接

提取码:wzds
自定义标题栏

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt 中,可以通过自定义 QWidget 的 paintEvent() 函数来实现自定义标题栏。具体步骤如下: 1.创建一个新的 QWidget,用于作为自定义标题栏。 2.将 QWidget 的窗口标志设置为 Qt::WindowFlags(Qt::FramelessWindowHint),这样可以去掉默认的标题栏。 3.重写 QWidget 的 paintEvent() 函数,在该函数中绘制自定义标题栏。 4.将 QWidget 设置为 QMainWindow 的标题栏,即调用 QMainWindow 的 setWindowTitle() 函数,并将其参数设置为自定义标题栏的指针。 下面是一个简单的示例代码: ``` #include <QtWidgets> // 继承 QWidget,作为自定义标题栏 class CustomTitleBar : public QWidget { public: CustomTitleBar(QWidget *parent = nullptr) : QWidget(parent) { // 设置窗口标志 setWindowFlags(Qt::FramelessWindowHint); } protected: void paintEvent(QPaintEvent *) override { QPainter painter(this); painter.fillRect(rect(), Qt::blue); painter.drawText(rect(), Qt::AlignCenter, "Custom Title Bar"); } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); QMainWindow mainWindow; // 设置主窗口标题 mainWindow.setWindowTitle("Main Window"); // 创建自定义标题栏 CustomTitleBar *titleBar = new CustomTitleBar(&mainWindow); // 设置自定义标题栏为主窗口的标题栏 mainWindow.setMenuWidget(titleBar); mainWindow.show(); return app.exec(); } ``` 运行该程序,可以看到自定义的蓝色标题栏。你可以根据自己的需要修改 paintEvent() 函数,来实现各种不同样式的标题栏

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值