]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/msw/ole/dropsrc.h
1 ///////////////////////////////////////////////////////////////////////////////
3 // Purpose: declaration of the wxDropSource class
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // Licence: wxWindows licence
10 ///////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_OLEDROPSRC_H
13 #define _WX_OLEDROPSRC_H
18 #include "wx/window.h"
19 #if !wxUSE_DRAG_AND_DROP
20 #error "You should #define wxUSE_DRAG_AND_DROP to 1 to compile this file!"
23 // ----------------------------------------------------------------------------
24 // forward declarations
25 // ----------------------------------------------------------------------------
31 wxDragError
, // error prevented the d&d operation from completing
32 wxDragNone
, // drag target didn't accept the data
33 wxDragCopy
, // the data was successfully copied
34 wxDragMove
, // the data was successfully moved
35 wxDragCancel
// the operation was cancelled by user (not an error)
38 // ----------------------------------------------------------------------------
39 // wxDropSource is used to start the drag-&-drop operation on associated
40 // wxDataObject object. It's responsible for giving UI feedback while dragging.
41 // ----------------------------------------------------------------------------
42 class WXDLLEXPORT wxDropSource
45 // ctors: if you use default ctor you must call SetData() later!
46 // NB: the "wxWindow *win" parameter is unused and is here only for wxGTK
48 wxDropSource(wxWindow
*win
= NULL
);
49 wxDropSource(wxDataObject
& data
, wxWindow
*win
= NULL
);
51 void SetData(wxDataObject
& data
);
53 virtual ~wxDropSource();
55 // do it (call this in response to a mouse button press, for example)
56 // params: if bAllowMove is false, data can be only copied
57 wxDragResult
DoDragDrop(bool bAllowMove
= FALSE
);
59 // overridable: you may give some custom UI feedback during d&d operation
60 // in this function (it's called on each mouse move, so it shouldn't be too
61 // slow). Just return false if you want default feedback.
62 virtual bool GiveFeedback(wxDragResult effect
, bool bScrolling
);
67 wxDataObject
*m_pData
; // pointer to associated data object
70 wxIDropSource
*m_pIDropSource
; // the pointer to COM interface
73 #endif //_WX_OLEDROPSRC_H