]> git.saurik.com Git - wxWidgets.git/blob - src/x11/cursor.cpp
Testing CVSROOT/loginfo changes
[wxWidgets.git] / src / x11 / cursor.cpp
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: cursor.cpp
3 // Purpose: wxCursor class
4 // Author: Julian Smart
5 // Modified by:
6 // Created: 17/09/98
7 // RCS-ID: $Id$
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
11
12 #include "wx/cursor.h"
13 #include "wx/gdicmn.h"
14 #include "wx/icon.h"
15 #include "wx/app.h"
16 #include "wx/utils.h"
17
18 #include "wx/x11/private.h"
19
20 #if !wxUSE_NANOX
21 #include <X11/cursorfont.h>
22 #endif
23
24 //-----------------------------------------------------------------------------
25 // wxCursor
26 //-----------------------------------------------------------------------------
27
28 class wxCursorRefData: public wxObjectRefData
29 {
30 public:
31
32 wxCursorRefData();
33 ~wxCursorRefData();
34
35 WXCursor m_cursor;
36 WXDisplay *m_display;
37 };
38
39 wxCursorRefData::wxCursorRefData()
40 {
41 m_cursor = NULL;
42 m_display = NULL;
43 }
44
45 wxCursorRefData::~wxCursorRefData()
46 {
47 if (m_cursor)
48 XFreeCursor( (Display*) m_display, (Cursor) m_cursor );
49 }
50
51 //-----------------------------------------------------------------------------
52
53 #define M_CURSORDATA ((wxCursorRefData *)m_refData)
54
55 IMPLEMENT_DYNAMIC_CLASS(wxCursor,wxObject)
56
57 wxCursor::wxCursor()
58 {
59
60 }
61
62 wxCursor::wxCursor( int cursorId )
63 {
64 m_refData = new wxCursorRefData();
65
66 #if wxUSE_NANOX
67 // TODO Create some standard cursors from bitmaps.
68
69
70 #else
71 // !wxUSE_NANOX
72
73 M_CURSORDATA->m_display = wxGlobalDisplay();
74 wxASSERT_MSG( M_CURSORDATA->m_display, wxT("No display") );
75
76 int x_cur = XC_left_ptr;
77 switch (cursorId)
78 {
79 case wxCURSOR_DEFAULT: x_cur = XC_left_ptr; break;
80 case wxCURSOR_HAND: x_cur = XC_hand1; break;
81 case wxCURSOR_CROSS: x_cur = XC_crosshair; break;
82 case wxCURSOR_SIZEWE: x_cur = XC_sb_h_double_arrow; break;
83 case wxCURSOR_SIZENS: x_cur = XC_sb_v_double_arrow; break;
84 case wxCURSOR_ARROWWAIT:
85 case wxCURSOR_WAIT:
86 case wxCURSOR_WATCH: x_cur = XC_watch; break;
87 case wxCURSOR_SIZING: x_cur = XC_sizing; break;
88 case wxCURSOR_SPRAYCAN: x_cur = XC_spraycan; break;
89 case wxCURSOR_IBEAM: x_cur = XC_xterm; break;
90 case wxCURSOR_PENCIL: x_cur = XC_pencil; break;
91 case wxCURSOR_NO_ENTRY: x_cur = XC_pirate; break;
92 case wxCURSOR_SIZENWSE:
93 case wxCURSOR_SIZENESW: x_cur = XC_fleur; break;
94 case wxCURSOR_QUESTION_ARROW: x_cur = XC_question_arrow; break;
95 case wxCURSOR_PAINT_BRUSH: x_cur = XC_spraycan; break;
96 case wxCURSOR_MAGNIFIER: x_cur = XC_plus; break;
97 case wxCURSOR_CHAR: x_cur = XC_xterm; break;
98 case wxCURSOR_LEFT_BUTTON: x_cur = XC_leftbutton; break;
99 case wxCURSOR_MIDDLE_BUTTON: x_cur = XC_middlebutton; break;
100 case wxCURSOR_RIGHT_BUTTON: x_cur = XC_rightbutton; break;
101 case wxCURSOR_BULLSEYE: x_cur = XC_target; break;
102
103 case wxCURSOR_POINT_LEFT: x_cur = XC_sb_left_arrow; break;
104 case wxCURSOR_POINT_RIGHT: x_cur = XC_sb_right_arrow; break;
105 /*
106 case wxCURSOR_DOUBLE_ARROW: x_cur = XC_double_arrow; break;
107 case wxCURSOR_CROSS_REVERSE: x_cur = XC_cross_reverse; break;
108 case wxCURSOR_BASED_ARROW_UP: x_cur = XC_based_arrow_up; break;
109 case wxCURSOR_BASED_ARROW_DOWN: x_cur = XC_based_arrow_down; break;
110 */
111 default:
112 wxFAIL_MSG(wxT("unsupported cursor type"));
113 // will use the standard one
114 }
115
116 M_CURSORDATA->m_cursor = (WXCursor) XCreateFontCursor( (Display*) M_CURSORDATA->m_display, x_cur );
117 #endif
118 }
119
120 wxCursor::wxCursor(const char bits[], int width, int height,
121 int hotSpotX, int hotSpotY,
122 const char maskBits[], wxColour *fg, wxColour *bg)
123 {
124 wxFAIL_MSG( wxT("wxCursor creation from bits not yet implemented") );
125 }
126
127 #if wxUSE_IMAGE
128 wxCursor::wxCursor( const wxImage & image )
129 {
130 wxFAIL_MSG( wxT("wxCursor creation from wxImage not yet implemented") );
131 }
132 #endif
133
134 wxCursor::~wxCursor()
135 {
136 }
137
138 bool wxCursor::operator == ( const wxCursor& cursor ) const
139 {
140 return m_refData == cursor.m_refData;
141 }
142
143 bool wxCursor::operator != ( const wxCursor& cursor ) const
144 {
145 return m_refData != cursor.m_refData;
146 }
147
148 bool wxCursor::Ok() const
149 {
150 return (m_refData != NULL);
151 }
152
153 WXCursor wxCursor::GetCursor() const
154 {
155 return M_CURSORDATA->m_cursor;
156 }
157
158 //-----------------------------------------------------------------------------
159 // busy cursor routines
160 //-----------------------------------------------------------------------------
161
162 /* extern */ wxCursor g_globalCursor;
163
164 static wxCursor gs_savedCursor;
165 static int gs_busyCount = 0;
166
167 const wxCursor &wxBusyCursor::GetStoredCursor()
168 {
169 return gs_savedCursor;
170 }
171
172 const wxCursor wxBusyCursor::GetBusyCursor()
173 {
174 return wxCursor(wxCURSOR_WATCH);
175 }
176
177 void wxEndBusyCursor()
178 {
179 if (--gs_busyCount > 0)
180 return;
181
182 wxSetCursor( gs_savedCursor );
183 gs_savedCursor = wxNullCursor;
184
185 if (wxTheApp)
186 wxTheApp->ProcessIdle();
187 }
188
189 void wxBeginBusyCursor( wxCursor *WXUNUSED(cursor) )
190 {
191 if (gs_busyCount++ > 0)
192 return;
193
194 wxASSERT_MSG( !gs_savedCursor.Ok(),
195 wxT("forgot to call wxEndBusyCursor, will leak memory") );
196
197 gs_savedCursor = g_globalCursor;
198
199 wxSetCursor( wxCursor(wxCURSOR_WATCH) );
200
201 if (wxTheApp)
202 wxTheApp->ProcessIdle();
203 }
204
205 bool wxIsBusy()
206 {
207 return gs_busyCount > 0;
208 }
209
210 void wxSetCursor( const wxCursor& cursor )
211 {
212 g_globalCursor = cursor;
213 }