Qt Qt-Advanced-Docking-System介绍及使用教程

发布时间 2023-03-23 15:32:18作者: 一杯清酒邀明月

一.概述

1.控件描述

  QT自带的Dock布局管理大家都用过,中规中矩,但是满足不了现在ui强大的人机交互需求。而Qt-Advanced-Docking-System在Dock的基础上进一步完善功能,具有更高的自由度、灵活性和可扩展性,满足程序员对人机交互的自由定义。这个开源控件类似于Devexpress中的DockPanel。

二.使用教程

1.新建QT项目

在新建项目时,要选择子目录项目。

新建父项目后,会自动弹出子项目新建选项。
这个按照常规QT项目新建。

 到这里,项目新建完成,下面可以开始编写代码了。
2.引入Qt-Advanced-Docking-System
解压Qt-Advanced-Docking-System-master.zip,找到src和ads.pri。

 将src和ads.pri拷贝到父项目文件夹下

 打开父项目.pro文件,在.pro中添加

DockUse.depends = src

打开子项目中.pro文件,在.pro中添加

 1 # dock use
 2 ADS_OUT_ROOT = $${OUT_PWD}/..
 3 
 4 # dock use
 5 DESTDIR = $${ADS_OUT_ROOT}/lib
 6 CONFIG += debug_and_release
 7 adsBuildStatic {
 8     DEFINES += ADS_STATIC
 9 }
10 
11 #LIBS += -L$${ADS_OUT_ROOT}/lib
12 include(../ads.pri)
13 INCLUDEPATH += ./src
14 DEPENDPATH += ./src
15 LIBS += -LD:/LiumuyiProgram/QTCode/TestPrograms/DoclProTest/ -lqtadvanceddockingd

在mainwindow.h中,引用

1 #include "../src/DockManager.h"
2 #include "qlabel.h"

定义变量

ads::CDockManager* m_pDockManager;

在mainwindow.cpp中,可以在构造函数中加入:

 1 m_pDockManager = new ads::CDockManager(this);
 2 
 3     QLabel* l = new QLabel();
 4     l->setWordWrap(true);
 5     l->setAlignment(Qt::AlignTop | Qt::AlignLeft);
 6     l->setText("Lorem ipsum dolor sit amet, consectetuer adipiscing elit. ");
 7 
 8 
 9     ads::CDockWidget* DockWidget = new ads::CDockWidget("Label 1");
10     DockWidget->setWidget(l);
11 
12     QLabel* ll = new QLabel();
13     ll->setWordWrap(true);
14     ll->setAlignment(Qt::AlignTop | Qt::AlignLeft);
15     ll->setText("Lorem ipsum dolor sit amet, consectetuer adipiscing elit. ");
16 
17 
18     ads::CDockWidget* DockWidget1 = new ads::CDockWidget("Label 2");
19     DockWidget1->setWidget(ll);
20 
21 
22     ui->menubar->addAction(DockWidget->toggleViewAction());
23     ui->menubar->addAction(DockWidget1->toggleViewAction());
24 
25     m_pDockManager->addDockWidget(ads::TopDockWidgetArea, DockWidget);
26     m_pDockManager->addDockWidget(ads::TopDockWidgetArea, DockWidget1);

然后依次构造编译,就完成了!