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
|
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
|
2008-04-14 05:36:08 +00:00
|
|
|
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 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).
|
2008-04-14 05:36:08 +00:00
|
|
|
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()
|
|
|
|
function is also available for MS Windows use.
|
|
|
|
|
|
|
|
@section cursor_custom Creating a Custom Cursor
|
|
|
|
|
|
|
|
The following is an example of creating a cursor from 32x32 bitmap data
|
|
|
|
(down_bits) and a mask (down_mask) where 1 is black and 0 is white for the
|
|
|
|
bits, and 1 is opaque and 0 is transparent for the mask. It works on
|
|
|
|
Windows and GTK+.
|
|
|
|
|
|
|
|
@code
|
|
|
|
static char down_bits[] = { 255, 255, 255, 255, 31,
|
|
|
|
255, 255, 255, 31, 255, 255, 255, 31, 255, 255, 255,
|
|
|
|
31, 255, 255, 255, 31, 255, 255, 255, 31, 255, 255,
|
|
|
|
255, 31, 255, 255, 255, 31, 255, 255, 255, 25, 243,
|
|
|
|
255, 255, 19, 249, 255, 255, 7, 252, 255, 255, 15, 254,
|
|
|
|
255, 255, 31, 255, 255, 255, 191, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255,
|
|
|
|
255 };
|
|
|
|
|
|
|
|
static char down_mask[] = { 240, 1, 0, 0, 240, 1,
|
|
|
|
0, 0, 240, 1, 0, 0, 240, 1, 0, 0, 240, 1, 0, 0, 240, 1,
|
|
|
|
0, 0, 240, 1, 0, 0, 240, 1, 0, 0, 255, 31, 0, 0, 255,
|
|
|
|
31, 0, 0, 254, 15, 0, 0, 252, 7, 0, 0, 248, 3, 0, 0,
|
|
|
|
240, 1, 0, 0, 224, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0, 0 };
|
|
|
|
|
|
|
|
#ifdef __WXMSW__
|
|
|
|
wxBitmap down_bitmap(down_bits, 32, 32);
|
|
|
|
wxBitmap down_mask_bitmap(down_mask, 32, 32);
|
|
|
|
|
|
|
|
down_bitmap.SetMask(new wxMask(down_mask_bitmap));
|
|
|
|
wxImage down_image = down_bitmap.ConvertToImage();
|
|
|
|
down_image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_X, 6);
|
|
|
|
down_image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_Y, 14);
|
|
|
|
wxCursor down_cursor = wxCursor(down_image);
|
|
|
|
#else
|
|
|
|
wxCursor down_cursor = wxCursor(down_bits, 32, 32, 6, 14,
|
|
|
|
down_mask, wxWHITE, wxBLACK);
|
|
|
|
#endif
|
|
|
|
@endcode
|
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-04-14 05:36:08 +00:00
|
|
|
- ::wxNullCursor
|
|
|
|
- ::wxSTANDARD_CURSOR
|
|
|
|
- ::wxHOURGLASS_CURSOR
|
|
|
|
- ::wxCROSS_CURSOR
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-05-02 04:12:39 +00:00
|
|
|
@see wxBitmap, wxIcon, wxWindow::SetCursor(), wxSetCursor(),
|
|
|
|
::wxStockCursor
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxCursor : public wxBitmap
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-14 05:36:08 +00:00
|
|
|
Default constructor.
|
|
|
|
*/
|
|
|
|
wxCursor();
|
|
|
|
/**
|
|
|
|
Constructs a cursor by passing an array of bits (Motif and GTK+ only).
|
|
|
|
@a maskBits is used only under Motif and GTK+. The parameters @a fg and
|
|
|
|
@a bg are only present on GTK+, and force the cursor to use particular
|
|
|
|
background and foreground colours.
|
|
|
|
|
|
|
|
If either @a hotSpotX or @a hotSpotY is -1, the hotspot will be the
|
|
|
|
centre of the cursor image (Motif only).
|
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-04-14 05:36:08 +00:00
|
|
|
*/
|
|
|
|
wxCursor(const char bits[], int width, int height,
|
|
|
|
int hotSpotX = -1, int hotSpotY = -1,
|
|
|
|
const char maskBits[] = NULL,
|
|
|
|
wxColour* fg = NULL, wxColour* bg = NULL);
|
|
|
|
/**
|
|
|
|
Constructs a cursor by passing a string resource name or filename.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
On MacOS when specifying a string resource name, first the color
|
|
|
|
cursors 'crsr' and then the black/white cursors 'CURS' in the resource
|
|
|
|
chain are scanned through.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
@a hotSpotX and @a hotSpotY are currently only used under Windows when
|
|
|
|
loading from an icon file, to specify the cursor hotspot relative to
|
|
|
|
the top left of the image.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
@param type
|
|
|
|
Icon type to load. Under Motif, type defaults to wxBITMAP_TYPE_XBM.
|
|
|
|
Under Windows, it defaults to wxBITMAP_TYPE_CUR_RESOURCE. Under
|
|
|
|
MacOS, it defaults to wxBITMAP_TYPE_MACCURSOR_RESOURCE.
|
|
|
|
Under X, the permitted cursor types are:
|
|
|
|
<ul>
|
|
|
|
<li>wxBITMAP_TYPE_XBM - Load an X bitmap file.</li>
|
|
|
|
</ul>
|
2008-03-09 12:33:59 +00:00
|
|
|
Under Windows, the permitted types are:
|
2008-04-14 05:36:08 +00:00
|
|
|
- wxBITMAP_TYPE_CUR - Load a cursor from a .cur cursor file (only
|
|
|
|
if USE_RESOURCE_LOADING_IN_MSW is enabled in
|
|
|
|
setup.h).
|
|
|
|
- wxBITMAP_TYPE_CUR_RESOURCE - Load a Windows resource (as
|
|
|
|
specified in the .rc file).
|
|
|
|
- wxBITMAP_TYPE_ICO - Load a cursor from a .ico icon file (only if
|
|
|
|
USE_RESOURCE_LOADING_IN_MSW is enabled in
|
|
|
|
setup.h). Specify @a hotSpotX and @a hotSpotY.
|
|
|
|
@param hotSpotX
|
|
|
|
Hotspot x coordinate.
|
|
|
|
@param hotSpotY
|
|
|
|
Hotspot y coordinate.
|
|
|
|
*/
|
|
|
|
wxCursor(const wxString& cursorName, long type,
|
|
|
|
int hotSpotX = 0, int hotSpotY = 0);
|
|
|
|
/**
|
|
|
|
Constructs a cursor using a cursor identifier.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param cursorId
|
2008-05-02 04:12:39 +00:00
|
|
|
A stock cursor identifier. See ::wxStockCursor.
|
2008-04-14 05:36:08 +00:00
|
|
|
*/
|
2008-05-02 04:12:39 +00:00
|
|
|
wxCursor(wxStockCursor cursorId);
|
2008-04-14 05:36:08 +00:00
|
|
|
/**
|
|
|
|
Constructs a cursor from a wxImage. If cursor are monochrome on the
|
|
|
|
current platform, colors with the RGB elements all greater than 127
|
|
|
|
will be foreground, colors less than this background. The mask (if any)
|
|
|
|
will be used to specify the transparent area.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
In wxMSW the foreground will be white and the background black. If the
|
|
|
|
cursor is larger than 32x32 it is resized.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
In wxGTK, colour cursors and alpha channel are supported (starting from
|
|
|
|
GTK+ 2.2). Otherwise the two most frequent colors will be used for
|
|
|
|
foreground and background. In any case, the cursor will be displayed at
|
|
|
|
the size of the image.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-04-14 05:36:08 +00:00
|
|
|
In wxMac, if the cursor is larger than 16x16 it is resized and
|
|
|
|
currently only shown as black/white (mask respected).
|
|
|
|
*/
|
|
|
|
wxCursor(const wxImage& image);
|
|
|
|
/**
|
|
|
|
Copy constructor, uses @ref overview_refcount "reference counting".
|
2008-03-20 13:45:17 +00:00
|
|
|
|
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
|
|
|
*/
|
2008-03-08 14:43:31 +00:00
|
|
|
wxCursor(const wxCursor& cursor);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-14 05:36:08 +00:00
|
|
|
Destroys the cursor. See
|
|
|
|
@ref overview_refcount_destruct "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.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
~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
|
|
|
|
|
|
|
/**
|
2008-04-14 05:36:08 +00:00
|
|
|
Assignment operator, using @ref overview_refcount "reference counting".
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxCursor operator =(const wxCursor& cursor);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|
|
|
|
|
2008-05-02 04:12:39 +00:00
|
|
|
/**
|
|
|
|
@name Predefined cursors.
|
|
|
|
|
|
|
|
@see wxStockCursor
|
|
|
|
*/
|
2008-04-14 05:36:08 +00:00
|
|
|
//@{
|
|
|
|
wxCursor wxNullCursor;
|
|
|
|
wxCursor* wxSTANDARD_CURSOR;
|
|
|
|
wxCursor* wxHOURGLASS_CURSOR;
|
|
|
|
wxCursor* wxCROSS_CURSOR;
|
|
|
|
//@}
|
2008-03-10 15:24:38 +00:00
|
|
|
|