]>
Commit | Line | Data |
---|---|---|
1 | /////////////////////////////////////////////////////////////////////////////// | |
2 | // Name: dnd.h | |
3 | // Purpose: declaration of the wxDropTarget class | |
4 | // Author: Robert Roebling | |
5 | // RCS-ID: $Id$ | |
6 | // Copyright: (c) 1998 Vadim Zeitlin, Robert Roebling | |
7 | // Licence: wxWindows license | |
8 | /////////////////////////////////////////////////////////////////////////////// | |
9 | ||
10 | ||
11 | #ifndef __GTKDNDH__ | |
12 | #define __GTKDNDH__ | |
13 | ||
14 | #ifdef __GNUG__ | |
15 | #pragma interface | |
16 | #endif | |
17 | ||
18 | #include "wx/defs.h" | |
19 | ||
20 | #if wxUSE_DRAG_AND_DROP | |
21 | ||
22 | #include "wx/object.h" | |
23 | #include "wx/string.h" | |
24 | #include "wx/dataobj.h" | |
25 | #include "wx/cursor.h" | |
26 | #include "wx/icon.h" | |
27 | #include "wx/gdicmn.h" | |
28 | ||
29 | //------------------------------------------------------------------------- | |
30 | // classes | |
31 | //------------------------------------------------------------------------- | |
32 | ||
33 | class wxWindow; | |
34 | ||
35 | class wxDropTarget; | |
36 | class wxTextDropTarget; | |
37 | class wxFileDropTarget; | |
38 | class wxPrivateDropTarget; | |
39 | ||
40 | class wxDropSource; | |
41 | ||
42 | //------------------------------------------------------------------------- | |
43 | // wxDropTarget | |
44 | //------------------------------------------------------------------------- | |
45 | ||
46 | class wxDropTarget: public wxObject | |
47 | { | |
48 | public: | |
49 | ||
50 | wxDropTarget(); | |
51 | ~wxDropTarget(); | |
52 | ||
53 | /* may be overridden to react to events */ | |
54 | virtual void OnEnter(); | |
55 | virtual void OnLeave(); | |
56 | ||
57 | /* may be overridden to reject certain formats or drops | |
58 | on certain areas. always returns TRUE by default | |
59 | indicating that you'd accept the data from the drag. */ | |
60 | virtual bool OnMove( int x, int y ); | |
61 | ||
62 | /* has to be overridden to accept a drop event. call | |
63 | IsSupported() to ask which formats are available | |
64 | and then call RequestData() to indicate the format | |
65 | you request. */ | |
66 | virtual bool OnDrop( int x, int y ); | |
67 | ||
68 | /* this gets called once the data has actually arrived. get | |
69 | it with GetData(). this has to be overridden. */ | |
70 | virtual bool OnData( int x, int y ); | |
71 | ||
72 | /* called from within OnDrop() to request a certain format | |
73 | from the drop event. */ | |
74 | bool RequestData( wxDataFormat format ); | |
75 | ||
76 | /* called to query what formats are available */ | |
77 | bool IsSupported( wxDataFormat format ); | |
78 | ||
79 | /* fill data with data from the dragging source */ | |
80 | bool GetData( wxDataObject *data ); | |
81 | ||
82 | // implementation | |
83 | ||
84 | void RegisterWidget( GtkWidget *widget ); | |
85 | void UnregisterWidget( GtkWidget *widget ); | |
86 | ||
87 | GdkDragContext *m_dragContext; | |
88 | GtkWidget *m_dragWidget; | |
89 | GtkSelectionData *m_dragData; | |
90 | guint m_dragTime; | |
91 | bool m_firstMotion; /* gdk has no "gdk_drag_enter" event */ | |
92 | ||
93 | void SetDragContext( GdkDragContext *dc ) { m_dragContext = dc; } | |
94 | void SetDragWidget( GtkWidget *w ) { m_dragWidget = w; } | |
95 | void SetDragData( GtkSelectionData *sd ) { m_dragData = sd; } | |
96 | void SetDragTime( guint time ) { m_dragTime = time; } | |
97 | }; | |
98 | ||
99 | //------------------------------------------------------------------------- | |
100 | // wxTextDropTarget | |
101 | //------------------------------------------------------------------------- | |
102 | ||
103 | class wxTextDropTarget: public wxDropTarget | |
104 | { | |
105 | public: | |
106 | ||
107 | wxTextDropTarget() {} | |
108 | ||
109 | virtual bool OnMove( int x, int y ); | |
110 | virtual bool OnDrop( int x, int y ); | |
111 | virtual bool OnData( int x, int y ); | |
112 | ||
113 | /* you have to override OnDropData to get at the text */ | |
114 | virtual bool OnDropText( int x, int y, const char *text ) = 0; | |
115 | ||
116 | }; | |
117 | ||
118 | //------------------------------------------------------------------------- | |
119 | // wxPrivateDropTarget | |
120 | //------------------------------------------------------------------------- | |
121 | ||
122 | class wxPrivateDropTarget: public wxDropTarget | |
123 | { | |
124 | public: | |
125 | ||
126 | /* sets id to "application/myprogram" where "myprogram" is the | |
127 | same as wxApp->GetAppName() */ | |
128 | wxPrivateDropTarget(); | |
129 | /* see SetId() below for explanation */ | |
130 | wxPrivateDropTarget( const wxString &id ); | |
131 | ||
132 | virtual bool OnMove( int x, int y ); | |
133 | virtual bool OnDrop( int x, int y ); | |
134 | virtual bool OnData( int x, int y ); | |
135 | ||
136 | /* you have to override OnDropData to get at the data */ | |
137 | virtual bool OnDropData( int x, int y, void *data, size_t size ) = 0; | |
138 | ||
139 | /* the string ID identifies the format of clipboard or DnD data. a word | |
140 | processor would e.g. add a wxTextDataObject and a wxPrivateDataObject | |
141 | to the clipboard - the latter with the Id "application/wxword" or | |
142 | "image/png". */ | |
143 | void SetId( const wxString& id ) { m_id = id; } | |
144 | wxString GetId() { return m_id; } | |
145 | ||
146 | private: | |
147 | ||
148 | wxString m_id; | |
149 | }; | |
150 | ||
151 | //---------------------------------------------------------------------------- | |
152 | // A drop target which accepts files (dragged from File Manager or Explorer) | |
153 | //---------------------------------------------------------------------------- | |
154 | ||
155 | class wxFileDropTarget: public wxDropTarget | |
156 | { | |
157 | public: | |
158 | ||
159 | wxFileDropTarget() {} | |
160 | ||
161 | virtual bool OnMove( int x, int y ); | |
162 | virtual bool OnDrop( int x, int y ); | |
163 | virtual bool OnData( int x, int y ); | |
164 | ||
165 | /* you have to override OnDropFiles to get at the file names */ | |
166 | virtual bool OnDropFiles( int x, int y, size_t nFiles, const wxChar * const aszFiles[] ) = 0; | |
167 | ||
168 | }; | |
169 | ||
170 | //------------------------------------------------------------------------- | |
171 | // wxDropSource | |
172 | //------------------------------------------------------------------------- | |
173 | ||
174 | enum wxDragResult | |
175 | { | |
176 | wxDragError, // error prevented the d&d operation from completing | |
177 | wxDragNone, // drag target didn't accept the data | |
178 | wxDragCopy, // the data was successfully copied | |
179 | wxDragMove, // the data was successfully moved (MSW only) | |
180 | wxDragCancel // the operation was cancelled by user (not an error) | |
181 | }; | |
182 | ||
183 | class wxDropSource: public wxObject | |
184 | { | |
185 | public: | |
186 | ||
187 | /* constructor. set data later with SetData() */ | |
188 | wxDropSource( wxWindow *win, const wxIcon &go = wxNullIcon, const wxIcon &stop = wxNullIcon ); | |
189 | ||
190 | /* constructor for setting one data object */ | |
191 | wxDropSource( wxDataObject *data, wxWindow *win, const wxIcon &go = wxNullIcon, const wxIcon &stop = wxNullIcon ); | |
192 | ||
193 | /* constructor for setting several data objects via wxDataBroker */ | |
194 | wxDropSource( wxDataBroker *data, wxWindow *win ); | |
195 | ||
196 | ~wxDropSource(); | |
197 | ||
198 | /* set several dataobjects via wxDataBroker */ | |
199 | void SetData( wxDataBroker *data ); | |
200 | ||
201 | /* set one dataobject */ | |
202 | void SetData( wxDataObject *data ); | |
203 | ||
204 | /* start drag action */ | |
205 | wxDragResult DoDragDrop( bool bAllowMove = FALSE ); | |
206 | ||
207 | /* override to give feedback */ | |
208 | virtual bool GiveFeedback( wxDragResult WXUNUSED(effect), bool WXUNUSED(bScrolling) ) { return TRUE; } | |
209 | ||
210 | /* GTK implementation */ | |
211 | ||
212 | void RegisterWindow(); | |
213 | void UnregisterWindow(); | |
214 | ||
215 | GtkWidget *m_widget; | |
216 | wxWindow *m_window; | |
217 | wxDragResult m_retValue; | |
218 | wxDataBroker *m_data; | |
219 | ||
220 | wxCursor m_defaultCursor; | |
221 | wxCursor m_goaheadCursor; | |
222 | ||
223 | wxIcon m_goIcon; | |
224 | wxIcon m_stopIcon; | |
225 | ||
226 | bool m_waiting; | |
227 | }; | |
228 | ||
229 | #endif | |
230 | ||
231 | // wxUSE_DRAG_AND_DROP | |
232 | ||
233 | #endif | |
234 | //__GTKDNDH__ | |
235 |