blob: ed578da993ae7e99419f48e815fb14a6439f8022 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
// Copyright (C) 2020 Uwe Kindler
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-2.1-or-later OR GPL-3.0-or-later
#pragma once
#include "floatingdockcontainer.h"
#include <QWidget>
namespace ADS {
class DockWidget;
class DockAreaWidget;
class FloatingDragPreviewPrivate;
/**
* A floating overlay is a temporary floating widget that is just used to
* indicate the floating widget movement.
* This widget is used as a placeholder for drag operations for non-opaque
* docking
*/
class FloatingDragPreview : public QWidget, public AbstractFloatingWidget
{
Q_OBJECT
private:
FloatingDragPreviewPrivate *d;
friend class FloatingDragPreviewPrivate;
/**
* Cancel non opaque undocking if application becomes inactive
*/
void onApplicationStateChanged(Qt::ApplicationState state);
protected:
/**
* Cares about painting the
*/
void paintEvent(QPaintEvent *event) override;
/**
* The content is a DockArea or a DockWidget
*/
FloatingDragPreview(QWidget *content, QWidget *parent);
public:
using Super = QWidget;
/**
* Creates an instance for undocking the DockWidget in Content parameter
*/
FloatingDragPreview(DockWidget *content);
/**
* Creates an instance for undocking the DockArea given in Content
* parameters
*/
FloatingDragPreview(DockAreaWidget *content);
/**
* Delete private data
*/
~FloatingDragPreview() override;
/**
* We filter the events of the assigned content widget to receive
* escape key presses for canceling the drag operation
*/
bool eventFilter(QObject *watched, QEvent *event) override;
public: // implements AbstractFloatingWidget
void startFloating(const QPoint &dragStartMousePos,
const QSize &size,
eDragState dragState,
QWidget *mouseEventHandler) override;
/**
* Moves the widget to a new position relative to the position given when
* startFloating() was called
*/
void moveFloating() override;
/**
* Finishes dragging.
* Hides the dock overlays and executes the real undocking and docking
* of the assigned Content widget
*/
void finishDragging() override;
signals:
/**
* This signal is emitted, if dragging has been canceled by escape key
* or by active application switching via task manager
*/
void draggingCanceled();
}; // class FloatingDragPreview
} // namespace ADS
|