Qt自定义标题栏【即取即用模板】

头文件

cpp 复制代码
#ifndef TITLEWDG_H
#define TITLEWDG_H

#include <QWidget>

namespace Ui {
class TitleWdg;
}

class TitleWdg : public QWidget
{
    Q_OBJECT

public:
    explicit TitleWdg(QWidget *parent = nullptr);
    ~TitleWdg();    

signals:
    void maximize();
    void minimize();
    void closeWindow();

protected:
    void paintEvent(QPaintEvent *event);

private slots:
    void on_close_clicked();
    void on_min_clicked();
    void on_max_clicked();

private:
    Ui::TitleWdg *ui;
};

#endif // TITLEWDG_H

源文件

cpp 复制代码
#include "titlewdg.h"
#include "ui_titlewdg.h"

#include <QPainter>
#include <QStyleOption>

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

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

void TitleWdg::paintEvent(QPaintEvent *event)
{
    Q_UNUSED(event)
    QStyleOption opt;
    opt.init(this);

    QPainter painter(this);
    style()->drawPrimitive(QStyle::PE_Widget, &opt, &painter, this);
}

void TitleWdg::on_close_clicked()
{
    closeWindow();
}

void TitleWdg::on_min_clicked()
{
    minimize();
}

void TitleWdg::on_max_clicked()
{
    maximize();
}

UI文件

cpp 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>TitleWdg</class>
 <widget class="QWidget" name="TitleWdg">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>636</width>
    <height>33</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Form</string>
  </property>
  <layout class="QHBoxLayout" name="horizontalLayout">
   <property name="leftMargin">
    <number>9</number>
   </property>
   <property name="topMargin">
    <number>5</number>
   </property>
   <property name="rightMargin">
    <number>9</number>
   </property>
   <property name="bottomMargin">
    <number>5</number>
   </property>
   <item>
    <widget class="QLabel" name="logo">
     <property name="text">
      <string/>
     </property>
    </widget>
   </item>
   <item>
    <widget class="QLabel" name="title">
     <property name="text">
      <string/>
     </property>
    </widget>
   </item>
   <item>
    <spacer name="horizontalSpacer">
     <property name="orientation">
      <enum>Qt::Horizontal</enum>
     </property>
     <property name="sizeHint" stdset="0">
      <size>
       <width>366</width>
       <height>20</height>
      </size>
     </property>
    </spacer>
   </item>
   <item>
    <widget class="QToolButton" name="min">
     <property name="text">
      <string/>
     </property>
    </widget>
   </item>
   <item>
    <widget class="QToolButton" name="max">
     <property name="text">
      <string/>
     </property>
    </widget>
   </item>
   <item>
    <widget class="QToolButton" name="close">
     <property name="text">
      <string/>
     </property>
    </widget>
   </item>
  </layout>
 </widget>
 <resources/>
 <connections/>
</ui>

qss

cpp 复制代码
#titleWdg
{
    color: #cdcdcd;
    background-color: #434343;
}

#titleWdg #max
{
    width: 26px;
    height: 26px;
    border-image: url(:/img/src/img/maximize-active.svg);
}

#titleWdg #max:hover
{
    border-image: url(:/img/src/img/maximize-hover.svg);
}

#titleWdg #min
{
    width: 26px;
    height: 26px;
    border-image: url(:/img/src/img/minimize-active.svg);
}

#titleWdg #min:hover
{
    border-image: url(:/img/src/img/minimize-hover.svg);
}

#titleWdg #close
{
    width: 26px;
    height: 26px;
    border-image: url(:/img/src/img/close-active.svg);
}

#titleWdg #close:hover
{
    border-image: url(:/img/src/img/close-hover.svg);
}

#titleWdg #logo
{
    min-width: 26px;
    height: 26px;
    border-image: url(:/img/YMTC.ico);
}

#titleWdg #title
{
    font: bold 12px;
    color: #FFFFFF;
    qproperty-text: "Working Log Tool v1.0.0";
}
相关推荐
木心爱编程18 小时前
【Qt 5.14.2 新手实战】QTC++入门筑基——按钮与标签联动:QPushButton + QLabel 实现图片切换器
java·c++·qt
小新11019 小时前
vs2022+Qt插件初体验,创建带 UI 界面的 Qt 项目
开发语言·qt·ui
神仙别闹21 小时前
基于QT(C++)实现的翻金币游戏
c++·qt·游戏
月上林梢1 天前
QT圆形加载进度条
数据库·c++·qt·进度条
A0_張張1 天前
记录一个PDF盖章工具(PyQt5 + PyMuPDF)
开发语言·python·qt·pdf
淼淼7631 天前
工厂方法模式
开发语言·c++·windows·qt·工厂方法模式
钱彬 (Qian Bin)1 天前
项目实践11—全球证件智能识别系统(切换为PostgreSQL数据库)
人工智能·qt·fastapi
深蓝海拓1 天前
PySide6从0开始学习的笔记(二) 控件(Widget)之容器类控件
笔记·qt·学习·pyqt
_OP_CHEN1 天前
【从零开始的Qt开发指南】(十一)Qt常用控件之多元素控件与容器类控件深度解析
开发语言·qt·前端开发·多元素控件·gui开发·qt常用控件·容器类控件
我送炭你添花1 天前
Pelco KBD300A 模拟器:06.用 PyQt5 实现 1:1 像素级完美复刻 Pelco KBD300A 键盘
python·qt·自动化·运维开发