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__ 
  14 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) 
  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
); 
  69     virtual void Refresh( bool eraseBackground 
= TRUE
, 
  70                           const wxRect 
*rect 
= (const wxRect 
*) NULL 
); 
  71     virtual void Update(); 
  72     virtual void ClearBackground(); 
  74     virtual bool SetBackgroundColour( const wxColour 
&colour 
); 
  75     virtual bool SetForegroundColour( const wxColour 
&colour 
); 
  76     virtual bool SetCursor( const wxCursor 
&cursor 
); 
  77     virtual bool SetFont( const wxFont 
&font 
); 
  79     virtual int GetCharHeight() const; 
  80     virtual int GetCharWidth() const; 
  81     virtual void GetTextExtent(const wxString
& string
, 
  83                                int *descent 
= (int *) NULL
, 
  84                                int *externalLeading 
= (int *) NULL
, 
  85                                const wxFont 
*theFont 
= (const wxFont 
*) NULL
) 
  88 #if wxUSE_MENUS_NATIVE 
  89     virtual bool DoPopupMenu( wxMenu 
*menu
, int x
, int y 
); 
  90 #endif // wxUSE_MENUS_NATIVE 
  92     virtual void SetScrollbar( int orient
, int pos
, int thumbVisible
, 
  93                                int range
, bool refresh 
= TRUE 
); 
  94     virtual void SetScrollPos( int orient
, int pos
, bool refresh 
= TRUE 
); 
  95     virtual int GetScrollPos( int orient 
) const; 
  96     virtual int GetScrollThumb( int orient 
) const; 
  97     virtual int GetScrollRange( int orient 
) const; 
  98     virtual void ScrollWindow( int dx
, int dy
, 
  99                                const wxRect
* rect 
= (wxRect 
*) NULL 
); 
 101 #if wxUSE_DRAG_AND_DROP 
 102     virtual void SetDropTarget( wxDropTarget 
*dropTarget 
); 
 103 #endif // wxUSE_DRAG_AND_DROP 
 108     virtual WXWidget 
GetHandle() const { return m_widget
; } 
 110     // I don't want users to override what's done in idle so everything that 
 111     // has to be done in idle time in order for wxGTK to work is done in 
 113     virtual void OnInternalIdle(); 
 115     // Internal represention of Update() 
 118     // For delayed background  
 119     void GtkSetBackgroundColour( const wxColour 
&colour 
); 
 120     void GtkSetForegroundColour( const wxColour 
&colour 
); 
 122     // For compatibility across platforms (not in event table) 
 123     void OnIdle(wxIdleEvent
& WXUNUSED(event
)) {} 
 125     // wxGTK-specific: called recursively by Enable, 
 126     // to give widgets an oppprtunity to correct their colours after they 
 127     // have been changed by Enable 
 128     virtual void OnParentEnable( bool WXUNUSED(enable
) ) {} 
 130     // Used by all window classes in the widget creation process. 
 131     bool PreCreation( wxWindowGTK 
*parent
, const wxPoint 
&pos
, const wxSize 
&size 
); 
 134     // Internal addition of child windows. differs from class 
 135     // to class not by using virtual functions but by using 
 136     // the m_insertCallback. 
 137     void DoAddChild(wxWindowGTK 
*child
); 
 139     // This methods sends wxPaintEvents to the window. It reads the 
 140     // update region, breaks it up into rects and sends an event 
 141     // for each rect. It is also responsible for background erase 
 142     // events and NC paint events. It is called from "draw" and 
 143     // "expose" handlers as well as from ::Update() 
 144     void GtkSendPaintEvents(); 
 146     // The methods below are required because many native widgets 
 147     // are composed of several subwidgets and setting a style for 
 148     // the widget means setting it for all subwidgets as well. 
 149     // also, it is nor clear, which native widget is the top 
 150     // widget where (most of) the input goes. even tooltips have 
 151     // to be applied to all subwidgets. 
 152     virtual GtkWidget
* GetConnectWidget(); 
 153     virtual bool IsOwnGtkWindow( GdkWindow 
*window 
); 
 154     void ConnectWidget( GtkWidget 
*widget 
); 
 156     // Creates a new widget style if none is there 
 157     // and sets m_widgetStyle to this value. 
 158     GtkStyle 
*GetWidgetStyle(); 
 161     // Returns the default context which usually is anti-aliased 
 162     PangoContext   
*GtkGetPangoDefaultContext(); 
 164     // Returns the X11 context which renders on the X11 client 
 165     // side (which can be remote) and which usually is not 
 166     // anti-aliased and is thus faster 
 167     PangoContext   
*GtkGetPangoX11Context(); 
 168     PangoContext   
