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 PopupMenu( 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 classes in the widget creation process */
124 void PreCreation( wxWindow
*parent
, wxWindowID id
, const wxPoint
&pos
,
125 const wxSize
&size
, long style
, const wxString
&name
);
128 void InsertChild(wxWindow
*child
) { (*m_insertCallback
)(this, child
); }
129 void DoAddChild(wxWindow
*child
) { AddChild(child
); InsertChild(child
); }
131 /* the methods below are required because many native widgets
132 are composed of several subwidgets and setting a style for
133 the widget means setting it for all subwidgets as well.
134 also, it is nor clear, which native widget is the top
135 widget where (most of) the input goes. even tooltips have
136 to be applied to all subwidgets. */
138 virtual GtkWidget
* GetConnectWidget();
139 virtual bool IsOwnGtkWindow( GdkWindow
*window
);
140 void ConnectWidget( GtkWidget
*widget
);
142 // creates a new widget style if none is there
143 // and sets m_widgetStyle to this value.
144 GtkStyle
*GetWidgetStyle();
146 // called by SetFont() and SetXXXColour etc
147 void SetWidgetStyle();
149 // overridden in many GTK widgets
150 virtual void ApplyWidgetStyle();
153 virtual void ApplyToolTip( GtkTooltips
*tips
, const wxChar
*tip
);
154 #endif // wxUSE_TOOLTIPS
156 // called from GTK signales handlers. it indicates that
157 // the layouting functions have to be called later on
158 // (i.e. in idle time, implemented in OnInternalIdle() ).
159 void UpdateSize() { m_sizeSet
= FALSE
; }
161 // position and size of the window
163 int m_width
, m_height
;
165 // see the docs in src/gtk/window.cpp
167 GtkWidget
*m_wxwindow
;
170 GtkAdjustment
*m_hAdjust
,*m_vAdjust
;
171 float m_oldHorizontalPos
;
172 float m_oldVerticalPos
;
174 // we need an extra XGC flag set to get exposed
175 // events from overlapping children upon moving
176 // them. this flag will be set in this GC and
177 // the GC will be used in wxWindow::ScrollWindow().
180 // extra (wxGTK-specific) flags
181 bool m_needParent
:1; /* ! wxFrame, wxDialog, wxNotebookPage ? */
182 bool m_hasScrolling
:1;
183 bool m_isScrolling
:1;
187 bool m_isStaticBox
:1; /* faster than IS_KIND_OF */
188 bool m_isFrame
:1; /* faster than IS_KIND_OF */
189 bool m_acceptsFocus
:1; /* ! wxStaticBox etc. */
191 // these are true if the style were set before the widget was realized
192 // (typcally in the constructor) but the actual GTK style must not be set
193 // before the widget has been "realized"
194 bool m_delayedFont
:1;
195 bool m_delayedForegroundColour
:1;
196 bool m_delayedBackgroundColour
:1;
197 bool m_delayedCursor
:1;
199 // the cursor is set in OnInternalIdle(). this fields holds
200 // a reference to the cursor currently set in theGdk window
201 // so that we don't have to set it more than once
202 wxCursor m_currentGdkCursor
;
204 // contains GTK's widgets internal information about non-default widget
205 // font and colours. we create one for each widget that gets any
206 // non-default attribute set via SetFont() or SetForegroundColour() /
207 // SetBackgroundColour().
208 GtkStyle
*m_widgetStyle
;
210 // C++ has no virtual methods in the constrcutor of any class but we need
211 // different methods of inserting a child window into a wxFrame,
212 // wxMDIFrame, wxNotebook etc. this is the callback that will get used.
213 wxInsertChildFunction m_insertCallback
;
215 // implement the base class pure virtuals
216 virtual void DoClientToScreen( int *x
, int *y
) const;
217 virtual void DoScreenToClient( int *x
, int *y
) const;
218 virtual void DoGetPosition( int *x
, int *y
) const;
219 virtual void DoGetSize( int *width
, int *height
) const;
220 virtual void DoGetClientSize( int *width
, int *height
) const;
221 virtual void DoSetSize(int x
, int y
,
222 int width
, int height
,
223 int sizeFlags
= wxSIZE_AUTO
);
224 virtual void DoSetClientSize(int width
, int height
);
227 virtual void DoSetToolTip( wxToolTip
*tip
);
228 #endif // wxUSE_TOOLTIPS
230 // common part of all ctors (can't be virtual because called from ctor)
234 DECLARE_NO_COPY_CLASS(wxWindow
);
237 #endif // __GTKWINDOWH__