1 /////////////////////////////////////////////////////////////////////////////
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 //-----------------------------------------------------------------------------
22 typedef void (*wxInsertChildFunction
)( wxWindow
*, wxWindow
* );
24 //-----------------------------------------------------------------------------
26 //-----------------------------------------------------------------------------
28 class wxWindow
: public wxWindowBase
30 DECLARE_DYNAMIC_CLASS(wxWindow
)
33 // creating the window
34 // -------------------
36 wxWindow(wxWindow
*parent
,
38 const wxPoint
& pos
= wxDefaultPosition
,
39 const wxSize
& size
= wxDefaultSize
,
41 const wxString
& name
= wxPanelNameStr
);
42 bool Create(wxWindow
*parent
,
44 const wxPoint
& pos
= wxDefaultPosition
,
45 const wxSize
& size
= wxDefaultSize
,
47 const wxString
& name
= wxPanelNameStr
);
50 // implement base class (pure) virtual methods
51 // -------------------------------------------
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( wxWindow
*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 virtual bool DoPopupMenu( wxMenu
*menu
, int x
, int y
);
91 virtual void SetScrollbar( int orient
, int pos
, int thumbVisible
,
92 int range
, bool refresh
= TRUE
);
93 virtual void SetScrollPos( int orient
, int pos
, bool refresh
= TRUE
);
94 virtual int GetScrollPos( int orient
) const;
95 virtual int GetScrollThumb( int orient
) const;
96 virtual int GetScrollRange( int orient
) const;
97 virtual void ScrollWindow( int dx
, int dy
,
98 const wxRect
* rect
= (wxRect
*) NULL
);
100 #if wxUSE_DRAG_AND_DROP
101 virtual void SetDropTarget( wxDropTarget
*dropTarget
);
102 #endif // wxUSE_DRAG_AND_DROP
107 virtual WXWidget
GetHandle() const { return m_widget
; }
109 // also sets the global flag
110 void SetScrolling(bool scroll
);
112 bool HasScrolling() const { return m_hasScrolling
; }
113 bool IsScrolling() const { return m_isScrolling
; }
115 /* I don't want users to override what's done in idle so everything that
116 has to be done in idle time in order for wxGTK to work is done in
118 virtual void OnInternalIdle();
120 /* For compatibility across platforms (not in event table) */
121 void OnIdle(wxIdleEvent
& WXUNUSED(event
)) {};
123 /* used by all window classes in the widget creation process */
124 bool PreCreation( wxWindow
*parent
, const wxPoint
&pos
, const wxSize
&size
);
127 /* internal addition of child windows. differs from class
128 to class not by using virtual functions but by using
129 the m_insertCallback */
130 void DoAddChild(wxWindow
*child
);
132 /* the methods below are required because many native widgets
133 are composed of several subwidgets and setting a style for
134 the widget means setting it for all subwidgets as well.
135 also, it is nor clear, which native widget is the top
136 widget where (most of) the input goes. even tooltips have
137 to be applied to all subwidgets. */
139 virtual GtkWidget
* GetConnectWidget();
140 virtual bool IsOwnGtkWindow( GdkWindow
*window
);
141 void ConnectWidget( GtkWidget
*widget
);
143 /* creates a new widget style if none is there
144 and sets m_widgetStyle to this value. */
145 GtkStyle
*GetWidgetStyle();
147 /* called by SetFont() and SetXXXColour etc */
148 void SetWidgetStyle();
150 /* overridden in many GTK widgets */
151 virtual void ApplyWidgetStyle();
154 virtual void ApplyToolTip( GtkTooltips
*tips
, const wxChar
*tip
);
155 #endif // wxUSE_TOOLTIPS
157 // called from GTK signales handlers. it indicates that
158 // the layouting functions have to be called later on
159 // (i.e. in idle time, implemented in OnInternalIdle() ).
160 void UpdateSize() { m_sizeSet
= FALSE
; }
162 // position and size of the window
164 int m_width
, m_height
;
166 /* see the docs in src/gtk/window.cpp */
168 GtkWidget
*m_wxwindow
;
170 /* scrolling stuff */
171 GtkAdjustment
*m_hAdjust
,*m_vAdjust
;
172 float m_oldHorizontalPos
;
173 float m_oldVerticalPos
;
175 // we need an extra XGC flag set to get exposed
176 // events from overlapping children upon moving
177 // them. this flag will be set in this GC and
178 // the GC will be used in wxWindow::ScrollWindow().
181 // extra (wxGTK-specific) flags
182 bool m_needParent
:1; /* ! wxFrame, wxDialog, wxNotebookPage ? */
183 bool m_hasScrolling
:1;
184 bool m_isScrolling
:1;
188 bool m_isStaticBox
:1; /* faster than IS_KIND_OF */
189 bool m_isRadioButton
:1; /* faster than IS_KIND_OF */
190 bool m_isFrame
:1; /* faster than IS_KIND_OF */
191 bool m_acceptsFocus
:1; /* ! wxStaticBox etc. */
193 // these are true if the style were set before the widget was realized
194 // (typcally in the constructor) but the actual GTK style must not be set
195 // before the widget has been "realized"
196 bool m_delayedFont
:1;
197 bool m_delayedForegroundColour
:1;
198 bool m_delayedBackgroundColour
:1;
199 bool m_delayedCursor
:1;
201 // the cursor is set in OnInternalIdle(). this fields holds
202 // a reference to the cursor currently set in theGdk window
203 // so that we don't have to set it more than once
204 wxCursor m_currentGdkCursor
;
206 // contains GTK's widgets internal information about non-default widget
207 // font and colours. we create one for each widget that gets any
208 // non-default attribute set via SetFont() or SetForegroundColour() /
209 // SetBackgroundColour().
210 GtkStyle
*m_widgetStyle
;
212 // C++ has no virtual methods in the constrcutor of any class but we need
213 // different methods of inserting a child window into a wxFrame,
214 // wxMDIFrame, wxNotebook etc. this is the callback that will get used.
215 wxInsertChildFunction m_insertCallback
;
217 // implement the base class pure virtuals
218 virtual void DoClientToScreen( int *x
, int *y
) const;
219 virtual void DoScreenToClient( int *x
, int *y
) const;
220 virtual void DoGetPosition( int *x
, int *y
) const;
221 virtual void DoGetSize( int *width
, int *height
) const;
222 virtual void DoGetClientSize( int *width
, int *height
) const;
223 virtual void DoSetSize(int x
, int y
,
224 int width
, int height
,
225 int sizeFlags
= wxSIZE_AUTO
);
226 virtual void DoSetClientSize(int width
, int height
);
229 virtual void DoSetToolTip( wxToolTip
*tip
);
230 #endif // wxUSE_TOOLTIPS
232 // common part of all ctors (can't be virtual because called from ctor)
236 DECLARE_NO_COPY_CLASS(wxWindow
);
239 #endif // __GTKWINDOWH__