1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/generic/dragimgg.h 
   3 // Purpose:     wxDragImage class: a kind of a cursor, that can cope 
   4 //              with more sophisticated images 
   5 // Author:      Julian Smart 
   9 // Copyright:   (c) Julian Smart 
  10 // Licence:     wxWindows licence 
  11 ///////////////////////////////////////////////////////////////////////////// 
  13 #ifndef _WX_DRAGIMGG_H_ 
  14 #define _WX_DRAGIMGG_H_ 
  17 #pragma interface "dragimgg.h" 
  20 #include "wx/bitmap.h" 
  22 #include "wx/cursor.h" 
  23 #include "wx/treectrl.h" 
  24 #include "wx/listctrl.h" 
  27   To use this class, create a wxDragImage when you start dragging, for example: 
  29   void MyTreeCtrl::OnBeginDrag(wxTreeEvent& event) 
  32     ::UpdateWindow((HWND) GetHWND()); // We need to implement this in wxWindows 
  37     m_dragImage = new wxDragImage(* this, itemId); 
  38     m_dragImage->BeginDrag(wxPoint(0, 0), this); 
  39     m_dragImage->Move(pt, this); 
  40     m_dragImage->Show(this); 
  44   In your OnMouseMove function, hide the image, do any display updating required, 
  45   then move and show the image again: 
  47   void MyTreeCtrl::OnMouseMove(wxMouseEvent& event) 
  49     if (m_dragMode == MY_TREE_DRAG_NONE) 
  55     // Prevent screen corruption by hiding the image 
  57         m_dragImage->Hide(this); 
  59     // Do some updating of the window, such as highlighting the drop target 
  64         ::UpdateWindow((HWND) GetHWND()); 
  67     // Move and show the image again 
  68     m_dragImage->Move(event.GetPosition(), this); 
  69     m_dragImage->Show(this); 
  72  Eventually we end the drag and delete the drag image. 
  74  void MyTreeCtrl::OnLeftUp(wxMouseEvent& event) 
  78     // End the drag and delete the drag image 
  81         m_dragImage->EndDrag(this); 
  93 class WXDLLEXPORT wxGenericDragImage
