]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/x11/window.h
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxWindow class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "window.h"
19 #include "wx/region.h"
21 // ----------------------------------------------------------------------------
22 // wxWindow class for Motif - see also wxWindowBase
23 // ----------------------------------------------------------------------------
25 class wxWindowX11
: public wxWindowBase
27 friend class WXDLLEXPORT wxDC
;
28 friend class WXDLLEXPORT wxWindowDC
;
31 wxWindowX11() { Init(); }
33 wxWindowX11(wxWindow
*parent
,
35 const wxPoint
& pos
= wxDefaultPosition
,
36 const wxSize
& size
= wxDefaultSize
,
38 const wxString
& name
= wxPanelNameStr
)
41 Create(parent
, id
, pos
, size
, style
, name
);
44 virtual ~wxWindowX11();
46 bool Create(wxWindow
*parent
,
48 const wxPoint
& pos
= wxDefaultPosition
,
49 const wxSize
& size
= wxDefaultSize
,
51 const wxString
& name
= wxPanelNameStr
);
56 virtual bool Show( bool show
= TRUE
);
57 virtual bool Enable( bool enable
= TRUE
);
59 virtual void SetFocus();
61 virtual void WarpPointer(int x
, int y
);
63 virtual void Refresh( bool eraseBackground
= TRUE
,
64 const wxRect
*rect
= (const wxRect
*) NULL
);
65 virtual void Update();
69 virtual bool SetBackgroundColour( const wxColour
&colour
);
70 virtual bool SetForegroundColour( const wxColour
&colour
);
72 virtual bool SetCursor( const wxCursor
&cursor
);
73 virtual bool SetFont( const wxFont
&font
);
75 virtual int GetCharHeight() const;
76 virtual int GetCharWidth() const;
77 virtual void GetTextExtent(const wxString
& string
,
79 int *descent
= (int *) NULL
,
80 int *externalLeading
= (int *) NULL
,
81 const wxFont
*theFont
= (const wxFont
*) NULL
)
84 virtual void ScrollWindow( int dx
, int dy
,
85 const wxRect
* rect
= (wxRect
*) NULL
);
87 virtual void SetSizeHints(int minW
, int minH
,
88 int maxW
= -1, int maxH
= -1,
89 int incW
= -1, int incH
= -1);
90 #if wxUSE_DRAG_AND_DROP
91 virtual void SetDropTarget( wxDropTarget
*dropTarget
);
92 #endif // wxUSE_DRAG_AND_DROP
94 // Accept files for dragging
95 virtual void DragAcceptFiles(bool accept
);
97 // Get the unique identifier of a window
98 virtual WXWindow
GetHandle() const { return GetMainWindow(); }
100 // implementation from now on
101 // --------------------------
106 // Get main widget for this window, e.g. a text widget
107 virtual WXWindow
GetMainWindow() const;
109 // Get the underlying X window and display
110 WXWindow
GetXWindow() const;
111 WXDisplay
*GetXDisplay() const;
113 void SetLastClick(int button
, long timestamp
)
114 { m_lastButton
= button
; m_lastTS
= timestamp
; }
116 int GetLastClickedButton() const { return m_lastButton
; }
117 long GetLastClickTime() const { return m_lastTS
; }
119 // Gives window a chance to do something in response to a size message, e.g.
120 // arrange status bar, toolbar etc.
121 virtual bool PreResize();
123 // Generates paint events from m_updateRegion
124 void SendPaintEvents();
126 // Generates erase events from m_clearRegion
127 void SendEraseEvents();
129 // Clip to paint region?
130 bool GetClipPaintRegion() { return m_clipPaintRegion
; }
132 // Return clear region
133 wxRegion
&GetClearRegion() { return m_clearRegion
; }
135 // sets the fore/background colour for the given widget
136 static void DoChangeForegroundColour(WXWindow widget
, wxColour
& foregroundColour
);
137 static void DoChangeBackgroundColour(WXWindow widget
, wxColour
& backgroundColour
, bool changeArmColour
= FALSE
);
139 // For implementation purposes - sometimes decorations make the client area
141 virtual wxPoint
GetClientAreaOrigin() const;
143 // I don't want users to override what's done in idle so everything that
144 // has to be done in idle time in order for wxX11 to work is done in
146 virtual void OnInternalIdle();
148 // For compatibility across platforms (not in event table)
149 void OnIdle(wxIdleEvent
& WXUNUSED(event
)) {}
151 // Go up to a toplevel window and query which window has the focus.
153 wxWindow
*GetFocusWidget();
156 // Makes an adjustment to the window position (for example, a frame that has
157 // a toolbar that it manages itself).
158 virtual void AdjustForParentClientOrigin(int& x
, int& y
, int sizeFlags
);
160 // Responds to colour changes: passes event on to children.
161 void OnSysColourChanged(wxSysColourChangedEvent
& event
);
163 // For double-click detection
164 long m_lastTS
; // last timestamp
165 int m_lastButton
; // last pressed button
168 WXWindow m_mainWidget
;
169 wxRegion m_clearRegion
;
170 bool m_clipPaintRegion
;
171 bool m_winCaptured
; // ????
172 bool m_needsInputFocus
; // Input focus set in OnIdle
174 // implement the base class pure virtuals
175 virtual void DoClientToScreen( int *x
, int *y
) const;
176 virtual void DoScreenToClient( int *x
, int *y
) const;
177 virtual void DoGetPosition( int *x
, int *y
) const;
178 virtual void DoGetSize( int *width
, int *height
) const;
179 virtual void DoGetClientSize( int *width
, int *height
) const;
180 virtual void DoSetSize(int x
, int y
,
181 int width
, int height
,
182 int sizeFlags
= wxSIZE_AUTO
);
183 virtual void DoSetClientSize(int width
, int height
);
184 virtual void DoMoveWindow(int x
, int y
, int width
, int height
);
185 virtual void DoCaptureMouse();
186 virtual void DoReleaseMouse();
189 virtual void DoSetToolTip( wxToolTip
*tip
);
190 #endif // wxUSE_TOOLTIPS
193 // common part of all ctors
196 DECLARE_DYNAMIC_CLASS(wxWindowX11
)
197 DECLARE_NO_COPY_CLASS(wxWindowX11
)
198 DECLARE_EVENT_TABLE()
201 // ----------------------------------------------------------------------------
202 // A little class to switch off `size optimization' while an instance of the
203 // object exists: this may be useful to temporarily disable the optimisation
204 // which consists to do nothing when the new size is equal to the old size -
205 // although quite useful usually to avoid flicker, sometimes it leads to
206 // undesired effects.
208 // Usage: create an instance of this class on the stack to disable the size
209 // optimisation, it will be reenabled as soon as the object goes out from scope.
210 // ----------------------------------------------------------------------------
212 class WXDLLEXPORT wxNoOptimize
215 wxNoOptimize() { ms_count
++; }
216 ~wxNoOptimize() { ms_count
--; }
218 static bool CanOptimize() { return ms_count
== 0; }