]>
Commit | Line | Data |
---|---|---|
1 | ///////////////////////////////////////////////////////////////////////////// | |
2 | // Name: _button.i | |
3 | // Purpose: SWIG interface defs for wxButton, wxBitmapButton | |
4 | // | |
5 | // Author: Robin Dunn | |
6 | // | |
7 | // Created: 10-June-1998 | |
8 | // RCS-ID: $Id$ | |
9 | // Copyright: (c) 2003 by Total Control Software | |
10 | // Licence: wxWindows license | |
11 | ///////////////////////////////////////////////////////////////////////////// | |
12 | ||
13 | // Not a %module | |
14 | ||
15 | ||
16 | //--------------------------------------------------------------------------- | |
17 | %newgroup; | |
18 | ||
19 | MAKE_CONST_WXSTRING(ButtonNameStr); | |
20 | ||
21 | enum { | |
22 | wxBU_LEFT, | |
23 | wxBU_TOP, | |
24 | wxBU_RIGHT, | |
25 | wxBU_BOTTOM, | |
26 | ||
27 | wxBU_ALIGN_MASK, | |
28 | ||
29 | wxBU_EXACTFIT, | |
30 | wxBU_AUTODRAW, | |
31 | }; | |
32 | ||
33 | //--------------------------------------------------------------------------- | |
34 | ||
35 | DocStr(wxButton, | |
36 | "A button is a control that contains a text string, and is one of the most | |
37 | common elements of a GUI. It may be placed on a dialog box or panel, or | |
38 | indeed almost any other window.", " | |
39 | ||
40 | Window Styles | |
41 | ------------- | |
42 | ============== ========================================== | |
43 | wx.BU_LEFT Left-justifies the label. Windows and GTK+ only. | |
44 | wx.BU_TOP Aligns the label to the top of the button. | |
45 | Windows and GTK+ only. | |
46 | wx.BU_RIGHT Right-justifies the bitmap label. Windows and GTK+ only. | |
47 | wx.BU_BOTTOM Aligns the label to the bottom of the button. | |
48 | Windows and GTK+ only. | |
49 | wx.BU_EXACTFIT Creates the button as small as possible | |
50 | instead of making it of the standard size | |
51 | (which is the default behaviour.) | |
52 | ============== ========================================== | |
53 | ||
54 | Events | |
55 | ------ | |
56 | ============ ========================================== | |
57 | EVT_BUTTON Sent when the button is clicked. | |
58 | ============ ========================================== | |
59 | ||
60 | :see: `wx.BitmapButton` | |
61 | "); | |
62 | ||
63 | ||
64 | MustHaveApp(wxButton); | |
65 | ||
66 | class wxButton : public wxControl | |
67 | { | |
68 | public: | |
69 | %pythonAppend wxButton "self._setOORInfo(self)" | |
70 | %pythonAppend wxButton() "" | |
71 | %typemap(out) wxButton*; // turn off this typemap | |
72 | ||
73 | ||
74 | DocCtorStr( | |
75 | wxButton(wxWindow* parent, wxWindowID id=-1, | |
76 | const wxString& label=wxPyEmptyString, | |
77 | const wxPoint& pos = wxDefaultPosition, | |
78 | const wxSize& size = wxDefaultSize, | |
79 | long style = 0, | |
80 | const wxValidator& validator = wxDefaultValidator, | |
81 | const wxString& name = wxPyButtonNameStr), | |
82 | "Create and show a button. The preferred way to create standard | |
83 | buttons is to use a standard ID and an empty label. In this case | |
84 | wxWigets will automatically use a stock label that coresponds to the | |
85 | ID given. In additon, the button will be decorated with stock icons | |
86 | under GTK+ 2.", " | |
87 | ||
88 | The stock IDs and coresponding labels are | |
89 | ||
90 | ===================== ====================== | |
91 | wx.ID_ADD 'Add' | |
92 | wx.ID_APPLY '\&Apply' | |
93 | wx.ID_BOLD '\&Bold' | |
94 | wx.ID_CANCEL '\&Cancel' | |
95 | wx.ID_CLEAR '\&Clear' | |
96 | wx.ID_CLOSE '\&Close' | |
97 | wx.ID_COPY '\&Copy' | |
98 | wx.ID_CUT 'Cu\&t' | |
99 | wx.ID_DELETE '\&Delete' | |
100 | wx.ID_FIND '\&Find' | |
101 | wx.ID_REPLACE 'Find and rep\&lace' | |
102 | wx.ID_BACKWARD '\&Back' | |
103 | wx.ID_DOWN '\&Down' | |
104 | wx.ID_FORWARD '\&Forward' | |
105 | wx.ID_UP '\&Up' | |
106 | wx.ID_HELP '\&Help' | |
107 | wx.ID_HOME '\&Home' | |
108 | wx.ID_INDENT 'Indent' | |
109 | wx.ID_INDEX '\&Index' | |
110 | wx.ID_ITALIC '\&Italic' | |
111 | wx.ID_JUSTIFY_CENTER 'Centered' | |
112 | wx.ID_JUSTIFY_FILL 'Justified' | |
113 | wx.ID_JUSTIFY_LEFT 'Align Left' | |
114 | wx.ID_JUSTIFY_RIGHT 'Align Right' | |
115 | wx.ID_NEW '\&New' | |
116 | wx.ID_NO '\&No' | |
117 | wx.ID_OK '\&OK' | |
118 | wx.ID_OPEN '\&Open' | |
119 | wx.ID_PASTE '\&Paste' | |
120 | wx.ID_PREFERENCES '\&Preferences' | |
121 | wx.ID_PRINT '\&Print' | |
122 | wx.ID_PREVIEW 'Print previe\&w' | |
123 | wx.ID_PROPERTIES '\&Properties' | |
124 | wx.ID_EXIT '\&Quit' | |
125 | wx.ID_REDO '\&Redo' | |
126 | wx.ID_REFRESH 'Refresh' | |
127 | wx.ID_REMOVE 'Remove' | |
128 | wx.ID_REVERT_TO_SAVED 'Revert to Saved' | |
129 | wx.ID_SAVE '\&Save' | |
130 | wx.ID_SAVEAS 'Save \&As...' | |
131 | wx.ID_STOP '\&Stop' | |
132 | wx.ID_UNDELETE 'Undelete' | |
133 | wx.ID_UNDERLINE '\&Underline' | |
134 | wx.ID_UNDO '\&Undo' | |
135 | wx.ID_UNINDENT '\&Unindent' | |
136 | wx.ID_YES '\&Yes' | |
137 | wx.ID_ZOOM_100 '\&Actual Size' | |
138 | wx.ID_ZOOM_FIT 'Zoom to \&Fit' | |
139 | wx.ID_ZOOM_IN 'Zoom \&In' | |
140 | wx.ID_ZOOM_OUT 'Zoom \&Out' | |
141 | ===================== ====================== | |
142 | "); | |
143 | ||
144 | DocCtorStrName( | |
145 | wxButton(), | |
146 | "Precreate a Button for 2-phase creation.", "", | |
147 | PreButton); | |
148 | ||
149 | // Turn it back on again | |
150 | %typemap(out) wxButton* { $result = wxPyMake_wxObject($1, $owner); } | |
151 | ||
152 | ||
153 | DocDeclStr( | |
154 | bool , Create(wxWindow* parent, wxWindowID id=-1, | |
155 | const wxString& label=wxPyEmptyString, | |
156 | const wxPoint& pos = wxDefaultPosition, | |
157 | const wxSize& size = wxDefaultSize, | |
158 | long style = 0, | |
159 | const wxValidator& validator = wxDefaultValidator, | |
160 | const wxString& name = wxPyButtonNameStr), | |
161 | "Acutally create the GUI Button for 2-phase creation.", ""); | |
162 | ||
163 | ||
164 | ||
165 | DocDeclStr( | |
166 | wxWindow* , SetDefault(), | |
167 | "This sets the button to be the default item for the panel or dialog box.", ""); | |
168 | ||
169 | ||
170 | DocDeclStr( | |
171 | static wxSize , GetDefaultSize(), | |
172 | "Returns the default button size for this platform.", ""); | |
173 | ||
174 | static wxVisualAttributes | |
175 | GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL); | |
176 | }; | |
177 | ||
178 | ||
179 | ||
180 | //--------------------------------------------------------------------------- | |
181 | ||
182 | ||
183 | DocStr(wxBitmapButton, | |
184 | "A Button that contains a bitmap. A bitmap button can be supplied with a | |
185 | single bitmap, and wxWidgets will draw all button states using this bitmap. If | |
186 | the application needs more control, additional bitmaps for the selected state, | |
187 | unpressed focused state, and greyed-out state may be supplied.", " | |
188 | ||
189 | Window Styles | |
190 | ------------- | |
191 | ============== ============================================= | |
192 | wx.BU_AUTODRAW If this is specified, the button will be drawn | |
193 | automatically using the label bitmap only, | |
194 | providing a 3D-look border. If this style is | |
195 | not specified, the button will be drawn | |
196 | without borders and using all provided | |
197 | bitmaps. WIN32 only. | |
198 | wx.BU_LEFT Left-justifies the label. WIN32 only. | |
199 | wx.BU_TOP Aligns the label to the top of the button. WIN32 | |
200 | only. | |
201 | wx.BU_RIGHT Right-justifies the bitmap label. WIN32 only. | |
202 | wx.BU_BOTTOM Aligns the label to the bottom of the | |
203 | button. WIN32 only. | |
204 | wx.BU_EXACTFIT Creates the button as small as possible | |
205 | instead of making it of the standard size | |
206 | (which is the default behaviour.) | |
207 | ============== ============================================= | |
208 | ||
209 | Events | |
210 | ------ | |
211 | =========== ================================== | |
212 | EVT_BUTTON Sent when the button is clicked. | |
213 | =========== ================================== | |
214 | ||
215 | :see: `wx.Button`, `wx.Bitmap` | |
216 | "); | |
217 | ||
218 | MustHaveApp(wxBitmapButton); | |
219 | ||
220 | class wxBitmapButton : public wxButton | |
221 | { | |
222 | public: | |
223 | %pythonAppend wxBitmapButton "self._setOORInfo(self)" | |
224 | %pythonAppend wxBitmapButton() "" | |
225 | %typemap(out) wxBitmapButton*; // turn off this typemap | |
226 | ||
227 | DocCtorStr( | |
228 | wxBitmapButton(wxWindow* parent, wxWindowID id=-1, | |
229 | const wxBitmap& bitmap = wxNullBitmap, | |
230 | const wxPoint& pos = wxDefaultPosition, | |
231 | const wxSize& size = wxDefaultSize, | |
232 | long style = wxBU_AUTODRAW, | |
233 | const wxValidator& validator = wxDefaultValidator, | |
234 | const wxString& name = wxPyButtonNameStr), | |
235 | "Create and show a button with a bitmap for the label.", ""); | |
236 | ||
237 | DocCtorStrName( | |
238 | wxBitmapButton(), | |
239 | "Precreate a BitmapButton for 2-phase creation.", "", | |
240 | PreBitmapButton); | |
241 | ||
242 | // Turn it back on again | |
243 | %typemap(out) wxBitmapButton* { $result = wxPyMake_wxObject($1, $owner); } | |
244 | ||
245 | ||
246 | DocDeclStr( | |
247 | bool , Create(wxWindow* parent, wxWindowID id=-1, | |
248 | const wxBitmap& bitmap = wxNullBitmap, | |
249 | const wxPoint& pos = wxDefaultPosition, | |
250 | const wxSize& size = wxDefaultSize, | |
251 | long style = wxBU_AUTODRAW, | |
252 | const wxValidator& validator = wxDefaultValidator, | |
253 | const wxString& name = wxPyButtonNameStr), | |
254 | "Acutally create the GUI BitmapButton for 2-phase creation.", ""); | |
255 | ||
256 | ||
257 | DocDeclStr( | |
258 | wxBitmap , GetBitmapLabel(), | |
259 | "Returns the label bitmap (the one passed to the constructor).", ""); | |
260 | ||
261 | DocDeclStr( | |
262 | wxBitmap , GetBitmapDisabled(), | |
263 | "Returns the bitmap for the disabled state.", ""); | |
264 | ||
265 | DocDeclStr( | |
266 | wxBitmap , GetBitmapFocus(), | |
267 | "Returns the bitmap for the focused state.", ""); | |
268 | ||
269 | ||
270 | DocDeclStr( | |
271 | wxBitmap , GetBitmapSelected(), | |
272 | "Returns the bitmap for the selected state.", ""); | |
273 | ||
274 | DocDeclStr( | |
275 | wxBitmap , GetBitmapHover(), | |
276 | "Returns the bitmap used when the mouse is over the button, may be invalid.", ""); | |
277 | ||
278 | ||
279 | DocDeclStr( | |
280 | void , SetBitmapDisabled(const wxBitmap& bitmap), | |
281 | "Sets the bitmap for the disabled button appearance.", ""); | |
282 | ||
283 | ||
284 | DocDeclStr( | |
285 | void , SetBitmapFocus(const wxBitmap& bitmap), | |
286 | "Sets the bitmap for the button appearance when it has the keyboard focus.", ""); | |
287 | ||
288 | ||
289 | DocDeclStr( | |
290 | void , SetBitmapSelected(const wxBitmap& bitmap), | |
291 | "Sets the bitmap for the selected (depressed) button appearance.", ""); | |
292 | ||
293 | ||
294 | DocDeclStr( | |
295 | void , SetBitmapLabel(const wxBitmap& bitmap), | |
296 | "Sets the bitmap label for the button. This is the bitmap used for the | |
297 | unselected state, and for all other states if no other bitmaps are provided.", ""); | |
298 | ||
299 | ||
300 | DocDeclStr( | |
301 | void , SetBitmapHover(const wxBitmap& hover), | |
302 | "Sets the bitmap to be shown when the mouse is over the button. This function | |
303 | is new since wxWidgets version 2.7.0 and the hover bitmap is currently only | |
304 | supported in wxMSW.", ""); | |
305 | ||
306 | void SetMargins(int x, int y); | |
307 | int GetMarginX() const; | |
308 | int GetMarginY() const; | |
309 | ||
310 | %property(BitmapDisabled, GetBitmapDisabled, SetBitmapDisabled, doc="See `GetBitmapDisabled` and `SetBitmapDisabled`"); | |
311 | %property(BitmapFocus, GetBitmapFocus, SetBitmapFocus, doc="See `GetBitmapFocus` and `SetBitmapFocus`"); | |
312 | %property(BitmapHover, GetBitmapHover, SetBitmapHover, doc="See `GetBitmapHover` and `SetBitmapHover`"); | |
313 | %property(BitmapLabel, GetBitmapLabel, SetBitmapLabel, doc="See `GetBitmapLabel` and `SetBitmapLabel`"); | |
314 | %property(BitmapSelected, GetBitmapSelected, SetBitmapSelected, doc="See `GetBitmapSelected` and `SetBitmapSelected`"); | |
315 | %property(MarginX, GetMarginX, doc="See `GetMarginX`"); | |
316 | %property(MarginY, GetMarginY, doc="See `GetMarginY`"); | |
317 | }; | |
318 | ||
319 | ||
320 | //--------------------------------------------------------------------------- |