-
Notifications
You must be signed in to change notification settings - Fork 3
/
vtkKWDragAndDropTargetSet.h
181 lines (149 loc) · 6.64 KB
/
vtkKWDragAndDropTargetSet.h
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
/*=========================================================================
Module: $RCSfile: vtkKWDragAndDropTargetSet.h,v $
Copyright (c) Kitware, Inc.
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// .NAME vtkKWDragAndDropTargetSet - a set of drag and drop targets
// .SECTION Description
// This class is a container for a set of drag and drop targets.
// It provides methods to set drag and drop callbacks between a *single*
// source and one or more targets.
// This is *not* a general drag and drop framework, where DnD types would
// be created and objects would register themselves as source and/or sinks
// for any of those types. This is a simpler framework to perform specific
// DnD actions between a know source and known targets.
// An instance of this class is available in vtkKWWidget and can be used
// to register DnD actions between that vtkKWWidget source and some targets.
// .SECTION See Also
// vtkKWWidget
#ifndef __vtkKWDragAndDropTargetSet_h
#define __vtkKWDragAndDropTargetSet_h
#include "vtkKWObject.h"
class vtkKWWidget;
class vtkKWDragAndDropTargetSetInternals;
class KWWidgets_EXPORT vtkKWDragAndDropTargetSet : public vtkKWObject
{
public:
static vtkKWDragAndDropTargetSet* New();
vtkTypeRevisionMacro(vtkKWDragAndDropTargetSet,vtkKWObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Enable/disable Drag and Drop between all the source and targets.
virtual void SetEnable(int);
vtkBooleanMacro(Enable, int);
vtkGetMacro(Enable, int);
// Description:
// Set/Get the Drag and Drop source widget. This is the widget that the
// the Drag and Drop originates from.
// Make sure you have called SetApplication(..) on the instance before.
virtual void SetSource(vtkKWWidget*);
vtkGetObjectMacro(Source, vtkKWWidget);
// Description:
// Set/Get the optional Drag and Drop source anchor widget. This is the
// actual widget that the user drags and drops (i.e. the actual widget the
// user starts the interaction with). It NULL, it defaults to the
// Source widget automatically. The anchor widget is a convenient way to
// specify that a sub-part of the Source widget is to be dragged & dropped,
// not the whole Source widget.
// Make sure you have called SetApplication(..) on the instance before.
virtual void SetSourceAnchor(vtkKWWidget*);
vtkGetObjectMacro(SourceAnchor, vtkKWWidget);
// Description:
// Add/Query/Remove a Drag & Drop target.
virtual int AddTarget(vtkKWWidget *target);
virtual int RemoveTarget(vtkKWWidget *target);
virtual int HasTarget(vtkKWWidget *target);
virtual int GetNumberOfTargets();
// Description:
// Set a Drag & Drop target callbacks/commands.
// If the target has not been added yet, it will be added automatically.
// The StartCommand of all targets is called when Drag & Drop starts.
// The PerformCommand of all targets is called while Drag & Drop is
// performed.
// The EndCommand of all targets that contain the drop coordinates is called
// when Drag & Drop ends.
// The 'object' argument is the object that will have the method called on
// it. The 'method' argument is the name of the method to be called and any
// arguments in string form. If the object is NULL, the method is still
// evaluated as a simple command.
// The following parameters are also passed to the commands:
// - absolute/screen (x,y) mouse coordinates: int, int
// - the Source widget: vtkKWWidget*
// - the SourceAnchor widget: vtkKWWidget* (same as Source widget most of
// the times)
// Additionally, EndCommand is passed a 5th parameter:
// - the target: vtkKWWidget*
virtual int SetTargetStartCommand(
vtkKWWidget *target, vtkObject *object, const char *method);
virtual int SetTargetPerformCommand(
vtkKWWidget *target, vtkObject *object, const char *method);
virtual int SetTargetEndCommand(
vtkKWWidget *target, vtkObject *object, const char *method);
// Description:
// Independent of any targets, the following commands can be set:
// The StartCommand is called when Drag & Drop starts.
// The PerformCommand is called while Drag & Drop is performed.
// The EndCommand is called when Drag & Drop ends.
// The 'object' argument is the object that will have the method called on
// it. The 'method' argument is the name of the method to be called and any
// arguments in string form. If the object is NULL, the method is still
// evaluated as a simple command.
// The following parameters are also passed to the commands:
// - absolute/screen (x,y) mouse coordinates: int, int
// None of them is called if Enable is false.
// StartCommand and PerformCommand are called *before* any target's
// corresponding command. EndCommand is called *after* any target's
// EndCommand.
virtual void SetStartCommand(vtkObject *object, const char *method);
virtual void SetPerformCommand(vtkObject *object, const char *method);
virtual void SetEndCommand(vtkObject *object, const char *method);
// Description:
// Callbacks. Internal, do not use.
virtual void StartCallback(int x, int y);
virtual void PerformCallback(int x, int y);
virtual void EndCallback(int x, int y);
protected:
vtkKWDragAndDropTargetSet();
~vtkKWDragAndDropTargetSet();
// Drag and Drop
//BTX
class TargetSlot
{
public:
vtkKWWidget *Target;
char *StartCommand;
char *PerformCommand;
char *EndCommand;
void SetStartCommand(const char*);
void SetEndCommand(const char*);
void SetPerformCommand(const char*);
TargetSlot();
~TargetSlot();
};
// PIMPL Encapsulation for STL containers
vtkKWDragAndDropTargetSetInternals *Internals;
friend class vtkKWDragAndDropTargetSetInternals;
TargetSlot* GetTarget(vtkKWWidget *target);
//ETX
int Enable;
vtkKWWidget *SourceAnchor;
vtkKWWidget *Source;
char *StartCommand;
char *PerformCommand;
char *EndCommand;
virtual void InvokeCommandWithCoordinates(const char *command, int x, int y);
virtual void InvokeStartCommand(int x, int y);
virtual void InvokePerformCommand(int x, int y);
virtual void InvokeEndCommand(int x, int y);
virtual void AddBindings();
virtual void RemoveBindings();
virtual void DeleteAllTargets();
private:
vtkKWDragAndDropTargetSet(const vtkKWDragAndDropTargetSet&); // Not implemented
void operator=(const vtkKWDragAndDropTargetSet&); // Not implemented
};
#endif