]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/ole/dropsrc.h
cleanups, proper event handling/cleanup
[wxWidgets.git] / include / wx / msw / ole / dropsrc.h
CommitLineData
1737035f
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: ole/dropsrc.h
3// Purpose: declaration of the wxDropSource class
4// Author: Vadim Zeitlin
e1ee679c 5// Modified by:
1737035f
VZ
6// Created: 06.03.98
7// RCS-ID: $Id$
8// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
65571936 9// Licence: wxWindows licence
1737035f
VZ
10///////////////////////////////////////////////////////////////////////////////
11
bbcdf8bc
JS
12#ifndef _WX_OLEDROPSRC_H
13#define _WX_OLEDROPSRC_H
1737035f 14
12028905 15#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
8e193f38 16 #pragma interface
1737035f 17#endif
8e193f38 18
0a0e6a5b 19#if wxUSE_DRAG_AND_DROP
1737035f
VZ
20
21// ----------------------------------------------------------------------------
22// forward declarations
23// ----------------------------------------------------------------------------
8e193f38 24
1737035f 25class wxIDropSource;
8e193f38
VZ
26class WXDLLEXPORT wxDataObject;
27class WXDLLEXPORT wxWindow;
28
f6bcfd97
BP
29// ----------------------------------------------------------------------------
30// macros
31// ----------------------------------------------------------------------------
32
33// this macro may be used instead for wxDropSource ctor arguments: it will use
34// the cursor 'name' from the resources under MSW, but will expand to
35// something else under GTK. If you don't use it, you will have to use #ifdef
36// in the application code.
c17ba76f 37#define wxDROP_ICON(name) wxCursor(_T(#name))
f6bcfd97 38
1737035f
VZ
39// ----------------------------------------------------------------------------
40// wxDropSource is used to start the drag-&-drop operation on associated
41// wxDataObject object. It's responsible for giving UI feedback while dragging.
42// ----------------------------------------------------------------------------
8e193f38 43
9e2896e5 44class WXDLLEXPORT wxDropSource : public wxDropSourceBase
1737035f
VZ
45{
46public:
e1ee679c
VZ
47 // ctors: if you use default ctor you must call SetData() later!
48 //
49 // NB: the "wxWindow *win" parameter is unused and is here only for wxGTK
50 // compatibility, as well as both icon parameters
51 wxDropSource(wxWindow *win = NULL,
2d93e133
VZ
52 const wxCursor &cursorCopy = wxNullCursor,
53 const wxCursor &cursorMove = wxNullCursor,
54 const wxCursor &cursorStop = wxNullCursor);
e1ee679c 55 wxDropSource(wxDataObject& data,
2d93e133
VZ
56 wxWindow *win = NULL,
57 const wxCursor &cursorCopy = wxNullCursor,
58 const wxCursor &cursorMove = wxNullCursor,
59 const wxCursor &cursorStop = wxNullCursor);
e1ee679c
VZ
60
61 virtual ~wxDropSource();
62
63 // do it (call this in response to a mouse button press, for example)
64 // params: if bAllowMove is false, data can be only copied
2245b2b2 65 virtual wxDragResult DoDragDrop(int flags = wxDrag_CopyOnly);
e1ee679c
VZ
66
67 // overridable: you may give some custom UI feedback during d&d operation
68 // in this function (it's called on each mouse move, so it shouldn't be
69 // too slow). Just return false if you want default feedback.
2d93e133 70 virtual bool GiveFeedback(wxDragResult effect);
1737035f
VZ
71
72protected:
e1ee679c 73 void Init();
1737035f
VZ
74
75private:
e1ee679c 76 wxIDropSource *m_pIDropSource; // the pointer to COM interface
22f3361e
VZ
77
78 DECLARE_NO_COPY_CLASS(wxDropSource)
1737035f
VZ
79};
80
0a0e6a5b
WS
81#endif //wxUSE_DRAG_AND_DROP
82
46ccb510 83#endif //_WX_OLEDROPSRC_H