| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 | 
							- /////////////////////////////////////////////////////////////////////////////
 
- // Name:        wx/msw/dragimag.h
 
- // Purpose:     wxDragImage class: a kind of a cursor, that can cope
 
- //              with more sophisticated images
 
- // Author:      Julian Smart
 
- // Modified by:
 
- // Created:     08/04/99
 
- // Copyright:   (c) Julian Smart
 
- // Licence:     wxWindows licence
 
- /////////////////////////////////////////////////////////////////////////////
 
- #ifndef _WX_DRAGIMAG_H_
 
- #define _WX_DRAGIMAG_H_
 
- #if wxUSE_DRAGIMAGE
 
- #include "wx/bitmap.h"
 
- #include "wx/icon.h"
 
- #include "wx/cursor.h"
 
- #include "wx/treectrl.h"
 
- #include "wx/listctrl.h"
 
- // If 1, use a simple wxCursor instead of ImageList_SetDragCursorImage
 
- #define wxUSE_SIMPLER_DRAGIMAGE 0
 
- /*
 
-   To use this class, create a wxDragImage when you start dragging, for example:
 
-   void MyTreeCtrl::OnBeginDrag(wxTreeEvent& event)
 
-   {
 
- #ifdef __WXMSW__
 
-     ::UpdateWindow((HWND) GetHWND()); // We need to implement this in wxWidgets
 
- #endif
 
-     CaptureMouse();
 
-     m_dragImage = new wxDragImage(* this, itemId);
 
-     m_dragImage->BeginDrag(wxPoint(0, 0), this);
 
-     m_dragImage->Move(pt, this);
 
-     m_dragImage->Show(this);
 
-     ...
 
-   }
 
-   In your OnMouseMove function, hide the image, do any display updating required,
 
-   then move and show the image again:
 
-   void MyTreeCtrl::OnMouseMove(wxMouseEvent& event)
 
-   {
 
-     if (m_dragMode == MY_TREE_DRAG_NONE)
 
-     {
 
-         event.Skip();
 
-         return;
 
-     }
 
-     // Prevent screen corruption by hiding the image
 
-     if (m_dragImage)
 
-         m_dragImage->Hide(this);
 
-     // Do some updating of the window, such as highlighting the drop target
 
-     ...
 
- #ifdef __WXMSW__
 
-     if (updateWindow)
 
-         ::UpdateWindow((HWND) GetHWND());
 
- #endif
 
-     // Move and show the image again
 
-     m_dragImage->Move(event.GetPosition(), this);
 
-     m_dragImage->Show(this);
 
-  }
 
-  Eventually we end the drag and delete the drag image.
 
-  void MyTreeCtrl::OnLeftUp(wxMouseEvent& event)
 
-  {
 
-     ...
 
-     // End the drag and delete the drag image
 
-     if (m_dragImage)
 
-     {
 
-         m_dragImage->EndDrag(this);
 
-         delete m_dragImage;
 
-         m_dragImage = NULL;
 
-     }
 
-     ReleaseMouse();
 
-  }
 
- */
 
- /*
 
-  Notes for Unix version:
 
-  Can we simply use cursors instead, creating a cursor dynamically, setting it into the window
 
-  in BeginDrag, and restoring the old cursor in EndDrag?
 
-  For a really bog-standard implementation, we could simply use a normal dragging cursor
 
-  and ignore the image.
 
- */
 
- /*
 
-  * wxDragImage
 
-  */
 
- class WXDLLIMPEXP_CORE wxDragImage: public wxObject
 