*m_x11Context
; 
 171     // Called by SetFont() and SetXXXColour etc 
 172     void SetWidgetStyle(); 
 174     // Overridden in many GTK widgets who have to handle subwidgets 
 175     virtual void ApplyWidgetStyle(); 
 178     virtual void ApplyToolTip( GtkTooltips 
*tips
, const wxChar 
*tip 
); 
 179 #endif // wxUSE_TOOLTIPS 
 181     // Called from GTK signales handlers. it indicates that 
 182     // the layouting functions have to be called later on 
 183     // (i.e. in idle time, implemented in OnInternalIdle() ). 
 184     void GtkUpdateSize() { m_sizeSet 
= FALSE
; } 
 186     // fix up the mouse event coords, used by wxListBox only so far 
 187     virtual void FixUpMouseEvent(GtkWidget 
* WXUNUSED(widget
), 
 188                                  wxCoord
& WXUNUSED(x
), 
 189                                  wxCoord
& WXUNUSED(y
)) { } 
 191     // is this window transparent for the mouse events (as wxStaticBox is)? 
 192     virtual bool IsTransparentForMouse() const { return FALSE
; } 
 194     // is this a radiobutton (used by radiobutton code itself only)? 
 195     virtual bool IsRadioButton() const { return FALSE
; } 
 197     // position and size of the window 
 199     int                  m_width
, m_height
; 
 200     int                  m_oldClientWidth
,m_oldClientHeight
; 
 202     // see the docs in src/gtk/window.cpp 
 203     GtkWidget           
*m_widget
;          // mostly the widget seen by the rest of GTK 
 204     GtkWidget           
*m_wxwindow
;        // mostly the client area as per wxWindows 
 206     // this widget will be queried for GTK's focus events 
 207     GtkWidget           
*m_focusWidget
; 
 210     GtkIMMulticontext   
*m_imContext
; 
 213     // XIM support for wxWindows 
 220     // The area to be cleared (and not just refreshed) 
 221     // We cannot make this distinction under GTK 2.0. 
 222     wxRegion             m_clearRegion
; 
 226     GtkAdjustment       
*m_hAdjust
,*m_vAdjust
; 
 227     float                m_oldHorizontalPos
; 
 228     float                m_oldVerticalPos
; 
 230     // extra (wxGTK-specific) flags 
 231     bool                 m_needParent
:1;        // ! wxFrame, wxDialog, wxNotebookPage ? 
 232     bool                 m_noExpose
:1;          // wxGLCanvas has its own redrawing 
 233     bool                 m_nativeSizeEvent
:1;   // wxGLCanvas sends wxSizeEvent upon "alloc_size" 
 234     bool                 m_hasScrolling
:1; 
 238     bool                 m_acceptsFocus
:1;      // true if not static 
 239     bool                 m_hasFocus
:1;          // true if == FindFocus() 
 240     bool                 m_isScrolling
:1;       // dragging scrollbar thumb? 
 241     bool                 m_clipPaintRegion
:1;   // TRUE after ScrollWindow() 
 242     bool                 m_queuedFullRedraw
:1;  // TRUE after DoMoveWindow 
 244     // These are true if the style were set before the widget was realized 
 245     // (typcally in the constructor) but the actual GTK style must not be set 
 246     // before the widget has been "realized" 
 247     bool                 m_delayedForegroundColour
:1; 
 248     bool                 m_delayedBackgroundColour
:1; 
 250     // Contains GTK's widgets internal information about non-default widget 
 251     // font and colours. we create one for each widget that gets any 
 252     // non-default attribute set via SetFont() or SetForegroundColour() / 
 253     // SetBackgroundColour(). 
 254     GtkStyle            
*m_widgetStyle
; 
 256     // C++ has no virtual methods in the constrcutor of any class but we need 
 257     // different methods of inserting a child window into a wxFrame, 
 258     // wxMDIFrame, wxNotebook etc. this is the callback that will get used. 
 259     wxInsertChildFunction  m_insertCallback
; 
 261     // implement the base class pure virtuals 
 262     virtual void DoClientToScreen( int *x
, int *y 
) const; 
 263     virtual void DoScreenToClient( int *x
, int *y 
) const; 
 264     virtual void DoGetPosition( int *x
, int *y 
) const; 
 265     virtual void DoGetSize( int *width
, int *height 
) const; 
 266     virtual void DoGetClientSize( int *width
, int *height 
) const; 
 267     virtual void DoSetSize(int x
, int y
, 
 268                            int width
, int height
, 
 269                            int sizeFlags 
= wxSIZE_AUTO
); 
 270     virtual void DoSetClientSize(int width
, int height
); 
 271     virtual void DoMoveWindow(int x
, int y
, int width
, int height
); 
 273     virtual void DoCaptureMouse(); 
 274     virtual void DoReleaseMouse(); 
 277     virtual void DoSetToolTip( wxToolTip 
*tip 
); 
 278 #endif // wxUSE_TOOLTIPS 
 281     // common part of all ctors (not virtual because called from ctor) 
 285     DECLARE_DYNAMIC_CLASS(wxWindowGTK
) 
 286     DECLARE_NO_COPY_CLASS(wxWindowGTK
) 
 289 extern wxWindow 
*wxFindFocusedChild(wxWindowGTK 
*win
); 
 291 #endif // __GTKWINDOWH__