2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: cursor.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxCursor
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxCursor
|
|
|
|
@wxheader{cursor.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A cursor is a small bitmap usually used for denoting where the mouse
|
|
|
|
pointer is, with a picture that might indicate the interpretation of a
|
|
|
|
mouse click. As with icons, cursors in X and MS Windows are created
|
|
|
|
in a different manner. Therefore, separate cursors will be created for the
|
|
|
|
different environments. Platform-specific methods for creating a @b wxCursor
|
|
|
|
object are catered for, and this is an occasion where
|
|
|
|
conditional compilation will probably be required (see wxIcon for
|
|
|
|
an example).
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A single cursor object may be used in many windows (any subwindow type).
|
|
|
|
The wxWidgets convention is to set the cursor for a window, as in X,
|
|
|
|
rather than to set it globally as in MS Windows, although a
|
|
|
|
global ::wxSetCursor is also available for MS Windows use.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{gdi}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@stdobjects
|
2008-03-10 15:24:38 +00:00
|
|
|
::Objects:, ::wxNullCursor, ::Pointers:, ::wxSTANDARD_CURSOR,
|
|
|
|
::wxHOURGLASS_CURSOR, ::wxCROSS_CURSOR,
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxBitmap, wxIcon, wxWindow::SetCursor, ::wxSetCursor
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxCursor : public wxBitmap
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Copy constructor, uses @ref overview_trefcount "reference counting".
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param bits
|
2008-03-09 12:33:59 +00:00
|
|
|
An array of bits.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param maskBits
|
2008-03-09 12:33:59 +00:00
|
|
|
Bits for a mask bitmap.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param width
|
2008-03-09 12:33:59 +00:00
|
|
|
Cursor width.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param height
|
2008-03-09 12:33:59 +00:00
|
|
|
Cursor height.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param hotSpotX
|
2008-03-09 12:33:59 +00:00
|
|
|
Hotspot x coordinate.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param hotSpotY
|
2008-03-09 12:33:59 +00:00
|
|
|
Hotspot y coordinate.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param type
|
2008-03-09 12:33:59 +00:00
|
|
|
Icon type to load. Under Motif, type defaults to wxBITMAP_TYPE_XBM. Under
|
2008-03-08 13:52:38 +00:00
|
|
|
Windows,
|
2008-03-09 12:33:59 +00:00
|
|
|
it defaults to wxBITMAP_TYPE_CUR_RESOURCE. Under MacOS, it defaults to
|
2008-03-08 13:52:38 +00:00
|
|
|
wxBITMAP_TYPE_MACCURSOR_RESOURCE.
|
2008-03-09 12:33:59 +00:00
|
|
|
Under X, the permitted cursor types are:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxBITMAP_TYPE_XBM
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Load an X bitmap file.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Under Windows, the permitted types are:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxBITMAP_TYPE_CUR
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Load a cursor from a .cur cursor file (only if USE_RESOURCE_LOADING_IN_MSW
|
|
|
|
is enabled in setup.h).
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxBITMAP_TYPE_CUR_RESOURCE
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Load a Windows resource (as specified in the .rc file).
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxBITMAP_TYPE_ICO
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Load a cursor from a .ico icon file (only if USE_RESOURCE_LOADING_IN_MSW
|
|
|
|
is enabled in setup.h). Specify hotSpotX and hotSpotY.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param cursorId
|
2008-03-09 12:33:59 +00:00
|
|
|
A stock cursor identifier. May be one of:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_ARROW
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A standard arrow cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_RIGHT_ARROW
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A standard arrow cursor
|
|
|
|
pointing to the right.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_BLANK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Transparent cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_BULLSEYE
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Bullseye cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_CHAR
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Rectangular character cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_CROSS
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A cross cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_HAND
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A hand cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_IBEAM
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
An I-beam cursor (vertical line).
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_LEFT_BUTTON
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Represents a mouse with the left button depressed.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_MAGNIFIER
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A magnifier icon.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_MIDDLE_BUTTON
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Represents a mouse with the middle button depressed.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_NO_ENTRY
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A no-entry sign cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_PAINT_BRUSH
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A paintbrush cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_PENCIL
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A pencil cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_POINT_LEFT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A cursor that points left.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_POINT_RIGHT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A cursor that points right.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_QUESTION_ARROW
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
An arrow and question mark.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_RIGHT_BUTTON
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Represents a mouse with the right button depressed.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SIZENESW
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A sizing cursor pointing NE-SW.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SIZENS
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A sizing cursor pointing N-S.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SIZENWSE
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A sizing cursor pointing NW-SE.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SIZEWE
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A sizing cursor pointing W-E.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SIZING
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A general sizing cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_SPRAYCAN
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A spraycan cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_WAIT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A wait cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_WATCH
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A watch cursor.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCURSOR_ARROWWAIT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
A cursor with both an arrow and
|
|
|
|
an hourglass, (windows.)
|
2008-03-20 13:45:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
Note that not all cursors are available on all platforms.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param cursor
|
2008-03-09 12:33:59 +00:00
|
|
|
Pointer or reference to a cursor to copy.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxCursor();
|
2008-03-08 14:43:31 +00:00
|
|
|
wxCursor(const char bits[], int width, int height,
|
2008-03-09 12:33:59 +00:00
|
|
|
int hotSpotX = -1, int hotSpotY = -1,
|
|
|
|
const char maskBits[] = NULL,
|
|
|
|
wxColour* fg = NULL,
|
|
|
|
wxColour* bg = NULL);
|
2008-03-08 14:43:31 +00:00
|
|
|
wxCursor(const wxString& cursorName, long type,
|
2008-03-09 12:33:59 +00:00
|
|
|
int hotSpotX = 0, int hotSpotY = 0);
|
2008-03-08 14:43:31 +00:00
|
|
|
wxCursor(int cursorId);
|
|
|
|
wxCursor(const wxImage& image);
|
|
|
|
wxCursor(const wxCursor& cursor);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destroys the cursor.
|
|
|
|
See @ref overview_refcountdestruct "reference-counted object destruction" for
|
|
|
|
more info.
|
|
|
|
A cursor can be reused for more
|
|
|
|
than one window, and does not get destroyed when the window is
|
|
|
|
destroyed. wxWidgets destroys all cursors on application exit, although
|
|
|
|
it is best to clean them up explicitly.
|
|
|
|
*/
|
|
|
|
~wxCursor();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if cursor data is present.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsOk() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Assignment operator, using @ref overview_trefcount "reference counting".
|
|
|
|
*/
|
|
|
|
wxCursor operator =(const wxCursor& cursor);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor Objects:
|
|
|
|
;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor wxNullCursor;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor Pointers:
|
|
|
|
;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor wxSTANDARD_CURSOR;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor wxHOURGLASS_CURSOR;
|
|
|
|
|
|
|
|
/**
|
|
|
|
FIXME
|
|
|
|
*/
|
|
|
|
wxCursor wxCROSS_CURSOR;
|
|
|
|
|
|
|
|
|