1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: SWIG interface for common event classes and event binders
7 // Created: 24-May-1998
9 // Copyright: (c) 2003 by Total Control Software
10 // Licence: wxWindows license
11 /////////////////////////////////////////////////////////////////////////////
16 //---------------------------------------------------------------------------
17 // Include some extra python code here
18 %pythoncode "_event_ex.py"
20 //---------------------------------------------------------------------------
23 // the predefined constants for the number of times we propagate event
24 // upwards window child-parent chain
25 enum Propagation_state
27 // don't propagate it at all
28 wxEVENT_PROPAGATE_NONE = 0,
30 // propagate it until it is processed
31 wxEVENT_PROPAGATE_MAX = INT_MAX
35 //---------------------------------------------------------------------------
38 wxEventType wxNewEventType();
41 %constant wxEventType wxEVT_NULL;
42 %constant wxEventType wxEVT_FIRST;
43 %constant wxEventType wxEVT_USER_FIRST;
45 %constant wxEventType wxEVT_COMMAND_BUTTON_CLICKED;
46 %constant wxEventType wxEVT_COMMAND_CHECKBOX_CLICKED;
47 %constant wxEventType wxEVT_COMMAND_CHOICE_SELECTED;
48 %constant wxEventType wxEVT_COMMAND_LISTBOX_SELECTED;
49 %constant wxEventType wxEVT_COMMAND_LISTBOX_DOUBLECLICKED;
50 %constant wxEventType wxEVT_COMMAND_CHECKLISTBOX_TOGGLED;
52 %constant wxEventType wxEVT_COMMAND_MENU_SELECTED;
53 %constant wxEventType wxEVT_COMMAND_TOOL_CLICKED;
54 %constant wxEventType wxEVT_COMMAND_SLIDER_UPDATED;
55 %constant wxEventType wxEVT_COMMAND_RADIOBOX_SELECTED;
56 %constant wxEventType wxEVT_COMMAND_RADIOBUTTON_SELECTED;
58 %constant wxEventType wxEVT_COMMAND_SCROLLBAR_UPDATED;
59 %constant wxEventType wxEVT_COMMAND_VLBOX_SELECTED;
60 %constant wxEventType wxEVT_COMMAND_COMBOBOX_SELECTED;
61 %constant wxEventType wxEVT_COMMAND_TOOL_RCLICKED;
62 %constant wxEventType wxEVT_COMMAND_TOOL_ENTER;
65 %constant wxEventType wxEVT_LEFT_DOWN;
66 %constant wxEventType wxEVT_LEFT_UP;
67 %constant wxEventType wxEVT_MIDDLE_DOWN;
68 %constant wxEventType wxEVT_MIDDLE_UP;
69 %constant wxEventType wxEVT_RIGHT_DOWN;
70 %constant wxEventType wxEVT_RIGHT_UP;
71 %constant wxEventType wxEVT_MOTION;
72 %constant wxEventType wxEVT_ENTER_WINDOW;
73 %constant wxEventType wxEVT_LEAVE_WINDOW;
74 %constant wxEventType wxEVT_LEFT_DCLICK;
75 %constant wxEventType wxEVT_MIDDLE_DCLICK;
76 %constant wxEventType wxEVT_RIGHT_DCLICK;
77 %constant wxEventType wxEVT_SET_FOCUS;
78 %constant wxEventType wxEVT_KILL_FOCUS;
79 %constant wxEventType wxEVT_CHILD_FOCUS;
80 %constant wxEventType wxEVT_MOUSEWHEEL;
82 // Non-client mouse events
83 %constant wxEventType wxEVT_NC_LEFT_DOWN;
84 %constant wxEventType wxEVT_NC_LEFT_UP;
85 %constant wxEventType wxEVT_NC_MIDDLE_DOWN;
86 %constant wxEventType wxEVT_NC_MIDDLE_UP;
87 %constant wxEventType wxEVT_NC_RIGHT_DOWN;
88 %constant wxEventType wxEVT_NC_RIGHT_UP;
89 %constant wxEventType wxEVT_NC_MOTION;
90 %constant wxEventType wxEVT_NC_ENTER_WINDOW;
91 %constant wxEventType wxEVT_NC_LEAVE_WINDOW;
92 %constant wxEventType wxEVT_NC_LEFT_DCLICK;
93 %constant wxEventType wxEVT_NC_MIDDLE_DCLICK;
94 %constant wxEventType wxEVT_NC_RIGHT_DCLICK;
96 // Character input event type
97 %constant wxEventType wxEVT_CHAR;
98 %constant wxEventType wxEVT_CHAR_HOOK;
99 %constant wxEventType wxEVT_NAVIGATION_KEY;
100 %constant wxEventType wxEVT_KEY_DOWN;
101 %constant wxEventType wxEVT_KEY_UP;
102 %constant wxEventType wxEVT_HOTKEY;
105 %constant wxEventType wxEVT_SET_CURSOR;
107 // wxScrollBar and wxSlider event identifiers
108 %constant wxEventType wxEVT_SCROLL_TOP;
109 %constant wxEventType wxEVT_SCROLL_BOTTOM;
110 %constant wxEventType wxEVT_SCROLL_LINEUP;
111 %constant wxEventType wxEVT_SCROLL_LINEDOWN;
112 %constant wxEventType wxEVT_SCROLL_PAGEUP;
113 %constant wxEventType wxEVT_SCROLL_PAGEDOWN;
114 %constant wxEventType wxEVT_SCROLL_THUMBTRACK;
115 %constant wxEventType wxEVT_SCROLL_THUMBRELEASE;
116 %constant wxEventType wxEVT_SCROLL_ENDSCROLL;
118 // Scroll events from wxWindow
119 %constant wxEventType wxEVT_SCROLLWIN_TOP;
120 %constant wxEventType wxEVT_SCROLLWIN_BOTTOM;
121 %constant wxEventType wxEVT_SCROLLWIN_LINEUP;
122 %constant wxEventType wxEVT_SCROLLWIN_LINEDOWN;
123 %constant wxEventType wxEVT_SCROLLWIN_PAGEUP;
124 %constant wxEventType wxEVT_SCROLLWIN_PAGEDOWN;
125 %constant wxEventType wxEVT_SCROLLWIN_THUMBTRACK;
126 %constant wxEventType wxEVT_SCROLLWIN_THUMBRELEASE;
129 %constant wxEventType wxEVT_SIZE;
130 %constant wxEventType wxEVT_MOVE;
131 %constant wxEventType wxEVT_CLOSE_WINDOW;
132 %constant wxEventType wxEVT_END_SESSION;
133 %constant wxEventType wxEVT_QUERY_END_SESSION;
134 %constant wxEventType wxEVT_ACTIVATE_APP;
135 %constant wxEventType wxEVT_POWER;
136 %constant wxEventType wxEVT_ACTIVATE;
137 %constant wxEventType wxEVT_CREATE;
138 %constant wxEventType wxEVT_DESTROY;
139 %constant wxEventType wxEVT_SHOW;
140 %constant wxEventType wxEVT_ICONIZE;
141 %constant wxEventType wxEVT_MAXIMIZE;
142 %constant wxEventType wxEVT_MOUSE_CAPTURE_CHANGED;
143 %constant wxEventType wxEVT_PAINT;
144 %constant wxEventType wxEVT_ERASE_BACKGROUND;
145 %constant wxEventType wxEVT_NC_PAINT;
146 %constant wxEventType wxEVT_PAINT_ICON;
147 %constant wxEventType wxEVT_MENU_OPEN;
148 %constant wxEventType wxEVT_MENU_CLOSE;
149 %constant wxEventType wxEVT_MENU_HIGHLIGHT;
151 %constant wxEventType wxEVT_CONTEXT_MENU;
152 %constant wxEventType wxEVT_SYS_COLOUR_CHANGED;
153 %constant wxEventType wxEVT_DISPLAY_CHANGED;
154 %constant wxEventType wxEVT_SETTING_CHANGED;
155 %constant wxEventType wxEVT_QUERY_NEW_PALETTE;
156 %constant wxEventType wxEVT_PALETTE_CHANGED;
157 %constant wxEventType wxEVT_DROP_FILES;
158 %constant wxEventType wxEVT_DRAW_ITEM;
159 %constant wxEventType wxEVT_MEASURE_ITEM;
160 %constant wxEventType wxEVT_COMPARE_ITEM;
161 %constant wxEventType wxEVT_INIT_DIALOG;
162 %constant wxEventType wxEVT_IDLE;
163 %constant wxEventType wxEVT_UPDATE_UI;
164 %constant wxEventType wxEVT_SIZING;
165 %constant wxEventType wxEVT_MOVING;
167 // Generic command events
168 // Note: a click is a higher-level event than button down/up
169 %constant wxEventType wxEVT_COMMAND_LEFT_CLICK;
170 %constant wxEventType wxEVT_COMMAND_LEFT_DCLICK;
171 %constant wxEventType wxEVT_COMMAND_RIGHT_CLICK;
172 %constant wxEventType wxEVT_COMMAND_RIGHT_DCLICK;
173 %constant wxEventType wxEVT_COMMAND_SET_FOCUS;
174 %constant wxEventType wxEVT_COMMAND_KILL_FOCUS;
175 %constant wxEventType wxEVT_COMMAND_ENTER;
181 %# Create some event binders
182 EVT_SIZE = wx.PyEventBinder( wxEVT_SIZE )
183 EVT_SIZING = wx.PyEventBinder( wxEVT_SIZING )
184 EVT_MOVE = wx.PyEventBinder( wxEVT_MOVE )
185 EVT_MOVING = wx.PyEventBinder( wxEVT_MOVING )
186 EVT_CLOSE = wx.PyEventBinder( wxEVT_CLOSE_WINDOW )
187 EVT_END_SESSION = wx.PyEventBinder( wxEVT_END_SESSION )
188 EVT_QUERY_END_SESSION = wx.PyEventBinder( wxEVT_QUERY_END_SESSION )
189 EVT_PAINT = wx.PyEventBinder( wxEVT_PAINT )
190 EVT_NC_PAINT = wx.PyEventBinder( wxEVT_NC_PAINT )
191 EVT_ERASE_BACKGROUND = wx.PyEventBinder( wxEVT_ERASE_BACKGROUND )
192 EVT_CHAR = wx.PyEventBinder( wxEVT_CHAR )
193 EVT_KEY_DOWN = wx.PyEventBinder( wxEVT_KEY_DOWN )
194 EVT_KEY_UP = wx.PyEventBinder( wxEVT_KEY_UP )
195 EVT_HOTKEY = wx.PyEventBinder( wxEVT_HOTKEY, 1)
196 EVT_CHAR_HOOK = wx.PyEventBinder( wxEVT_CHAR_HOOK )
197 EVT_MENU_OPEN = wx.PyEventBinder( wxEVT_MENU_OPEN )
198 EVT_MENU_CLOSE = wx.PyEventBinder( wxEVT_MENU_CLOSE )
199 EVT_MENU_HIGHLIGHT = wx.PyEventBinder( wxEVT_MENU_HIGHLIGHT, 1)
200 EVT_MENU_HIGHLIGHT_ALL = wx.PyEventBinder( wxEVT_MENU_HIGHLIGHT )
201 EVT_SET_FOCUS = wx.PyEventBinder( wxEVT_SET_FOCUS )
202 EVT_KILL_FOCUS = wx.PyEventBinder( wxEVT_KILL_FOCUS )
203 EVT_CHILD_FOCUS = wx.PyEventBinder( wxEVT_CHILD_FOCUS )
204 EVT_ACTIVATE = wx.PyEventBinder( wxEVT_ACTIVATE )
205 EVT_ACTIVATE_APP = wx.PyEventBinder( wxEVT_ACTIVATE_APP )
206 EVT_END_SESSION = wx.PyEventBinder( wxEVT_END_SESSION )
207 EVT_QUERY_END_SESSION = wx.PyEventBinder( wxEVT_QUERY_END_SESSION )
208 EVT_DROP_FILES = wx.PyEventBinder( wxEVT_DROP_FILES )
209 EVT_INIT_DIALOG = wx.PyEventBinder( wxEVT_INIT_DIALOG )
210 EVT_SYS_COLOUR_CHANGED = wx.PyEventBinder( wxEVT_SYS_COLOUR_CHANGED )
211 EVT_DISPLAY_CHANGED = wx.PyEventBinder( wxEVT_DISPLAY_CHANGED )
212 EVT_SHOW = wx.PyEventBinder( wxEVT_SHOW )
213 EVT_MAXIMIZE = wx.PyEventBinder( wxEVT_MAXIMIZE )
214 EVT_ICONIZE = wx.PyEventBinder( wxEVT_ICONIZE )
215 EVT_NAVIGATION_KEY = wx.PyEventBinder( wxEVT_NAVIGATION_KEY )
216 EVT_PALETTE_CHANGED = wx.PyEventBinder( wxEVT_PALETTE_CHANGED )
217 EVT_QUERY_NEW_PALETTE = wx.PyEventBinder( wxEVT_QUERY_NEW_PALETTE )
218 EVT_WINDOW_CREATE = wx.PyEventBinder( wxEVT_CREATE )
219 EVT_WINDOW_DESTROY = wx.PyEventBinder( wxEVT_DESTROY )
220 EVT_SET_CURSOR = wx.PyEventBinder( wxEVT_SET_CURSOR )
221 EVT_MOUSE_CAPTURE_CHANGED = wx.PyEventBinder( wxEVT_MOUSE_CAPTURE_CHANGED )
223 EVT_LEFT_DOWN = wx.PyEventBinder( wxEVT_LEFT_DOWN )
224 EVT_LEFT_UP = wx.PyEventBinder( wxEVT_LEFT_UP )
225 EVT_MIDDLE_DOWN = wx.PyEventBinder( wxEVT_MIDDLE_DOWN )
226 EVT_MIDDLE_UP = wx.PyEventBinder( wxEVT_MIDDLE_UP )
227 EVT_RIGHT_DOWN = wx.PyEventBinder( wxEVT_RIGHT_DOWN )
228 EVT_RIGHT_UP = wx.PyEventBinder( wxEVT_RIGHT_UP )
229 EVT_MOTION = wx.PyEventBinder( wxEVT_MOTION )
230 EVT_LEFT_DCLICK = wx.PyEventBinder( wxEVT_LEFT_DCLICK )
231 EVT_MIDDLE_DCLICK = wx.PyEventBinder( wxEVT_MIDDLE_DCLICK )
232 EVT_RIGHT_DCLICK = wx.PyEventBinder( wxEVT_RIGHT_DCLICK )
233 EVT_LEAVE_WINDOW = wx.PyEventBinder( wxEVT_LEAVE_WINDOW )
234 EVT_ENTER_WINDOW = wx.PyEventBinder( wxEVT_ENTER_WINDOW )
235 EVT_MOUSEWHEEL = wx.PyEventBinder( wxEVT_MOUSEWHEEL )
237 EVT_MOUSE_EVENTS = wx.PyEventBinder([ wxEVT_LEFT_DOWN,
253 %# Scrolling from wxWindow (sent to wxScrolledWindow)
254 EVT_SCROLLWIN = wx.PyEventBinder([ wxEVT_SCROLLWIN_TOP,
255 wxEVT_SCROLLWIN_BOTTOM,
256 wxEVT_SCROLLWIN_LINEUP,
257 wxEVT_SCROLLWIN_LINEDOWN,
258 wxEVT_SCROLLWIN_PAGEUP,
259 wxEVT_SCROLLWIN_PAGEDOWN,
260 wxEVT_SCROLLWIN_THUMBTRACK,
261 wxEVT_SCROLLWIN_THUMBRELEASE,
264 EVT_SCROLLWIN_TOP = wx.PyEventBinder( wxEVT_SCROLLWIN_TOP )
265 EVT_SCROLLWIN_BOTTOM = wx.PyEventBinder( wxEVT_SCROLLWIN_BOTTOM )
266 EVT_SCROLLWIN_LINEUP = wx.PyEventBinder( wxEVT_SCROLLWIN_LINEUP )
267 EVT_SCROLLWIN_LINEDOWN = wx.PyEventBinder( wxEVT_SCROLLWIN_LINEDOWN )
268 EVT_SCROLLWIN_PAGEUP = wx.PyEventBinder( wxEVT_SCROLLWIN_PAGEUP )
269 EVT_SCROLLWIN_PAGEDOWN = wx.PyEventBinder( wxEVT_SCROLLWIN_PAGEDOWN )
270 EVT_SCROLLWIN_THUMBTRACK = wx.PyEventBinder( wxEVT_SCROLLWIN_THUMBTRACK )
271 EVT_SCROLLWIN_THUMBRELEASE = wx.PyEventBinder( wxEVT_SCROLLWIN_THUMBRELEASE )
273 %# Scrolling from wxSlider and wxScrollBar
274 EVT_SCROLL = wx.PyEventBinder([ wxEVT_SCROLL_TOP,
277 wxEVT_SCROLL_LINEDOWN,
279 wxEVT_SCROLL_PAGEDOWN,
280 wxEVT_SCROLL_THUMBTRACK,
281 wxEVT_SCROLL_THUMBRELEASE,
282 wxEVT_SCROLL_ENDSCROLL,
285 EVT_SCROLL_TOP = wx.PyEventBinder( wxEVT_SCROLL_TOP )
286 EVT_SCROLL_BOTTOM = wx.PyEventBinder( wxEVT_SCROLL_BOTTOM )
287 EVT_SCROLL_LINEUP = wx.PyEventBinder( wxEVT_SCROLL_LINEUP )
288 EVT_SCROLL_LINEDOWN = wx.PyEventBinder( wxEVT_SCROLL_LINEDOWN )
289 EVT_SCROLL_PAGEUP = wx.PyEventBinder( wxEVT_SCROLL_PAGEUP )
290 EVT_SCROLL_PAGEDOWN = wx.PyEventBinder( wxEVT_SCROLL_PAGEDOWN )
291 EVT_SCROLL_THUMBTRACK = wx.PyEventBinder( wxEVT_SCROLL_THUMBTRACK )
292 EVT_SCROLL_THUMBRELEASE = wx.PyEventBinder( wxEVT_SCROLL_THUMBRELEASE )
293 EVT_SCROLL_ENDSCROLL = wx.PyEventBinder( wxEVT_SCROLL_ENDSCROLL )
295 %# Scrolling from wxSlider and wxScrollBar, with an id
296 EVT_COMMAND_SCROLL = wx.PyEventBinder([ wxEVT_SCROLL_TOP,
299 wxEVT_SCROLL_LINEDOWN,
301 wxEVT_SCROLL_PAGEDOWN,
302 wxEVT_SCROLL_THUMBTRACK,
303 wxEVT_SCROLL_THUMBRELEASE,
304 wxEVT_SCROLL_ENDSCROLL,
307 EVT_COMMAND_SCROLL_TOP = wx.PyEventBinder( wxEVT_SCROLL_TOP, 1)
308 EVT_COMMAND_SCROLL_BOTTOM = wx.PyEventBinder( wxEVT_SCROLL_BOTTOM, 1)
309 EVT_COMMAND_SCROLL_LINEUP = wx.PyEventBinder( wxEVT_SCROLL_LINEUP, 1)
310 EVT_COMMAND_SCROLL_LINEDOWN = wx.PyEventBinder( wxEVT_SCROLL_LINEDOWN, 1)
311 EVT_COMMAND_SCROLL_PAGEUP = wx.PyEventBinder( wxEVT_SCROLL_PAGEUP, 1)
312 EVT_COMMAND_SCROLL_PAGEDOWN = wx.PyEventBinder( wxEVT_SCROLL_PAGEDOWN, 1)
313 EVT_COMMAND_SCROLL_THUMBTRACK = wx.PyEventBinder( wxEVT_SCROLL_THUMBTRACK, 1)
314 EVT_COMMAND_SCROLL_THUMBRELEASE = wx.PyEventBinder( wxEVT_SCROLL_THUMBRELEASE, 1)
315 EVT_COMMAND_SCROLL_ENDSCROLL = wx.PyEventBinder( wxEVT_SCROLL_ENDSCROLL, 1)
317 EVT_BUTTON = wx.PyEventBinder( wxEVT_COMMAND_BUTTON_CLICKED, 1)
318 EVT_CHECKBOX = wx.PyEventBinder( wxEVT_COMMAND_CHECKBOX_CLICKED, 1)
319 EVT_CHOICE = wx.PyEventBinder( wxEVT_COMMAND_CHOICE_SELECTED, 1)
320 EVT_LISTBOX = wx.PyEventBinder( wxEVT_COMMAND_LISTBOX_SELECTED, 1)
321 EVT_LISTBOX_DCLICK = wx.PyEventBinder( wxEVT_COMMAND_LISTBOX_DOUBLECLICKED, 1)
322 EVT_MENU = wx.PyEventBinder( wxEVT_COMMAND_MENU_SELECTED, 1)
323 EVT_MENU_RANGE = wx.PyEventBinder( wxEVT_COMMAND_MENU_SELECTED, 2)
324 EVT_SLIDER = wx.PyEventBinder( wxEVT_COMMAND_SLIDER_UPDATED, 1)
325 EVT_RADIOBOX = wx.PyEventBinder( wxEVT_COMMAND_RADIOBOX_SELECTED, 1)
326 EVT_RADIOBUTTON = wx.PyEventBinder( wxEVT_COMMAND_RADIOBUTTON_SELECTED, 1)
328 EVT_SCROLLBAR = wx.PyEventBinder( wxEVT_COMMAND_SCROLLBAR_UPDATED, 1)
329 EVT_VLBOX = wx.PyEventBinder( wxEVT_COMMAND_VLBOX_SELECTED, 1)
330 EVT_COMBOBOX = wx.PyEventBinder( wxEVT_COMMAND_COMBOBOX_SELECTED, 1)
331 EVT_TOOL = wx.PyEventBinder( wxEVT_COMMAND_TOOL_CLICKED, 1)
332 EVT_TOOL_RANGE = wx.PyEventBinder( wxEVT_COMMAND_TOOL_CLICKED, 2)
333 EVT_TOOL_RCLICKED = wx.PyEventBinder( wxEVT_COMMAND_TOOL_RCLICKED, 1)
334 EVT_TOOL_RCLICKED_RANGE = wx.PyEventBinder( wxEVT_COMMAND_TOOL_RCLICKED, 2)
335 EVT_TOOL_ENTER = wx.PyEventBinder( wxEVT_COMMAND_TOOL_ENTER, 1)
336 EVT_CHECKLISTBOX = wx.PyEventBinder( wxEVT_COMMAND_CHECKLISTBOX_TOGGLED, 1)
339 EVT_COMMAND_LEFT_CLICK = wx.PyEventBinder( wxEVT_COMMAND_LEFT_CLICK, 1)
340 EVT_COMMAND_LEFT_DCLICK = wx.PyEventBinder( wxEVT_COMMAND_LEFT_DCLICK, 1)
341 EVT_COMMAND_RIGHT_CLICK = wx.PyEventBinder( wxEVT_COMMAND_RIGHT_CLICK, 1)
342 EVT_COMMAND_RIGHT_DCLICK = wx.PyEventBinder( wxEVT_COMMAND_RIGHT_DCLICK, 1)
343 EVT_COMMAND_SET_FOCUS = wx.PyEventBinder( wxEVT_COMMAND_SET_FOCUS, 1)
344 EVT_COMMAND_KILL_FOCUS = wx.PyEventBinder( wxEVT_COMMAND_KILL_FOCUS, 1)
345 EVT_COMMAND_ENTER = wx.PyEventBinder( wxEVT_COMMAND_ENTER, 1)
347 EVT_IDLE = wx.PyEventBinder( wxEVT_IDLE )
349 EVT_UPDATE_UI = wx.PyEventBinder( wxEVT_UPDATE_UI, 1)
350 EVT_UPDATE_UI_RANGE = wx.PyEventBinder( wxEVT_UPDATE_UI, 2)
352 EVT_CONTEXT_MENU = wx.PyEventBinder( wxEVT_CONTEXT_MENU )
357 //---------------------------------------------------------------------------
360 class wxEvent : public wxObject {
362 // wxEvent(int winid = 0, wxEventType commandType = wxEVT_NULL); // *** This class is now an ABC
365 void SetEventType(wxEventType typ);
366 wxEventType GetEventType() const;
367 wxObject *GetEventObject() const;
368 void SetEventObject(wxObject *obj);
369 long GetTimestamp() const;
370 void SetTimestamp(long ts = 0);
375 bool IsCommandEvent() const;
377 // Can instruct event processor that we wish to ignore this event
378 // (treat as if the event table entry had not been found): this must be done
379 // to allow the event processing by the base classes (calling event.Skip()
380 // is the analog of calling the base class verstion of a virtual function)
381 void Skip(bool skip = True);
382 bool GetSkipped() const;
384 // Determine if this event should be propagating to the parent window.
385 bool ShouldPropagate() const;
387 // Stop an event from propagating to its parent window, returns the old
388 // propagation level value
389 int StopPropagation();
391 // Resume the event propagation by restoring the propagation level
392 // (returned by StopPropagation())
393 void ResumePropagation(int propagationLevel);
395 // this function is used to create a copy of the event polymorphically and
396 // all derived classes must implement it because otherwise wxPostEvent()
397 // for them wouldn't work (it needs to do a copy of the event)
398 virtual wxEvent *Clone() /* =0*/;
402 //---------------------------------------------------------------------------
405 // Helper class to temporarily change an event not to propagate.
406 class wxPropagationDisabler
409 wxPropagationDisabler(wxEvent& event);
410 ~wxPropagationDisabler();
414 // Another one to temporarily lower propagation level.
415 class wxPropagateOnce
418 wxPropagateOnce(wxEvent& event);
422 //---------------------------------------------------------------------------
425 class wxCommandEvent : public wxEvent
428 wxCommandEvent(wxEventType commandType = wxEVT_NULL, int winid = 0);
431 // // Set/Get client data from controls
432 // void SetClientData(void* clientData) { m_clientData = clientData; }
433 // void *GetClientData() const { return m_clientData; }
435 // // Set/Get client object from controls
436 // void SetClientObject(wxClientData* clientObject) { m_clientObject = clientObject; }
437 // void *GetClientObject() const { return m_clientObject; }
440 // Get listbox selection if single-choice
441 int GetSelection() const;
443 // Set/Get listbox/choice selection string
444 void SetString(const wxString& s);
445 wxString GetString() const;
447 // Get checkbox value
448 bool IsChecked() const;
449 %pythoncode { Checked = IsChecked }
451 // True if the listbox event was a selection.
452 bool IsSelection() const;
454 void SetExtraLong(long extraLong);
455 long GetExtraLong() const;
460 virtual wxEvent *Clone() const;
464 //---------------------------------------------------------------------------
467 // this class adds a possibility to react (from the user) code to a control
468 // notification: allow or veto the operation being reported.
469 class wxNotifyEvent : public wxCommandEvent
472 wxNotifyEvent(wxEventType commandType = wxEVT_NULL, int winid = 0);
474 // veto the operation (usually it's allowed by default)
477 // allow the operation if it was disabled by default
480 // for implementation code only: is the operation allowed?
485 //---------------------------------------------------------------------------
488 // Scroll event class, derived form wxCommandEvent. wxScrollEvents are
489 // sent by wxSlider and wxScrollBar.
490 class wxScrollEvent : public wxCommandEvent
493 wxScrollEvent(wxEventType commandType = wxEVT_NULL,
494 int winid = 0, int pos = 0, int orient = 0);
496 int GetOrientation() const;
497 int GetPosition() const;
498 void SetOrientation(int orient);
499 void SetPosition(int pos);
503 //---------------------------------------------------------------------------
506 // ScrollWin event class, derived fom wxEvent. wxScrollWinEvents
507 // are sent by wxWindow.
508 class wxScrollWinEvent : public wxEvent
511 wxScrollWinEvent(wxEventType commandType = wxEVT_NULL,
512 int pos = 0, int orient = 0);
514 int GetOrientation() const;
515 int GetPosition() const;
516 void SetOrientation(int orient);
517 void SetPosition(int pos);
520 //---------------------------------------------------------------------------
523 // the symbolic names for the mouse buttons
526 wxMOUSE_BTN_ANY = -1,
527 wxMOUSE_BTN_NONE = -1,
528 wxMOUSE_BTN_LEFT = 0,
529 wxMOUSE_BTN_MIDDLE = 1,
530 wxMOUSE_BTN_RIGHT = 2
535 class wxMouseEvent : public wxEvent
538 wxMouseEvent(wxEventType mouseType = wxEVT_NULL);
540 // Was it a button event? (*doesn't* mean: is any button *down*?)
541 bool IsButton() const;
543 // Was it a down event from this (or any) button?
544 bool ButtonDown(int but = wxMOUSE_BTN_ANY) const;
546 // Was it a dclick event from this (or any) button?
547 bool ButtonDClick(int but = wxMOUSE_BTN_ANY) const;
549 // Was it a up event from this (or any) button?
550 bool ButtonUp(int but = wxMOUSE_BTN_ANY) const;
552 // Was the given button changing state?
553 bool Button(int but) const;
555 // Was the given button in Down state?
556 bool ButtonIsDown(int but) const;
558 // Get the button which is changing state (wxMOUSE_BTN_NONE if none)
559 int GetButton() const;
561 // Find state of shift/control keys
562 bool ControlDown() const;
563 bool MetaDown() const;
564 bool AltDown() const;
565 bool ShiftDown() const;
567 // Find which event was just generated
568 bool LeftDown() const;
569 bool MiddleDown() const;
570 bool RightDown() const;
573 bool MiddleUp() const;
574 bool RightUp() const;
576 bool LeftDClick() const;
577 bool MiddleDClick() const;
578 bool RightDClick() const;
580 // Find the current state of the mouse buttons (regardless
581 // of current event type)
586 // True if a button is down and the mouse is moving
587 bool Dragging() const;
589 // True if the mouse is moving, and no button is down
592 // True if the mouse is just entering the window
593 bool Entering() const;
595 // True if the mouse is just leaving the window
596 bool Leaving() const;
599 DocStr(GetPosition, // sets the docstring for both
600 "Returns the position of the mouse in window coordinates when the event
602 wxPoint GetPosition();
605 void, GetPosition(long *OUTPUT, long *OUTPUT),
606 "GetPositionTuple() -> (x,y)",
609 // Find the logical position of the event given the DC
610 wxPoint GetLogicalPosition(const wxDC& dc) const;
613 wxCoord GetX() const;
616 wxCoord GetY() const;
618 // Get wheel rotation, positive or negative indicates direction of
619 // rotation. Current devices all send an event when rotation is equal to
620 // +/-WheelDelta, but this allows for finer resolution devices to be
621 // created in the future. Because of this you shouldn't assume that one
622 // event is equal to 1 line or whatever, but you should be able to either
623 // do partial line scrolling or wait until +/-WheelDelta rotation values
624 // have been accumulated before scrolling.
625 int GetWheelRotation() const;
627 // Get wheel delta, normally 120. This is the threshold for action to be
628 // taken, and one such action (for example, scrolling one increment)
629 // should occur for each delta.
630 int GetWheelDelta() const;
632 // Returns the configured number of lines (or whatever) to be scrolled per
633 // wheel action. Defaults to one.
634 int GetLinesPerAction() const;
636 // Is the system set to do page scrolling?
637 bool IsPageScroll() const;
653 int m_linesPerAction;
656 //---------------------------------------------------------------------------
660 class wxSetCursorEvent : public wxEvent
663 wxSetCursorEvent(wxCoord x = 0, wxCoord y = 0);
665 wxCoord GetX() const;
666 wxCoord GetY() const;
668 void SetCursor(const wxCursor& cursor);
669 const wxCursor& GetCursor() const;
670 bool HasCursor() const;
673 //---------------------------------------------------------------------------
676 // Keyboard input event class
678 class wxKeyEvent : public wxEvent
681 wxKeyEvent(wxEventType keyType = wxEVT_NULL);
683 // Find state of shift/control keys
684 bool ControlDown() const;
685 bool MetaDown() const;
686 bool AltDown() const;
687 bool ShiftDown() const;
689 // exclude MetaDown() from HasModifiers() because NumLock under X is often
690 // configured as mod2 modifier, yet the key events even when it is pressed
691 // should be processed normally, not like Ctrl- or Alt-key
692 bool HasModifiers() const;
694 // get the key code: an ASCII7 char or an element of wxKeyCode enum
695 int GetKeyCode() const;
696 %pythoncode { KeyCode = GetKeyCode }
701 return self->m_uniChar;
708 // get the raw key code (platform-dependent)
709 wxUint32 GetRawKeyCode() const;
711 // get the raw key flags (platform-dependent)
712 wxUint32 GetRawKeyFlags() const;
715 DocStr(GetPosition, // sets the docstring for both
716 "Find the position of the event.", "");
717 wxPoint GetPosition();
720 void, GetPosition(long *OUTPUT, long *OUTPUT),
721 "GetPositionTuple() -> (x,y)",
725 wxCoord GetX() const;
728 wxCoord GetY() const;
741 // these fields contain the platform-specific information about
742 // key that was pressed
747 //---------------------------------------------------------------------------
751 class wxSizeEvent : public wxEvent
754 wxSizeEvent(const wxSize& sz=wxDefaultSize, int winid = 0);
756 wxSize GetSize() const;
757 wxRect GetRect() const;
758 void SetRect(wxRect rect);
760 void SetSize(wxSize size) {
767 wxRect m_rect; // Used for wxEVT_SIZING
771 //---------------------------------------------------------------------------
775 class wxMoveEvent : public wxEvent
778 wxMoveEvent(const wxPoint& pos=wxDefaultPosition, int winid = 0);
780 wxPoint GetPosition() const;
781 wxRect GetRect() const;
782 void SetRect(wxRect rect);
784 void SetPosition(wxPoint pos) {
793 //---------------------------------------------------------------------------
797 class wxPaintEvent : public wxEvent
800 wxPaintEvent(int Id = 0);
804 class wxNcPaintEvent : public wxEvent
807 wxNcPaintEvent(int winid = 0);
810 //---------------------------------------------------------------------------
813 class wxEraseEvent : public wxEvent
816 wxEraseEvent(int Id = 0, wxDC *dc = (wxDC *) NULL);
822 //---------------------------------------------------------------------------
825 class wxFocusEvent : public wxEvent
828 wxFocusEvent(wxEventType type = wxEVT_NULL, int winid = 0);
830 // The window associated with this event is the window which had focus
831 // before for SET event and the window which will have focus for the KILL
832 // one. NB: it may be NULL in both cases!
833 wxWindow *GetWindow() const;
834 void SetWindow(wxWindow *win);
837 //---------------------------------------------------------------------------
840 // wxChildFocusEvent notifies the parent that a child has got the focus: unlike
841 // wxFocusEvent it is propagated upwards the window chain
842 class wxChildFocusEvent : public wxCommandEvent
845 wxChildFocusEvent(wxWindow *win = NULL);
847 wxWindow *GetWindow() const;
850 //---------------------------------------------------------------------------
853 class wxActivateEvent : public wxEvent
856 wxActivateEvent(wxEventType type = wxEVT_NULL, bool active = True, int Id = 0);
857 bool GetActive() const;
861 //---------------------------------------------------------------------------
864 class wxInitDialogEvent : public wxEvent
867 wxInitDialogEvent(int Id = 0);
871 //---------------------------------------------------------------------------
874 class wxMenuEvent : public wxEvent
877 wxMenuEvent(wxEventType type = wxEVT_NULL, int winid = 0, wxMenu* menu = NULL);
879 // only for wxEVT_MENU_HIGHLIGHT
880 int GetMenuId() const;
882 // only for wxEVT_MENU_OPEN/CLOSE
883 bool IsPopup() const;
885 // only for wxEVT_MENU_OPEN/CLOSE
886 wxMenu* GetMenu() const;
889 //---------------------------------------------------------------------------
892 // Window close or session close event class
893 class wxCloseEvent : public wxEvent
896 wxCloseEvent(wxEventType type = wxEVT_NULL, int winid = 0);
898 void SetLoggingOff(bool logOff);
899 bool GetLoggingOff() const;
901 void Veto(bool veto = True);
902 void SetCanVeto(bool canVeto);
904 bool CanVeto() const;
905 bool GetVeto() const;
909 //---------------------------------------------------------------------------
912 class wxShowEvent : public wxEvent
915 wxShowEvent(int winid = 0, bool show = False);
917 void SetShow(bool show);
918 bool GetShow() const;
923 //---------------------------------------------------------------------------
926 class wxIconizeEvent: public wxEvent
929 wxIconizeEvent(int id = 0, bool iconized = True);
934 //---------------------------------------------------------------------------
937 class wxMaximizeEvent: public wxEvent
940 wxMaximizeEvent(int id = 0);
943 //---------------------------------------------------------------------------
946 class wxDropFilesEvent: public wxEvent
949 wxPoint GetPosition();
950 int GetNumberOfFiles();
953 PyObject* GetFiles() {
954 int count = self->GetNumberOfFiles();
955 wxString* files = self->GetFiles();
956 PyObject* list = PyList_New(count);
959 PyErr_SetString(PyExc_MemoryError, "Can't allocate list of files!");
963 for (int i=0; i<count; i++) {
964 PyList_SetItem(list, i, wx2PyString(files[i]));
973 //---------------------------------------------------------------------------
977 // Whether to always send update events to windows, or
978 // to only send update events to those with the
979 // wxWS_EX_PROCESS_UI_UPDATES style.
983 // Send UI update events to all windows
984 wxUPDATE_UI_PROCESS_ALL,
986 // Send UI update events to windows that have
987 // the wxWS_EX_PROCESS_UI_UPDATES flag specified
988 wxUPDATE_UI_PROCESS_SPECIFIED
993 class wxUpdateUIEvent : public wxCommandEvent
996 wxUpdateUIEvent(wxWindowID commandId = 0);
998 bool GetChecked() const;
999 bool GetEnabled() const;
1000 wxString GetText() const;
1001 bool GetSetText() const;
1002 bool GetSetChecked() const;
1003 bool GetSetEnabled() const;
1005 void Check(bool check);
1006 void Enable(bool enable);
1007 void SetText(const wxString& text);
1009 // Sets the interval between updates in milliseconds.
1010 // Set to -1 to disable updates, or to 0 to update as frequently as possible.
1011 static void SetUpdateInterval(long updateInterval);
1013 // Returns the current interval between updates in milliseconds
1014 static long GetUpdateInterval();
1016 // Can we update this window?
1017 static bool CanUpdate(wxWindow *win);
1019 // Reset the update time to provide a delay until the next
1020 // time we should update
1021 static void ResetUpdateTime();
1023 // Specify how wxWindows will send update events: to
1024 // all windows, or only to those which specify that they
1025 // will process the events.
1026 static void SetMode(wxUpdateUIMode mode);
1028 // Returns the UI update mode
1029 static wxUpdateUIMode GetMode();
1032 //---------------------------------------------------------------------------
1035 class wxSysColourChangedEvent: public wxEvent {
1037 wxSysColourChangedEvent();
1040 //---------------------------------------------------------------------------
1044 // wxEVT_MOUSE_CAPTURE_CHANGED
1045 // The window losing the capture receives this message
1046 // (even if it released the capture itself).
1047 class wxMouseCaptureChangedEvent : public wxEvent
1050 wxMouseCaptureChangedEvent(wxWindowID winid = 0, wxWindow* gainedCapture = NULL);
1052 wxWindow* GetCapturedWindow() const;
1055 //---------------------------------------------------------------------------
1058 class wxDisplayChangedEvent : public wxEvent
1061 wxDisplayChangedEvent();
1064 //---------------------------------------------------------------------------
1067 class wxPaletteChangedEvent : public wxEvent
1070 wxPaletteChangedEvent(wxWindowID id = 0);
1072 void SetChangedWindow(wxWindow* win);
1073 wxWindow* GetChangedWindow();
1077 //---------------------------------------------------------------------------
1081 // wxEVT_QUERY_NEW_PALETTE
1082 // Indicates the window is getting keyboard focus and should re-do its palette.
1083 class wxQueryNewPaletteEvent : public wxEvent
1086 wxQueryNewPaletteEvent(wxWindowID winid = 0);
1088 // App sets this if it changes the palette.
1089 void SetPaletteRealized(bool realized);
1090 bool GetPaletteRealized() const;
1093 //---------------------------------------------------------------------------
1097 // Event generated by dialog navigation keys
1098 // wxEVT_NAVIGATION_KEY
1100 class wxNavigationKeyEvent : public wxEvent
1103 wxNavigationKeyEvent();
1105 // direction: forward (True) or backward (False)
1106 bool GetDirection() const;
1107 void SetDirection(bool forward);
1109 // it may be a window change event (MDI, notebook pages...) or a control
1111 bool IsWindowChange() const;
1112 void SetWindowChange(bool ischange);
1114 void SetFlags(long flags);
1116 // the child which has the focus currently (may be NULL - use
1117 // wxWindow::FindFocus then)
1118 wxWindow* GetCurrentFocus() const;
1119 void SetCurrentFocus(wxWindow *win);
1128 //---------------------------------------------------------------------------
1131 // Window creation/destruction events: the first is sent as soon as window is
1132 // created (i.e. the underlying GUI object exists), but when the C++ object is
1133 // fully initialized (so virtual functions may be called). The second,
1134 // wxEVT_DESTROY, is sent right before the window is destroyed - again, it's
1135 // still safe to call virtual functions at this moment
1137 class wxWindowCreateEvent : public wxCommandEvent
1140 wxWindowCreateEvent(wxWindow *win = NULL);
1141 wxWindow *GetWindow() const;
1144 class wxWindowDestroyEvent : public wxCommandEvent
1147 wxWindowDestroyEvent(wxWindow *win = NULL);
1148 wxWindow *GetWindow() const;
1152 //---------------------------------------------------------------------------
1155 // A Context event is sent when the user right clicks on a window or
1156 // presses Shift-F10
1157 // NOTE : Under windows this is a repackaged WM_CONTETXMENU message
1158 // Under other systems it may have to be generated from a right click event
1163 class wxContextMenuEvent : public wxCommandEvent
1166 wxContextMenuEvent(wxEventType type = wxEVT_NULL,
1167 wxWindowID winid = 0,
1168 const wxPoint& pt = wxDefaultPosition);
1170 // Position of event (in screen coordinates)
1171 const wxPoint& GetPosition() const;
1172 void SetPosition(const wxPoint& pos);
1175 //---------------------------------------------------------------------------
1178 // Whether to always send idle events to windows, or
1179 // to only send update events to those with the
1180 // wxWS_EX_PROCESS_IDLE style.
1184 // Send idle events to all windows
1187 // Send idle events to windows that have
1188 // the wxWS_EX_PROCESS_IDLE flag specified
1189 wxIDLE_PROCESS_SPECIFIED
1193 class wxIdleEvent : public wxEvent
1198 void RequestMore(bool needMore = True);
1199 bool MoreRequested() const;
1201 // Specify how wxWindows will send idle events: to
1202 // all windows, or only to those which specify that they
1203 // will process the events.
1204 static void SetMode(wxIdleMode mode);
1206 // Returns the idle event mode
1207 static wxIdleMode GetMode();
1209 // Can we send an idle event?
1210 static bool CanSend(wxWindow* win);
1213 //---------------------------------------------------------------------------
1216 // These classes can be derived from in Python and passed through the event
1217 // system without loosing anything. They do this by keeping a reference to
1218 // themselves and some special case handling in wxPyCallback::EventThunker.
1220 class wxPyEvent : public wxEvent {
1222 %pythonAppend wxPyEvent "self.SetSelf(self)"
1223 wxPyEvent(int winid=0, wxEventType commandType = wxEVT_NULL );
1227 void SetSelf(PyObject* self);
1228 PyObject* GetSelf();
1232 class wxPyCommandEvent : public wxCommandEvent {
1234 %pythonAppend wxPyCommandEvent "self.SetSelf(self)"
1235 wxPyCommandEvent(wxEventType commandType = wxEVT_NULL, int id=0);
1236 ~wxPyCommandEvent();
1238 void SetSelf(PyObject* self);
1239 PyObject* GetSelf();
1244 //---------------------------------------------------------------------------