class WXDLLIMPEXP_CORE wxTopLevelWindowGTK : public wxTopLevelWindowBase
{
+ typedef wxTopLevelWindowBase base_type;
public:
// construction
wxTopLevelWindowGTK() { Init(); }
virtual bool IsMaximized() const;
virtual void Iconize(bool iconize = true);
virtual bool IsIconized() const;
- virtual void SetIcon(const wxIcon& icon);
virtual void SetIcons(const wxIconBundle& icons);
virtual void Restore();
virtual bool EnableCloseButton(bool enable = true);
+ virtual void ShowWithoutActivating();
virtual bool ShowFullScreen(bool show, long style = wxFULLSCREEN_ALL);
virtual bool IsFullScreen() const { return m_fsIsShowing; };
virtual void RemoveGrab();
virtual bool IsGrabbed() const { return m_grabbed; }
+
+ virtual void Refresh( bool eraseBackground = true,
+ const wxRect *rect = (const wxRect *) NULL );
+
// implementation from now on
// --------------------------
// GTK callbacks
- virtual void GtkOnSize();
virtual void OnInternalIdle();
// do *not* call this to iconize the frame, this is a private function!
void SetIconizeState(bool iconic);
- int m_miniEdge,
- m_miniTitle;
GtkWidget *m_mainWidget;
- bool m_insertInClientArea; /* not from within OnCreateXXX */
bool m_fsIsShowing; /* full screen */
- long m_fsSaveGdkFunc, m_fsSaveGdkDecor;
- long m_fsSaveFlag;
+ int m_fsSaveGdkFunc, m_fsSaveGdkDecor;
wxRect m_fsSaveFrame;
// m_windowStyle translated to GDK's terms
- long m_gdkFunc,
+ int m_gdkFunc,
m_gdkDecor;
+ // size of WM decorations
+ wxSize m_decorSize;
+
+ // shape of the frame
+ wxRegion m_shape;
+
// private gtk_timeout_add result for mimicing wxUSER_ATTENTION_INFO and
// wxUSER_ATTENTION_ERROR difference, -2 for no hint, -1 for ERROR hint, rest for GtkTimeout handle.
int m_urgency_hint;
- // give hints to the Window Manager for how the size
- // of the TLW can be changed by dragging
- virtual void DoSetSizeHints( int minW, int minH,
- int maxW = wxDefaultCoord, int maxH = wxDefaultCoord,
- int incW = wxDefaultCoord, int incH = wxDefaultCoord );
-
- // return the full size of the window without WM decorations
+ // return the size of the window without WM decorations
void GTKDoGetSize(int *width, int *height) const;
+ void GTKUpdateDecorSize(const wxSize& decorSize);
+
protected:
+ // give hints to the Window Manager for how the size
+ // of the TLW can be changed by dragging
+ virtual void DoSetSizeHints( int minW, int minH,
+ int maxW, int maxH,
+ int incW, int incH);
// common part of all ctors
void Init();
- // move the window to the specified location and resize it: this is called
- // from both DoSetSize() and DoSetClientSize()
+ // move the window to the specified location and resize it
virtual void DoMoveWindow(int x, int y, int width, int height);
// take into account WM decorations here
- virtual void DoGetSize(int *width, int *height) const;
virtual void DoSetSize(int x, int y,
int width, int height,
int sizeFlags = wxSIZE_AUTO);
- // override these methods to take into account tool/menu/statusbars
virtual void DoSetClientSize(int width, int height);
virtual void DoGetClientSize(int *width, int *height) const;
- // this method takes the size of the window not taking account of
- // decorations and is used by both DoSetSize() and DoSetClientSize()
- void GTKDoSetSize(int width, int height);
-
-
// string shown in the title bar
wxString m_title;
+ bool m_deferShow;
+
+private:
+ wxSize& GetCachedDecorSize();
+
// is the frame currently iconized?
bool m_isIconized;
// is the frame currently grabbed explicitly by the application?
bool m_grabbed;
+
+ bool m_updateDecorSize;
+ bool m_deferShowAllowed;
};
#endif // _WX_GTK_TOPLEVEL_H_