]> git.saurik.com Git - wxWidgets.git/blame - wxPython/contrib/gizmos/gizmos.i
No need to use wxPyMake_wxObject for wxImageList. There are no
[wxWidgets.git] / wxPython / contrib / gizmos / gizmos.i
CommitLineData
ebf4302c
RD
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
c8fac2b6
RD
13%define DOCSTRING
14"Various *gizmo* classes: `DynamicSashWindow`, `EditableListBox`,
15`LEDNumberCtrl`, `TreeListCtrl`, etc."
16%enddef
17
b2eb030f 18%module(package="wx", docstring=DOCSTRING) gizmos
ebf4302c
RD
19
20
21%{
d14a1e28
RD
22#include "wx/wxPython/wxPython.h"
23#include "wx/wxPython/pyclasses.h"
28eab81f 24
611dc22c
RD
25#include <wx/gizmos/dynamicsash.h>
26#include <wx/gizmos/editlbox.h>
27#include <wx/gizmos/splittree.h>
950e7faf 28#include <wx/gizmos/ledctrl.h>
7e4b7f9a 29#include <wx/gizmos/statpict.h>
1fded56b 30
7c379a20 31#include <wx/listctrl.h>
1fded56b
RD
32#include <wx/treectrl.h>
33#include <wx/imaglist.h>
28eab81f 34
137b5242
RD
35%}
36
d14a1e28
RD
37//---------------------------------------------------------------------------
38
39%import windows.i
40%import controls.i
648d396c
RD
41%pythoncode { import wx }
42%pythoncode { __docfilter__ = wx._core.__DocFilter(globals()) }
d14a1e28 43
b2dc1044 44
089142a5
RD
45MAKE_CONST_WXSTRING2(DynamicSashNameStr, wxT("dynamicSashWindow"));
46MAKE_CONST_WXSTRING2(EditableListBoxNameStr, wxT("editableListBox"));
d3397f6a 47MAKE_CONST_WXSTRING(StaticPictureNameStr);
7e4b7f9a 48
b2dc1044
RD
49MAKE_CONST_WXSTRING_NOSWIG(EmptyString);
50
d14a1e28 51//---------------------------------------------------------------------------
137b5242 52
ebf4302c 53enum {
ebf4302c
RD
54 wxDS_MANAGE_SCROLLBARS,
55 wxDS_DRAG_CORNER,
56};
57
6c56259a
RD
58%constant wxEventType wxEVT_DYNAMIC_SASH_SPLIT;
59%constant wxEventType wxEVT_DYNAMIC_SASH_UNIFY;
60
ebf4302c
RD
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*/
69class wxDynamicSashSplitEvent : public wxCommandEvent {
70public:
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*/
85class wxDynamicSashUnifyEvent : public wxCommandEvent {
86public:
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
611dc22c 110 provided below, and then create a view window whose parent is the
ebf4302c
RD
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.)
611dc22c 122 In this case, you will need to construct your wxDynamicSashWindow without
ebf4302c
RD
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
ab1f7d2a
RD
137MustHaveApp(wxDynamicSashWindow);
138
ebf4302c
RD
139class wxDynamicSashWindow : public wxWindow {
140public:
2b9048c5
RD
141 %pythonAppend wxDynamicSashWindow "self._setOORInfo(self)"
142 %pythonAppend wxDynamicSashWindow() ""
d14a1e28 143
d5573410 144 wxDynamicSashWindow(wxWindow *parent, wxWindowID id=-1,
ebf4302c
RD
145 const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
146 long style = wxCLIP_CHILDREN | wxDS_MANAGE_SCROLLBARS | wxDS_DRAG_CORNER,
137b5242 147 const wxString& name = wxPyDynamicSashNameStr);
1b8c7ba6 148 %RenameCtor(PreDynamicSashWindow, wxDynamicSashWindow());
ebf4302c 149
d5573410 150 bool Create(wxWindow *parent, wxWindowID id=-1,
ebf4302c
RD
151 const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
152 long style = wxCLIP_CHILDREN | wxDS_MANAGE_SCROLLBARS | wxDS_DRAG_CORNER,
137b5242 153 const wxString& name = wxPyDynamicSashNameStr);
ebf4302c 154
ebf4302c
RD
155 wxScrollBar *GetHScrollBar(const wxWindow *child) const;
156 wxScrollBar *GetVScrollBar(const wxWindow *child) const;
157};
158
159
160
d14a1e28
RD
161%pythoncode {
162EVT_DYNAMIC_SASH_SPLIT = wx.PyEventBinder( wxEVT_DYNAMIC_SASH_SPLIT, 1 )
163EVT_DYNAMIC_SASH_UNIFY = wx.PyEventBinder( wxEVT_DYNAMIC_SASH_UNIFY, 1 )
164}
ebf4302c 165
d14a1e28
RD
166//---------------------------------------------------------------------------
167//---------------------------------------------------------------------------
7b7ac0ab 168
6187ec8f
RD
169enum {
170 wxEL_ALLOW_NEW,
171 wxEL_ALLOW_EDIT,
172 wxEL_ALLOW_DELETE,
173};
7b7ac0ab
RD
174
175// This class provides a composite control that lets the
176// user easily enter list of strings
ab1f7d2a 177MustHaveApp(wxEditableListBox);
7b7ac0ab
RD
178class wxEditableListBox : public wxPanel
179{
180public:
2b9048c5
RD
181 %pythonAppend wxEditableListBox "self._setOORInfo(self)"
182 %pythonAppend wxEditableListBox() ""
d14a1e28 183
d5573410
RD
184 wxEditableListBox(wxWindow *parent, wxWindowID id=-1,
185 const wxString& label = wxPyEmptyString,
7b7ac0ab
RD
186 const wxPoint& pos = wxDefaultPosition,
187 const wxSize& size = wxDefaultSize,
6187ec8f 188 long style = wxEL_ALLOW_NEW | wxEL_ALLOW_EDIT | wxEL_ALLOW_DELETE,
137b5242 189 const wxString& name = wxPyEditableListBoxNameStr);
7b7ac0ab 190
611dc22c 191
7b7ac0ab
RD
192 void SetStrings(const wxArrayString& strings);
193
194 //void GetStrings(wxArrayString& strings);
d14a1e28 195 %extend {
7b7ac0ab
RD
196 PyObject* GetStrings() {
197 wxArrayString strings;
198 self->GetStrings(strings);
199 return wxArrayString2PyList_helper(strings);
200 }
201 }
366d7bd6 202
15f80007 203 wxPyListCtrl* GetListCtrl();
d14a1e28
RD
204 wxBitmapButton* GetDelButton();
205 wxBitmapButton* GetNewButton();
206 wxBitmapButton* GetUpButton();
207 wxBitmapButton* GetDownButton();
208 wxBitmapButton* GetEditButton();
e70b4d2d
RD
209
210 %property(DelButton, GetDelButton, doc="See `GetDelButton`");
211 %property(DownButton, GetDownButton, doc="See `GetDownButton`");
212 %property(EditButton, GetEditButton, doc="See `GetEditButton`");
213 %property(ListCtrl, GetListCtrl, doc="See `GetListCtrl`");
214 %property(NewButton, GetNewButton, doc="See `GetNewButton`");
215 %property(Strings, GetStrings, SetStrings, doc="See `GetStrings` and `SetStrings`");
216 %property(UpButton, GetUpButton, doc="See `GetUpButton`");
7b7ac0ab
RD
217};
218
219
220
d14a1e28 221//---------------------------------------------------------------------------
611dc22c
RD
222
223
224/*
225 * wxRemotelyScrolledTreeCtrl
226 *
227 * This tree control disables its vertical scrollbar and catches scroll
228 * events passed by a scrolled window higher in the hierarchy.
229 * It also updates the scrolled window vertical scrollbar as appropriate.
230 */
231
232%{
233 typedef wxTreeCtrl wxPyTreeCtrl;
234%}
235
ab1f7d2a
RD
236MustHaveApp(wxRemotelyScrolledTreeCtrl);
237
611dc22c
RD
238class wxRemotelyScrolledTreeCtrl: public wxPyTreeCtrl
239{
240public:
2b9048c5
RD
241 %pythonAppend wxRemotelyScrolledTreeCtrl "self._setOORInfo(self)"
242 %pythonAppend wxRemotelyScrolledTreeCtrl() ""
d14a1e28 243
611dc22c
RD
244 wxRemotelyScrolledTreeCtrl(wxWindow* parent, wxWindowID id,
245 const wxPoint& pos = wxDefaultPosition,
246 const wxSize& size = wxDefaultSize,
247 long style = wxTR_HAS_BUTTONS);
611dc22c
RD
248
249
250 void HideVScrollbar();
251
252 // Adjust the containing wxScrolledWindow's scrollbars appropriately
253 void AdjustRemoteScrollbars();
254
255 // Find the scrolled window that contains this control
256 wxScrolledWindow* GetScrolledWindow() const;
257
258 // Scroll to the given line (in scroll units where each unit is
259 // the height of an item)
260 void ScrollToLine(int posHoriz, int posVert);
261
262 // The companion window is one which will get notified when certain
263 // events happen such as node expansion
264 void SetCompanionWindow(wxWindow* companion);
265 wxWindow* GetCompanionWindow() const;
e70b4d2d
RD
266
267 %property(CompanionWindow, GetCompanionWindow, SetCompanionWindow, doc="See `GetCompanionWindow` and `SetCompanionWindow`");
268 %property(ScrolledWindow, GetScrolledWindow, doc="See `GetScrolledWindow`");
611dc22c
RD
269};
270
271
272
273/*
274 * wxTreeCompanionWindow
275 *
276 * A window displaying values associated with tree control items.
277 */
278
279%{
280class wxPyTreeCompanionWindow: public wxTreeCompanionWindow
281{
282public:
283 wxPyTreeCompanionWindow(wxWindow* parent, wxWindowID id = -1,
284 const wxPoint& pos = wxDefaultPosition,
285 const wxSize& size = wxDefaultSize,
286 long style = 0)
287 : wxTreeCompanionWindow(parent, id, pos, size, style) {}
288
289
290 virtual void DrawItem(wxDC& dc, wxTreeItemId id, const wxRect& rect) {
291 bool found;
6e6b3557 292 wxPyBlock_t blocked = wxPyBeginBlockThreads();
611dc22c 293 if ((found = wxPyCBH_findCallback(m_myInst, "DrawItem"))) {
6d450e1a 294 PyObject* dcobj = wxPyMake_wxObject(&dc,false);
a72f4631
RD
295 PyObject* idobj = wxPyConstructObject((void*)&id, wxT("wxTreeItemId"), false);
296 PyObject* recobj= wxPyConstructObject((void*)&rect, wxT("wxRect"), false);
611dc22c
RD
297 wxPyCBH_callCallback(m_myInst, Py_BuildValue("(OOO)", dcobj, idobj, recobj));
298 Py_DECREF(dcobj);
299 Py_DECREF(idobj);
300 Py_DECREF(recobj);
301 }
da32eb53 302 wxPyEndBlockThreads(blocked);
611dc22c
RD
303 if (! found)
304 wxTreeCompanionWindow::DrawItem(dc, id, rect);
305 }
306
307 PYPRIVATE;
308};
309%}
310
311
ab1f7d2a
RD
312MustHaveApp(wxPyTreeCompanionWindow);
313
1b8c7ba6
RD
314%rename(TreeCompanionWindow) wxPyTreeCompanionWindow;
315class wxPyTreeCompanionWindow: public wxWindow
611dc22c
RD
316{
317public:
2b9048c5
RD
318 %pythonAppend wxPyTreeCompanionWindow "self._setOORInfo(self);self._setCallbackInfo(self, TreeCompanionWindow)"
319 %pythonAppend wxPyTreeCompanionWindow() ""
d14a1e28 320
611dc22c
RD
321 wxPyTreeCompanionWindow(wxWindow* parent, wxWindowID id = -1,
322 const wxPoint& pos = wxDefaultPosition,
323 const wxSize& size = wxDefaultSize,
324 long style = 0);
325 void _setCallbackInfo(PyObject* self, PyObject* _class);
611dc22c
RD
326
327 wxRemotelyScrolledTreeCtrl* GetTreeCtrl() const;
328 void SetTreeCtrl(wxRemotelyScrolledTreeCtrl* treeCtrl);
e70b4d2d
RD
329
330 %property(TreeCtrl, GetTreeCtrl, SetTreeCtrl, doc="See `GetTreeCtrl` and `SetTreeCtrl`");
611dc22c
RD
331};
332
333
334
335/*
336 * wxThinSplitterWindow
337 *
338 * Implements a splitter with a less obvious sash
339 * than the usual one.
340 */
341
ab1f7d2a
RD
342MustHaveApp(wxThinSplitterWindow);
343
611dc22c
RD
344class wxThinSplitterWindow: public wxSplitterWindow
345{
346public:
2b9048c5
RD
347 %pythonAppend wxThinSplitterWindow "self._setOORInfo(self)"
348 %pythonAppend wxThinSplitterWindow() ""
d14a1e28 349
611dc22c
RD
350 wxThinSplitterWindow(wxWindow* parent, wxWindowID id = -1,
351 const wxPoint& pos = wxDefaultPosition,
352 const wxSize& size = wxDefaultSize,
353 long style = wxSP_3D | wxCLIP_CHILDREN);
611dc22c
RD
354};
355
356
d14a1e28 357
611dc22c
RD
358/*
359 * wxSplitterScrolledWindow
360 *
361 * This scrolled window is aware of the fact that one of its
362 * children is a splitter window. It passes on its scroll events
363 * (after some processing) to both splitter children for them
364 * scroll appropriately.
365 */
366
ab1f7d2a
RD
367MustHaveApp(wxSplitterScrolledWindow);
368
611dc22c
RD
369class wxSplitterScrolledWindow: public wxScrolledWindow
370{
371public:
2b9048c5
RD
372 %pythonAppend wxSplitterScrolledWindow "self._setOORInfo(self)"
373 %pythonAppend wxSplitterScrolledWindow() ""
d14a1e28 374
611dc22c
RD
375 wxSplitterScrolledWindow(wxWindow* parent, wxWindowID id = -1,
376 const wxPoint& pos = wxDefaultPosition,
377 const wxSize& size = wxDefaultSize,
378 long style = 0);
611dc22c
RD
379};
380
381
d14a1e28
RD
382//---------------------------------------------------------------------------
383//---------------------------------------------------------------------------
950e7faf
RD
384
385
386enum wxLEDValueAlign
387{
388 wxLED_ALIGN_LEFT,
389 wxLED_ALIGN_RIGHT,
390 wxLED_ALIGN_CENTER,
391
392 wxLED_ALIGN_MASK,
393
394 wxLED_DRAW_FADED,
395};
396
397
ab1f7d2a
RD
398MustHaveApp(wxLEDNumberCtrl);
399
950e7faf
RD
400class wxLEDNumberCtrl : public wxControl
401{
402public:
2b9048c5
RD
403 %pythonAppend wxLEDNumberCtrl "self._setOORInfo(self)"
404 %pythonAppend wxLEDNumberCtrl() ""
d14a1e28 405
950e7faf
RD
406 wxLEDNumberCtrl(wxWindow *parent, wxWindowID id = -1,
407 const wxPoint& pos = wxDefaultPosition,
408 const wxSize& size = wxDefaultSize,
409 long style = wxLED_ALIGN_LEFT | wxLED_DRAW_FADED);
1b8c7ba6 410 %RenameCtor(PreLEDNumberCtrl, wxLEDNumberCtrl());
950e7faf 411
950e7faf
RD
412 bool Create(wxWindow *parent, wxWindowID id = -1,
413 const wxPoint& pos = wxDefaultPosition,
414 const wxSize& size = wxDefaultSize,
415 long style = wxLED_ALIGN_LEFT | wxLED_DRAW_FADED);
416
d14a1e28
RD
417 wxLEDValueAlign GetAlignment() const;
418 bool GetDrawFaded() const;
419 const wxString &GetValue() const;
950e7faf
RD
420
421 void SetAlignment(wxLEDValueAlign Alignment, bool Redraw = true);
422 void SetDrawFaded(bool DrawFaded, bool Redraw = true);
423 void SetValue(const wxString &Value, bool Redraw = true);
424
e70b4d2d
RD
425 %property(Alignment, GetAlignment, SetAlignment, doc="See `GetAlignment` and `SetAlignment`");
426 %property(DrawFaded, GetDrawFaded, SetDrawFaded, doc="See `GetDrawFaded` and `SetDrawFaded`");
427 %property(Value, GetValue, SetValue, doc="See `GetValue` and `SetValue`");
950e7faf
RD
428};
429
1fded56b
RD
430
431
33328cd8 432//----------------------------------------------------------------------
1fded56b 433
33328cd8 434%include _treelist.i
1fded56b 435
7e4b7f9a
RD
436//----------------------------------------------------------------------
437
438enum
439{
440 wxSCALE_HORIZONTAL,
441 wxSCALE_VERTICAL,
442 wxSCALE_UNIFORM,
443 wxSCALE_CUSTOM
444};
445
446MustHaveApp(wxStaticPicture);
447
448class wxStaticPicture : public wxControl
449{
450public:
451 %pythonAppend wxStaticPicture "self._setOORInfo(self)"
452 %pythonAppend wxStaticPicture() ""
453
d3397f6a
RD
454 wxStaticPicture( wxWindow* parent, wxWindowID id=-1,
455 const wxBitmap& label=wxNullBitmap,
7e4b7f9a
RD
456 const wxPoint& pos = wxDefaultPosition,
457 const wxSize& size = wxDefaultSize,
458 long style = 0,
459 const wxString& name = wxPyStaticPictureNameStr );
460
461 %RenameCtor(PreStaticPicture, wxStaticPicture());
462
d3397f6a
RD
463 bool Create( wxWindow* parent, wxWindowID id=-1,
464 const wxBitmap& label=wxNullBitmap,
7e4b7f9a
RD
465 const wxPoint& pos = wxDefaultPosition,
466 const wxSize& size = wxDefaultSize,
467 long style = 0,
468 const wxString& name = wxPyStaticPictureNameStr );
469
470 void SetBitmap( const wxBitmap& bmp );
471 wxBitmap GetBitmap() const;
472 void SetIcon( const wxIcon& icon );
473 wxIcon GetIcon() const;
1fded56b 474
7e4b7f9a
RD
475 void SetAlignment( int align );
476 int GetAlignment() const;
477
478 void SetScale( int scale );
479 int GetScale() const;
480
481 void SetCustomScale( float sx, float sy );
482 void GetCustomScale( float* OUTPUT, float* OUTPUT ) const;
483
e70b4d2d
RD
484 %property(Alignment, GetAlignment, SetAlignment, doc="See `GetAlignment` and `SetAlignment`");
485 %property(Bitmap, GetBitmap, SetBitmap, doc="See `GetBitmap` and `SetBitmap`");
486 %property(Icon, GetIcon, SetIcon, doc="See `GetIcon` and `SetIcon`");
487 %property(Scale, GetScale, SetScale, doc="See `GetScale` and `SetScale`");
7e4b7f9a 488};
1fded56b
RD
489
490
950e7faf 491//----------------------------------------------------------------------
ebf4302c
RD
492//----------------------------------------------------------------------
493
494%init %{
611dc22c 495 wxPyPtrTypeMap_Add("wxTreeCompanionWindow", "wxPyTreeCompanionWindow");
ebf4302c
RD
496%}
497
ebf4302c
RD
498//----------------------------------------------------------------------
499//----------------------------------------------------------------------
500