- {
 
- public:
 
-     // Ctors & dtor
 
-     ////////////////////////////////////////////////////////////////////////////
 
-     wxDragImage();
 
-     wxDragImage(const wxBitmap& image, const wxCursor& cursor = wxNullCursor)
 
-     {
 
-         Init();
 
-         Create(image, cursor);
 
-     }
 
-     wxDragImage(const wxIcon& image, const wxCursor& cursor = wxNullCursor)
 
-     {
 
-         Init();
 
-         Create(image, cursor);
 
-     }
 
-     wxDragImage(const wxString& str, const wxCursor& cursor = wxNullCursor)
 
-     {
 
-         Init();
 
-         Create(str, cursor);
 
-     }
 
- #if wxUSE_TREECTRL
 
-     wxDragImage(const wxTreeCtrl& treeCtrl, wxTreeItemId& id)
 
-     {
 
-         Init();
 
-         Create(treeCtrl, id);
 
-     }
 
- #endif
 
- #if wxUSE_LISTCTRL
 
-     wxDragImage(const wxListCtrl& listCtrl, long id)
 
-     {
 
-         Init();
 
-         Create(listCtrl, id);
 
-     }
 
- #endif
 
-     virtual ~wxDragImage();
 
-     // Attributes
 
-     ////////////////////////////////////////////////////////////////////////////
 
-     // Operations
 
-     ////////////////////////////////////////////////////////////////////////////
 
-     // Create a drag image from a bitmap and optional cursor
 
-     bool Create(const wxBitmap& image, const wxCursor& cursor = wxNullCursor);
 
-     // Create a drag image from an icon and optional cursor
 
-     bool Create(const wxIcon& image, const wxCursor& cursor = wxNullCursor);
 
-     // Create a drag image from a string and optional cursor
 
-     bool Create(const wxString& str, const wxCursor& cursor = wxNullCursor);
 
- #if wxUSE_TREECTRL
 
-     // Create a drag image for the given tree control item
 
-     bool Create(const wxTreeCtrl& treeCtrl, wxTreeItemId& id);
 
- #endif
 
- #if wxUSE_LISTCTRL
 
-     // Create a drag image for the given list control item
 
-     bool Create(const wxListCtrl& listCtrl, long id);
 
- #endif
 
-     // Begin drag. hotspot is the location of the drag position relative to the upper-left
 
-     // corner of the image.
 
-     bool BeginDrag(const wxPoint& hotspot, wxWindow* window, bool fullScreen = false, wxRect* rect = NULL);
 
-     // Begin drag. hotspot is the location of the drag position relative to the upper-left
 
-     // corner of the image. This is full screen only. fullScreenRect gives the
 
-     // position of the window on the screen, to restrict the drag to.
 
-     bool BeginDrag(const wxPoint& hotspot, wxWindow* window, wxWindow* fullScreenRect);
 
-     // End drag
 
-     bool EndDrag();
 
-     // Move the image: call from OnMouseMove. Pt is in window client coordinates if window
 
-     // is non-NULL, or in screen coordinates if NULL.
 
-     bool Move(const wxPoint& pt);
 
-     // Show the image
 
-     bool Show();
 
-     // Hide the image
 
-     bool Hide();
 
-     // Implementation
 
-     ////////////////////////////////////////////////////////////////////////////
 
-     // Initialize variables
 
-     void Init();
 
-     // Returns the native image list handle
 
-     WXHIMAGELIST GetHIMAGELIST() const { return m_hImageList; }
 
- #if !wxUSE_SIMPLER_DRAGIMAGE
 
-     // Returns the native image list handle for the cursor
 
-     WXHIMAGELIST GetCursorHIMAGELIST() const { return m_hCursorImageList; }
 
- #endif
 
-     // don't use in new code, use versions without hot spot parameter
 
- #if WXWIN_COMPATIBILITY_2_8
 
-     wxDEPRECATED_CONSTRUCTOR( wxDragImage(const wxBitmap& image, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
-     wxDEPRECATED_CONSTRUCTOR( wxDragImage(const wxString& str, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
-     wxDEPRECATED_CONSTRUCTOR( wxDragImage(const wxIcon& image, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
-     wxDEPRECATED( bool Create(const wxBitmap& image, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
-     wxDEPRECATED( bool Create(const wxIcon& image, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
-     wxDEPRECATED( bool Create(const wxString& str, const wxCursor& cursor, const wxPoint& cursorHotspot) );
 
- #endif // WXWIN_COMPATIBILITY_2_8
 
- protected:
 
-     WXHIMAGELIST    m_hImageList;
 
- #if wxUSE_SIMPLER_DRAGIMAGE
 
-     wxCursor        m_oldCursor;
 
- #else
 
-     WXHIMAGELIST    m_hCursorImageList;
 
- #endif
 
-     wxCursor        m_cursor;
 
- //    wxPoint         m_cursorHotspot; // Obsolete
 
-     wxPoint         m_position;
 
-     wxWindow*       m_window;
 
-     wxRect          m_boundingRect;
 
-     bool            m_fullScreen;
 
- private:
 
-     DECLARE_DYNAMIC_CLASS(wxDragImage)
 
-     wxDECLARE_NO_COPY_CLASS(wxDragImage);
 
- };
 
- #endif // wxUSE_DRAGIMAGE
 
- #endif
 
-     // _WX_DRAGIMAG_H_
 
 
  |