1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/gtk/window.h
4 // Author: Robert Roebling
6 // Copyright: (c) 1998 Robert Roebling
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////////
11 #ifndef __GTKWINDOWH__
12 #define __GTKWINDOWH__
18 //-----------------------------------------------------------------------------
19 // callback definition for inserting a window (internal)
20 //-----------------------------------------------------------------------------
23 typedef void (*wxInsertChildFunction
)( wxWindowGTK
*, wxWindowGTK
* );
25 //-----------------------------------------------------------------------------
27 //-----------------------------------------------------------------------------
29 class wxWindowGTK
: public wxWindowBase
32 // creating the window
33 // -------------------
35 wxWindowGTK(wxWindow
*parent
,
37 const wxPoint
& pos
= wxDefaultPosition
,
38 const wxSize
& size
= wxDefaultSize
,
40 const wxString
& name
= wxPanelNameStr
);
41 bool Create(wxWindow
*parent
,
43 const wxPoint
& pos
= wxDefaultPosition
,
44 const wxSize
& size
= wxDefaultSize
,
46 const wxString
& name
= wxPanelNameStr
);
47 virtual ~wxWindowGTK();
49 // implement base class (pure) virtual methods
50 // -------------------------------------------
52 virtual bool Destroy();
57 virtual bool Show( bool show
= TRUE
);
58 virtual bool Enable( bool enable
= TRUE
);
60 virtual bool IsRetained() const;
62 virtual void SetFocus();
63 virtual bool AcceptsFocus() const;
65 virtual bool Reparent( wxWindowBase
*newParent
);
67 virtual void WarpPointer(int x
, int y
);
68 virtual void CaptureMouse();
69 virtual void ReleaseMouse();
71 virtual void Refresh( bool eraseBackground
= TRUE
,
72 const wxRect
*rect
= (const wxRect
*) NULL
);
75 virtual bool SetBackgroundColour( const wxColour
&colour
);
76 virtual bool SetForegroundColour( const wxColour
&colour
);
77 virtual bool SetCursor( const wxCursor
&cursor
);
78 virtual bool SetFont( const wxFont
&font
);
80 virtual int GetCharHeight() const;
81 virtual int GetCharWidth() const;
82 virtual void GetTextExtent(const wxString
& string
,
84 int *descent
= (int *) NULL
,
85 int *externalLeading
= (int *) NULL
,
86 const wxFont
*theFont
= (const wxFont
*) NULL
)
89 #if wxUSE_MENUS_NATIVE
90 virtual bool DoPopupMenu( wxMenu
*menu
, int x
, int y
);
91 #endif // wxUSE_MENUS_NATIVE
93 virtual void SetScrollbar( int orient
, int pos
, int thumbVisible
,
94 int range
, bool refresh
= TRUE
);
95 virtual void SetScrollPos( int orient
, int pos
, bool refresh
= TRUE
);
96 virtual int GetScrollPos( int orient
) const;
97 virtual int GetScrollThumb( int orient
) const;
98 virtual int GetScrollRange( int orient
) const;
99 virtual void ScrollWindow( int dx
, int dy
,
100 const wxRect
* rect
= (wxRect
*) NULL
);
102 #if wxUSE_DRAG_AND_DROP
103 virtual void SetDropTarget( wxDropTarget
*dropTarget
);
104 #endif // wxUSE_DRAG_AND_DROP
109 virtual WXWidget
GetHandle() const { return m_widget
; }
111 /* I don't want users to override what's done in idle so everything that
112 has to be done in idle time in order for wxGTK to work is done in
114 virtual void OnInternalIdle();
116 /* For compatibility across platforms (not in event table) */
117 void OnIdle(wxIdleEvent
& WXUNUSED(event
)) {};
119 // wxGTK-specific: called recursively by Enable,
120 // to give widgets an oppprtunity to correct their colours after they
121 // have been changed by Enable
122 virtual void OnParentEnable( bool WXUNUSED(enable
) ) {};
124 /* used by all window classes in the widget creation process */
125 bool PreCreation( wxWindowGTK
*parent
, const wxPoint
&pos
, const wxSize
&size
);
128 /* internal addition of child windows. differs from class
129 to class not by using virtual functions but by using
130 the m_insertCallback */
131 void DoAddChild(wxWindowGTK
*child
);
133 /* the methods below are required because many native widgets
134 are composed of several subwidgets and setting a style for
135 the widget means setting it for all subwidgets as well.
136 also, it is nor clear, which native widget is the top
137 widget where (most of) the input goes. even tooltips have
138 to be applied to all subwidgets. */
140 virtual GtkWidget
* GetConnectWidget();
141 virtual bool IsOwnGtkWindow( GdkWindow
*window
);
142 void ConnectWidget( GtkWidget
*widget
);
144 /* creates a new widget style if none is there
145 and sets m_widgetStyle to this value. */
146 GtkStyle
*GetWidgetStyle();
148 /* called by SetFont() and SetXXXColour etc */
149 void SetWidgetStyle();
151 /* overridden in many GTK widgets */
152 virtual void ApplyWidgetStyle();
155 virtual void ApplyToolTip( GtkTooltips
*tips
, const wxChar
*tip
);
156 #endif // wxUSE_TOOLTIPS
158 // called from GTK signales handlers. it indicates that
159 // the layouting functions have to be called later on
160 // (i.e. in idle time, implemented in OnInternalIdle() ).
161 void GtkUpdateSize() { m_sizeSet
= FALSE
; }
163 // position and size of the window
165 int m_width
, m_height
;
166 int m_oldClientWidth
,m_oldClientHeight
;
168 // see the docs in src/gtk/window.cpp
169 GtkWidget
*m_widget
; // mostly the widget seen by the rest of GTK
170 GtkWidget
*m_wxwindow
; // mostly the client area as per wxWindows
172 // this widget will be queried for GTK's focus events
173 GtkWidget
*m_focusWidget
;
176 // XIM support for wxWindows
182 GtkAdjustment
*m_hAdjust
,*m_vAdjust
;
183 float m_oldHorizontalPos
;
184 float m_oldVerticalPos
;
186 // extra (wxGTK-specific) flags
187 bool m_needParent
:1; // ! wxFrame, wxDialog, wxNotebookPage ?
188 bool m_noExpose
:1; // wxGLCanvas has its own redrawing
189 bool m_nativeSizeEvent
:1; // wxGLCanvas sends wxSizeEvent upon "alloc_size"
190 bool m_hasScrolling
:1;
194 bool m_isStaticBox
:1; // faster than IS_KIND_OF
195 bool m_isRadioButton
:1; // faster than IS_KIND_OF
196 bool m_isFrame
:1; // faster than IS_KIND_OF
197 bool m_acceptsFocus
:1; // not wxStaticBox, not wxStaticBitmap etc.
199 bool m_clipPaintRegion
; // TRUE after ScrollWindow()
200 bool m_queuedFullRedraw
; // TRUE after DoMoveWindow
202 // these are true if the style were set before the widget was realized
203 // (typcally in the constructor) but the actual GTK style must not be set
204 // before the widget has been "realized"
205 bool m_delayedForegroundColour
:1;
206 bool m_delayedBackgroundColour
:1;
208 // contains GTK's widgets internal information about non-default widget
209 // font and colours. we create one for each widget that gets any
210 // non-default attribute set via SetFont() or SetForegroundColour() /
211 // SetBackgroundColour().
212 GtkStyle
*m_widgetStyle
;
214 // C++ has no virtual methods in the constrcutor of any class but we need
215 // different methods of inserting a child window into a wxFrame,
216 // wxMDIFrame, wxNotebook etc. this is the callback that will get used.
217 wxInsertChildFunction m_insertCallback
;
219 // implement the base class pure virtuals
220 virtual void DoClientToScreen( int *x
, int *y
) const;
221 virtual void DoScreenToClient( int *x
, int *y
) const;
222 virtual void DoGetPosition( int *x
, int *y
) const;
223 virtual void DoGetSize( int *width
, int *height
) const;
224 virtual void DoGetClientSize( int *width
, int *height
) const;
225 virtual void DoSetSize(int x
, int y
,
226 int width
, int height
,
227 int sizeFlags
= wxSIZE_AUTO
);
228 virtual void DoSetClientSize(int width
, int height
);
229 virtual void DoMoveWindow(int x
, int y
, int width
, int height
);
232 virtual void DoSetToolTip( wxToolTip
*tip
);
233 #endif // wxUSE_TOOLTIPS
235 // common part of all ctors (can't be virtual because called from ctor)
239 DECLARE_DYNAMIC_CLASS(wxWindowGTK
)
240 DECLARE_NO_COPY_CLASS(wxWindowGTK
)
243 extern wxWindow
*wxFindFocusedChild(wxWindowGTK
*win
);
245 #endif // __GTKWINDOWH__