目录
1.简介
Qt-Nice-Frameless-Window 是一个基于 Qt 框架的第三方库,主要用于快速实现跨平台的无边框窗口(Frameless Window),同时解决了原生 Qt 无边框窗口在实际开发中遇到的诸多问题(如窗口拖拽、缩放、标题栏交互、平台兼容性等)。
它的核心功能有:
1.跨平台支持:兼容 Windows、Linux、macOS 三大主流系统,自动适配各平台的窗口行为规范。
2.完整的窗口交互:封装了无边框窗口的基础功能,包括:
- 窗口拖拽(标题栏区域)
 - 边缘 / 角落缩放
 - 最小化 / 最大化 / 关闭按钮交互
 - 双击标题栏最大化 / 还原
 
3.视觉增强:支持窗口阴影、半透明效果、自定义标题栏样式,提升界面美观度。
4.轻量易集成:代码结构简洁,无需复杂配置,可快速嵌入现有 Qt 项目。
5.原生体验保留:在 macOS 上保留窗口全屏手势,在 Windows 上支持任务栏预览等原生特性。
与 Qt 原生无边框的对比:
Qt 原生通过 setWindowFlags(Qt::FramelessWindowHint) 可实现无边框,但存在明显缺陷:
- 需手动实现拖拽、缩放逻辑,且跨平台适配复杂;
 - 窗口阴影、半透明效果需自行处理,不同平台表现不一致;
 - 缺失系统级窗口行为(如 Windows 任务栏右键菜单、macOS 全屏动画)。
 
而 Qt-Nice-Frameless-Window 封装了这些细节,开发者可专注于业务逻辑而非窗口基础交互。
2.安装与集成
1.获取库
git地址:https://github.com/luoyayun361/Qt-Nice-Frameless-Window.git
通常可从 GitHub 等代码仓库获取源码(如搜索 Qt-Nice-Frameless-Window),通过 Qt Creator 编译为静态库或动态库,或直接将源码文件加入项目。

2.继承核心窗口类
库中通常提供一个基础窗口类(如 NiceFramelessWindow),通过继承该类实现自定义窗口:
            
            
              cpp
              
              
            
          
          //mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include "framelesswindow.h"
#include <QString>
namespace Ui {
class MainWindow;
}
class MainWindow : public CFramelessWindow
{
    Q_OBJECT
public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();
private slots:
    void on_btnMin_clicked();
    void on_btnMax_clicked();
    void on_btnClose_clicked();
    void on_bthFull_clicked();
    void on_btnIncreaseMargin_clicked();
    void on_btnDecreaseMargin_clicked();
    void on_btnResizeable_clicked();
private:
    QString currentMargins();
private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
        
            
            
              cpp
              
              
            
          
          //mainWindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QRect>
MainWindow::MainWindow(QWidget *parent) :
    CFramelessWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
#ifdef Q_OS_WIN
    //feel free to change this number to see how it works
    setResizeableAreaWidth(8);
    //set titlebar widget, wo we can drag MainWindow by it
    setTitleBar(ui->widgetTitlebar);
    //labelTitleText is a child widget of widgetTitlebar
    //add labelTitleText to ignore list, so we can drag MainWindow by it too
    addIgnoreWidget(ui->labelTitleText);
    //further more, btnMin/btnMax... are child widgets of widgetTitlebar too
    //but we DO NOT want to drag MainWindow by them
#endif
    ui->labelMargins->setText(currentMargins());
}
MainWindow::~MainWindow()
{
    delete ui;
}
void MainWindow::on_btnMin_clicked()
{
    showMinimized();
}
void MainWindow::on_btnMax_clicked()
{
    if (isMaximized()) showNormal();
    else showMaximized();
}
void MainWindow::on_btnClose_clicked()
{
    close();
}
void MainWindow::on_bthFull_clicked()
{
    if (isFullScreen()) showNormal();
    else showFullScreen();
}
void MainWindow::on_btnIncreaseMargin_clicked()
{
    QMargins margin = contentsMargins();
    margin += 2;
    setContentsMargins(margin);
    ui->labelMargins->setText(currentMargins());
}
void MainWindow::on_btnDecreaseMargin_clicked()
{
    QMargins margin = contentsMargins();
    margin -= 2;
    setContentsMargins(margin);
    ui->labelMargins->setText(currentMargins());
}
QString MainWindow::currentMargins()
{
    QMargins margins = contentsMargins();
    QRect rect = contentsRect();
    return QString("Current Margins:%1,%2,%3,%4; ContentRect:%5,%6,%7,%8").\
            arg(margins.left()).arg(margins.top()).\
            arg(margins.right()).arg(margins.bottom()).\
            arg(rect.left()).arg(rect.top()).\
            arg(rect.right()).arg(rect.bottom());
}
void MainWindow::on_btnResizeable_clicked()
{
    setResizeable(!isResizeable());
}
        3.在 main 函数中使用
            
            
              cpp
              
              
            
          
          #include "mainwindow.h"
#include <QApplication>
int main(int argc, char *argv[])
{
    QApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
    QApplication a(argc, argv);
    MainWindow w;
    w.show();
    return a.exec();
}
        4.展示效果

3.注意事项
- 不同版本的库 API 可能略有差异,需参考对应仓库的文档;
 - 若需深度定制窗口行为(如自定义缩放区域、修改阴影参数),可通过重写库提供的虚函数实现;
 - 对于高 DPI 屏幕,需确保 Qt 项目已开启高 DPI 支持(
QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling))。