X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a660d684eda27638bca0384b2058911a31c8e845..ab9717339232a7a728dea666c59b73fd6ac78dd3:/docs/latex/wx/mouseevt.tex diff --git a/docs/latex/wx/mouseevt.tex b/docs/latex/wx/mouseevt.tex index f8d03b988f..f7f87bf4b9 100644 --- a/docs/latex/wx/mouseevt.tex +++ b/docs/latex/wx/mouseevt.tex @@ -1,11 +1,55 @@ \section{\class{wxMouseEvent}}\label{wxmouseevent} -This event class contains information about mouse events, particularly -events received by canvases. See \helpref{wxWindow::OnMouseEvent}{wxwindowonmouseevent}. +This event class contains information about the events generated by the mouse: +they include mouse buttons press and release events and mouse move events. + +All mouse events involving the buttons use {\tt wxMOUSE\_BTN\_LEFT} for the +left mouse button, {\tt wxMOUSE\_BTN\_MIDDLE} for the middle one and +{\tt wxMOUSE\_BTN\_RIGHT} for the right one. And if the system supports more +buttons, the \texttt{wxMOUSE\_BTN\_AUX1} and \texttt{wxMOUSE\_BTN\_AUX2} events +can also be generated. Note that not all mice have even a middle button so a +portable application should avoid relying on the events from it (but the right +button click can be emulated using the left mouse button with the control key +under Mac platforms with a single button mouse). + +For the \texttt{wxEVT\_ENTER\_WINDOW} and \texttt{wxEVT\_LEAVE\_WINDOW} events +purposes, the mouse is considered to be inside the window if it is in the +window client area and not inside one of its children. In other words, the +parent window receives \texttt{wxEVT\_LEAVE\_WINDOW} event not only when the +mouse leaves the window entirely but also when it enters one of its children. + +{\bf NB:} Note that under Windows CE mouse enter and leave events are not natively supported +by the system but are generated by wxWidgets itself. This has several +drawbacks: the LEAVE\_WINDOW event might be received some time after the mouse +left the window and the state variables for it may have changed during this +time. + +{\bf NB:} Note the difference between methods like +\helpref{LeftDown}{wxmouseeventleftdown} and +\helpref{LeftIsDown}{wxmouseeventleftisdown}: the former returns {\tt true} +when the event corresponds to the left mouse button click while the latter +returns {\tt true} if the left mouse button is currently being pressed. For +example, when the user is dragging the mouse you can use +\helpref{LeftIsDown}{wxmouseeventleftisdown} to test +whether the left mouse button is (still) depressed. Also, by convention, if +\helpref{LeftDown}{wxmouseeventleftdown} returns {\tt true}, +\helpref{LeftIsDown}{wxmouseeventleftisdown} will also return {\tt true} in +wxWidgets whatever the underlying GUI behaviour is (which is +platform-dependent). The same applies, of course, to other mouse buttons as +well. \wxheading{Derived from} -\helpref{wxEvent}{wxevent} +\helpref{wxEvent}{wxevent}\\ +\helpref{wxObject}{wxobject} + +\wxheading{Include files} + + + +\wxheading{Library} + +\helpref{wxCore}{librarieslist} \wxheading{Event table macros} @@ -14,7 +58,10 @@ functions that take a wxMouseEvent argument. \twocolwidtha{7cm} \begin{twocollist}\itemsep=0pt -\twocolitem{{\bf EVT\_LEFT\_DOWN(func)}}{Process a wxEVT\_LEFT\_DOWN event.} +\twocolitem{{\bf EVT\_LEFT\_DOWN(func)}}{Process a wxEVT\_LEFT\_DOWN event. The +handler of this event should normally call \helpref{event.Skip()}{wxeventskip} to +allow the default processing to take place as otherwise the window under mouse +wouldn't get the focus.} \twocolitem{{\bf EVT\_LEFT\_UP(func)}}{Process a wxEVT\_LEFT\_UP event.} \twocolitem{{\bf EVT\_LEFT\_DCLICK(func)}}{Process a wxEVT\_LEFT\_DCLICK event.} \twocolitem{{\bf EVT\_MIDDLE\_DOWN(func)}}{Process a wxEVT\_MIDDLE\_DOWN event.} @@ -23,76 +70,111 @@ functions that take a wxMouseEvent argument. \twocolitem{{\bf EVT\_RIGHT\_DOWN(func)}}{Process a wxEVT\_RIGHT\_DOWN event.} \twocolitem{{\bf EVT\_RIGHT\_UP(func)}}{Process a wxEVT\_RIGHT\_UP event.} \twocolitem{{\bf EVT\_RIGHT\_DCLICK(func)}}{Process a wxEVT\_RIGHT\_DCLICK event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX1\_DOWN(func)}}{Process a wxEVT\_MOUSE\_AUX1\_DOWN event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX1\_UP(func)}}{Process a wxEVT\_MOUSE\_AUX1\_UP event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX1\_DCLICK(func)}}{Process a wxEVT\_MOUSE\_AUX1\_DCLICK event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX2\_DOWN(func)}}{Process a wxEVT\_MOUSE\_AUX2\_DOWN event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX2\_UP(func)}}{Process a wxEVT\_MOUSE\_AUX2\_UP event.} +\twocolitem{{\bf EVT\_MOUSE\_AUX2\_DCLICK(func)}}{Process a wxEVT\_MOUSE\_AUX2\_DCLICK event.} \twocolitem{{\bf EVT\_MOTION(func)}}{Process a wxEVT\_MOTION event.} \twocolitem{{\bf EVT\_ENTER\_WINDOW(func)}}{Process a wxEVT\_ENTER\_WINDOW event.} \twocolitem{{\bf EVT\_LEAVE\_WINDOW(func)}}{Process a wxEVT\_LEAVE\_WINDOW event.} +\twocolitem{{\bf EVT\_MOUSEWHEEL(func)}}{Process a wxEVT\_MOUSEWHEEL event.} +\twocolitem{{\bf EVT\_MOUSE\_EVENTS(func)}}{Process all mouse events.} \end{twocollist}% \latexignore{\rtfignore{\wxheading{Members}}} -\membersection{wxMouseEvent::m\_altDown} + +\membersection{wxMouseEvent::m\_altDown}\label{wxmouseeventmaltdown} \member{bool}{m\_altDown} -TRUE if the Alt key is pressed down. +true if the Alt key is pressed down. -\membersection{wxMouseEvent::m\_controlDown} + +\membersection{wxMouseEvent::m\_controlDown}\label{wxmouseeventmcontroldown} \member{bool}{m\_controlDown} -TRUE if control key is pressed down. +true if control key is pressed down. + -\membersection{wxMouseEvent::m\_leftDown} +\membersection{wxMouseEvent::m\_leftDown}\label{wxmouseeventmleftdown} \member{bool}{m\_leftDown} -TRUE if the left mouse button is currently pressed down. +true if the left mouse button is currently pressed down. -\membersection{wxMouseEvent::m\_middleDown} + +\membersection{wxMouseEvent::m\_middleDown}\label{wxmouseeventmmiddledown} \member{bool}{m\_middleDown} -TRUE if the middle mouse button is currently pressed down. +true if the middle mouse button is currently pressed down. -\membersection{wxMouseEvent::m\_rightDown} -\member{bool}{m\_rightDown} +\membersection{wxMouseEvent::m\_rightDown}\label{wxmouseeventmrightdown} -TRUE if the right mouse button is currently pressed down. - -\membersection{wxMouseEvent::m\_leftDown} +\member{bool}{m\_rightDown} -\member{bool}{m\_leftDown} +true if the right mouse button is currently pressed down. -TRUE if the left mouse button is currently pressed down. -\membersection{wxMouseEvent::m\_metaDown} +\membersection{wxMouseEvent::m\_metaDown}\label{wxmouseeventmmetadown} \member{bool}{m\_metaDown} -TRUE if the Meta key is pressed down. +true if the Meta key is pressed down. + -\membersection{wxMouseEvent::m\_shiftDown} +\membersection{wxMouseEvent::m\_shiftDown}\label{wxmouseeventmshiftdown} \member{bool}{m\_shiftDown} -TRUE if shift is pressed down. +true if shift is pressed down. -\membersection{wxMouseEvent::m\_x} -\member{float}{m\_x} +\membersection{wxMouseEvent::m\_x}\label{wxmouseeventmx} + +\member{long}{m\_x} X-coordinate of the event. -\membersection{wxMouseEvent::m\_y} -\member{float}{m\_y} +\membersection{wxMouseEvent::m\_y}\label{wxmouseeventmy} + +\member{long}{m\_y} Y-coordinate of the event. -\membersection{wxMouseEvent::wxMouseEvent} -\func{}{wxMouseEvent}{\param{WXTYPE}{ mouseEventType = 0}, \param{int}{ id = 0}} +\membersection{wxMouseEvent::m\_wheelRotation}\label{wxmouseeventmwheelrotation} + +\member{int}{m\_wheelRotation} + +The distance the mouse wheel is rotated. + + +\membersection{wxMouseEvent::m\_wheelDelta}\label{wxmouseeventmwheeldelta} + +\member{int}{m\_wheelDelta} + +The wheel delta, normally $120$. + + +\membersection{wxMouseEvent::m\_linesPerAction}\label{wxmouseeventmlinesperaction} + +\member{int}{m\_linesPerAction} + +The configured number of lines (or whatever) to be scrolled per wheel +action. + + + +\membersection{wxMouseEvent::wxMouseEvent}\label{wxmouseeventctor} + +\func{}{wxMouseEvent}{\param{WXTYPE}{ mouseEventType = 0}} Constructor. Valid event types are: @@ -109,219 +191,391 @@ Constructor. Valid event types are: \item {\bf wxEVT\_RIGHT\_DOWN} \item {\bf wxEVT\_RIGHT\_UP} \item {\bf wxEVT\_RIGHT\_DCLICK} +\item {\bf wxEVT\_MOUSE\_AUX1\_DOWN} +\item {\bf wxEVT\_MOUSE\_AUX1\_UP} +\item {\bf wxEVT\_MOUSE\_AUX1\_DCLICK} +\item {\bf wxEVT\_MOUSE\_AUX2\_DOWN} +\item {\bf wxEVT\_MOUSE\_AUX2\_UP} +\item {\bf wxEVT\_MOUSE\_AUX2\_DCLICK} \item {\bf wxEVT\_MOTION} +\item {\bf wxEVT\_MOUSEWHEEL} \end{itemize} -\membersection{wxMouseEvent::AltDown} + +\membersection{wxMouseEvent::AltDown}\label{wxmouseeventaltdown} \func{bool}{AltDown}{\void} -Returns TRUE if the Alt key was down at the time of the event. +Returns true if the Alt key was down at the time of the event. + + +\membersection{wxMouseEvent::Aux1DClick}\label{wxmouseeventaux1dclick} + +\constfunc{bool}{Aux1DClick}{\void} -\membersection{wxMouseEvent::Button} +Returns true if the event was a first extra button double click. + + +\membersection{wxMouseEvent::Aux1Down}\label{wxmouseeventaux1down} + +\constfunc{bool}{Aux1Down}{\void} + +Returns true if the first extra button mouse button changed to down. + + +\membersection{wxMouseEvent::Aux1IsDown}\label{wxmouseeventaux1isdown} + +\constfunc{bool}{Aux1IsDown}{\void} + +Returns true if the first extra button mouse button is currently down, independent +of the current event type. + + +\membersection{wxMouseEvent::Aux1Up}\label{wxmouseeventaux1up} + +\constfunc{bool}{Aux1Up}{\void} + +Returns true if the first extra button mouse button changed to up. + + +\membersection{wxMouseEvent::Aux2DClick}\label{wxmouseeventaux2dclick} + +\constfunc{bool}{Aux2DClick}{\void} + +Returns true if the event was a second extra button double click. + + +\membersection{wxMouseEvent::Aux2Down}\label{wxmouseeventaux2down} + +\constfunc{bool}{Aux2Down}{\void} + +Returns true if the second extra button mouse button changed to down. + + +\membersection{wxMouseEvent::Aux2IsDown}\label{wxmouseeventaux2isdown} + +\constfunc{bool}{Aux2IsDown}{\void} + +Returns true if the second extra button mouse button is currently down, independent +of the current event type. + + +\membersection{wxMouseEvent::Aux2Up}\label{wxmouseeventaux2up} + +\constfunc{bool}{Aux2Up}{\void} + +Returns true if the second extra button mouse button changed to up. + + +\membersection{wxMouseEvent::Button}\label{wxmouseeventbutton} \func{bool}{Button}{\param{int}{ button}} -Returns TRUE if the identified mouse button is changing state. Valid -values of {\it button} are 1, 2 or 3 for left, middle and right -buttons respectively. +Returns true if the identified mouse button is changing state. Valid +values of {\it button} are: -Not all mice have middle buttons so a portable application should avoid -this one. +\begin{twocollist}\itemsep=0pt +\twocolitem{{\tt wxMOUSE\_BTN\_LEFT}}{check if left button was pressed} +\twocolitem{{\tt wxMOUSE\_BTN\_MIDDLE}}{check if middle button was pressed} +\twocolitem{{\tt wxMOUSE\_BTN\_RIGHT}}{check if right button was pressed} +\twocolitem{{\tt wxMOUSE\_BTN\_AUX1}}{check if the first extra button was pressed} +\twocolitem{{\tt wxMOUSE\_BTN\_AUX2}}{check if the second extra button was pressed} +\twocolitem{{\tt wxMOUSE\_BTN\_ANY}}{check if any button was pressed} +\end{twocollist} -\membersection{wxMouseEvent::ButtonDClick}\label{buttondclick} -\func{bool}{ButtonDClick}{\param{int}{ but = -1}} +\membersection{wxMouseEvent::ButtonDClick}\label{wxmouseeventbuttondclick} -If the argument is omitted, this returns TRUE if the event was a mouse +\func{bool}{ButtonDClick}{\param{int}{ but = wxMOUSE\_BTN\_ANY}} + +If the argument is omitted, this returns true if the event was a mouse double click event. Otherwise the argument specifies which double click event -was generated (1, 2 or 3 for left, middle and right buttons respectively). +was generated (see \helpref{Button}{wxmouseeventbutton} for the possible +values). + -\membersection{wxMouseEvent::ButtonDown} +\membersection{wxMouseEvent::ButtonDown}\label{wxmouseeventbuttondown} \func{bool}{ButtonDown}{\param{int}{ but = -1}} -If the argument is omitted, this returns TRUE if the event was a mouse +If the argument is omitted, this returns true if the event was a mouse button down event. Otherwise the argument specifies which button-down event -was generated (1, 2 or 3 for left, middle and right buttons respectively). +was generated (see \helpref{Button}{wxmouseeventbutton} for the possible +values). + -\membersection{wxMouseEvent::ButtonUp} + +\membersection{wxMouseEvent::ButtonUp}\label{wxmouseeventbuttonup} \func{bool}{ButtonUp}{\param{int}{ but = -1}} -If the argument is omitted, this returns TRUE if the event was a mouse +If the argument is omitted, this returns true if the event was a mouse button up event. Otherwise the argument specifies which button-up event -was generated (1, 2 or 3 for left, middle and right buttons respectively). +was generated (see \helpref{Button}{wxmouseeventbutton} for the possible +values). + + + +\membersection{wxMouseEvent::CmdDown}\label{wxmouseeventcmddown} + +\constfunc{bool}{CmdDown}{\void} + +Same as \helpref{MetaDown}{wxmouseeventmetadown} under Mac, same as +\helpref{ControlDown}{wxmouseeventcontroldown} elsewhere. -\membersection{wxMouseEvent::ControlDown} +\wxheading{See also} + +\helpref{wxKeyEvent::CmdDown}{wxkeyeventcmddown} + + +\membersection{wxMouseEvent::ControlDown}\label{wxmouseeventcontroldown} \func{bool}{ControlDown}{\void} -Returns TRUE if the control key was down at the time of the event. +Returns true if the control key was down at the time of the event. + -\membersection{wxMouseEvent::Dragging} +\membersection{wxMouseEvent::Dragging}\label{wxmouseeventdragging} \func{bool}{Dragging}{\void} -Returns TRUE if this was a dragging event (motion while a button is depressed). +Returns true if this was a dragging event (motion while a button is depressed). + +\wxheading{See also} + +\helpref{Moving}{wxmouseeventmoving} + \membersection{wxMouseEvent::Entering}\label{wxmouseevententering} \func{bool}{Entering}{\void} -Returns TRUE if the mouse was entering the canvas (MS Windows and Motif). +Returns true if the mouse was entering the window. See also \helpref{wxMouseEvent::Leaving}{wxmouseeventleaving}. + +\membersection{wxMouseEvent::GetButton}\label{wxmouseeventgetbutton} + +\constfunc{int}{GetButton}{\void} + +Returns the mouse button which generated this event or {\tt wxMOUSE\_BTN\_NONE} +if no button is involved (for mouse move, enter or leave event, for example). +Otherwise {\tt wxMOUSE\_BTN\_LEFT} is returned for the left button down, up and +double click events, {\tt wxMOUSE\_BTN\_MIDDLE} and {\tt wxMOUSE\_BTN\_RIGHT} +for the same events for the middle and the right buttons respectively. + + +\membersection{wxMouseEvent::GetPosition}\label{wxmouseeventgetposition} + +\constfunc{wxPoint}{GetPosition}{\void} + +\constfunc{void}{GetPosition}{\param{wxCoord*}{ x}, \param{wxCoord*}{ y}} + +\constfunc{void}{GetPosition}{\param{long*}{ x}, \param{long*}{ y}} + +Sets *x and *y to the position at which the event occurred. + +Returns the physical mouse position in pixels. + +Note that if the mouse event has been artificially generated from a special +keyboard combination (e.g. under Windows when the ``menu'' key is pressed), the +returned position is \texttt{wxDefaultPosition}. + + +\membersection{wxMouseEvent::GetLogicalPosition}\label{wxmouseeventgetlogicalposition} + +\constfunc{wxPoint}{GetLogicalPosition}{\param{const wxDC\&}{ dc}} + +Returns the logical mouse position in pixels (i.e. translated according to the +translation set for the DC, which usually indicates that the window has been scrolled). + + + +\membersection{wxMouseEvent::GetLinesPerAction}\label{wxmouseeventgetlinesperaction} + +\constfunc{int}{GetLinesPerAction}{\void} + +Returns the configured number of lines (or whatever) to be scrolled per +wheel action. Defaults to three. + + +\membersection{wxMouseEvent::GetWheelRotation}\label{wxmouseeventgetwheelrotation} + +\constfunc{int}{GetWheelRotation}{\void} + +Get wheel rotation, positive or negative indicates direction of +rotation. Current devices all send an event when rotation is at least ++/-WheelDelta, but finer resolution devices can be created in the future. +Because of this you shouldn't assume that one event is equal to 1 line, but you +should be able to either do partial line scrolling or wait until several +events accumulate before scrolling. + + +\membersection{wxMouseEvent::GetWheelDelta}\label{wxmouseeventgetwheeldelta} + +\constfunc{int}{GetWheelDelta}{\void} + +Get wheel delta, normally $120$. This is the threshold for action to be +taken, and one such action (for example, scrolling one increment) +should occur for each delta. + + \membersection{wxMouseEvent::GetX}\label{wxmouseeventgetx} -\func{float}{GetX}{\void} +\constfunc{long}{GetX}{\void} + +Returns X coordinate of the physical mouse event position. -Returns X coordinate of the mouse event position. \membersection{wxMouseEvent::GetY}\label{wxmouseeventgety} -\func{float}{GetY}{\void} +\func{long}{GetY}{\void} -Returns Y coordinate of the mouse event position. +Returns Y coordinate of the physical mouse event position. -\membersection{wxMouseEvent::IsButton} -\func{bool}{IsButton}{\void} +\membersection{wxMouseEvent::IsButton}\label{wxmouseeventisbutton} -Returns TRUE if the event was a mouse button event (not necessarily a button down event - +\constfunc{bool}{IsButton}{\void} + +Returns true if the event was a mouse button event (not necessarily a button down event - that may be tested using {\it ButtonDown}). + +\membersection{wxMouseEvent::IsPageScroll}\label{wxmouseeventispagescroll} + +\constfunc{bool}{IsPageScroll}{\void} + +Returns true if the system has been setup to do page scrolling with +the mouse wheel instead of line scrolling. + + \membersection{wxMouseEvent::Leaving}\label{wxmouseeventleaving} -\func{bool}{Leaving}{\void} +\constfunc{bool}{Leaving}{\void} -Returns TRUE if the mouse was leaving the canvas (MS Windows and Motif). +Returns true if the mouse was leaving the window. See also \helpref{wxMouseEvent::Entering}{wxmouseevententering}. -\membersection{wxMouseEvent::LeftDClick} -\func{bool}{LeftDClick}{\void} +\membersection{wxMouseEvent::LeftDClick}\label{wxmouseeventleftdclick} -Returns TRUE if the event was a left double click. +\constfunc{bool}{LeftDClick}{\void} -\membersection{wxMouseEvent::LeftDown} +Returns true if the event was a left double click. -\func{bool}{LeftDown}{\void} -Returns TRUE if the left mouse button changed to down. +\membersection{wxMouseEvent::LeftDown}\label{wxmouseeventleftdown} -\membersection{wxMouseEvent::LeftIsDown} +\constfunc{bool}{LeftDown}{\void} -\func{bool}{LeftIsDown}{\void} +Returns true if the left mouse button changed to down. -Returns TRUE if the left mouse button is currently down, independent + +\membersection{wxMouseEvent::LeftIsDown}\label{wxmouseeventleftisdown} + +\constfunc{bool}{LeftIsDown}{\void} + +Returns true if the left mouse button is currently down, independent of the current event type. -\membersection{wxMouseEvent::LeftUp} +Please notice that it is \emph{not} the same as +\helpref{LeftDown}{wxmouseeventleftdown} which returns \true if the event was +generated by the left mouse button being pressed. Rather, it simply describes +the state of the left mouse button at the time when the event was generated +(so while it will be true for a left click event, it can also be true for +a right click if it happened while the left mouse button was pressed). -\func{bool}{LeftUp}{\void} +This event is usually used in the mouse event handlers which process "move +mouse" messages to determine whether the user is (still) dragging the mouse. -Returns TRUE if the left mouse button changed to up. -\membersection{wxMouseEvent::MetaDown} +\membersection{wxMouseEvent::LeftUp}\label{wxmouseeventleftup} -\func{bool}{MetaDown}{\void} +\constfunc{bool}{LeftUp}{\void} -Returns TRUE if the Meta key was down at the time of the event. +Returns true if the left mouse button changed to up. -\membersection{wxMouseEvent::MiddleDClick} -\func{bool}{MiddleDClick}{\void} +\membersection{wxMouseEvent::MetaDown}\label{wxmouseeventmetadown} -Returns TRUE if the event was a middle double click. +\constfunc{bool}{MetaDown}{\void} -\membersection{wxMouseEvent::MiddleDown} +Returns true if the Meta key was down at the time of the event. -\func{bool}{MiddleDown}{\void} -Returns TRUE if the middle mouse button changed to down. +\membersection{wxMouseEvent::MiddleDClick}\label{wxmouseeventmiddledclick} -\membersection{wxMouseEvent::MiddleIsDown} +\constfunc{bool}{MiddleDClick}{\void} -\func{bool}{MiddleIsDown}{\void} +Returns true if the event was a middle double click. -Returns TRUE if the middle mouse button is currently down, independent -of the current event type. -\membersection{wxMouseEvent::MiddleUp} +\membersection{wxMouseEvent::MiddleDown}\label{wxmouseeventmiddledown} -\func{bool}{MiddleUp}{\void} +\constfunc{bool}{MiddleDown}{\void} -Returns TRUE if the middle mouse button changed to up. +Returns true if the middle mouse button changed to down. -\membersection{wxMouseEvent::Moving} -\func{bool}{Moving}{\void} +\membersection{wxMouseEvent::MiddleIsDown}\label{wxmouseeventmiddleisdown} -Returns TRUE if this was a motion event (no buttons depressed). +\constfunc{bool}{MiddleIsDown}{\void} -\membersection{wxMouseEvent::Position} +Returns true if the middle mouse button is currently down, independent +of the current event type. + + +\membersection{wxMouseEvent::MiddleUp}\label{wxmouseeventmiddleup} + +\constfunc{bool}{MiddleUp}{\void} -\func{void}{Position}{\param{float *}{x}, \param{float *}{y}} +Returns true if the middle mouse button changed to up. -Sets *x and *y to the position at which the event occurred. If the -window is a canvas, the position is converted to logical units -(according to the current mapping mode) with scrolling taken into -account. To get back to device units (for example to calculate where on the -screen to place a dialog box associated with a canvas mouse event), use -\rtfsp{\bf wxDC::LogicalToDeviceX} and {\bf wxDC::LogicalToDeviceY}. -For example, the following code calculates screen pixel coordinates -from the frame position, canvas view start (assuming the canvas is the only -subwindow on the frame and therefore at the top left of it), and the -logical event position. A menu is popped up at the position where the -mouse click occurred. (Note that the application should also check that -the dialog box will be visible on the screen, since the click could have -occurred near the screen edge!) +\membersection{wxMouseEvent::Moving}\label{wxmouseeventmoving} -\begin{verbatim} - float event_x, event_y; - event.Position(&event_x, &event_y); - frame->GetPosition(&x, &y); - canvas->ViewStart(&x1, &y1); - int mouse_x = (int)(canvas->GetDC()->LogicalToDeviceX(event_x + x - x1); - int mouse_y = (int)(canvas->GetDC()->LogicalToDeviceY(event_y + y - y1); +\constfunc{bool}{Moving}{\void} - char *choice = wxGetSingleChoice("Menu", "Pick a node action", - no_choices, choices, frame, mouse_x, mouse_y); -\end{verbatim} +Returns true if this was a motion event and no mouse buttons were pressed. +If any mouse button is held pressed, then this method returns \false and +\helpref{Dragging}{wxmouseeventdragging} returns \true. -\membersection{wxMouseEvent::RightDClick} -\func{bool}{RightDClick}{\void} +\membersection{wxMouseEvent::RightDClick}\label{wxmouseeventrightdclick} -Returns TRUE if the event was a right double click. +\constfunc{bool}{RightDClick}{\void} -\membersection{wxMouseEvent::RightDown} +Returns true if the event was a right double click. -\func{bool}{RightDown}{\void} -Returns TRUE if the right mouse button changed to down. +\membersection{wxMouseEvent::RightDown}\label{wxmouseeventrightdown} -\membersection{wxMouseEvent::RightIsDown} +\constfunc{bool}{RightDown}{\void} -\func{bool}{RightIsDown}{\void} +Returns true if the right mouse button changed to down. -Returns TRUE if the right mouse button is currently down, independent + +\membersection{wxMouseEvent::RightIsDown}\label{wxmouseeventrightisdown} + +\constfunc{bool}{RightIsDown}{\void} + +Returns true if the right mouse button is currently down, independent of the current event type. -\membersection{wxMouseEvent::RightUp} -\func{bool}{RightUp}{\void} +\membersection{wxMouseEvent::RightUp}\label{wxmouseeventrightup} + +\constfunc{bool}{RightUp}{\void} -Returns TRUE if the right mouse button changed to up. +Returns true if the right mouse button changed to up. -\membersection{wxMouseEvent::ShiftDown} +\membersection{wxMouseEvent::ShiftDown}\label{wxmouseeventshiftdown} -\func{bool}{ShiftDown}{\void} +\constfunc{bool}{ShiftDown}{\void} -Returns TRUE if the shift key was down at the time of the event. +Returns true if the shift key was down at the time of the event.