2017-02-25 05:44:02 +08:00
|
|
|
#ifndef ads_globalsH
|
|
|
|
#define ads_globalsH
|
2017-02-27 21:15:20 +08:00
|
|
|
/*******************************************************************************
|
2017-06-10 04:04:02 +08:00
|
|
|
** Qt Advanced Docking System
|
2017-02-27 21:15:20 +08:00
|
|
|
** Copyright (C) 2017 Uwe Kindler
|
2017-06-10 04:04:02 +08:00
|
|
|
**
|
|
|
|
** This library is free software; you can redistribute it and/or
|
|
|
|
** modify it under the terms of the GNU Lesser General Public
|
|
|
|
** License as published by the Free Software Foundation; either
|
|
|
|
** version 2.1 of the License, or (at your option) any later version.
|
|
|
|
**
|
|
|
|
** This library is distributed in the hope that it will be useful,
|
2017-02-27 21:15:20 +08:00
|
|
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2017-06-10 04:04:02 +08:00
|
|
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
** Lesser General Public License for more details.
|
|
|
|
**
|
|
|
|
** You should have received a copy of the GNU Lesser General Public
|
|
|
|
** License along with this library; If not, see <http://www.gnu.org/licenses/>.
|
2017-02-27 21:15:20 +08:00
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
2017-02-25 05:44:02 +08:00
|
|
|
//============================================================================
|
|
|
|
/// \file ads_globals.h
|
|
|
|
/// \author Uwe Kindler
|
|
|
|
/// \date 24.02.2017
|
2017-02-27 21:15:20 +08:00
|
|
|
/// \brief Declaration of
|
2017-02-25 05:44:02 +08:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
// INCLUDES
|
|
|
|
//============================================================================
|
2017-02-27 01:13:56 +08:00
|
|
|
#include <QPair>
|
2018-07-17 21:11:49 +08:00
|
|
|
#include <QtCore/QtGlobal>
|
2018-11-08 17:04:29 +08:00
|
|
|
#include <QPixmap>
|
2018-12-11 22:19:59 +08:00
|
|
|
#include <QWidget>
|
2019-11-26 21:40:56 +08:00
|
|
|
#include <QDebug>
|
2018-07-17 21:11:49 +08:00
|
|
|
|
2019-01-16 17:44:34 +08:00
|
|
|
#ifndef ADS_STATIC
|
2018-07-17 21:11:49 +08:00
|
|
|
#ifdef ADS_SHARED_EXPORT
|
|
|
|
#define ADS_EXPORT Q_DECL_EXPORT
|
|
|
|
#else
|
|
|
|
#define ADS_EXPORT Q_DECL_IMPORT
|
|
|
|
#endif
|
2019-01-16 17:44:34 +08:00
|
|
|
#else
|
|
|
|
#define ADS_EXPORT
|
|
|
|
#endif
|
2017-02-27 01:13:56 +08:00
|
|
|
|
2019-08-26 13:58:56 +08:00
|
|
|
// Define ADS_DEBUG_PRINT to enable a lot of debug output
|
2019-07-21 15:53:24 +08:00
|
|
|
#ifdef ADS_DEBUG_PRINT
|
|
|
|
#define ADS_PRINT(s) qDebug() << s
|
|
|
|
#else
|
|
|
|
#define ADS_PRINT(s)
|
|
|
|
#endif
|
|
|
|
|
2019-08-26 13:58:56 +08:00
|
|
|
// Set ADS_DEBUG_LEVEL to enable additional debug output and to enable layout
|
|
|
|
// dumps to qDebug and std::cout after layout changes
|
2018-09-14 14:46:10 +08:00
|
|
|
#define ADS_DEBUG_LEVEL 0
|
|
|
|
|
2017-02-25 05:44:02 +08:00
|
|
|
class QSplitter;
|
|
|
|
|
|
|
|
namespace ads
|
|
|
|
{
|
2019-11-29 22:56:57 +08:00
|
|
|
enum eStateFileVersion
|
|
|
|
{
|
|
|
|
InitialVerison = 0,
|
|
|
|
Version1 = 1,
|
|
|
|
CurrentVersion = Version1
|
|
|
|
};
|
|
|
|
|
2018-12-03 19:52:57 +08:00
|
|
|
class CDockSplitter;
|
|
|
|
|
2017-02-25 05:44:02 +08:00
|
|
|
enum DockWidgetArea
|
|
|
|
{
|
|
|
|
NoDockWidgetArea = 0x00,
|
|
|
|
LeftDockWidgetArea = 0x01,
|
|
|
|
RightDockWidgetArea = 0x02,
|
|
|
|
TopDockWidgetArea = 0x04,
|
|
|
|
BottomDockWidgetArea = 0x08,
|
|
|
|
CenterDockWidgetArea = 0x10,
|
|
|
|
|
2017-03-02 18:43:48 +08:00
|
|
|
InvalidDockWidgetArea = NoDockWidgetArea,
|
2017-02-27 01:13:56 +08:00
|
|
|
OuterDockAreas = TopDockWidgetArea | LeftDockWidgetArea | RightDockWidgetArea | BottomDockWidgetArea,
|
|
|
|
AllDockAreas = OuterDockAreas | CenterDockWidgetArea
|
2017-02-25 05:44:02 +08:00
|
|
|
};
|
|
|
|
Q_DECLARE_FLAGS(DockWidgetAreas, DockWidgetArea)
|
|
|
|
|
2017-03-27 16:41:27 +08:00
|
|
|
|
2018-11-04 03:51:02 +08:00
|
|
|
enum TitleBarButton
|
|
|
|
{
|
|
|
|
TitleBarButtonTabsMenu,
|
|
|
|
TitleBarButtonUndock,
|
|
|
|
TitleBarButtonClose
|
|
|
|
};
|
|
|
|
|
2018-12-20 23:25:30 +08:00
|
|
|
/**
|
|
|
|
* The different dragging states
|
|
|
|
*/
|
|
|
|
enum eDragState
|
|
|
|
{
|
|
|
|
DraggingInactive, //!< DraggingInactive
|
|
|
|
DraggingMousePressed, //!< DraggingMousePressed
|
|
|
|
DraggingTab, //!< DraggingTab
|
|
|
|
DraggingFloatingWidget//!< DraggingFloatingWidget
|
|
|
|
};
|
|
|
|
|
2019-10-18 14:31:26 +08:00
|
|
|
/**
|
|
|
|
* The different icons used in the UI
|
|
|
|
*/
|
|
|
|
enum eIcon
|
|
|
|
{
|
|
|
|
TabCloseIcon, //!< TabCloseIcon
|
|
|
|
DockAreaMenuIcon, //!< DockAreaMenuIcon
|
|
|
|
DockAreaUndockIcon,//!< DockAreaUndockIcon
|
|
|
|
DockAreaCloseIcon, //!< DockAreaCloseIcon
|
|
|
|
|
|
|
|
IconCount, //!< just a delimiter for range checks
|
|
|
|
};
|
|
|
|
|
2020-01-06 18:42:36 +08:00
|
|
|
/**
|
|
|
|
* For bitwise combination of dock wdget features
|
|
|
|
*/
|
|
|
|
enum eBitwiseOperator
|
|
|
|
{
|
|
|
|
BitwiseAnd,
|
|
|
|
BitwiseOr
|
|
|
|
};
|
|
|
|
|
2017-02-25 05:44:02 +08:00
|
|
|
namespace internal
|
|
|
|
{
|
2018-12-11 22:19:59 +08:00
|
|
|
static const bool RestoreTesting = true;
|
|
|
|
static const bool Restore = false;
|
2019-10-01 17:48:53 +08:00
|
|
|
static const char* const ClosedProperty = "close";
|
|
|
|
static const char* const DirtyProperty = "dirty";
|
2017-02-27 01:13:56 +08:00
|
|
|
|
2017-03-01 21:09:56 +08:00
|
|
|
/**
|
|
|
|
* Replace the from widget in the given splitter with the To widget
|
|
|
|
*/
|
|
|
|
void replaceSplitterWidget(QSplitter* Splitter, QWidget* From, QWidget* To);
|
|
|
|
|
2018-12-03 19:52:57 +08:00
|
|
|
/**
|
|
|
|
* This function walks the splitter tree upwards to hides all splitters
|
|
|
|
* that do not have visible content
|
|
|
|
*/
|
|
|
|
void hideEmptyParentSplitters(CDockSplitter* FirstParentSplitter);
|
|
|
|
|
2017-03-01 05:41:34 +08:00
|
|
|
/**
|
|
|
|
* Convenience class for QPair to provide better naming than first and
|
|
|
|
* second
|
|
|
|
*/
|
|
|
|
class CDockInsertParam : public QPair<Qt::Orientation, bool>
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
using QPair::QPair;
|
|
|
|
Qt::Orientation orientation() const {return this->first;}
|
|
|
|
bool append() const {return this->second;}
|
|
|
|
int insertOffset() const {return append() ? 1 : 0;}
|
|
|
|
};
|
|
|
|
|
2017-02-27 01:13:56 +08:00
|
|
|
/**
|
|
|
|
* Returns the insertion parameters for the given dock area
|
|
|
|
*/
|
2017-03-01 05:41:34 +08:00
|
|
|
CDockInsertParam dockAreaInsertParameters(DockWidgetArea Area);
|
|
|
|
|
|
|
|
/**
|
2017-03-01 21:09:56 +08:00
|
|
|
* Searches for the parent widget of the given type.
|
|
|
|
* Returns the parent widget of the given widget or 0 if the widget is not
|
|
|
|
* child of any widget of type T
|
2018-10-15 14:29:30 +08:00
|
|
|
*
|
|
|
|
* It is not safe to use this function in in CDockWidget because only
|
|
|
|
* the current dock widget has a parent. All dock widgets that are not the
|
|
|
|
* current dock widget in a dock area have no parent.
|
2017-03-01 05:41:34 +08:00
|
|
|
*/
|
2017-03-01 21:09:56 +08:00
|
|
|
template <class T>
|
|
|
|
T findParent(const QWidget* w)
|
|
|
|
{
|
|
|
|
QWidget* parentWidget = w->parentWidget();
|
|
|
|
while (parentWidget)
|
|
|
|
{
|
2018-10-10 21:15:59 +08:00
|
|
|
T ParentImpl = qobject_cast<T>(parentWidget);
|
2017-03-01 21:09:56 +08:00
|
|
|
if (ParentImpl)
|
|
|
|
{
|
|
|
|
return ParentImpl;
|
|
|
|
}
|
|
|
|
parentWidget = parentWidget->parentWidget();
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-11-08 17:04:29 +08:00
|
|
|
/**
|
|
|
|
* Creates a semi transparent pixmap from the given pixmap Source.
|
|
|
|
* The Opacity parameter defines the opacity from completely transparent (0.0)
|
|
|
|
* to completely opaque (1.0)
|
|
|
|
*/
|
|
|
|
QPixmap createTransparentPixmap(const QPixmap& Source, qreal Opacity);
|
|
|
|
|
2019-09-13 20:19:43 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper function for settings flags in a QFlags instance.
|
|
|
|
*/
|
|
|
|
template <class T>
|
|
|
|
void setFlag(T& Flags, typename T::enum_type flag, bool on = true)
|
|
|
|
{
|
|
|
|
#if QT_VERSION >= 0x050700
|
|
|
|
Flags.setFlag(flag, on);
|
|
|
|
#else
|
|
|
|
if(on)
|
|
|
|
{
|
2019-09-13 20:26:18 +08:00
|
|
|
Flags |= flag;
|
2019-09-13 20:19:43 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-13 20:26:18 +08:00
|
|
|
Flags &= ~flag;
|
2019-09-13 20:19:43 +08:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2017-02-25 05:44:02 +08:00
|
|
|
} // namespace internal
|
|
|
|
} // namespace ads
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
#endif // ads_globalsH
|