1 /////////////////////////////////////////////////////////////////////////////
4 // Author: Robert Roebling
6 // Copyright: (c) 1998 Robert Roebling, Julian Smart
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////////
12 #pragma implementation "window.h"
16 #include "wx/window.h"
20 #include "wx/layout.h"
22 #include "wx/dialog.h"
23 #include "wx/msgdlg.h"
24 #include "wx/dcclient.h"
28 #include "wx/notebook.h"
29 #include "wx/statusbr.h"
31 #include "wx/gtk/win_gtk.h"
32 #include "gdk/gdkprivate.h"
33 #include "gdk/gdkkeysyms.h"
37 //-----------------------------------------------------------------------------
38 // documentation on internals
39 //-----------------------------------------------------------------------------
42 I have been asked several times about writing some documentation about
43 the GTK port of wxWindows, especially its internal structures. Obviously,
44 you cannot understand wxGTK without knowing a little about the GTK, but
45 some more information about what the wxWindow, which is the base class
46 for all other window classes, does seems required as well.
48 What does wxWindow do? It contains the common interface for the following
49 jobs of its descentants:
51 1) Define the rudimentary behaviour common to all window classes, such as
52 resizing, intercepting user input so as to make it possible to use these
53 events for special purposes in a derived class, window names etc.
55 2) Provide the possibility to contain and manage children, if the derived
56 class is allowed to contain children, which holds true for those window
57 classes, which do not display a native GTK widget. To name them, these
58 classes are wxPanel, wxScrolledWindow, wxDialog, wxFrame. The MDI frame-
59 work classes are a special case and are handled a bit differently from
62 3) Provide the possibility to draw into a client area of a window. This,
63 too, only holds true for classes that do not display a native GTK widget
66 4) Provide the entire mechanism for scrolling widgets. This actaul inter-
67 face for this is usually in wxScrolledWidget, but the GTK implementation
70 5) A multitude of helper or extra methods for special purposes, such as
71 Drag'n'Drop, managing validators etc.
73 Normally one might expect, that one wxWindows class would always contain
74 one GTK widget. Under GTK, there is no such allround widget that has all
75 the functionality. Moreover, the GTK defines a client area as a different
76 widget from the actual widget you are handling. Last but not least some
77 special classes (e.g. wxFrame) handle different categories of widgets and
78 still have the possibility to draw something in the client area.
79 It was therefore required to write a special purpose GTK widget, that would
80 represent a client area in the sense of wxWindows capable to do the jobs
81 2), 3) and 4). I have written this class and it resides in win_gtk.c of
84 All windows must have a widget, with which they interact with other under-
85 lying GTK widget. It is this widget, e.g. that has to be resized etc and
86 thw wxWindow class has a member variable called m_widget which holds a
87 pointer to this widget. When the window class displays a GTK native widget,
88 this is the only GTK widget the class manages. When the class has a client
89 area for drawing into and for containing children it must have at least
90 one more GTK widget to handle (of the type GtkMyFixed, defined in win_gtk.c),
91 but there can be any number of widgets, handled by a class (e.g. the frame
92 class handles three). The common rule for all windows is only, that the
93 widget that interacts with the rest of GTK must be referenced in m_widget
94 and all other widgets must be children of this widget on the GTK level.
95 The top-most widget, which also represents the client area, must be in
96 the m_wxwindow field and must be of the type GtkMyFixed.
98 As I said, the window classes that display a GTK native widget only have
99 one widget, so in the case of e.g. the wxButton class m_widget holds a
100 pointer to a GtkButton widget. But windows with client areas (for drawing
101 and children) have a m_widget field that is a pointer to a GtkScrolled-
102 Window and a m_wxwindow field that is pointer to a GtkMyFixed and this
103 one is (in the GTK sense) a child of the GtkScrolledWindow.
105 If the m_wxwindow field is set, then all input to this widget is inter-
106 cepted and sent to the wxWindows class. If not, all input to the widget
107 that gets pointed to by m_widget gets intercepted and sent to the class.
111 //-----------------------------------------------------------------------------
113 //-----------------------------------------------------------------------------
115 extern wxList wxPendingDelete
;
116 extern wxList wxTopLevelWindows
;
117 extern bool g_blockEventsOnDrag
;
118 static bool g_capturing
= FALSE
;
120 // hack: we need something to pass to gtk_menu_popup, so we store the time of
121 // the last click here
122 static guint32 gs_timeLastClick
= 0;
124 //-----------------------------------------------------------------------------
125 // "expose_event" (of m_wxwindow, not of m_widget)
126 //-----------------------------------------------------------------------------
128 static void gtk_window_expose_callback( GtkWidget
*WXUNUSED(widget
), GdkEventExpose
*gdk_event
, wxWindow
*win
)
130 if (!win
->HasVMT()) return;
131 if (g_blockEventsOnDrag
) return;
133 win
->m_updateRegion
.Union( gdk_event
->area
.x
,
135 gdk_event
->area
.width
,
136 gdk_event
->area
.height
);
138 if (gdk_event
->count
> 0) return;
141 printf( "OnExpose from " );
142 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
143 printf( win->GetClassInfo()->GetClassName() );
147 wxPaintEvent
event( win
->GetId() );
148 event
.SetEventObject( win
);
149 win
->GetEventHandler()->ProcessEvent( event
);
151 win
->m_updateRegion
.Clear();
154 //-----------------------------------------------------------------------------
155 // "draw" (of m_wxwindow, not of m_widget)
156 //-----------------------------------------------------------------------------
158 static void gtk_window_draw_callback( GtkWidget
*WXUNUSED(widget
), GdkRectangle
*rect
, wxWindow
*win
)
160 if (!win
->HasVMT()) return;
161 if (g_blockEventsOnDrag
) return;
163 win
->m_updateRegion
.Union( rect
->x
, rect
->y
, rect
->width
, rect
->height
);
165 wxPaintEvent
event( win
->GetId() );
166 event
.SetEventObject( win
);
167 win
->GetEventHandler()->ProcessEvent( event
);
169 win
->m_updateRegion
.Clear();
172 //-----------------------------------------------------------------------------
174 //-----------------------------------------------------------------------------
176 static gint
gtk_window_key_press_callback( GtkWidget
*widget
, GdkEventKey
*gdk_event
, wxWindow
*win
)
178 if (!win
->HasVMT()) return FALSE
;
179 if (g_blockEventsOnDrag
) return FALSE
;
182 printf( "OnKeyPress from " );
183 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
184 printf( win->GetClassInfo()->GetClassName() );
189 switch (gdk_event
->keyval
)
191 case GDK_BackSpace
: key_code
= WXK_BACK
; break;
192 case GDK_Tab
: key_code
= WXK_TAB
; break;
193 case GDK_Linefeed
: key_code
= WXK_RETURN
; break;
194 case GDK_Clear
: key_code
= WXK_CLEAR
; break;
195 case GDK_Return
: key_code
= WXK_RETURN
; break;
196 case GDK_Pause
: key_code
= WXK_PAUSE
; break;
197 case GDK_Scroll_Lock
: key_code
= WXK_SCROLL
; break;
198 case GDK_Escape
: key_code
= WXK_ESCAPE
; break;
199 case GDK_Delete
: key_code
= WXK_DELETE
; break;
200 case GDK_Home
: key_code
= WXK_HOME
; break;
201 case GDK_Left
: key_code
= WXK_LEFT
; break;
202 case GDK_Up
: key_code
= WXK_UP
; break;
203 case GDK_Right
: key_code
= WXK_RIGHT
; break;
204 case GDK_Down
: key_code
= WXK_DOWN
; break;
205 case GDK_Prior
: key_code
= WXK_PRIOR
; break;
206 // case GDK_Page_Up: key_code = WXK_PAGEUP; break;
207 case GDK_Next
: key_code
= WXK_NEXT
; break;
208 // case GDK_Page_Down: key_code = WXK_PAGEDOWN; break;
209 case GDK_End
: key_code
= WXK_END
; break;
210 case GDK_Begin
: key_code
= WXK_HOME
; break;
211 case GDK_Select
: key_code
= WXK_SELECT
; break;
212 case GDK_Print
: key_code
= WXK_PRINT
; break;
213 case GDK_Execute
: key_code
= WXK_EXECUTE
; break;
214 case GDK_Insert
: key_code
= WXK_INSERT
; break;
215 case GDK_Num_Lock
: key_code
= WXK_NUMLOCK
; break;
216 case GDK_KP_Tab
: key_code
= WXK_TAB
; break;
217 case GDK_KP_Enter
: key_code
= WXK_RETURN
; break;
218 case GDK_KP_Home
: key_code
= WXK_HOME
; break;
219 case GDK_KP_Left
: key_code
= WXK_LEFT
; break;
220 case GDK_KP_Up
: key_code
= WXK_UP
; break;
221 case GDK_KP_Right
: key_code
= WXK_RIGHT
; break;
222 case GDK_KP_Down
: key_code
= WXK_DOWN
; break;
223 case GDK_KP_Prior
: key_code
= WXK_PRIOR
; break;
224 // case GDK_KP_Page_Up: key_code = WXK_PAGEUP; break;
225 case GDK_KP_Next
: key_code
= WXK_NEXT
; break;
226 // case GDK_KP_Page_Down: key_code = WXK_PAGEDOWN; break;
227 case GDK_KP_End
: key_code
= WXK_END
; break;
228 case GDK_KP_Begin
: key_code
= WXK_HOME
; break;
229 case GDK_KP_Insert
: key_code
= WXK_INSERT
; break;
230 case GDK_KP_Delete
: key_code
= WXK_DELETE
; break;
231 case GDK_KP_Multiply
: key_code
= WXK_MULTIPLY
; break;
232 case GDK_KP_Add
: key_code
= WXK_ADD
; break;
233 case GDK_KP_Separator
: key_code
= WXK_SEPARATOR
; break;
234 case GDK_KP_Subtract
: key_code
= WXK_SUBTRACT
; break;
235 case GDK_KP_Decimal
: key_code
= WXK_DECIMAL
; break;
236 case GDK_KP_Divide
: key_code
= WXK_DIVIDE
; break;
237 case GDK_KP_0
: key_code
= WXK_NUMPAD0
; break;
238 case GDK_KP_1
: key_code
= WXK_NUMPAD1
; break;
239 case GDK_KP_2
: key_code
= WXK_NUMPAD2
; break;
240 case GDK_KP_3
: key_code
= WXK_NUMPAD3
; break;
241 case GDK_KP_4
: key_code
= WXK_NUMPAD4
; break;
242 case GDK_KP_5
: key_code
= WXK_NUMPAD5
; break;
243 case GDK_KP_6
: key_code
= WXK_NUMPAD6
; break;
244 case GDK_KP_7
: key_code
= WXK_NUMPAD7
; break;
245 case GDK_KP_8
: key_code
= WXK_NUMPAD7
; break;
246 case GDK_KP_9
: key_code
= WXK_NUMPAD9
; break;
247 case GDK_F1
: key_code
= WXK_F1
; break;
248 case GDK_F2
: key_code
= WXK_F2
; break;
249 case GDK_F3
: key_code
= WXK_F3
; break;
250 case GDK_F4
: key_code
= WXK_F4
; break;
251 case GDK_F5
: key_code
= WXK_F5
; break;
252 case GDK_F6
: key_code
= WXK_F6
; break;
253 case GDK_F7
: key_code
= WXK_F7
; break;
254 case GDK_F8
: key_code
= WXK_F8
; break;
255 case GDK_F9
: key_code
= WXK_F9
; break;
256 case GDK_F10
: key_code
= WXK_F10
; break;
257 case GDK_F11
: key_code
= WXK_F11
; break;
258 case GDK_F12
: key_code
= WXK_F12
; break;
261 if ((gdk_event
->keyval
>= 0x20) && (gdk_event
->keyval
<= 0xFF))
262 key_code
= gdk_event
->keyval
;
266 if (!key_code
) return FALSE
;
268 wxKeyEvent
event( wxEVT_CHAR
);
269 event
.m_shiftDown
= (gdk_event
->state
& GDK_SHIFT_MASK
);
270 event
.m_controlDown
= (gdk_event
->state
& GDK_CONTROL_MASK
);
271 event
.m_altDown
= (gdk_event
->state
& GDK_MOD1_MASK
);
272 event
.m_metaDown
= (gdk_event
->state
& GDK_MOD2_MASK
);
273 event
.m_keyCode
= key_code
;
276 event
.SetEventObject( win
);
278 bool ret
= win
->GetEventHandler()->ProcessEvent( event
);
282 wxWindow
*ancestor
= win
;
285 int command
= ancestor
->GetAcceleratorTable()->GetCommand( event
);
288 wxCommandEvent
command_event( wxEVT_COMMAND_MENU_SELECTED
, command
);
289 ret
= ancestor
->GetEventHandler()->ProcessEvent( command_event
);
292 ancestor
= ancestor
->GetParent();
298 if ((gdk_event
->keyval
>= 0x20) && (gdk_event
->keyval
<= 0xFF))
299 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "key_press_event" );
305 //-----------------------------------------------------------------------------
306 // "button_press_event"
307 //-----------------------------------------------------------------------------
309 static gint
gtk_window_button_press_callback( GtkWidget
*widget
, GdkEventButton
*gdk_event
, wxWindow
*win
)
311 if (!win
->IsOwnGtkWindow( gdk_event
->window
)) return TRUE
;
313 if (g_blockEventsOnDrag
) return TRUE
;
317 if (GTK_WIDGET_CAN_FOCUS(win
->m_wxwindow
) && !GTK_WIDGET_HAS_FOCUS (win
->m_wxwindow
) )
319 gtk_widget_grab_focus (win
->m_wxwindow
);
322 printf( "GrabFocus from " );
323 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
324 printf( win->GetClassInfo()->GetClassName() );
331 if (!win
->HasVMT()) return TRUE
;
334 printf( "OnButtonPress from " );
335 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
336 printf( win->GetClassInfo()->GetClassName() );
340 wxEventType event_type
= wxEVT_LEFT_DOWN
;
342 if (gdk_event
->button
== 1)
344 switch (gdk_event
->type
)
346 case GDK_BUTTON_PRESS
: event_type
= wxEVT_LEFT_DOWN
; break;
347 case GDK_2BUTTON_PRESS
: event_type
= wxEVT_LEFT_DCLICK
; break;
351 else if (gdk_event
->button
== 2)
353 switch (gdk_event
->type
)
355 case GDK_BUTTON_PRESS
: event_type
= wxEVT_MIDDLE_DOWN
; break;
356 case GDK_2BUTTON_PRESS
: event_type
= wxEVT_MIDDLE_DCLICK
; break;
360 else if (gdk_event
->button
== 3)
362 switch (gdk_event
->type
)
364 case GDK_BUTTON_PRESS
: event_type
= wxEVT_RIGHT_DOWN
; break;
365 case GDK_2BUTTON_PRESS
: event_type
= wxEVT_RIGHT_DCLICK
; break;
370 wxMouseEvent
event( event_type
);
371 event
.m_shiftDown
= (gdk_event
->state
& GDK_SHIFT_MASK
);
372 event
.m_controlDown
= (gdk_event
->state
& GDK_CONTROL_MASK
);
373 event
.m_altDown
= (gdk_event
->state
& GDK_MOD1_MASK
);
374 event
.m_metaDown
= (gdk_event
->state
& GDK_MOD2_MASK
);
375 event
.m_leftDown
= (gdk_event
->state
& GDK_BUTTON1_MASK
);
376 event
.m_middleDown
= (gdk_event
->state
& GDK_BUTTON2_MASK
);
377 event
.m_rightDown
= (gdk_event
->state
& GDK_BUTTON3_MASK
);
379 event
.m_x
= (long)gdk_event
->x
;
380 event
.m_y
= (long)gdk_event
->y
;
382 // Some control don't have their own X window and thus cannot get
387 wxNode
*node
= win
->GetChildren()->First();
390 wxWindow
*child
= (wxWindow
*)node
->Data();
391 if ((child
->m_x
<= event
.m_x
) &&
392 (child
->m_y
<= event
.m_y
) &&
393 (child
->m_x
+child
->m_width
>= event
.m_x
) &&
394 (child
->m_y
+child
->m_height
>= event
.m_y
))
397 event
.m_x
-= child
->m_x
;
398 event
.m_y
-= child
->m_y
;
405 event
.SetEventObject( win
);
407 gs_timeLastClick
= gdk_event
->time
;
409 if (win
->GetEventHandler()->ProcessEvent( event
))
410 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "button_press_event" );
415 //-----------------------------------------------------------------------------
416 // "button_release_event"
417 //-----------------------------------------------------------------------------
419 static gint
gtk_window_button_release_callback( GtkWidget
*widget
, GdkEventButton
*gdk_event
, wxWindow
*win
)
421 if (!win
->IsOwnGtkWindow( gdk_event
->window
)) return TRUE
;
423 if (g_blockEventsOnDrag
) return TRUE
;
425 if (!win
->HasVMT()) return TRUE
;
428 printf( "OnButtonRelease from " );
429 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
430 printf( win->GetClassInfo()->GetClassName() );
434 wxEventType event_type
= wxEVT_NULL
;
436 switch (gdk_event
->button
)
438 case 1: event_type
= wxEVT_LEFT_UP
; break;
439 case 2: event_type
= wxEVT_MIDDLE_UP
; break;
440 case 3: event_type
= wxEVT_RIGHT_UP
; break;
443 wxMouseEvent
event( event_type
);
444 event
.m_shiftDown
= (gdk_event
->state
& GDK_SHIFT_MASK
);
445 event
.m_controlDown
= (gdk_event
->state
& GDK_CONTROL_MASK
);
446 event
.m_altDown
= (gdk_event
->state
& GDK_MOD1_MASK
);
447 event
.m_metaDown
= (gdk_event
->state
& GDK_MOD2_MASK
);
448 event
.m_leftDown
= (gdk_event
->state
& GDK_BUTTON1_MASK
);
449 event
.m_middleDown
= (gdk_event
->state
& GDK_BUTTON2_MASK
);
450 event
.m_rightDown
= (gdk_event
->state
& GDK_BUTTON3_MASK
);
451 event
.m_x
= (long)gdk_event
->x
;
452 event
.m_y
= (long)gdk_event
->y
;
454 // Some control don't have their own X window and thus cannot get
459 wxNode
*node
= win
->GetChildren()->First();
462 wxWindow
*child
= (wxWindow
*)node
->Data();
463 if ((child
->m_x
<= event
.m_x
) &&
464 (child
->m_y
<= event
.m_y
) &&
465 (child
->m_x
+child
->m_width
>= event
.m_x
) &&
466 (child
->m_y
+child
->m_height
>= event
.m_y
))
469 event
.m_x
-= child
->m_x
;
470 event
.m_y
-= child
->m_y
;
477 event
.SetEventObject( win
);
479 if (win
->GetEventHandler()->ProcessEvent( event
))
480 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "button_release_event" );
485 //-----------------------------------------------------------------------------
486 // "motion_notify_event"
487 //-----------------------------------------------------------------------------
489 static gint
gtk_window_motion_notify_callback( GtkWidget
*widget
, GdkEventMotion
*gdk_event
, wxWindow
*win
)
491 if (!win
->IsOwnGtkWindow( gdk_event
->window
)) return TRUE
;
493 if (g_blockEventsOnDrag
) return TRUE
;
495 if (!win
->HasVMT()) return TRUE
;
498 printf( "OnMotion from " );
499 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
500 printf( win->GetClassInfo()->GetClassName() );
504 wxMouseEvent
event( wxEVT_MOTION
);
505 event
.m_shiftDown
= (gdk_event
->state
& GDK_SHIFT_MASK
);
506 event
.m_controlDown
= (gdk_event
->state
& GDK_CONTROL_MASK
);
507 event
.m_altDown
= (gdk_event
->state
& GDK_MOD1_MASK
);
508 event
.m_metaDown
= (gdk_event
->state
& GDK_MOD2_MASK
);
509 event
.m_leftDown
= (gdk_event
->state
& GDK_BUTTON1_MASK
);
510 event
.m_middleDown
= (gdk_event
->state
& GDK_BUTTON2_MASK
);
511 event
.m_rightDown
= (gdk_event
->state
& GDK_BUTTON3_MASK
);
513 event
.m_x
= (long)gdk_event
->x
;
514 event
.m_y
= (long)gdk_event
->y
;
516 // Some control don't have their own X window and thus cannot get
521 wxNode
*node
= win
->GetChildren()->First();
524 wxWindow
*child
= (wxWindow
*)node
->Data();
525 if ((child
->m_x
<= event
.m_x
) &&
526 (child
->m_y
<= event
.m_y
) &&
527 (child
->m_x
+child
->m_width
>= event
.m_x
) &&
528 (child
->m_y
+child
->m_height
>= event
.m_y
))
531 event
.m_x
-= child
->m_x
;
532 event
.m_y
-= child
->m_y
;
539 event
.SetEventObject( win
);
541 if (win
->GetEventHandler()->ProcessEvent( event
))
542 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "motion_notify_event" );
547 //-----------------------------------------------------------------------------
549 //-----------------------------------------------------------------------------
551 static gint
gtk_window_focus_in_callback( GtkWidget
*widget
, GdkEvent
*WXUNUSED(event
), wxWindow
*win
)
553 if (g_blockEventsOnDrag
) return TRUE
;
556 if (GTK_WIDGET_CAN_FOCUS(win
->m_wxwindow
))
558 GTK_WIDGET_SET_FLAGS (win
->m_wxwindow
, GTK_HAS_FOCUS
);
560 printf( "SetFocus flag from " );
561 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
562 printf( win->GetClassInfo()->GetClassName() );
568 if (!win
->HasVMT()) return TRUE
;
571 printf( "OnSetFocus from " );
572 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
573 printf( win->GetClassInfo()->GetClassName() );
575 printf( WXSTRINGCAST win->GetLabel() );
579 wxFocusEvent
event( wxEVT_SET_FOCUS
, win
->GetId() );
580 event
.SetEventObject( win
);
582 if (win
->GetEventHandler()->ProcessEvent( event
))
583 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "focus_in_event" );
588 //-----------------------------------------------------------------------------
590 //-----------------------------------------------------------------------------
592 static gint
gtk_window_focus_out_callback( GtkWidget
*widget
, GdkEvent
*WXUNUSED(event
), wxWindow
*win
)
594 if (g_blockEventsOnDrag
) return TRUE
;
597 if (GTK_WIDGET_CAN_FOCUS(win
->m_wxwindow
))
598 GTK_WIDGET_UNSET_FLAGS (win
->m_wxwindow
, GTK_HAS_FOCUS
);
601 if (!win
->HasVMT()) return TRUE
;
604 printf( "OnKillFocus from " );
605 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
606 printf( win->GetClassInfo()->GetClassName() );
610 wxFocusEvent
event( wxEVT_KILL_FOCUS
, win
->GetId() );
611 event
.SetEventObject( win
);
613 if (win
->GetEventHandler()->ProcessEvent( event
))
614 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "focus_out_event" );
619 //-----------------------------------------------------------------------------
620 // "enter_notify_event"
621 //-----------------------------------------------------------------------------
623 static gint
gtk_window_enter_callback( GtkWidget
*widget
, GdkEventCrossing
*gdk_event
, wxWindow
*win
)
625 if (widget
->window
!= gdk_event
->window
) return TRUE
;
627 if (g_blockEventsOnDrag
) return TRUE
;
629 if (!win
->HasVMT()) return TRUE
;
632 printf( "OnEnter from " );
633 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
634 printf( win->GetClassInfo()->GetClassName() );
638 if ((widget
->window
) && (win
->m_cursor
))
639 gdk_window_set_cursor( widget
->window
, win
->m_cursor
->GetCursor() );
641 wxMouseEvent
event( wxEVT_ENTER_WINDOW
);
642 event
.SetEventObject( win
);
644 if (win
->GetEventHandler()->ProcessEvent( event
))
645 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "enter_notify_event" );
650 //-----------------------------------------------------------------------------
651 // "leave_notify_event"
652 //-----------------------------------------------------------------------------
654 static gint
gtk_window_leave_callback( GtkWidget
*widget
, GdkEventCrossing
*gdk_event
, wxWindow
*win
)
656 if (widget
->window
!= gdk_event
->window
) return TRUE
;
658 if (g_blockEventsOnDrag
) return TRUE
;
660 if (!win
->HasVMT()) return TRUE
;
663 printf( "OnLeave from " );
664 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
665 printf( win->GetClassInfo()->GetClassName() );
669 if ((widget
->window
) && (win
->m_cursor
))
670 gdk_window_set_cursor( widget
->window
, wxSTANDARD_CURSOR
->GetCursor() );
672 wxMouseEvent
event( wxEVT_LEAVE_WINDOW
);
673 event
.SetEventObject( win
);
675 if (win
->GetEventHandler()->ProcessEvent( event
))
676 gtk_signal_emit_stop_by_name( GTK_OBJECT(widget
), "leave_notify_event" );
681 //-----------------------------------------------------------------------------
682 // "value_changed" from m_vAdjust
683 //-----------------------------------------------------------------------------
685 static void gtk_window_vscroll_callback( GtkWidget
*WXUNUSED(widget
), wxWindow
*win
)
687 if (g_blockEventsOnDrag
) return;
690 printf( "OnVScroll from " );
691 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
692 printf( win->GetClassInfo()->GetClassName() );
696 if (!win
->HasVMT()) return;
698 float diff
= win
->m_vAdjust
->value
- win
->m_oldVerticalPos
;
699 if (fabs(diff
) < 0.2) return;
701 wxEventType command
= wxEVT_NULL
;
703 float line_step
= win
->m_vAdjust
->step_increment
;
704 float page_step
= win
->m_vAdjust
->page_increment
;
706 if (fabs(diff
-line_step
) < 0.2) command
= wxEVT_SCROLL_LINEDOWN
;
707 else if (fabs(diff
+line_step
) < 0.2) command
= wxEVT_SCROLL_LINEUP
;
708 else if (fabs(diff
-page_step
) < 0.2) command
= wxEVT_SCROLL_PAGEDOWN
;
709 else if (fabs(diff
+page_step
) < 0.2) command
= wxEVT_SCROLL_PAGEUP
;
710 else command
= wxEVT_SCROLL_THUMBTRACK
;
712 int value
= (int)(win
->m_vAdjust
->value
+0.5);
714 wxScrollEvent
event( command
, win
->GetId(), value
, wxVERTICAL
);
715 event
.SetEventObject( win
);
716 win
->GetEventHandler()->ProcessEvent( event
);
719 //-----------------------------------------------------------------------------
720 // "value_changed" from m_hAdjust
721 //-----------------------------------------------------------------------------
723 static void gtk_window_hscroll_callback( GtkWidget
*WXUNUSED(widget
), wxWindow
*win
)
725 if (g_blockEventsOnDrag
) return;
728 printf( "OnHScroll from " );
729 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
730 printf( win->GetClassInfo()->GetClassName() );
734 if (!win
->HasVMT()) return;
736 float diff
= win
->m_hAdjust
->value
- win
->m_oldHorizontalPos
;
737 if (fabs(diff
) < 0.2) return;
739 wxEventType command
= wxEVT_NULL
;
741 float line_step
= win
->m_hAdjust
->step_increment
;
742 float page_step
= win
->m_hAdjust
->page_increment
;
744 if (fabs(diff
-line_step
) < 0.2) command
= wxEVT_SCROLL_LINEDOWN
;
745 else if (fabs(diff
+line_step
) < 0.2) command
= wxEVT_SCROLL_LINEUP
;
746 else if (fabs(diff
-page_step
) < 0.2) command
= wxEVT_SCROLL_PAGEDOWN
;
747 else if (fabs(diff
+page_step
) < 0.2) command
= wxEVT_SCROLL_PAGEUP
;
748 else command
= wxEVT_SCROLL_THUMBTRACK
;
750 int value
= (int)(win
->m_hAdjust
->value
+0.5);
752 wxScrollEvent
event( command
, win
->GetId(), value
, wxHORIZONTAL
);
753 event
.SetEventObject( win
);
754 win
->GetEventHandler()->ProcessEvent( event
);
757 //-----------------------------------------------------------------------------
758 // "changed" from m_vAdjust
759 //-----------------------------------------------------------------------------
761 static void gtk_window_vscroll_change_callback( GtkWidget
*WXUNUSED(widget
), wxWindow
*win
)
763 if (g_blockEventsOnDrag
) return;
766 printf( "OnVScroll change from " );
767 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
768 printf( win->GetClassInfo()->GetClassName() );
772 if (!win
->HasVMT()) return;
774 wxEventType command
= wxEVT_SCROLL_THUMBTRACK
;
775 int value
= (int)(win
->m_vAdjust
->value
+0.5);
777 wxScrollEvent
event( command
, win
->GetId(), value
, wxVERTICAL
);
778 event
.SetEventObject( win
);
779 win
->GetEventHandler()->ProcessEvent( event
);
782 //-----------------------------------------------------------------------------
783 // "changed" from m_hAdjust
784 //-----------------------------------------------------------------------------
786 static void gtk_window_hscroll_change_callback( GtkWidget
*WXUNUSED(widget
), wxWindow
*win
)
788 if (g_blockEventsOnDrag
) return;
791 printf( "OnHScroll change from " );
792 if (win->GetClassInfo() && win->GetClassInfo()->GetClassName())
793 printf( win->GetClassInfo()->GetClassName() );
797 if (!win
->HasVMT()) return;
799 wxEventType command
= wxEVT_SCROLL_THUMBTRACK
;
800 int value
= (int)(win
->m_hAdjust
->value
+0.5);
802 wxScrollEvent
event( command
, win
->GetId(), value
, wxHORIZONTAL
);
803 event
.SetEventObject( win
);
804 win
->GetEventHandler()->ProcessEvent( event
);
807 //-----------------------------------------------------------------------------
808 // "button_press_event" from scrollbar
809 //-----------------------------------------------------------------------------
811 static gint
gtk_scrollbar_button_press_callback( GtkRange
*widget
, GdkEventButton
*gdk_event
, wxWindow
*win
)
813 if (gdk_event
->window
!= widget
->slider
) return FALSE
;
815 win
->m_isScrolling
= TRUE
;
820 //-----------------------------------------------------------------------------
821 // "button_release_event" from scrollbar
822 //-----------------------------------------------------------------------------
824 static gint
gtk_scrollbar_button_release_callback( GtkRange
*widget
, GdkEventButton
*gdk_event
, wxWindow
*win
)
826 if (gdk_event
->window
!= widget
->slider
) return FALSE
;
828 GtkScrolledWindow
*s_window
= GTK_SCROLLED_WINDOW(win
->m_widget
);
830 if (widget
== GTK_RANGE(s_window
->vscrollbar
))
831 gtk_signal_emit_by_name( GTK_OBJECT(win
->m_hAdjust
), "value_changed" );
833 gtk_signal_emit_by_name( GTK_OBJECT(win
->m_vAdjust
), "value_changed" );
835 win
->m_isScrolling
= FALSE
;
840 //-----------------------------------------------------------------------------
841 // "drop_data_available_event"
842 //-----------------------------------------------------------------------------
844 static void gtk_window_drop_callback( GtkWidget
*widget
, GdkEventDropDataAvailable
*event
, wxWindow
*win
)
846 if (!win
->HasVMT()) return;
848 if (win
->GetDropTarget())
852 gdk_window_get_pointer( widget
->window
, &x
, &y
, (GdkModifierType
*) NULL
);
853 win
->GetDropTarget()->m_size
= event
->data_numbytes
;
854 win
->GetDropTarget()->Drop( event
, x
, y
);
858 g_free (event->dropdataavailable.data);
859 g_free (event->dropdataavailable.data_type);
863 //-----------------------------------------------------------------------------
865 //-----------------------------------------------------------------------------
867 IMPLEMENT_DYNAMIC_CLASS(wxWindow
,wxEvtHandler
)
869 BEGIN_EVENT_TABLE(wxWindow
, wxEvtHandler
)
870 EVT_SIZE(wxWindow::OnSize
)
871 EVT_SYS_COLOUR_CHANGED(wxWindow::OnSysColourChanged
)
872 EVT_INIT_DIALOG(wxWindow::OnInitDialog
)
873 EVT_IDLE(wxWindow::OnIdle
)
878 m_widget
= (GtkWidget
*) NULL
;
879 m_wxwindow
= (GtkWidget
*) NULL
;
880 m_parent
= (wxWindow
*) NULL
;
881 m_children
.DeleteContents( FALSE
);
891 m_eventHandler
= this;
892 m_windowValidator
= (wxValidator
*) NULL
;
894 m_cursor
= (wxCursor
*) NULL
;
895 m_font
= *wxSWISS_FONT
;
897 m_windowName
= "noname";
898 m_constraints
= (wxLayoutConstraints
*) NULL
;
899 m_constraintsInvolvedIn
= (wxList
*) NULL
;
900 m_windowSizer
= (wxSizer
*) NULL
;
901 m_sizerParent
= (wxWindow
*) NULL
;
902 m_autoLayout
= FALSE
;
906 m_hasScrolling
= FALSE
;
907 m_isScrolling
= FALSE
;
908 m_hAdjust
= (GtkAdjustment
*) NULL
;
909 m_vAdjust
= (GtkAdjustment
*) NULL
;
910 m_oldHorizontalPos
= 0.0;
911 m_oldVerticalPos
= 0.0;
914 m_pDropTarget
= (wxDropTarget
*) NULL
;
916 m_scrollGC
= (GdkGC
*) NULL
;
917 m_widgetStyle
= (GtkStyle
*) NULL
;
920 bool wxWindow::Create( wxWindow
*parent
, wxWindowID id
,
921 const wxPoint
&pos
, const wxSize
&size
,
922 long style
, const wxString
&name
)
928 m_cursor
= (wxCursor
*) NULL
;
930 PreCreation( parent
, id
, pos
, size
, style
, name
);
932 m_widget
= gtk_scrolled_window_new( (GtkAdjustment
*) NULL
, (GtkAdjustment
*) NULL
);
933 m_hasScrolling
= TRUE
;
935 GtkScrolledWindow
*s_window
= GTK_SCROLLED_WINDOW(m_widget
);
937 gtk_signal_connect( GTK_OBJECT(s_window
->vscrollbar
), "button_press_event",
938 (GtkSignalFunc
)gtk_scrollbar_button_press_callback
, (gpointer
) this );
940 gtk_signal_connect( GTK_OBJECT(s_window
->hscrollbar
), "button_press_event",
941 (GtkSignalFunc
)gtk_scrollbar_button_press_callback
, (gpointer
) this );
943 gtk_signal_connect( GTK_OBJECT(s_window
->vscrollbar
), "button_release_event",
944 (GtkSignalFunc
)gtk_scrollbar_button_release_callback
, (gpointer
) this );
946 gtk_signal_connect( GTK_OBJECT(s_window
->hscrollbar
), "button_release_event",
947 (GtkSignalFunc
)gtk_scrollbar_button_release_callback
, (gpointer
) this );
949 GtkScrolledWindowClass
*scroll_class
= GTK_SCROLLED_WINDOW_CLASS( GTK_OBJECT(m_widget
)->klass
);
950 scroll_class
->scrollbar_spacing
= 0;
952 gtk_scrolled_window_set_policy( s_window
, GTK_POLICY_AUTOMATIC
, GTK_POLICY_AUTOMATIC
);
954 m_oldHorizontalPos
= 0.0;
955 m_oldVerticalPos
= 0.0;
957 m_hAdjust
= gtk_range_get_adjustment( GTK_RANGE(s_window
->hscrollbar
) );
958 m_vAdjust
= gtk_range_get_adjustment( GTK_RANGE(s_window
->vscrollbar
) );
960 gtk_signal_connect( GTK_OBJECT(m_hAdjust
), "value_changed",
961 (GtkSignalFunc
) gtk_window_hscroll_callback
, (gpointer
) this );
962 gtk_signal_connect( GTK_OBJECT(m_vAdjust
), "value_changed",
963 (GtkSignalFunc
) gtk_window_vscroll_callback
, (gpointer
) this );
965 gtk_signal_connect( GTK_OBJECT(m_hAdjust
), "changed",
966 (GtkSignalFunc
) gtk_window_hscroll_change_callback
, (gpointer
) this );
967 gtk_signal_connect(GTK_OBJECT(m_vAdjust
), "changed",
968 (GtkSignalFunc
) gtk_window_vscroll_change_callback
, (gpointer
) this );
970 GtkViewport
*viewport
= GTK_VIEWPORT(s_window
->viewport
);
972 if (m_windowStyle
& wxRAISED_BORDER
)
974 gtk_viewport_set_shadow_type( viewport
, GTK_SHADOW_OUT
);
976 else if (m_windowStyle
& wxSUNKEN_BORDER
)
978 gtk_viewport_set_shadow_type( viewport
, GTK_SHADOW_IN
);
982 gtk_viewport_set_shadow_type( viewport
, GTK_SHADOW_NONE
);
985 m_wxwindow
= gtk_myfixed_new();
987 GTK_WIDGET_UNSET_FLAGS( m_widget
, GTK_CAN_FOCUS
);
989 if (m_windowStyle
& wxTAB_TRAVERSAL
== wxTAB_TRAVERSAL
)
990 GTK_WIDGET_UNSET_FLAGS( m_wxwindow
, GTK_CAN_FOCUS
);
992 GTK_WIDGET_SET_FLAGS( m_wxwindow
, GTK_CAN_FOCUS
);
994 gtk_container_add( GTK_CONTAINER(m_widget
), m_wxwindow
);
996 // shut the viewport up
997 gtk_viewport_set_hadjustment( viewport
, (GtkAdjustment
*) gtk_adjustment_new( 0.0, 0.0, 0.0, 0.0, 0.0, 0.0) );
998 gtk_viewport_set_vadjustment( viewport
, (GtkAdjustment
*) gtk_adjustment_new( 0.0, 0.0, 0.0, 0.0, 0.0, 0.0) );
1000 // I _really_ don't want scrollbars in the beginning
1001 m_vAdjust
->lower
= 0.0;
1002 m_vAdjust
->upper
= 1.0;
1003 m_vAdjust
->value
= 0.0;
1004 m_vAdjust
->step_increment
= 1.0;
1005 m_vAdjust
->page_increment
= 1.0;
1006 m_vAdjust
->page_size
= 5.0;
1007 gtk_signal_emit_by_name( GTK_OBJECT(m_vAdjust
), "changed" );
1008 m_hAdjust
->lower
= 0.0;
1009 m_hAdjust
->upper
= 1.0;
1010 m_hAdjust
->value
= 0.0;
1011 m_hAdjust
->step_increment
= 1.0;
1012 m_hAdjust
->page_increment
= 1.0;
1013 m_hAdjust
->page_size
= 5.0;
1014 gtk_signal_emit_by_name( GTK_OBJECT(m_hAdjust
), "changed" );
1016 gtk_widget_show( m_wxwindow
);
1025 wxWindow::~wxWindow()
1029 if (m_pDropTarget
) delete m_pDropTarget
;
1031 if (m_parent
) m_parent
->RemoveChild( this );
1032 if (m_widget
) Show( FALSE
);
1036 if (m_widgetStyle
) gtk_style_unref( m_widgetStyle
);
1038 if (m_scrollGC
) gdk_gc_unref( m_scrollGC
);
1040 if (m_wxwindow
) gtk_widget_destroy( m_wxwindow
);
1042 if (m_widget
) gtk_widget_destroy( m_widget
);
1046 DeleteRelatedConstraints();
1049 // This removes any dangling pointers to this window
1050 // in other windows' constraintsInvolvedIn lists.
1051 UnsetConstraints(m_constraints
);
1052 delete m_constraints
;
1053 m_constraints
= (wxLayoutConstraints
*) NULL
;
1057 delete m_windowSizer
;
1058 m_windowSizer
= (wxSizer
*) NULL
;
1060 // If this is a child of a sizer, remove self from parent
1061 if (m_sizerParent
) m_sizerParent
->RemoveChild((wxWindow
*)this);
1063 // Just in case the window has been Closed, but
1064 // we're then deleting immediately: don't leave
1065 // dangling pointers.
1066 wxPendingDelete
.DeleteObject(this);
1068 // Just in case we've loaded a top-level window via
1069 // wxWindow::LoadNativeDialog but we weren't a dialog
1071 wxTopLevelWindows
.DeleteObject(this);
1073 if (m_windowValidator
) delete m_windowValidator
;
1076 void wxWindow::PreCreation( wxWindow
*parent
, wxWindowID id
,
1077 const wxPoint
&pos
, const wxSize
&size
,
1078 long style
, const wxString
&name
)
1080 if (m_needParent
&& (parent
== NULL
))
1081 wxFatalError( "Need complete parent.", name
);
1083 m_widget
= (GtkWidget
*) NULL
;
1086 m_children
.DeleteContents( FALSE
);
1090 if (m_width
== -1) m_width
= 20;
1092 if (m_height
== -1) m_height
= 20;
1098 m_eventHandler
= this;
1101 if (m_cursor
== NULL
)
1102 m_cursor
= new wxCursor( wxCURSOR_ARROW
);
1103 m_font
= *wxSWISS_FONT
;
1104 // m_backgroundColour = wxWHITE;
1105 // m_foregroundColour = wxBLACK;
1106 m_windowStyle
= style
;
1107 m_windowName
= name
;
1108 m_constraints
= (wxLayoutConstraints
*) NULL
;
1109 m_constraintsInvolvedIn
= (wxList
*) NULL
;
1110 m_windowSizer
= (wxSizer
*) NULL
;
1111 m_sizerParent
= (wxWindow
*) NULL
;
1112 m_autoLayout
= FALSE
;
1113 m_hasScrolling
= FALSE
;
1114 m_isScrolling
= FALSE
;
1115 m_pDropTarget
= (wxDropTarget
*) NULL
;
1117 m_windowValidator
= (wxValidator
*) NULL
;
1118 m_scrollGC
= (GdkGC
*) NULL
;
1119 m_widgetStyle
= (GtkStyle
*) NULL
;
1122 void wxWindow::PostCreation()
1124 if (m_parent
) m_parent
->AddChild( this );
1128 gtk_signal_connect( GTK_OBJECT(m_wxwindow
), "expose_event",
1129 GTK_SIGNAL_FUNC(gtk_window_expose_callback
), (gpointer
)this );
1131 gtk_signal_connect( GTK_OBJECT(m_wxwindow
), "draw",
1132 GTK_SIGNAL_FUNC(gtk_window_draw_callback
), (gpointer
)this );
1135 ConnectWidget( GetConnectWidget() );
1137 if (m_widget
&& m_parent
) gtk_widget_realize( m_widget
);
1139 if (m_wxwindow
) gtk_widget_realize( m_wxwindow
);
1141 SetCursor( *wxSTANDARD_CURSOR
);
1146 void wxWindow::ConnectWidget( GtkWidget
*widget
)
1148 gtk_signal_connect( GTK_OBJECT(widget
), "key_press_event",
1149 GTK_SIGNAL_FUNC(gtk_window_key_press_callback
), (gpointer
)this );
1151 gtk_signal_connect( GTK_OBJECT(widget
), "button_press_event",
1152 GTK_SIGNAL_FUNC(gtk_window_button_press_callback
), (gpointer
)this );
1154 gtk_signal_connect( GTK_OBJECT(widget
), "button_release_event",
1155 GTK_SIGNAL_FUNC(gtk_window_button_release_callback
), (gpointer
)this );
1157 gtk_signal_connect( GTK_OBJECT(widget
), "motion_notify_event",
1158 GTK_SIGNAL_FUNC(gtk_window_motion_notify_callback
), (gpointer
)this );
1160 gtk_signal_connect( GTK_OBJECT(widget
), "focus_in_event",
1161 GTK_SIGNAL_FUNC(gtk_window_focus_in_callback
), (gpointer
)this );
1163 gtk_signal_connect( GTK_OBJECT(widget
), "focus_out_event",
1164 GTK_SIGNAL_FUNC(gtk_window_focus_out_callback
), (gpointer
)this );
1166 gtk_signal_connect( GTK_OBJECT(widget
), "enter_notify_event",
1167 GTK_SIGNAL_FUNC(gtk_window_enter_callback
), (gpointer
)this );
1169 gtk_signal_connect( GTK_OBJECT(widget
), "leave_notify_event",
1170 GTK_SIGNAL_FUNC(gtk_window_leave_callback
), (gpointer
)this );
1173 bool wxWindow::HasVMT()
1178 bool wxWindow::Close( bool force
)
1180 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1182 wxCloseEvent
event(wxEVT_CLOSE_WINDOW
, m_windowId
);
1183 event
.SetEventObject(this);
1184 event
.SetForce(force
);
1186 return GetEventHandler()->ProcessEvent(event
);
1189 bool wxWindow::Destroy()
1191 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1198 bool wxWindow::DestroyChildren()
1203 while ((node
= GetChildren()->First()) != (wxNode
*)NULL
)
1206 if ((child
= (wxWindow
*)node
->Data()) != (wxWindow
*)NULL
)
1209 if (GetChildren()->Member(child
)) delete node
;
1216 void wxWindow::PrepareDC( wxDC
&WXUNUSED(dc
) )
1218 // are we to set fonts here ?
1221 void wxWindow::ImplementSetSize()
1223 if ((m_minWidth
!= -1) && (m_width
< m_minWidth
)) m_width
= m_minWidth
;
1224 if ((m_minHeight
!= -1) && (m_height
< m_minHeight
)) m_height
= m_minHeight
;
1225 if ((m_maxWidth
!= -1) && (m_width
> m_maxWidth
)) m_width
= m_minWidth
;
1226 if ((m_maxHeight
!= -1) && (m_height
> m_maxHeight
)) m_height
= m_minHeight
;
1227 gtk_widget_set_usize( m_widget
, m_width
, m_height
);
1230 void wxWindow::ImplementSetPosition()
1232 if (IS_KIND_OF(this,wxFrame
) || IS_KIND_OF(this,wxDialog
))
1234 if ((m_x
!= -1) || (m_y
!= -1))
1235 gtk_widget_set_uposition( m_widget
, m_x
, m_y
);
1241 wxFAIL_MSG( "wxWindow::SetSize error.\n" );
1245 if ((m_parent
) && (m_parent
->m_wxwindow
))
1246 gtk_myfixed_move( GTK_MYFIXED(m_parent
->m_wxwindow
), m_widget
, m_x
, m_y
);
1248 // Don't do anything for children of wxNotebook and wxMDIChildFrame
1251 void wxWindow::SetSize( int x
, int y
, int width
, int height
, int sizeFlags
)
1253 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1255 if (m_resizing
) return; // I don't like recursions
1263 if ((sizeFlags
& wxSIZE_USE_EXISTING
) == wxSIZE_USE_EXISTING
)
1265 if (newX
== -1) newX
= m_x
;
1266 if (newY
== -1) newY
= m_y
;
1267 if (newW
== -1) newW
= m_width
;
1268 if (newH
== -1) newH
= m_height
;
1271 if ((sizeFlags
& wxSIZE_AUTO_WIDTH
) == wxSIZE_AUTO_WIDTH
)
1273 if (newW
== -1) newW
= 80;
1276 if ((sizeFlags
& wxSIZE_AUTO_HEIGHT
) == wxSIZE_AUTO_HEIGHT
)
1278 if (newH
== -1) newH
= 26;
1281 if ((m_x
!= newX
) || (m_y
!= newY
) || (!m_sizeSet
))
1285 ImplementSetPosition();
1287 if ((m_width
!= newW
) || (m_height
!= newH
) || (!m_sizeSet
))
1295 wxSizeEvent
event( wxSize(m_width
,m_height
), GetId() );
1296 event
.SetEventObject( this );
1297 ProcessEvent( event
);
1302 void wxWindow::SetSize( int width
, int height
)
1304 SetSize( -1, -1, width
, height
, wxSIZE_USE_EXISTING
);
1307 void wxWindow::Move( int x
, int y
)
1309 SetSize( x
, y
, -1, -1, wxSIZE_USE_EXISTING
);
1312 void wxWindow::GetSize( int *width
, int *height
) const
1314 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1316 if (width
) (*width
) = m_width
;
1317 if (height
) (*height
) = m_height
;
1320 void wxWindow::SetClientSize( int width
, int height
)
1322 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1326 SetSize( width
, height
);
1333 if (!m_hasScrolling
)
1336 do we have sunken dialogs ?
1338 GtkStyleClass *window_class = m_wxwindow->style->klass;
1340 dw += 2 * window_class->xthickness;
1341 dh += 2 * window_class->ythickness;
1346 GtkScrolledWindow
*scroll_window
= GTK_SCROLLED_WINDOW(m_widget
);
1347 GtkScrolledWindowClass
*scroll_class
= GTK_SCROLLED_WINDOW_CLASS( GTK_OBJECT(m_widget
)->klass
);
1349 GtkWidget
*viewport
= scroll_window
->viewport
;
1350 GtkStyleClass
*viewport_class
= viewport
->style
->klass
;
1352 GtkWidget
*hscrollbar
= scroll_window
->hscrollbar
;
1353 GtkWidget
*vscrollbar
= scroll_window
->vscrollbar
;
1355 if ((m_windowStyle
& wxRAISED_BORDER
) ||
1356 (m_windowStyle
& wxSUNKEN_BORDER
))
1358 dw
+= 2 * viewport_class
->xthickness
;
1359 dh
+= 2 * viewport_class
->ythickness
;
1362 if (GTK_WIDGET_VISIBLE(vscrollbar
))
1364 dw
+= vscrollbar
->allocation
.width
;
1365 dw
+= scroll_class
->scrollbar_spacing
;
1368 if (GTK_WIDGET_VISIBLE(hscrollbar
))
1370 dh
+= hscrollbar
->allocation
.height
;
1371 dw
+= scroll_class
->scrollbar_spacing
;
1375 SetSize( width
+dw
, height
+dh
);
1379 void wxWindow::GetClientSize( int *width
, int *height
) const
1381 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1385 if (width
) (*width
) = m_width
;
1386 if (height
) (*height
) = m_height
;
1393 if (!m_hasScrolling
)
1396 do we have sunken dialogs ?
1398 GtkStyleClass *window_class = m_wxwindow->style->klass;
1400 dw += 2 * window_class->xthickness;
1401 dh += 2 * window_class->ythickness;
1406 GtkScrolledWindow
*scroll_window
= GTK_SCROLLED_WINDOW(m_widget
);
1407 GtkScrolledWindowClass
*scroll_class
= GTK_SCROLLED_WINDOW_CLASS( GTK_OBJECT(m_widget
)->klass
);
1409 GtkWidget
*viewport
= scroll_window
->viewport
;
1410 GtkStyleClass
*viewport_class
= viewport
->style
->klass
;
1412 GtkWidget
*hscrollbar
= scroll_window
->hscrollbar
;
1413 GtkWidget
*vscrollbar
= scroll_window
->vscrollbar
;
1415 if ((m_windowStyle
& wxRAISED_BORDER
) ||
1416 (m_windowStyle
& wxSUNKEN_BORDER
))
1418 dw
+= 2 * viewport_class
->xthickness
;
1419 dh
+= 2 * viewport_class
->ythickness
;
1422 if (GTK_WIDGET_VISIBLE(vscrollbar
))
1424 // dw += vscrollbar->allocation.width;
1425 dw
+= 15; // range.slider_width = 11 + 2*2pts edge
1426 dw
+= scroll_class
->scrollbar_spacing
;
1429 if (GTK_WIDGET_VISIBLE(hscrollbar
))
1431 // dh += hscrollbar->allocation.height;
1433 dh
+= scroll_class
->scrollbar_spacing
;
1437 if (width
) (*width
) = m_width
- dw
;
1438 if (height
) (*height
) = m_height
- dh
;
1442 void wxWindow::GetPosition( int *x
, int *y
) const
1444 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1450 void wxWindow::ClientToScreen( int *x
, int *y
)
1452 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1454 GdkWindow
*source
= (GdkWindow
*) NULL
;
1456 source
= m_wxwindow
->window
;
1458 source
= m_widget
->window
;
1462 gdk_window_get_origin( source
, &org_x
, &org_y
);
1466 if (GTK_WIDGET_NO_WINDOW (m_widget
))
1468 org_x
+= m_widget
->allocation
.x
;
1469 org_y
+= m_widget
->allocation
.y
;
1477 void wxWindow::ScreenToClient( int *x
, int *y
)
1479 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1481 GdkWindow
*source
= (GdkWindow
*) NULL
;
1483 source
= m_wxwindow
->window
;
1485 source
= m_widget
->window
;
1489 gdk_window_get_origin( source
, &org_x
, &org_y
);
1493 if (GTK_WIDGET_NO_WINDOW (m_widget
))
1495 org_x
+= m_widget
->allocation
.x
;
1496 org_y
+= m_widget
->allocation
.y
;
1504 void wxWindow::Centre( int direction
)
1506 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1508 if (IS_KIND_OF(this,wxDialog
) || IS_KIND_OF(this,wxFrame
))
1510 if (direction
& wxHORIZONTAL
== wxHORIZONTAL
) m_x
= (gdk_screen_width () - m_width
) / 2;
1511 if (direction
& wxVERTICAL
== wxVERTICAL
) m_y
= (gdk_screen_height () - m_height
) / 2;
1512 ImplementSetPosition();
1520 m_parent
->GetSize( &p_w
, &p_h
);
1521 if (direction
& wxHORIZONTAL
== wxHORIZONTAL
) m_x
= (p_w
- m_width
) / 2;
1522 if (direction
& wxVERTICAL
== wxVERTICAL
) m_y
= (p_h
- m_height
) / 2;
1523 ImplementSetPosition();
1528 void wxWindow::Fit()
1530 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1534 wxNode
*node
= GetChildren()->First();
1537 wxWindow
*win
= (wxWindow
*)node
->Data();
1539 win
->GetPosition(&wx
, &wy
);
1540 win
->GetSize(&ww
, &wh
);
1541 if ( wx
+ ww
> maxX
)
1543 if ( wy
+ wh
> maxY
)
1546 node
= node
->Next();
1548 SetClientSize(maxX
+ 5, maxY
+ 10);
1551 void wxWindow::SetSizeHints( int minW
, int minH
, int maxW
, int maxH
, int WXUNUSED(incW
), int WXUNUSED(incH
) )
1553 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1561 void wxWindow::OnSize( wxSizeEvent
&WXUNUSED(event
) )
1563 //if (GetAutoLayout()) Layout();
1566 bool wxWindow::Show( bool show
)
1568 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1571 gtk_widget_show( m_widget
);
1573 gtk_widget_hide( m_widget
);
1578 void wxWindow::Enable( bool enable
)
1580 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1582 m_isEnabled
= enable
;
1583 gtk_widget_set_sensitive( m_widget
, enable
);
1584 if (m_wxwindow
) gtk_widget_set_sensitive( m_wxwindow
, enable
);
1587 int wxWindow::GetCharHeight() const
1589 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1593 wxFAIL_MSG( "invalid font" );
1597 GdkFont
*font
= m_font
.GetInternalFont( 1.0 );
1598 return font
->ascent
+ font
->descent
;
1601 int wxWindow::GetCharWidth() const
1603 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1607 wxFAIL_MSG( "invalid font" );
1611 GdkFont
*font
= m_font
.GetInternalFont( 1.0 );
1612 return gdk_string_width( font
, "H" );
1615 void wxWindow::GetTextExtent( const wxString
& string
, int *x
, int *y
,
1616 int *descent
, int *externalLeading
, const wxFont
*theFont
, bool WXUNUSED(use16
) ) const
1618 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1620 wxFont fontToUse
= m_font
;
1621 if (theFont
) fontToUse
= *theFont
;
1623 if (!fontToUse
.Ok())
1625 wxFAIL_MSG( "invalid font" );
1628 wxASSERT_MSG( (m_font
.Ok()), "invalid font" );
1630 GdkFont
*font
= fontToUse
.GetInternalFont( 1.0 );
1631 if (x
) (*x
) = gdk_string_width( font
, string
);
1632 if (y
) (*y
) = font
->ascent
+ font
->descent
;
1633 if (descent
) (*descent
) = font
->descent
;
1634 if (externalLeading
) (*externalLeading
) = 0; // ??
1637 void wxWindow::MakeModal( bool modal
)
1640 // Disable all other windows
1641 if (this->IsKindOf(CLASSINFO(wxDialog
)) || this->IsKindOf(CLASSINFO(wxFrame
)))
1643 wxNode
*node
= wxTopLevelWindows
.First();
1646 wxWindow
*win
= (wxWindow
*)node
->Data();
1648 win
->Enable(!modal
);
1650 node
= node
->Next();
1655 void wxWindow::SetFocus()
1657 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1659 GtkWidget
*connect_widget
= GetConnectWidget();
1662 if (GTK_WIDGET_CAN_FOCUS(connect_widget
) && !GTK_WIDGET_HAS_FOCUS (connect_widget
) )
1664 gtk_widget_grab_focus (connect_widget
);
1669 bool wxWindow::OnClose()
1674 void wxWindow::AddChild( wxWindow
*child
)
1676 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1677 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window need client area" );
1678 wxASSERT_MSG( (child
!= NULL
), "invalid child" );
1679 wxASSERT_MSG( (child
->m_widget
!= NULL
), "invalid child" );
1681 // Addchild is (often) called before the program
1682 // has left the parents constructor so that no
1683 // virtual tables work yet. The approach below
1684 // practically imitates virtual tables, i.e. it
1685 // implements a different AddChild() behaviour
1686 // for wxFrame, wxDialog, wxWindow and
1687 // wxMDIParentFrame.
1689 // wxFrame and wxDialog as children aren't placed into the parents
1691 if (( IS_KIND_OF(child
,wxFrame
) || IS_KIND_OF(child
,wxDialog
) ) &&
1692 (!IS_KIND_OF(child
,wxMDIChildFrame
)))
1694 m_children
.Append( child
);
1696 if ((child
->m_x
!= -1) && (child
->m_y
!= -1))
1697 gtk_widget_set_uposition( child
->m_widget
, child
->m_x
, child
->m_y
);
1702 // In the case of an wxMDIChildFrame descendant, we use the
1703 // client windows's AddChild()
1705 if (IS_KIND_OF(this,wxMDIParentFrame
))
1707 if (IS_KIND_OF(child
,wxMDIChildFrame
))
1709 wxMDIClientWindow
*client
= ((wxMDIParentFrame
*)this)->GetClientWindow();
1712 client
->AddChild( child
);
1718 // wxNotebook is very special, so it has a private AddChild()
1720 if (IS_KIND_OF(this,wxNotebook
))
1722 wxNotebook
*tab
= (wxNotebook
*)this;
1723 tab
->AddChild( child
);
1727 // wxFrame has a private AddChild
1729 if (IS_KIND_OF(this,wxFrame
) && !IS_KIND_OF(this,wxMDIChildFrame
))
1731 wxFrame
*frame
= (wxFrame
*)this;
1732 frame
->AddChild( child
);
1738 m_children
.Append( child
);
1739 if (m_wxwindow
) gtk_myfixed_put( GTK_MYFIXED(m_wxwindow
), child
->m_widget
,
1740 child
->m_x
, child
->m_y
);
1742 gtk_widget_set_usize( child
->m_widget
, child
->m_width
, child
->m_height
);
1745 wxList
*wxWindow::GetChildren()
1747 return (&m_children
);
1750 void wxWindow::RemoveChild( wxWindow
*child
)
1753 GetChildren()->DeleteObject( child
);
1754 child
->m_parent
= (wxWindow
*) NULL
;
1757 void wxWindow::SetReturnCode( int retCode
)
1759 m_retCode
= retCode
;
1762 int wxWindow::GetReturnCode()
1767 void wxWindow::Raise()
1769 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1771 if (m_widget
) gdk_window_raise( m_widget
->window
);
1774 void wxWindow::Lower()
1776 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1778 if (m_widget
) gdk_window_lower( m_widget
->window
);
1781 wxEvtHandler
*wxWindow::GetEventHandler()
1783 return m_eventHandler
;
1786 void wxWindow::SetEventHandler( wxEvtHandler
*handler
)
1788 m_eventHandler
= handler
;
1791 void wxWindow::PushEventHandler(wxEvtHandler
*handler
)
1793 handler
->SetNextHandler(GetEventHandler());
1794 SetEventHandler(handler
);
1797 wxEvtHandler
*wxWindow::PopEventHandler(bool deleteHandler
)
1799 if (GetEventHandler())
1801 wxEvtHandler
*handlerA
= GetEventHandler();
1802 wxEvtHandler
*handlerB
= handlerA
->GetNextHandler();
1803 handlerA
->SetNextHandler((wxEvtHandler
*) NULL
);
1804 SetEventHandler(handlerB
);
1808 return (wxEvtHandler
*) NULL
;
1814 return (wxEvtHandler
*) NULL
;
1817 wxValidator
*wxWindow::GetValidator()
1819 return m_windowValidator
;
1822 void wxWindow::SetValidator( const wxValidator
& validator
)
1824 if (m_windowValidator
) delete m_windowValidator
;
1825 m_windowValidator
= validator
.Clone();
1826 if (m_windowValidator
) m_windowValidator
->SetWindow(this);
1829 bool wxWindow::IsBeingDeleted()
1834 void wxWindow::SetId( wxWindowID id
)
1839 wxWindowID
wxWindow::GetId()
1844 void wxWindow::SetCursor( const wxCursor
&cursor
)
1846 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1848 if (m_cursor
== NULL
)
1850 wxFAIL_MSG( "wxWindow::SetCursor m_cursor == NULL" );
1851 m_cursor
= new wxCursor( wxCURSOR_ARROW
);
1856 if (*((wxCursor
*)&cursor
) == m_cursor
) return;
1861 *m_cursor
= *wxSTANDARD_CURSOR
;
1864 if ((m_widget
) && (m_widget
->window
))
1865 gdk_window_set_cursor( m_widget
->window
, m_cursor
->GetCursor() );
1867 if ((m_wxwindow
) && (m_wxwindow
->window
))
1868 gdk_window_set_cursor( m_wxwindow
->window
, m_cursor
->GetCursor() );
1871 void wxWindow::Refresh( bool eraseBackground
, const wxRect
*rect
)
1873 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
1875 if (eraseBackground
&& m_wxwindow
&& m_wxwindow
->window
)
1878 gdk_window_clear_area( m_wxwindow
->window
,
1892 GetClientSize( &w
, &h
);
1894 GdkRectangle gdk_rect
;
1898 gdk_rect
.height
= h
;
1899 gtk_widget_draw( m_wxwindow
, &gdk_rect
);
1904 GdkRectangle gdk_rect
;
1905 gdk_rect
.x
= rect
->x
;
1906 gdk_rect
.y
= rect
->y
;
1907 gdk_rect
.width
= rect
->width
;
1908 gdk_rect
.height
= rect
->height
;
1911 gtk_widget_draw( m_wxwindow
, &gdk_rect
);
1913 gtk_widget_draw( m_widget
, &gdk_rect
);
1917 wxRegion
wxWindow::GetUpdateRegion() const
1919 return m_updateRegion
;
1922 bool wxWindow::IsExposed( int x
, int y
) const
1924 return (m_updateRegion
.Contains( x
, y
) != wxOutRegion
);
1927 bool wxWindow::IsExposed( int x
, int y
, int w
, int h
) const
1929 return (m_updateRegion
.Contains( x
, y
, w
, h
) != wxOutRegion
);
1932 bool wxWindow::IsExposed( const wxPoint
& pt
) const
1934 return (m_updateRegion
.Contains( pt
.x
, pt
.y
) != wxOutRegion
);
1937 bool wxWindow::IsExposed( const wxRect
& rect
) const
1939 return (m_updateRegion
.Contains( rect
.x
, rect
.y
, rect
.width
, rect
.height
) != wxOutRegion
);
1942 void wxWindow::Clear()
1944 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
1946 if (m_wxwindow
&& m_wxwindow
->window
) gdk_window_clear( m_wxwindow
->window
);
1949 wxColour
wxWindow::GetBackgroundColour() const
1951 return m_backgroundColour
;
1954 void wxWindow::SetBackgroundColour( const wxColour
&colour
)
1956 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
1958 m_backgroundColour
= colour
;
1959 if (!m_backgroundColour
.Ok()) return;
1963 GdkWindow
*window
= m_wxwindow
->window
;
1964 m_backgroundColour
.CalcPixel( gdk_window_get_colormap( window
) );
1965 gdk_window_set_background( window
, m_backgroundColour
.GetColor() );
1966 gdk_window_clear( window
);
1972 wxColour
wxWindow::GetForegroundColour() const
1974 return m_foregroundColour
;
1977 void wxWindow::SetForegroundColour( const wxColour
&colour
)
1979 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
1981 m_foregroundColour
= colour
;
1982 if (!m_foregroundColour
.Ok()) return;
1987 GtkStyle
*wxWindow::GetWidgetStyle()
1989 if (m_widgetStyle
) gtk_style_unref( m_widgetStyle
);
1993 gtk_widget_get_style( m_widget
) );
1995 return m_widgetStyle
;
1998 void wxWindow::SetWidgetStyle()
2000 GtkStyle
*style
= GetWidgetStyle();
2002 gdk_font_unref( style
->font
);
2003 style
->font
= gdk_font_ref( m_font
.GetInternalFont( 1.0 ) );
2005 if (m_foregroundColour
.Ok())
2007 m_foregroundColour
.CalcPixel( gdk_window_get_colormap( m_widget
->window
) );
2008 style
->fg
[GTK_STATE_NORMAL
] = *m_foregroundColour
.GetColor();
2009 style
->fg
[GTK_STATE_PRELIGHT
] = *m_foregroundColour
.GetColor();
2010 style
->fg
[GTK_STATE_ACTIVE
] = *m_foregroundColour
.GetColor();
2013 if (m_backgroundColour
.Ok())
2015 m_backgroundColour
.CalcPixel( gdk_window_get_colormap( m_widget
->window
) );
2016 style
->bg
[GTK_STATE_NORMAL
] = *m_backgroundColour
.GetColor();
2017 style
->base
[GTK_STATE_NORMAL
] = *m_backgroundColour
.GetColor();
2018 style
->bg
[GTK_STATE_PRELIGHT
] = *m_backgroundColour
.GetColor();
2019 style
->base
[GTK_STATE_PRELIGHT
] = *m_backgroundColour
.GetColor();
2020 style
->bg
[GTK_STATE_ACTIVE
] = *m_backgroundColour
.GetColor();
2021 style
->base
[GTK_STATE_ACTIVE
] = *m_backgroundColour
.GetColor();
2022 style
->bg
[GTK_STATE_INSENSITIVE
] = *m_backgroundColour
.GetColor();
2023 style
->base
[GTK_STATE_INSENSITIVE
] = *m_backgroundColour
.GetColor();
2027 void wxWindow::ApplyWidgetStyle()
2031 bool wxWindow::Validate()
2033 wxCHECK_MSG( m_widget
!= NULL
, FALSE
, "invalid window" );
2035 wxNode
*node
= GetChildren()->First();
2038 wxWindow
*child
= (wxWindow
*)node
->Data();
2039 if (child
->GetValidator() && /* child->GetValidator()->Ok() && */ !child
->GetValidator()->Validate(this))
2041 node
= node
->Next();
2046 bool wxWindow::TransferDataToWindow()
2048 wxCHECK_MSG( m_widget
!= NULL
, FALSE
, "invalid window" );
2050 wxNode
*node
= GetChildren()->First();
2053 wxWindow
*child
= (wxWindow
*)node
->Data();
2054 if (child
->GetValidator() && /* child->GetValidator()->Ok() && */
2055 !child
->GetValidator()->TransferToWindow() )
2057 wxMessageBox( _("Application Error"), _("Could not transfer data to window"), wxOK
|wxICON_EXCLAMATION
);
2060 node
= node
->Next();
2065 bool wxWindow::TransferDataFromWindow()
2067 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2069 wxNode
*node
= GetChildren()->First();
2072 wxWindow
*child
= (wxWindow
*)node
->Data();
2073 if ( child
->GetValidator() && /* child->GetValidator()->Ok() && */ !child
->GetValidator()->TransferFromWindow() )
2075 node
= node
->Next();
2080 void wxWindow::SetAcceleratorTable( const wxAcceleratorTable
& accel
)
2082 m_acceleratorTable
= accel
;
2085 void wxWindow::OnInitDialog( wxInitDialogEvent
&WXUNUSED(event
) )
2087 TransferDataToWindow();
2090 void wxWindow::InitDialog()
2092 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
2094 wxInitDialogEvent
event(GetId());
2095 event
.SetEventObject( this );
2096 GetEventHandler()->ProcessEvent(event
);
2099 static void SetInvokingWindow( wxMenu
*menu
, wxWindow
*win
)
2101 menu
->SetInvokingWindow( win
);
2102 wxNode
*node
= menu
->m_items
.First();
2105 wxMenuItem
*menuitem
= (wxMenuItem
*)node
->Data();
2106 if (menuitem
->IsSubMenu())
2107 SetInvokingWindow( menuitem
->GetSubMenu(), win
);
2108 node
= node
->Next();
2112 bool wxWindow::PopupMenu( wxMenu
*menu
, int WXUNUSED(x
), int WXUNUSED(y
) )
2114 wxCHECK_MSG( m_widget
!= NULL
, FALSE
, "invalid window" );
2116 wxCHECK_MSG( menu
!= NULL
, FALSE
, "invalid popup-menu" );
2118 SetInvokingWindow( menu
, this );
2120 GTK_MENU(menu
->m_menu
),
2121 (GtkWidget
*)NULL
, // parent menu shell
2122 (GtkWidget
*)NULL
, // parent menu item
2123 (GtkMenuPositionFunc
)NULL
,
2124 NULL
, // client data
2125 0, // button used to activate it
2126 0//gs_timeLastClick // the time of activation
2131 void wxWindow::SetDropTarget( wxDropTarget
*dropTarget
)
2133 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
2135 GtkWidget
*dnd_widget
= GetConnectWidget();
2137 DisconnectDnDWidget( dnd_widget
);
2139 if (m_pDropTarget
) delete m_pDropTarget
;
2140 m_pDropTarget
= dropTarget
;
2142 ConnectDnDWidget( dnd_widget
);
2145 wxDropTarget
*wxWindow::GetDropTarget() const
2147 return m_pDropTarget
;
2150 void wxWindow::ConnectDnDWidget( GtkWidget
*widget
)
2152 if (!m_pDropTarget
) return;
2154 m_pDropTarget
->RegisterWidget( widget
);
2156 gtk_signal_connect( GTK_OBJECT(widget
), "drop_data_available_event",
2157 GTK_SIGNAL_FUNC(gtk_window_drop_callback
), (gpointer
)this );
2160 void wxWindow::DisconnectDnDWidget( GtkWidget
*widget
)
2162 if (!m_pDropTarget
) return;
2164 gtk_signal_disconnect_by_func( GTK_OBJECT(widget
),
2165 GTK_SIGNAL_FUNC(gtk_window_drop_callback
), (gpointer
)this );
2167 m_pDropTarget
->UnregisterWidget( widget
);
2170 GtkWidget
* wxWindow::GetConnectWidget()
2172 GtkWidget
*connect_widget
= m_widget
;
2173 if (m_wxwindow
) connect_widget
= m_wxwindow
;
2175 return connect_widget
;
2178 bool wxWindow::IsOwnGtkWindow( GdkWindow
*window
)
2180 if (m_wxwindow
) return (window
== m_wxwindow
->window
);
2181 return (window
== m_widget
->window
);
2184 void wxWindow::SetFont( const wxFont
&font
)
2186 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
2188 if (((wxFont
*)&font
)->Ok())
2191 m_font
= *wxSWISS_FONT
;
2196 wxFont
*wxWindow::GetFont()
2201 void wxWindow::SetWindowStyleFlag( long flag
)
2203 m_windowStyle
= flag
;
2206 long wxWindow::GetWindowStyleFlag() const
2208 return m_windowStyle
;
2211 void wxWindow::CaptureMouse()
2213 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
2215 wxCHECK_RET( g_capturing
== FALSE
, "CaptureMouse called twice" );
2217 GtkWidget
*connect_widget
= GetConnectWidget();
2218 gtk_grab_add( connect_widget
);
2219 gdk_pointer_grab ( connect_widget
->window
, FALSE
,
2221 (GDK_BUTTON_PRESS_MASK
|
2222 GDK_BUTTON_RELEASE_MASK
|
2223 GDK_POINTER_MOTION_MASK
),
2224 (GdkWindow
*) NULL
, (GdkCursor
*) NULL
, GDK_CURRENT_TIME
);
2228 void wxWindow::ReleaseMouse()
2230 wxCHECK_RET( m_widget
!= NULL
, "invalid window" );
2232 wxCHECK_RET( g_capturing
== TRUE
, "ReleaseMouse called twice" );
2234 GtkWidget
*connect_widget
= GetConnectWidget();
2235 gtk_grab_remove( connect_widget
);
2236 gdk_pointer_ungrab ( GDK_CURRENT_TIME
);
2237 g_capturing
= FALSE
;
2240 void wxWindow::SetTitle( const wxString
&WXUNUSED(title
) )
2244 wxString
wxWindow::GetTitle() const
2246 return (wxString
&)m_windowName
;
2249 wxString
wxWindow::GetLabel() const
2254 void wxWindow::SetName( const wxString
&name
)
2256 m_windowName
= name
;
2259 wxString
wxWindow::GetName() const
2261 return (wxString
&)m_windowName
;
2264 bool wxWindow::IsShown() const
2269 bool wxWindow::IsRetained()
2274 wxWindow
*wxWindow::FindWindow( long id
)
2276 if (id
== m_windowId
) return this;
2277 wxNode
*node
= m_children
.First();
2280 wxWindow
*child
= (wxWindow
*)node
->Data();
2281 wxWindow
*res
= child
->FindWindow( id
);
2282 if (res
) return res
;
2283 node
= node
->Next();
2285 return (wxWindow
*) NULL
;
2288 wxWindow
*wxWindow::FindWindow( const wxString
& name
)
2290 if (name
== m_windowName
) return this;
2291 wxNode
*node
= m_children
.First();
2294 wxWindow
*child
= (wxWindow
*)node
->Data();
2295 wxWindow
*res
= child
->FindWindow( name
);
2296 if (res
) return res
;
2297 node
= node
->Next();
2299 return (wxWindow
*) NULL
;
2302 void wxWindow::SetScrollbar( int orient
, int pos
, int thumbVisible
,
2303 int range
, bool refresh
)
2305 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2307 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2309 if (!m_wxwindow
) return;
2311 if (orient
== wxHORIZONTAL
)
2313 float fpos
= (float)pos
;
2314 float frange
= (float)range
;
2315 float fthumb
= (float)thumbVisible
;
2317 if ((fabs(frange
-m_hAdjust
->upper
) < 0.2) &&
2318 (fabs(fthumb
-m_hAdjust
->page_size
) < 0.2))
2320 SetScrollPos( orient
, pos
, refresh
);
2324 m_oldHorizontalPos
= fpos
;
2326 m_hAdjust
->lower
= 0.0;
2327 m_hAdjust
->upper
= frange
;
2328 m_hAdjust
->value
= fpos
;
2329 m_hAdjust
->step_increment
= 1.0;
2330 m_hAdjust
->page_increment
= (float)(wxMax(fthumb
,0));
2331 m_hAdjust
->page_size
= fthumb
;
2335 float fpos
= (float)pos
;
2336 float frange
= (float)range
;
2337 float fthumb
= (float)thumbVisible
;
2339 if ((fabs(frange
-m_vAdjust
->upper
) < 0.2) &&
2340 (fabs(fthumb
-m_vAdjust
->page_size
) < 0.2))
2342 SetScrollPos( orient
, pos
, refresh
);
2346 m_oldVerticalPos
= fpos
;
2348 m_vAdjust
->lower
= 0.0;
2349 m_vAdjust
->upper
= frange
;
2350 m_vAdjust
->value
= fpos
;
2351 m_vAdjust
->step_increment
= 1.0;
2352 m_vAdjust
->page_increment
= (float)(wxMax(fthumb
,0));
2353 m_vAdjust
->page_size
= fthumb
;
2356 if (m_wxwindow
->window
)
2358 if (orient
== wxHORIZONTAL
)
2359 gtk_signal_emit_by_name( GTK_OBJECT(m_hAdjust
), "changed" );
2361 gtk_signal_emit_by_name( GTK_OBJECT(m_vAdjust
), "changed" );
2363 gtk_widget_set_usize( m_widget
, m_width
, m_height
);
2367 void wxWindow::SetScrollPos( int orient
, int pos
, bool WXUNUSED(refresh
) )
2369 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2371 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2373 if (!m_wxwindow
) return;
2375 if (orient
== wxHORIZONTAL
)
2377 float fpos
= (float)pos
;
2378 m_oldHorizontalPos
= fpos
;
2380 if (fabs(fpos
-m_hAdjust
->value
) < 0.2) return;
2381 m_hAdjust
->value
= fpos
;
2385 float fpos
= (float)pos
;
2386 m_oldVerticalPos
= fpos
;
2387 if (fabs(fpos
-m_vAdjust
->value
) < 0.2) return;
2388 m_vAdjust
->value
= fpos
;
2393 if (m_wxwindow
->window
)
2395 if (orient
== wxHORIZONTAL
)
2396 gtk_signal_emit_by_name( GTK_OBJECT(m_hAdjust
), "value_changed" );
2398 gtk_signal_emit_by_name( GTK_OBJECT(m_vAdjust
), "value_changed" );
2403 int wxWindow::GetScrollThumb( int orient
) const
2405 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2407 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2409 if (!m_wxwindow
) return 0;
2411 if (orient
== wxHORIZONTAL
)
2412 return (int)(m_hAdjust
->page_size
+0.5);
2414 return (int)(m_vAdjust
->page_size
+0.5);
2417 int wxWindow::GetScrollPos( int orient
) const
2419 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2421 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2423 if (!m_wxwindow
) return 0;
2425 if (orient
== wxHORIZONTAL
)
2426 return (int)(m_hAdjust
->value
+0.5);
2428 return (int)(m_vAdjust
->value
+0.5);
2431 int wxWindow::GetScrollRange( int orient
) const
2433 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2435 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2437 if (!m_wxwindow
) return 0;
2439 if (orient
== wxHORIZONTAL
)
2440 return (int)(m_hAdjust
->upper
+0.5);
2442 return (int)(m_vAdjust
->upper
+0.5);
2445 void wxWindow::ScrollWindow( int dx
, int dy
, const wxRect
* WXUNUSED(rect
) )
2447 wxASSERT_MSG( (m_widget
!= NULL
), "invalid window" );
2449 wxASSERT_MSG( (m_wxwindow
!= NULL
), "window needs client area" );
2451 if (!m_wxwindow
) return;
2455 GetClientSize( &cw
, &ch
);
2457 int w
= cw
- abs(dx
);
2458 int h
= ch
- abs(dy
);
2459 if ((h
< 0) || (w
< 0))
2466 if (dx
< 0) s_x
= -dx
;
2467 if (dy
< 0) s_y
= -dy
;
2470 if (dx
> 0) d_x
= dx
;
2471 if (dy
> 0) d_y
= dy
;
2475 m_scrollGC
= gdk_gc_new( m_wxwindow
->window
);
2476 gdk_gc_set_exposures( m_scrollGC
, TRUE
);
2479 gdk_window_copy_area( m_wxwindow
->window
, m_scrollGC
, d_x
, d_y
,
2480 m_wxwindow
->window
, s_x
, s_y
, w
, h
);
2483 if (dx
< 0) rect
.x
= cw
+dx
; else rect
.x
= 0;
2484 if (dy
< 0) rect
.y
= ch
+dy
; else rect
.y
= 0;
2485 if (dy
!= 0) rect
.width
= cw
; else rect
.width
= abs(dx
);
2486 if (dx
!= 0) rect
.height
= ch
; else rect
.height
= abs(dy
);
2488 Refresh( TRUE
, &rect
);
2491 //-------------------------------------------------------------------------------------
2493 //-------------------------------------------------------------------------------------
2495 wxLayoutConstraints
*wxWindow::GetConstraints() const
2497 return m_constraints
;
2500 void wxWindow::SetConstraints( wxLayoutConstraints
*constraints
)
2504 UnsetConstraints(m_constraints
);
2505 delete m_constraints
;
2507 m_constraints
= constraints
;
2510 // Make sure other windows know they're part of a 'meaningful relationship'
2511 if (m_constraints
->left
.GetOtherWindow() && (m_constraints
->left
.GetOtherWindow() != this))
2512 m_constraints
->left
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2513 if (m_constraints
->top
.GetOtherWindow() && (m_constraints
->top
.GetOtherWindow() != this))
2514 m_constraints
->top
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2515 if (m_constraints
->right
.GetOtherWindow() && (m_constraints
->right
.GetOtherWindow() != this))
2516 m_constraints
->right
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2517 if (m_constraints
->bottom
.GetOtherWindow() && (m_constraints
->bottom
.GetOtherWindow() != this))
2518 m_constraints
->bottom
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2519 if (m_constraints
->width
.GetOtherWindow() && (m_constraints
->width
.GetOtherWindow() != this))
2520 m_constraints
->width
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2521 if (m_constraints
->height
.GetOtherWindow() && (m_constraints
->height
.GetOtherWindow() != this))
2522 m_constraints
->height
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2523 if (m_constraints
->centreX
.GetOtherWindow() && (m_constraints
->centreX
.GetOtherWindow() != this))
2524 m_constraints
->centreX
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2525 if (m_constraints
->centreY
.GetOtherWindow() && (m_constraints
->centreY
.GetOtherWindow() != this))
2526 m_constraints
->centreY
.GetOtherWindow()->AddConstraintReference((wxWindow
*)this);
2532 void wxWindow::SetAutoLayout( bool autoLayout
)
2534 m_autoLayout
= autoLayout
;
2537 bool wxWindow::GetAutoLayout() const
2539 return m_autoLayout
;
2542 wxSizer
*wxWindow::GetSizer() const
2544 return m_windowSizer
;
2547 void wxWindow::SetSizerParent( wxWindow
*win
)
2549 m_sizerParent
= win
;
2552 wxWindow
*wxWindow::GetSizerParent() const
2554 return m_sizerParent
;
2557 // This removes any dangling pointers to this window
2558 // in other windows' constraintsInvolvedIn lists.
2559 void wxWindow::UnsetConstraints(wxLayoutConstraints
*c
)
2563 if (c
->left
.GetOtherWindow() && (c
->top
.GetOtherWindow() != this))
2564 c
->left
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2565 if (c
->top
.GetOtherWindow() && (c
->top
.GetOtherWindow() != this))
2566 c
->top
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2567 if (c
->right
.GetOtherWindow() && (c
->right
.GetOtherWindow() != this))
2568 c
->right
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2569 if (c
->bottom
.GetOtherWindow() && (c
->bottom
.GetOtherWindow() != this))
2570 c
->bottom
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2571 if (c
->width
.GetOtherWindow() && (c
->width
.GetOtherWindow() != this))
2572 c
->width
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2573 if (c
->height
.GetOtherWindow() && (c
->height
.GetOtherWindow() != this))
2574 c
->height
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2575 if (c
->centreX
.GetOtherWindow() && (c
->centreX
.GetOtherWindow() != this))
2576 c
->centreX
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2577 if (c
->centreY
.GetOtherWindow() && (c
->centreY
.GetOtherWindow() != this))
2578 c
->centreY
.GetOtherWindow()->RemoveConstraintReference((wxWindow
*)this);
2582 // Back-pointer to other windows we're involved with, so if we delete
2583 // this window, we must delete any constraints we're involved with.
2584 void wxWindow::AddConstraintReference(wxWindow
*otherWin
)
2586 if (!m_constraintsInvolvedIn
)
2587 m_constraintsInvolvedIn
= new wxList
;
2588 if (!m_constraintsInvolvedIn
->Member(otherWin
))
2589 m_constraintsInvolvedIn
->Append(otherWin
);
2592 // REMOVE back-pointer to other windows we're involved with.
2593 void wxWindow::RemoveConstraintReference(wxWindow
*otherWin
)
2595 if (m_constraintsInvolvedIn
)
2596 m_constraintsInvolvedIn
->DeleteObject(otherWin
);
2599 // Reset any constraints that mention this window
2600 void wxWindow::DeleteRelatedConstraints()
2602 if (m_constraintsInvolvedIn
)
2604 wxNode
*node
= m_constraintsInvolvedIn
->First();
2607 wxWindow
*win
= (wxWindow
*)node
->Data();
2608 wxNode
*next
= node
->Next();
2609 wxLayoutConstraints
*constr
= win
->GetConstraints();
2611 // Reset any constraints involving this window
2614 constr
->left
.ResetIfWin((wxWindow
*)this);
2615 constr
->top
.ResetIfWin((wxWindow
*)this);
2616 constr
->right
.ResetIfWin((wxWindow
*)this);
2617 constr
->bottom
.ResetIfWin((wxWindow
*)this);
2618 constr
->width
.ResetIfWin((wxWindow
*)this);
2619 constr
->height
.ResetIfWin((wxWindow
*)this);
2620 constr
->centreX
.ResetIfWin((wxWindow
*)this);
2621 constr
->centreY
.ResetIfWin((wxWindow
*)this);
2626 delete m_constraintsInvolvedIn
;
2627 m_constraintsInvolvedIn
= (wxList
*) NULL
;
2631 void wxWindow::SetSizer(wxSizer
*sizer
)
2633 m_windowSizer
= sizer
;
2635 sizer
->SetSizerParent((wxWindow
*)this);
2642 bool wxWindow::Layout()
2644 if (GetConstraints())
2647 GetClientSize(&w
, &h
);
2648 GetConstraints()->width
.SetValue(w
);
2649 GetConstraints()->height
.SetValue(h
);
2652 // If top level (one sizer), evaluate the sizer's constraints.
2656 GetSizer()->ResetConstraints(); // Mark all constraints as unevaluated
2657 GetSizer()->LayoutPhase1(&noChanges
);
2658 GetSizer()->LayoutPhase2(&noChanges
);
2659 GetSizer()->SetConstraintSizes(); // Recursively set the real window sizes
2664 // Otherwise, evaluate child constraints
2665 ResetConstraints(); // Mark all constraints as unevaluated
2666 DoPhase(1); // Just one phase need if no sizers involved
2668 SetConstraintSizes(); // Recursively set the real window sizes
2674 // Do a phase of evaluating constraints:
2675 // the default behaviour. wxSizers may do a similar
2676 // thing, but also impose their own 'constraints'
2677 // and order the evaluation differently.
2678 bool wxWindow::LayoutPhase1(int *noChanges
)
2680 wxLayoutConstraints
*constr
= GetConstraints();
2683 return constr
->SatisfyConstraints((wxWindow
*)this, noChanges
);
2689 bool wxWindow::LayoutPhase2(int *noChanges
)
2699 // Do a phase of evaluating child constraints
2700 bool wxWindow::DoPhase(int phase
)
2702 int noIterations
= 0;
2703 int maxIterations
= 500;
2707 while ((noChanges
> 0) && (noIterations
< maxIterations
))
2711 wxNode
*node
= GetChildren()->First();
2714 wxWindow
*child
= (wxWindow
*)node
->Data();
2715 if (!child
->IsKindOf(CLASSINFO(wxFrame
)) && !child
->IsKindOf(CLASSINFO(wxDialog
)))
2717 wxLayoutConstraints
*constr
= child
->GetConstraints();
2720 if (succeeded
.Member(child
))
2725 int tempNoChanges
= 0;
2726 bool success
= ( (phase
== 1) ? child
->LayoutPhase1(&tempNoChanges
) : child
->LayoutPhase2(&tempNoChanges
) ) ;
2727 noChanges
+= tempNoChanges
;
2730 succeeded
.Append(child
);
2735 node
= node
->Next();
2742 void wxWindow::ResetConstraints()
2744 wxLayoutConstraints
*constr
= GetConstraints();
2747 constr
->left
.SetDone(FALSE
);
2748 constr
->top
.SetDone(FALSE
);
2749 constr
->right
.SetDone(FALSE
);
2750 constr
->bottom
.SetDone(FALSE
);
2751 constr
->width
.SetDone(FALSE
);
2752 constr
->height
.SetDone(FALSE
);
2753 constr
->centreX
.SetDone(FALSE
);
2754 constr
->centreY
.SetDone(FALSE
);
2756 wxNode
*node
= GetChildren()->First();
2759 wxWindow
*win
= (wxWindow
*)node
->Data();
2760 if (!win
->IsKindOf(CLASSINFO(wxFrame
)) && !win
->IsKindOf(CLASSINFO(wxDialog
)))
2761 win
->ResetConstraints();
2762 node
= node
->Next();
2766 // Need to distinguish between setting the 'fake' size for
2767 // windows and sizers, and setting the real values.
2768 void wxWindow::SetConstraintSizes(bool recurse
)
2770 wxLayoutConstraints
*constr
= GetConstraints();
2771 if (constr
&& constr
->left
.GetDone() && constr
->right
.GetDone() &&
2772 constr
->width
.GetDone() && constr
->height
.GetDone())
2774 int x
= constr
->left
.GetValue();
2775 int y
= constr
->top
.GetValue();
2776 int w
= constr
->width
.GetValue();
2777 int h
= constr
->height
.GetValue();
2779 // If we don't want to resize this window, just move it...
2780 if ((constr
->width
.GetRelationship() != wxAsIs
) ||
2781 (constr
->height
.GetRelationship() != wxAsIs
))
2783 // Calls Layout() recursively. AAAGH. How can we stop that.
2784 // Simply take Layout() out of non-top level OnSizes.
2785 SizerSetSize(x
, y
, w
, h
);
2794 char *windowClass
= this->GetClassInfo()->GetClassName();
2797 if (GetName() == "")
2798 winName
= _("unnamed");
2800 winName
= GetName();
2801 wxDebugMsg(_("Constraint(s) not satisfied for window of type %s, name %s:\n"), (const char *)windowClass
, (const char *)winName
);
2802 if (!constr
->left
.GetDone())
2803 wxDebugMsg(_(" unsatisfied 'left' constraint.\n"));
2804 if (!constr
->right
.GetDone())
2805 wxDebugMsg(_(" unsatisfied 'right' constraint.\n"));
2806 if (!constr
->width
.GetDone())
2807 wxDebugMsg(_(" unsatisfied 'width' constraint.\n"));
2808 if (!constr
->height
.GetDone())
2809 wxDebugMsg(_(" unsatisfied 'height' constraint.\n"));
2810 wxDebugMsg(_("Please check constraints: try adding AsIs() constraints.\n"));
2815 wxNode
*node
= GetChildren()->First();
2818 wxWindow
*win
= (wxWindow
*)node
->Data();
2819 if (!win
->IsKindOf(CLASSINFO(wxFrame
)) && !win
->IsKindOf(CLASSINFO(wxDialog
)))
2820 win
->SetConstraintSizes();
2821 node
= node
->Next();
2826 // This assumes that all sizers are 'on' the same
2827 // window, i.e. the parent of this window.
2828 void wxWindow::TransformSizerToActual(int *x
, int *y
) const
2830 if (!m_sizerParent
|| m_sizerParent
->IsKindOf(CLASSINFO(wxDialog
)) ||
2831 m_sizerParent
->IsKindOf(CLASSINFO(wxFrame
)) )
2835 m_sizerParent
->GetPosition(&xp
, &yp
);
2836 m_sizerParent
->TransformSizerToActual(&xp
, &yp
);
2841 void wxWindow::SizerSetSize(int x
, int y
, int w
, int h
)
2845 TransformSizerToActual(&xx
, &yy
);
2846 SetSize(xx
, yy
, w
, h
);
2849 void wxWindow::SizerMove(int x
, int y
)
2853 TransformSizerToActual(&xx
, &yy
);
2857 // Only set the size/position of the constraint (if any)
2858 void wxWindow::SetSizeConstraint(int x
, int y
, int w
, int h
)
2860 wxLayoutConstraints
*constr
= GetConstraints();
2865 constr
->left
.SetValue(x
);
2866 constr
->left
.SetDone(TRUE
);
2870 constr
->top
.SetValue(y
);
2871 constr
->top
.SetDone(TRUE
);
2875 constr
->width
.SetValue(w
);
2876 constr
->width
.SetDone(TRUE
);
2880 constr
->height
.SetValue(h
);
2881 constr
->height
.SetDone(TRUE
);
2886 void wxWindow::MoveConstraint(int x
, int y
)
2888 wxLayoutConstraints
*constr
= GetConstraints();
2893 constr
->left
.SetValue(x
);
2894 constr
->left
.SetDone(TRUE
);
2898 constr
->top
.SetValue(y
);
2899 constr
->top
.SetDone(TRUE
);
2904 void wxWindow::GetSizeConstraint(int *w
, int *h
) const
2906 wxLayoutConstraints
*constr
= GetConstraints();
2909 *w
= constr
->width
.GetValue();
2910 *h
= constr
->height
.GetValue();
2916 void wxWindow::GetClientSizeConstraint(int *w
, int *h
) const
2918 wxLayoutConstraints
*constr
= GetConstraints();
2921 *w
= constr
->width
.GetValue();
2922 *h
= constr
->height
.GetValue();
2925 GetClientSize(w
, h
);
2928 void wxWindow::GetPositionConstraint(int *x
, int *y
) const
2930 wxLayoutConstraints
*constr
= GetConstraints();
2933 *x
= constr
->left
.GetValue();
2934 *y
= constr
->top
.GetValue();
2940 bool wxWindow::AcceptsFocus() const
2942 return IsEnabled() && IsShown();
2945 void wxWindow::OnIdle(wxIdleEvent
& WXUNUSED(event
) )