Added variable cursor to highlight embedded user data.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2141 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -58,6 +58,7 @@ BEGIN_EVENT_TABLE(wxLayoutWindow,wxScrolledWindow)
|
|||||||
EVT_LEFT_DOWN(wxLayoutWindow::OnLeftMouseClick)
|
EVT_LEFT_DOWN(wxLayoutWindow::OnLeftMouseClick)
|
||||||
EVT_RIGHT_DOWN(wxLayoutWindow::OnRightMouseClick)
|
EVT_RIGHT_DOWN(wxLayoutWindow::OnRightMouseClick)
|
||||||
EVT_LEFT_DCLICK(wxLayoutWindow::OnMouseDblClick)
|
EVT_LEFT_DCLICK(wxLayoutWindow::OnMouseDblClick)
|
||||||
|
EVT_MOTION (wxLayoutWindow::OnMouseMove)
|
||||||
EVT_MENU_RANGE(WXLOWIN_MENU_FIRST, WXLOWIN_MENU_LAST, wxLayoutWindow::OnMenu)
|
EVT_MENU_RANGE(WXLOWIN_MENU_FIRST, WXLOWIN_MENU_LAST, wxLayoutWindow::OnMenu)
|
||||||
EVT_SET_FOCUS(wxLayoutWindow::OnSetFocus)
|
EVT_SET_FOCUS(wxLayoutWindow::OnSetFocus)
|
||||||
EVT_KILL_FOCUS(wxLayoutWindow::OnKillFocus)
|
EVT_KILL_FOCUS(wxLayoutWindow::OnKillFocus)
|
||||||
@@ -142,6 +143,24 @@ wxLayoutWindow::OnMouse(int eventId, wxMouseEvent& event)
|
|||||||
wxLogDebug("wxLayoutWindow::OnMouse: Found no object.");
|
wxLogDebug("wxLayoutWindow::OnMouse: Found no object.");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//has the mouse only been moved?
|
||||||
|
if(eventId == WXLOWIN_MENU_MOUSEMOVE)
|
||||||
|
{
|
||||||
|
if(obj && obj->GetUserData() != NULL)
|
||||||
|
{
|
||||||
|
if(!m_HandCursor)
|
||||||
|
SetCursor(wxCURSOR_HAND);
|
||||||
|
m_HandCursor = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(m_HandCursor)
|
||||||
|
SetCursor(wxCURSOR_IBEAM);
|
||||||
|
m_HandCursor = FALSE;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// always move cursor to mouse click:
|
// always move cursor to mouse click:
|
||||||
if(obj && eventId == WXLOWIN_MENU_LCLICK)
|
if(obj && eventId == WXLOWIN_MENU_LCLICK)
|
||||||
{
|
{
|
||||||
|
@@ -38,7 +38,8 @@ enum
|
|||||||
WXLOWIN_MENU_RCLICK,
|
WXLOWIN_MENU_RCLICK,
|
||||||
WXLOWIN_MENU_LCLICK,
|
WXLOWIN_MENU_LCLICK,
|
||||||
WXLOWIN_MENU_DBLCLICK,
|
WXLOWIN_MENU_DBLCLICK,
|
||||||
WXLOWIN_MENU_LAST = WXLOWIN_MENU_DBLCLICK
|
WXLOWIN_MENU_MOUSEMOVE,
|
||||||
|
WXLOWIN_MENU_LAST = WXLOWIN_MENU_MOUSEMOVE
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -131,6 +132,7 @@ public:
|
|||||||
void OnLeftMouseClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_LCLICK, event); }
|
void OnLeftMouseClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_LCLICK, event); }
|
||||||
void OnRightMouseClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_RCLICK, event); }
|
void OnRightMouseClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_RCLICK, event); }
|
||||||
void OnMouseDblClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_DBLCLICK, event); }
|
void OnMouseDblClick(wxMouseEvent& event) { OnMouse(WXLOWIN_MENU_DBLCLICK, event); }
|
||||||
|
void OnMouseMove(wxMouseEvent &event) { OnMouse(WXLOWIN_MENU_MOUSEMOVE, event) ; }
|
||||||
void OnSetFocus(wxFocusEvent &ev);
|
void OnSetFocus(wxFocusEvent &ev);
|
||||||
void OnKillFocus(wxFocusEvent &ev);
|
void OnKillFocus(wxFocusEvent &ev);
|
||||||
//@}
|
//@}
|
||||||
@@ -170,6 +172,8 @@ protected:
|
|||||||
bool m_DoPopupMenu;
|
bool m_DoPopupMenu;
|
||||||
/// Should InternalPaint() scroll to cursor.
|
/// Should InternalPaint() scroll to cursor.
|
||||||
bool m_ScrollToCursor;
|
bool m_ScrollToCursor;
|
||||||
|
/// Do we currently have a non-standard cursor?
|
||||||
|
bool m_HandCursor;
|
||||||
/// the menu
|
/// the menu
|
||||||
wxMenu * m_PopupMenu;
|
wxMenu * m_PopupMenu;
|
||||||
/// for derived classes, set when mouse is clicked
|
/// for derived classes, set when mouse is clicked
|
||||||
|
Reference in New Issue
Block a user