]>
Commit | Line | Data |
---|---|---|
1 | ///////////////////////////////////////////////////////////////////////////// | |
2 | // Name: gizmos.i | |
3 | // Purpose: Wrappers for the "gizmo" classes in wx/contrib | |
4 | // | |
5 | // Author: Robin Dunn | |
6 | // | |
7 | // Created: 23-Nov-2001 | |
8 | // RCS-ID: $Id$ | |
9 | // Copyright: (c) 2001 by Total Control Software | |
10 | // Licence: wxWindows license | |
11 | ///////////////////////////////////////////////////////////////////////////// | |
12 | ||
13 | %define DOCSTRING | |
14 | "Various *gizmo* classes: `DynamicSashWindow`, `EditableListBox`, | |
15 | `LEDNumberCtrl`, `TreeListCtrl`, etc." | |
16 | %enddef | |
17 | ||
18 | %module(package="wx", docstring=DOCSTRING) gizmos | |
19 | ||
20 | ||
21 | %{ | |
22 | #include "wx/wxPython/wxPython.h" | |
23 | #include "wx/wxPython/pyclasses.h" | |
24 | ||
25 | #include <wx/gizmos/dynamicsash.h> | |
26 | #include <wx/gizmos/editlbox.h> | |
27 | #include <wx/gizmos/splittree.h> | |
28 | #include <wx/gizmos/ledctrl.h> | |
29 | #include <wx/gizmos/statpict.h> | |
30 | ||
31 | #include <wx/listctrl.h> | |
32 | #include <wx/treectrl.h> | |
33 | #include <wx/imaglist.h> | |
34 | ||
35 | %} | |
36 | ||
37 | //--------------------------------------------------------------------------- | |
38 | ||
39 | %import windows.i | |
40 | %import controls.i | |
41 | %pythoncode { import wx } | |
42 | %pythoncode { __docfilter__ = wx._core.__DocFilter(globals()) } | |
43 | ||
44 | ||
45 | MAKE_CONST_WXSTRING2(DynamicSashNameStr, wxT("dynamicSashWindow")); | |
46 | MAKE_CONST_WXSTRING2(EditableListBoxNameStr, wxT("editableListBox")); | |
47 | MAKE_CONST_WXSTRING(StaticPictureNameStr); | |
48 | ||
49 | MAKE_CONST_WXSTRING_NOSWIG(EmptyString); | |
50 | ||
51 | //--------------------------------------------------------------------------- | |
52 | ||
53 | enum { | |
54 | wxDS_MANAGE_SCROLLBARS, | |
55 | wxDS_DRAG_CORNER, | |
56 | }; | |
57 | ||
58 | %constant wxEventType wxEVT_DYNAMIC_SASH_SPLIT; | |
59 | %constant wxEventType wxEVT_DYNAMIC_SASH_UNIFY; | |
60 | ||
61 | ||
62 | /* | |
63 | wxDynamicSashSplitEvents are sent to your view by wxDynamicSashWindow | |
64 | whenever your view is being split by the user. It is your | |
65 | responsibility to handle this event by creating a new view window as | |
66 | a child of the wxDynamicSashWindow. wxDynamicSashWindow will | |
67 | automatically reparent it to the proper place in its window hierarchy. | |
68 | */ | |
69 | class wxDynamicSashSplitEvent : public wxCommandEvent { | |
70 | public: | |
71 | wxDynamicSashSplitEvent(wxObject *target); | |
72 | }; | |
73 | ||
74 | ||
75 | /* | |
76 | wxDynamicSashUnifyEvents are sent to your view by wxDynamicSashWindow | |
77 | whenever the sash which splits your view and its sibling is being | |
78 | reunified such that your view is expanding to replace its sibling. | |
79 | You needn't do anything with this event if you are allowing | |
80 | wxDynamicSashWindow to manage your view's scrollbars, but it is useful | |
81 | if you are managing the scrollbars yourself so that you can keep | |
82 | the scrollbars' event handlers connected to your view's event handler | |
83 | class. | |
84 | */ | |
85 | class wxDynamicSashUnifyEvent : public wxCommandEvent { | |
86 | public: | |
87 | wxDynamicSashUnifyEvent(wxObject *target); | |
88 | }; | |
89 | ||
90 | ||
91 | ||
92 | /* | |
93 | ||
94 | wxDynamicSashWindow | |
95 | ||
96 | wxDynamicSashWindow widgets manages the way other widgets are viewed. | |
97 | When a wxDynamicSashWindow is first shown, it will contain one child | |
98 | view, a viewport for that child, and a pair of scrollbars to allow the | |
99 | user to navigate the child view area. Next to each scrollbar is a small | |
100 | tab. By clicking on either tab and dragging to the appropriate spot, a | |
101 | user can split the view area into two smaller views separated by a | |
102 | draggable sash. Later, when the user wishes to reunify the two subviews, | |
103 | the user simply drags the sash to the side of the window. | |
104 | wxDynamicSashWindow will automatically reparent the appropriate child | |
105 | view back up the window hierarchy, and the wxDynamicSashWindow will have | |
106 | only one child view once again. | |
107 | ||
108 | As an application developer, you will simply create a wxDynamicSashWindow | |
109 | using either the Create() function or the more complex constructor | |
110 | provided below, and then create a view window whose parent is the | |
111 | wxDynamicSashWindow. The child should respond to | |
112 | wxDynamicSashSplitEvents -- perhaps with an OnSplit() event handler -- by | |
113 | constructing a new view window whose parent is also the | |
114 | wxDynamicSashWindow. That's it! Now your users can dynamically split | |
115 | and reunify the view you provided. | |
116 | ||
117 | If you wish to handle the scrollbar events for your view, rather than | |
118 | allowing wxDynamicSashWindow to do it for you, things are a bit more | |
119 | complex. (You might want to handle scrollbar events yourself, if, | |
120 | for instance, you wish to scroll a subwindow of the view you add to | |
121 | your wxDynamicSashWindow object, rather than scrolling the whole view.) | |
122 | In this case, you will need to construct your wxDynamicSashWindow without | |
123 | the wxDS_MANAGE_SCROLLBARS style and you will need to use the | |
124 | GetHScrollBar() and GetVScrollBar() methods to retrieve the scrollbar | |
125 | controls and call SetEventHanler() on them to redirect the scrolling | |
126 | events whenever your window is reparented by wxDyanmicSashWindow. | |
127 | You will need to set the scrollbars' event handler at three times: | |
128 | ||
129 | * When your view is created | |
130 | * When your view receives a wxDynamicSashSplitEvent | |
131 | * When your view receives a wxDynamicSashUnifyEvent | |
132 | ||
133 | See the dynsash_switch sample application for an example which does this. | |
134 | ||
135 | */ | |
136 | ||
137 | MustHaveApp(wxDynamicSashWindow); | |
138 | ||
139 | class wxDynamicSashWindow : public wxWindow { | |
140 | public: | |
141 | %pythonAppend wxDynamicSashWindow "self._setOORInfo(self)" | |
142 | %pythonAppend wxDynamicSashWindow() "" | |
143 | ||
144 | wxDynamicSashWindow(wxWindow *parent, wxWindowID id=-1, | |
145 | const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, | |
146 | long style = wxCLIP_CHILDREN | wxDS_MANAGE_SCROLLBARS | wxDS_DRAG_CORNER, | |
147 | const wxString& name = wxPyDynamicSashNameStr); | |
148 | %RenameCtor(PreDynamicSashWindow, wxDynamicSashWindow()); | |
149 | ||
150 | bool Create(wxWindow *parent, wxWindowID id=-1, | |
151 | const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, | |
152 | long style = wxCLIP_CHILDREN | wxDS_MANAGE_SCROLLBARS | wxDS_DRAG_CORNER, | |
153 | const wxString& name = wxPyDynamicSashNameStr); | |
154 | ||
155 | wxScrollBar *GetHScrollBar(const wxWindow *child) const; | |
156 | wxScrollBar *GetVScrollBar(const wxWindow *child) const; | |
157 | }; | |
158 | ||
159 | ||
160 | ||
161 | %pythoncode { | |
162 | EVT_DYNAMIC_SASH_SPLIT = wx.PyEventBinder( wxEVT_DYNAMIC_SASH_SPLIT, 1 ) | |
163 | EVT_DYNAMIC_SASH_UNIFY = wx.PyEventBinder( wxEVT_DYNAMIC_SASH_UNIFY, 1 ) | |
164 | } | |
165 | ||
166 | //--------------------------------------------------------------------------- | |
167 | //--------------------------------------------------------------------------- | |
168 | ||
169 | enum { | |
170 | wxEL_ALLOW_NEW, | |
171 | wxEL_ALLOW_EDIT, | |
172 | wxEL_ALLOW_DELETE, | |
173 | }; | |
174 | ||
175 | ||
176 | %typemap(out) wxPyListCtrl* | |
177 | { $result = wxPyMake_wxObject((wxObject*)$1, (bool)$owner); } | |
178 | ||
179 | ||
180 | // This class provides a composite control that lets the | |
181 | // user easily enter list of strings | |
182 | MustHaveApp(wxEditableListBox); | |
183 | class wxEditableListBox : public wxPanel | |
184 | { | |
185 | public: | |
186 | %pythonAppend wxEditableListBox "self._setOORInfo(self)" | |
187 | %pythonAppend wxEditableListBox() "" | |
188 | ||
189 | wxEditableListBox(wxWindow *parent, wxWindowID id=-1, | |
190 | const wxString& label = wxPyEmptyString, | |
191 | const wxPoint& pos = wxDefaultPosition, | |
192 | const wxSize& size = wxDefaultSize, | |
193 | long style = wxEL_ALLOW_NEW | wxEL_ALLOW_EDIT | wxEL_ALLOW_DELETE, | |
194 | const wxString& name = wxPyEditableListBoxNameStr); | |
195 | ||
196 | ||
197 | void SetStrings(const wxArrayString& strings); | |
198 | ||
199 | //void GetStrings(wxArrayString& strings); | |
200 | %extend { | |
201 | PyObject* GetStrings() { | |
202 | wxArrayString strings; | |
203 | self->GetStrings(strings); | |
204 | return wxArrayString2PyList_helper(strings); | |
205 | } | |
206 | } | |
207 | ||
208 | wxPyListCtrl* GetListCtrl(); | |
209 | wxBitmapButton* GetDelButton(); | |
210 | wxBitmapButton* GetNewButton(); | |
211 | wxBitmapButton* GetUpButton(); | |
212 | wxBitmapButton* GetDownButton(); | |
213 | wxBitmapButton* GetEditButton(); | |
214 | ||
215 | %property(DelButton, GetDelButton, doc="See `GetDelButton`"); | |
216 | %property(DownButton, GetDownButton, doc="See `GetDownButton`"); | |
217 | %property(EditButton, GetEditButton, doc="See `GetEditButton`"); | |
218 | %property(ListCtrl, GetListCtrl, doc="See `GetListCtrl`"); | |
219 | %property(NewButton, GetNewButton, doc="See `GetNewButton`"); | |
220 | %property(Strings, GetStrings, SetStrings, doc="See `GetStrings` and `SetStrings`"); | |
221 | %property(UpButton, GetUpButton, doc="See `GetUpButton`"); | |
222 | }; | |
223 | ||
224 | ||
225 | ||
226 | //--------------------------------------------------------------------------- | |
227 | ||
228 | ||
229 | /* | |
230 | * wxRemotelyScrolledTreeCtrl | |
231 | * | |
232 | * This tree control disables its vertical scrollbar and catches scroll | |
233 | * events passed by a scrolled window higher in the hierarchy. | |
234 | * It also updates the scrolled window vertical scrollbar as appropriate. | |
235 | */ | |
236 | ||
237 | %{ | |
238 | typedef wxTreeCtrl wxPyTreeCtrl; | |
239 | %} | |
240 | ||
241 | MustHaveApp(wxRemotelyScrolledTreeCtrl); | |
242 | ||
243 | class wxRemotelyScrolledTreeCtrl: public wxPyTreeCtrl | |
244 | { | |
245 | public: | |
246 | %pythonAppend wxRemotelyScrolledTreeCtrl "self._setOORInfo(self)" | |
247 | %pythonAppend wxRemotelyScrolledTreeCtrl() "" | |
248 | ||
249 | wxRemotelyScrolledTreeCtrl(wxWindow* parent, wxWindowID id, | |
250 | const wxPoint& pos = wxDefaultPosition, | |
251 | const wxSize& size = wxDefaultSize, | |
252 | long style = wxTR_HAS_BUTTONS); | |
253 | ||
254 | ||
255 | void HideVScrollbar(); | |
256 | ||
257 | // Adjust the containing wxScrolledWindow's scrollbars appropriately | |
258 | void AdjustRemoteScrollbars(); | |
259 | ||
260 | // Find the scrolled window that contains this control | |
261 | wxScrolledWindow* GetScrolledWindow() const; | |
262 | ||
263 | // Scroll to the given line (in scroll units where each unit is | |
264 | // the height of an item) | |
265 | void ScrollToLine(int posHoriz, int posVert); | |
266 | ||
267 | // The companion window is one which will get notified when certain | |
268 | // events happen such as node expansion | |
269 | void SetCompanionWindow(wxWindow* companion); | |
270 | wxWindow* GetCompanionWindow() const; | |
271 | ||
272 | %property(CompanionWindow, GetCompanionWindow, SetCompanionWindow, doc="See `GetCompanionWindow` and `SetCompanionWindow`"); | |
273 | %property(ScrolledWindow, GetScrolledWindow, doc="See `GetScrolledWindow`"); | |
274 | }; | |
275 | ||
276 | ||
277 | ||
278 | /* | |
279 | * wxTreeCompanionWindow | |
280 | * | |
281 | * A window displaying values associated with tree control items. | |
282 | */ | |
283 | ||
284 | %{ | |
285 | class wxPyTreeCompanionWindow: public wxTreeCompanionWindow | |
286 | { | |
287 | public: | |
288 | wxPyTreeCompanionWindow(wxWindow* parent, wxWindowID id = -1, | |
289 | const wxPoint& pos = wxDefaultPosition, | |
290 | const wxSize& size = wxDefaultSize, | |
291 | long style = 0) | |
292 | : wxTreeCompanionWindow(parent, id, pos, size, style) {} | |
293 | ||
294 | ||
295 | virtual void DrawItem(wxDC& dc, wxTreeItemId id, const wxRect& rect) { | |
296 | bool found; | |
297 | wxPyBlock_t blocked = wxPyBeginBlockThreads(); | |
298 | if ((found = wxPyCBH_findCallback(m_myInst, "DrawItem"))) { | |
299 | PyObject* dcobj = wxPyMake_wxObject(&dc,false); | |
300 | PyObject* idobj = wxPyConstructObject((void*)&id, wxT("wxTreeItemId"), false); | |
301 | PyObject* recobj= wxPyConstructObject((void*)&rect, wxT("wxRect"), false); | |
302 | wxPyCBH_callCallback(m_myInst, Py_BuildValue("(OOO)", dcobj, idobj, recobj)); | |
303 | Py_DECREF(dcobj); | |
304 | Py_DECREF(idobj); | |
305 | Py_DECREF(recobj); | |
306 | } | |
307 | wxPyEndBlockThreads(blocked); | |
308 | if (! found) | |
309 | wxTreeCompanionWindow::DrawItem(dc, id, rect); | |
310 | } | |
311 | ||
312 | PYPRIVATE; | |
313 | }; | |
314 | %} | |
315 | ||
316 | ||
317 | MustHaveApp(wxPyTreeCompanionWindow); | |
318 | ||
319 | %rename(TreeCompanionWindow) wxPyTreeCompanionWindow; | |
320 | class wxPyTreeCompanionWindow: public wxWindow | |
321 | { | |
322 | public: | |
323 | %pythonAppend wxPyTreeCompanionWindow "self._setOORInfo(self);" setCallbackInfo(TreeCompanionWindow) | |
324 | %pythonAppend wxPyTreeCompanionWindow() "" | |
325 | ||
326 | wxPyTreeCompanionWindow(wxWindow* parent, wxWindowID id = -1, | |
327 | const wxPoint& pos = wxDefaultPosition, | |
328 | const wxSize& size = wxDefaultSize, | |
329 | long style = 0); | |
330 | void _setCallbackInfo(PyObject* self, PyObject* _class); | |
331 | ||
332 | wxRemotelyScrolledTreeCtrl* GetTreeCtrl() const; | |
333 | void SetTreeCtrl(wxRemotelyScrolledTreeCtrl* treeCtrl); | |
334 | ||
335 | %property(TreeCtrl, GetTreeCtrl, SetTreeCtrl, doc="See `GetTreeCtrl` and `SetTreeCtrl`"); | |
336 | }; | |
337 | ||
338 | ||
339 | ||
340 | /* | |
341 | * wxThinSplitterWindow | |
342 | * | |
343 | * Implements a splitter with a less obvious sash | |
344 | * than the usual one. | |
345 | */ | |
346 | ||
347 | MustHaveApp(wxThinSplitterWindow); | |
348 | ||
349 | class wxThinSplitterWindow: public wxSplitterWindow | |
350 | { | |
351 | public: | |
352 | %pythonAppend wxThinSplitterWindow "self._setOORInfo(self)" | |
353 | %pythonAppend wxThinSplitterWindow() "" | |
354 | ||
355 | wxThinSplitterWindow(wxWindow* parent, wxWindowID id = -1, | |
356 | const wxPoint& pos = wxDefaultPosition, | |
357 | const wxSize& size = wxDefaultSize, | |
358 | long style = wxSP_3D | wxCLIP_CHILDREN); | |
359 | }; | |
360 | ||
361 | ||
362 | ||
363 | /* | |
364 | * wxSplitterScrolledWindow | |
365 | * | |
366 | * This scrolled window is aware of the fact that one of its | |
367 | * children is a splitter window. It passes on its scroll events | |
368 | * (after some processing) to both splitter children for them | |
369 | * scroll appropriately. | |
370 | */ | |
371 | ||
372 | MustHaveApp(wxSplitterScrolledWindow); | |
373 | ||
374 | class wxSplitterScrolledWindow: public wxScrolledWindow | |
375 | { | |
376 | public: | |
377 | %pythonAppend wxSplitterScrolledWindow "self._setOORInfo(self)" | |
378 | %pythonAppend wxSplitterScrolledWindow() "" | |
379 | ||
380 | wxSplitterScrolledWindow(wxWindow* parent, wxWindowID id = -1, | |
381 | const wxPoint& pos = wxDefaultPosition, | |
382 | const wxSize& size = wxDefaultSize, | |
383 | long style = 0); | |
384 | }; | |
385 | ||
386 | ||
387 | //--------------------------------------------------------------------------- | |
388 | //--------------------------------------------------------------------------- | |
389 | ||
390 | ||
391 | enum wxLEDValueAlign | |
392 | { | |
393 | wxLED_ALIGN_LEFT, | |
394 | wxLED_ALIGN_RIGHT, | |
395 | wxLED_ALIGN_CENTER, | |
396 | ||
397 | wxLED_ALIGN_MASK, | |
398 | ||
399 | wxLED_DRAW_FADED, | |
400 | }; | |
401 | ||
402 | ||
403 | MustHaveApp(wxLEDNumberCtrl); | |
404 | ||
405 | class wxLEDNumberCtrl : public wxControl | |
406 | { | |
407 | public: | |
408 | %pythonAppend wxLEDNumberCtrl "self._setOORInfo(self)" | |
409 | %pythonAppend wxLEDNumberCtrl() "" | |
410 | ||
411 | wxLEDNumberCtrl(wxWindow *parent, wxWindowID id = -1, | |
412 | const wxPoint& pos = wxDefaultPosition, | |
413 | const wxSize& size = wxDefaultSize, | |
414 | long style = wxLED_ALIGN_LEFT | wxLED_DRAW_FADED); | |
415 | %RenameCtor(PreLEDNumberCtrl, wxLEDNumberCtrl()); | |
416 | ||
417 | bool Create(wxWindow *parent, wxWindowID id = -1, | |
418 | const wxPoint& pos = wxDefaultPosition, | |
419 | const wxSize& size = wxDefaultSize, | |
420 | long style = wxLED_ALIGN_LEFT | wxLED_DRAW_FADED); | |
421 | ||
422 | wxLEDValueAlign GetAlignment() const; | |
423 | bool GetDrawFaded() const; | |
424 | const wxString &GetValue() const; | |
425 | ||
426 | void SetAlignment(wxLEDValueAlign Alignment, bool Redraw = true); | |
427 | void SetDrawFaded(bool DrawFaded, bool Redraw = true); | |
428 | void SetValue(const wxString &Value, bool Redraw = true); | |
429 | ||
430 | %property(Alignment, GetAlignment, SetAlignment, doc="See `GetAlignment` and `SetAlignment`"); | |
431 | %property(DrawFaded, GetDrawFaded, SetDrawFaded, doc="See `GetDrawFaded` and `SetDrawFaded`"); | |
432 | %property(Value, GetValue, SetValue, doc="See `GetValue` and `SetValue`"); | |
433 | }; | |
434 | ||
435 | ||
436 | ||
437 | //---------------------------------------------------------------------- | |
438 | ||
439 | %include _treelist.i | |
440 | ||
441 | //---------------------------------------------------------------------- | |
442 | ||
443 | enum | |
444 | { | |
445 | wxSCALE_HORIZONTAL, | |
446 | wxSCALE_VERTICAL, | |
447 | wxSCALE_UNIFORM, | |
448 | wxSCALE_CUSTOM | |
449 | }; | |
450 | ||
451 | MustHaveApp(wxStaticPicture); | |
452 | ||
453 | class wxStaticPicture : public wxControl | |
454 | { | |
455 | public: | |
456 | %pythonAppend wxStaticPicture "self._setOORInfo(self)" | |
457 | %pythonAppend wxStaticPicture() "" | |
458 | ||
459 | wxStaticPicture( wxWindow* parent, wxWindowID id=-1, | |
460 | const wxBitmap& label=wxNullBitmap, | |
461 | const wxPoint& pos = wxDefaultPosition, | |
462 | const wxSize& size = wxDefaultSize, | |
463 | long style = 0, | |
464 | const wxString& name = wxPyStaticPictureNameStr ); | |
465 | ||
466 | %RenameCtor(PreStaticPicture, wxStaticPicture()); | |
467 | ||
468 | bool Create( wxWindow* parent, wxWindowID id=-1, | |
469 | const wxBitmap& label=wxNullBitmap, | |
470 | const wxPoint& pos = wxDefaultPosition, | |
471 | const wxSize& size = wxDefaultSize, | |
472 | long style = 0, | |
473 | const wxString& name = wxPyStaticPictureNameStr ); | |
474 | ||
475 | void SetBitmap( const wxBitmap& bmp ); | |
476 | wxBitmap GetBitmap() const; | |
477 | void SetIcon( const wxIcon& icon ); | |
478 | wxIcon GetIcon() const; | |
479 | ||
480 | void SetAlignment( int align ); | |
481 | int GetAlignment() const; | |
482 | ||
483 | void SetScale( int scale ); | |
484 | int GetScale() const; | |
485 | ||
486 | void SetCustomScale( float sx, float sy ); | |
487 | void GetCustomScale( float* OUTPUT, float* OUTPUT ) const; | |
488 | ||
489 | %property(Alignment, GetAlignment, SetAlignment, doc="See `GetAlignment` and `SetAlignment`"); | |
490 | %property(Bitmap, GetBitmap, SetBitmap, doc="See `GetBitmap` and `SetBitmap`"); | |
491 | %property(Icon, GetIcon, SetIcon, doc="See `GetIcon` and `SetIcon`"); | |
492 | %property(Scale, GetScale, SetScale, doc="See `GetScale` and `SetScale`"); | |
493 | }; | |
494 | ||
495 | ||
496 | //---------------------------------------------------------------------- | |
497 | //---------------------------------------------------------------------- | |
498 | ||
499 | %init %{ | |
500 | wxPyPtrTypeMap_Add("wxTreeCompanionWindow", "wxPyTreeCompanionWindow"); | |
501 | %} | |
502 | ||
503 | //---------------------------------------------------------------------- | |
504 | //---------------------------------------------------------------------- | |
505 |