]> git.saurik.com Git - wxWidgets.git/blob - utils/wxPython/src/stattool.i
e68fccaf47d95fd9454fd44bb7a4a9750e9796ed
[wxWidgets.git] / utils / wxPython / src / stattool.i
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: stattool.i
3 // Purpose: SWIG definitions for StatusBar and ToolBar classes
4 //
5 // Author: Robin Dunn
6 //
7 // Created: 08/24/1998
8 // RCS-ID: $Id$
9 // Copyright: (c) 1998 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
12
13
14 %module stattool
15
16 %{
17 #include "helpers.h"
18 #include <wx/toolbar.h>
19 #include <wx/tbarsmpl.h>
20 %}
21
22 //----------------------------------------------------------------------
23
24 %include typemaps.i
25 %include my_typemaps.i
26
27 // Import some definitions of other classes, etc.
28 %import _defs.i
29 %import misc.i
30 %import windows.i
31 %import controls.i
32
33 %pragma(python) code = "import wx"
34
35 //---------------------------------------------------------------------------
36
37 class wxStatusBar : public wxWindow {
38 public:
39 wxStatusBar(wxWindow* parent, wxWindowID id,
40 const wxPoint& pos = wxPyDefaultPosition,
41 const wxSize& size = wxPyDefaultSize,
42 long style = wxST_SIZEGRIP,
43 char* name = "statusBar");
44
45 %pragma(python) addtomethod = "__init__:wx._StdWindowCallbacks(self)"
46
47 %addmethods {
48 %new wxRect* GetFieldRect(long item) {
49 wxRect* rect= new wxRect;
50 self->GetFieldRect(item, *rect);
51 return rect;
52 }
53 }
54 int GetFieldsCount(void);
55 wxString GetStatusText(int ir = 0);
56 void DrawField(wxDC& dc, int i);
57 void DrawFieldText(wxDC& dc, int i);
58 void InitColours(void);
59
60 // OnSysColourChanged(wxSysColourChangedEvent& event);
61
62 void SetFieldsCount(int number = 1);
63 void SetStatusText(const wxString& text, int i = 0);
64 void SetStatusWidths(int LCOUNT, int* LIST);
65 };
66
67
68 //---------------------------------------------------------------------------
69
70 class wxToolBarTool {
71 public:
72 wxToolBarTool();
73 ~wxToolBarTool();
74 #ifdef __WXMSW__
75 void SetSize( long w, long h ) { m_width = w; m_height = h; }
76 long GetWidth () const { return m_width; }
77 long GetHeight () const { return m_height; }
78 #endif
79
80 public:
81 int m_toolStyle;
82 wxObject * m_clientData;
83 int m_index;
84 #ifdef __WXMSW__
85 long m_x;
86 long m_y;
87 long m_width;
88 long m_height;
89 #endif
90 bool m_toggleState;
91 bool m_isToggle;
92 bool m_deleteSecondBitmap;
93 bool m_enabled;
94 wxBitmap m_bitmap1;
95 wxBitmap m_bitmap2;
96 bool m_isMenuCommand;
97 wxString m_shortHelpString;
98 wxString m_longHelpString;
99 };
100
101
102
103 // class wxToolBarBase : public wxControl {
104 // public:
105
106 class wxToolBar : public wxControl {
107 public:
108 wxToolBar(wxWindow* parent, wxWindowID id,
109 const wxPoint& pos = wxPyDefaultPosition,
110 const wxSize& size = wxPyDefaultSize,
111 long style = wxTB_HORIZONTAL | wxNO_BORDER,
112 char* name = "toolBar");
113
114 %pragma(python) addtomethod = "__init__:wx._StdWindowCallbacks(self)"
115
116
117 void AddSeparator(void);
118
119 // Ignoge the clientData for now...
120 %addmethods {
121 wxToolBarTool* AddTool(int toolIndex,
122 const wxBitmap& bitmap1,
123 const wxBitmap& bitmap2 = wxNullBitmap,
124 int isToggle = FALSE,
125 long xPos = -1,
126 long yPos = -1,
127 //wxObject* clientData = NULL,
128 const wxString& shortHelpString = wxPyEmptyStr,
129 const wxString& longHelpString = wxPyEmptyStr) {
130 return self->AddTool(toolIndex, bitmap1, bitmap2,
131 isToggle, xPos, yPos, NULL,
132 shortHelpString, longHelpString);
133 }
134 }
135
136 // void DrawTool(wxMemoryDC& memDC, wxToolBarTool* tool);
137 void EnableTool(int toolIndex, const bool enable);
138 #ifdef __WXMSW__
139 wxToolBarTool* FindToolForPosition(const float x, const float y);
140 wxSize GetToolSize();
141 wxSize GetToolBitmapSize();
142 // wxSize GetMargins();
143 wxSize GetMaxSize();
144 // wxObject* GetToolClientData(int toolIndex);
145 #endif
146 bool GetToolEnabled(int toolIndex);
147 #ifdef __WXMSW__
148 wxString GetToolLongHelp(int toolIndex);
149 int GetToolPacking();
150 int GetToolSeparation();
151 wxString GetToolShortHelp(int toolIndex);
152 #endif
153 bool GetToolState(int toolIndex);
154
155 // TODO: figure out how to handle these
156 //bool OnLeftClick(int toolIndex, bool toggleDown);
157 //void OnMouseEnter(int toolIndex);
158 //void OnRightClick(int toolIndex, float x, float y);
159
160
161 #ifdef __WXMSW__
162 bool Realize();
163 #else
164 void Realize();
165 #endif
166 #ifdef __WXMSW__
167 void SetToolBitmapSize(const wxSize& size);
168 void SetToolLongHelp(int toolIndex, const wxString& helpString);
169 void SetToolShortHelp(int toolIndex, const wxString& helpString);
170 #endif
171 void SetMargins(const wxSize& size);
172 void SetToolPacking(int packing);
173 void SetToolSeparation(int separation);
174 void ToggleTool(int toolIndex, const bool toggle);
175 };
176
177
178
179 // // The Native Toolbar
180 // class wxToolBar : public wxToolBarBase {
181 // public:
182 // wxToolBar(wxWindow* parent, wxWindowID id,
183 // const wxPoint& pos = wxPyDefaultPosition,
184 // const wxSize& size = wxPyDefaultSize,
185 // long style = wxTB_HORIZONTAL | wxNO_BORDER,
186 // char* name = "toolBar");
187
188 // %pragma(python) addtomethod = "__init__:wx._StdWindowCallbacks(self)"
189
190 // };
191
192
193 // // A generic toolbar
194 // class wxToolBarSimple : public wxToolBarBase {
195 // public:
196 // wxToolBarSimple(wxWindow* parent, wxWindowID id,
197 // const wxPoint& pos = wxPyDefaultPosition,
198 // const wxSize& size = wxPyDefaultSize,
199 // long style = wxTB_HORIZONTAL | wxNO_BORDER,
200 // char* name = "toolBar");
201
202 // %pragma(python) addtomethod = "__init__:wx._StdWindowCallbacks(self)"
203
204 // };
205
206
207 //---------------------------------------------------------------------------
208
209 /////////////////////////////////////////////////////////////////////////////
210 //
211 // $Log$
212 // Revision 1.3 1998/12/15 20:41:23 RD
213 // Changed the import semantics from "from wxPython import *" to "from
214 // wxPython.wx import *" This is for people who are worried about
215 // namespace pollution, they can use "from wxPython import wx" and then
216 // prefix all the wxPython identifiers with "wx."
217 //
218 // Added wxTaskbarIcon for wxMSW.
219 //
220 // Made the events work for wxGrid.
221 //
222 // Added wxConfig.
223 //
224 // Added wxMiniFrame for wxGTK, (untested.)
225 //
226 // Changed many of the args and return values that were pointers to gdi
227 // objects to references to reflect changes in the wxWindows API.
228 //
229 // Other assorted fixes and additions.
230 //
231 // Revision 1.2 1998/10/07 07:34:34 RD
232 // Version 0.4.1 for wxGTK
233 //
234 // Revision 1.1 1998/10/02 06:40:42 RD
235 //
236 // Version 0.4 of wxPython for MSW.
237 //
238 //
239
240
241
242
243
244
245