: public wxObject
 
  98     //////////////////////////////////////////////////////////////////////////// 
 100     wxGenericDragImage(const wxCursor
& cursor 
= wxNullCursor
) 
 106     // Deprecated version of the above 
 107     wxGenericDragImage(const wxCursor
& cursor
, const wxPoint
& cursorHotspot
) 
 110         Create(cursor
, cursorHotspot
); 
 113     wxGenericDragImage(const wxBitmap
& image
, const wxCursor
& cursor 
= wxNullCursor
) 
 117         Create(image
, cursor
); 
 120     // Deprecated version of the above 
 121     wxGenericDragImage(const wxBitmap
& image
, const wxCursor
& cursor
, const wxPoint
& cursorHotspot
) 
 125         Create(image
, cursor
, cursorHotspot
); 
 128     wxGenericDragImage(const wxIcon
& image
, const wxCursor
& cursor 
= wxNullCursor
) 
 132         Create(image
, cursor
); 
 135     // Deprecated version of the above 
 136     wxGenericDragImage(const wxIcon
& image
, const wxCursor
& cursor
, const wxPoint
& cursorHotspot
) 
 140         Create(image
, cursor
, cursorHotspot
); 
 143     wxGenericDragImage(const wxString
& str
, const wxCursor
& cursor 
= wxNullCursor
) 
 150     // Deprecated version of the above 
 151     wxGenericDragImage(const wxString
& str
, const wxCursor
& cursor
, const wxPoint
& cursorHotspot
) 
 155         Create(str
, cursor
, cursorHotspot
); 
 158     wxGenericDragImage(const wxTreeCtrl
& treeCtrl
, wxTreeItemId
& id
) 
 162         Create(treeCtrl
, id
); 
 165     wxGenericDragImage(const wxListCtrl
& listCtrl
, long id
) 
 169         Create(listCtrl
, id
); 
 171     ~wxGenericDragImage(); 
 174     //////////////////////////////////////////////////////////////////////////// 
 176     // For efficiency, tell wxGenericDragImage to use a bitmap that's already 
 177     // created (e.g. from last drag) 
 178     void SetBackingBitmap(wxBitmap
* bitmap
) { m_pBackingBitmap 
= bitmap
; } 
 181     //////////////////////////////////////////////////////////////////////////// 
 183     // Create a drag image with a virtual image (need to override DoDrawImage, GetImageRect) 
 184     bool Create(const wxCursor
& cursor 
= wxNullCursor
); 
 185     bool Create(const wxCursor
& cursor
, const wxPoint
& WXUNUSED(cursorHotspot
)) 
 187         wxLogDebug(wxT("wxDragImage::Create: use of a cursor hotspot is now deprecated. Please omit this argument.")); 
 188         return Create(cursor
); 
 191     // Create a drag image from a bitmap and optional cursor 
 192     bool Create(const wxBitmap
& image
, const wxCursor
& cursor 
= wxNullCursor
); 
 193     bool Create(const wxBitmap
& image
, const wxCursor
& cursor
, const wxPoint
& WXUNUSED(cursorHotspot
)) 
 195         wxLogDebug(wxT("wxDragImage::Create: use of a cursor hotspot is now deprecated. Please omit this argument.")); 
 196         return Create(image
, cursor
); 
 199     // Create a drag image from an icon and optional cursor 
 200     bool Create(const wxIcon
& image
, const wxCursor
& cursor 
= wxNullCursor
); 
 201     bool Create(const wxIcon
& image
, const wxCursor
& cursor
, const wxPoint
& WXUNUSED(cursorHotspot
)) 
 203         wxLogDebug(wxT("wxDragImage::Create: use of a cursor hotspot is now deprecated. Please omit this argument.")); 
 204         return Create(image
, cursor
); 
 207     // Create a drag image from a string and optional cursor 
 208     bool Create(const wxString
& str
, const wxCursor
& cursor 
= wxNullCursor
); 
 209     bool Create(const wxString
& str
, const wxCursor
& cursor
, const wxPoint
& WXUNUSED(cursorHotspot
)) 
 211         wxLogDebug(wxT("wxDragImage::Create: use of a cursor hotspot is now deprecated. Please omit this argument.")); 
 212         return Create(str
, cursor
); 
 215     // Create a drag image for the given tree control item 
 216     bool Create(const wxTreeCtrl
& treeCtrl
, wxTreeItemId
& id
); 
 218     // Create a drag image for the given list control item 
 219     bool Create(const wxListCtrl
& listCtrl
, long id
); 
 221     // Begin drag. hotspot is the location of the drag position relative to the upper-left 
 222     // corner of the image. 
 223     bool BeginDrag(const wxPoint
& hotspot
, wxWindow
* window
, bool fullScreen 
= FALSE
, wxRect
* rect 
= (wxRect
*) NULL
); 
 225     // Begin drag. hotspot is the location of the drag position relative to the upper-left 
 226     // corner of the image. This is full screen only. fullScreenRect gives the 
 227     // position of the window on the screen, to restrict the drag to. 
 228     bool BeginDrag(const wxPoint
& hotspot
, wxWindow
* window
, wxWindow
* fullScreenRect
); 
 233     // Move the image: call from OnMouseMove. Pt is in window client coordinates if window 
 234     // is non-NULL, or in screen coordinates if NULL. 
 235     bool Move(const wxPoint
& pt
); 
 244     //////////////////////////////////////////////////////////////////////////// 
 248     // Override this if you are using a virtual image (drawing your own image) 
 249     virtual wxRect 
GetImageRect(const wxPoint
& pos
) const; 
 251     // Override this if you are using a virtual image (drawing your own image) 
 252     virtual bool DoDrawImage(wxDC
& dc
, const wxPoint
& pos
) const; 
 254     // Override this if you wish to draw the window contents to the backing bitmap 
 255     // yourself. This can be desirable if you wish to avoid flicker by not having to 
 256     // redraw the window itself before dragging in order to be graphic-minus-dragged-objects. 
 257     // Instead, paint the drag image's backing bitmap to be correct, and leave the window 
 258     // to be updated only when dragging the objects away (thus giving a smoother appearance). 
 259     virtual bool UpdateBackingFromWindow(wxDC
& windowDC
, wxMemoryDC
& destDC
, 
 260         const wxRect
& sourceRect
, const wxRect
& destRect
) const; 
 262     // Erase and redraw simultaneously if possible 
 263     virtual bool RedrawImage(const wxPoint
& oldPos
, const wxPoint
& newPos
, bool eraseOld
, bool drawNew
); 
 269     wxCursor        m_oldCursor
; 
 270 //    wxPoint         m_hotspot; 
 271     wxPoint         m_offset
; // The hostpot value passed to BeginDrag 
 278     // Stores the window contents while we're dragging the image around 
 279     wxBitmap        m_backingBitmap
; 
 280     wxBitmap
*       m_pBackingBitmap
; // Pointer to existing backing bitmap 
 281                                       // (pass to wxGenericDragImage as an efficiency measure) 
 282     // A temporary bitmap for repairing/redrawing 
 283     wxBitmap        m_repairBitmap
; 
 285     wxRect          m_boundingRect
; 
 289     DECLARE_DYNAMIC_CLASS(wxGenericDragImage
)