/////////////////////////////////////////////////////////////////////////////
-// Name: frame.h
+// Name: wx/gtk/frame.h
// Purpose:
// Author: Robert Roebling
// Id: $Id$
#define __GTKFRAMEH__
#ifdef __GNUG__
-#pragma interface
+ #pragma interface "frame.h"
#endif
-#include "wx/defs.h"
-#include "wx/object.h"
-#include "wx/window.h"
-#include "wx/icon.h"
-
//-----------------------------------------------------------------------------
// classes
//-----------------------------------------------------------------------------
class wxToolBar;
class wxStatusBar;
-class wxFrame;
-
-//-----------------------------------------------------------------------------
-// global data
-//-----------------------------------------------------------------------------
-
-extern const wxChar *wxFrameNameStr;
-extern const wxChar *wxToolBarNameStr;
-
//-----------------------------------------------------------------------------
-// wxFrame
+// wxFrameGTK
//-----------------------------------------------------------------------------
-class wxFrame: public wxWindow
+class wxFrameGTK : public wxFrameBase
{
-DECLARE_DYNAMIC_CLASS(wxFrame)
-
public:
- wxFrame() { Init(); }
- wxFrame( wxWindow *parent, wxWindowID id, const wxString &title,
- const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
- long style = wxDEFAULT_FRAME_STYLE, const wxString &name = wxFrameNameStr );
- bool Create( wxWindow *parent, wxWindowID id, const wxString &title,
- const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize,
- long style = wxDEFAULT_FRAME_STYLE, const wxString &name = wxFrameNameStr );
- ~wxFrame();
- bool Destroy();
-
- virtual bool Show( bool show );
- virtual void Centre( int direction = wxHORIZONTAL );
+ // construction
+ wxFrameGTK() { Init(); }
+ wxFrameGTK(wxWindow *parent,
+ wxWindowID id,
+ const wxString& title,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxDEFAULT_FRAME_STYLE,
+ const wxString& name = wxFrameNameStr)
+ {
+ Init();
+
+ Create(parent, id, title, pos, size, style, name);
+ }
+
+ bool Create(wxWindow *parent,
+ wxWindowID id,
+ const wxString& title,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxDEFAULT_FRAME_STYLE,
+ const wxString& name = wxFrameNameStr);
+
+ virtual ~wxFrameGTK();
+
+ // implement base class pure virtuals
+ virtual void Maximize(bool maximize = TRUE);
+ virtual bool IsMaximized() const;
+ virtual void Iconize(bool iconize = TRUE);
+ virtual bool IsIconized() const;
+ virtual void SetIcon(const wxIcon& icon);
+ virtual void MakeModal(bool modal = TRUE);
+ virtual void Restore();
+
+ virtual bool ShowFullScreen(bool show, long style = wxFULLSCREEN_ALL);
+ virtual bool IsFullScreen() const { return m_fsIsShowing; };
#if wxUSE_STATUSBAR
- virtual wxStatusBar* CreateStatusBar(int number=1, long style = wxST_SIZEGRIP, wxWindowID id = 0,
- const wxString& name = _T("statusBar"));
- virtual wxStatusBar *OnCreateStatusBar( int number, long style, wxWindowID id,
- const wxString& name );
- virtual wxStatusBar *GetStatusBar() const;
- inline void SetStatusBar(wxStatusBar *statusBar) { m_frameStatusBar = statusBar; }
- virtual void SetStatusText( const wxString &text, int number = 0 );
- virtual void SetStatusWidths( int n, const int widths_field[] );
+ virtual void PositionStatusBar();
+
+ virtual wxStatusBar* CreateStatusBar(int number = 1,
+ long style = wxST_SIZEGRIP,
+ wxWindowID id = 0,
+ const wxString& name = wxStatusLineNameStr);
#endif // wxUSE_STATUSBAR
#if wxUSE_TOOLBAR
- virtual wxToolBar* CreateToolBar( long style = wxNO_BORDER|wxTB_HORIZONTAL, wxWindowID id = -1,
- const wxString& name = wxToolBarNameStr);
- virtual wxToolBar *OnCreateToolBar( long style, wxWindowID id, const wxString& name );
- virtual wxToolBar *GetToolBar() const;
- void SetToolBar(wxToolBar *toolbar) { m_frameToolBar = toolbar; }
+ virtual wxToolBar* CreateToolBar(long style = wxNO_BORDER | wxTB_HORIZONTAL | wxTB_FLAT,
+ wxWindowID id = -1,
+ const wxString& name = wxToolBarNameStr);
+ void SetToolBar(wxToolBar *toolbar);
#endif // wxUSE_TOOLBAR
- virtual void SetMenuBar( wxMenuBar *menuBar );
- virtual wxMenuBar *GetMenuBar() const;
+ virtual bool Show(bool show = TRUE);
virtual void SetTitle( const wxString &title );
virtual wxString GetTitle() const { return m_title; }
- // make the window modal (all other windows unresponsive)
- virtual void MakeModal(bool modal = TRUE);
-
- virtual void SetIcon( const wxIcon &icon );
- virtual void Iconize( bool WXUNUSED(iconize)) { }
- virtual bool IsIconized() const { return FALSE; }
- bool Iconized() const { return IsIconized(); }
- virtual void Maximize(bool WXUNUSED(maximize)) {}
- virtual void Restore() {}
-
- virtual void Command( int id );
-
- void OnCloseWindow( wxCloseEvent& event );
- void OnActivate( wxActivateEvent &WXUNUSED(event) ) { } // called from docview.cpp
- void OnSize( wxSizeEvent &event );
-
- void OnMenuHighlight( wxMenuEvent& event );
+ // implementation from now on
+ // --------------------------
- // implementation
+ // move the window to the specified location and resize it: this is called
+ // from both DoSetSize() and DoSetClientSize()
+ virtual void DoMoveWindow(int x, int y, int width, int height);
+ // GTK callbacks
virtual void GtkOnSize( int x, int y, int width, int height );
- void DoMenuUpdates();
- void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin);
virtual void OnInternalIdle();
- wxMenuBar *m_frameMenuBar;
-#if wxUSE_STATUSBAR
- wxStatusBar *m_frameStatusBar;
-#endif
-#if wxUSE_TOOLBAR
- wxToolBar *m_frameToolBar;
-#endif
+ // do *not* call this to iconize the frame, this is a private function!
+ void SetIconizeState(bool iconic);
+
wxString m_title;
- wxIcon m_icon;
- int m_miniEdge,m_miniTitle;
+ int m_miniEdge,
+ m_miniTitle;
GtkWidget *m_mainWidget;
bool m_menuBarDetached;
bool m_toolBarDetached;
bool m_insertInClientArea; /* not from within OnCreateXXX */
+ bool m_fsIsShowing; /* full screen */
+ long m_fsSaveStyle;
+ long m_fsSaveFlag;
+ wxRect m_fsSaveFrame;
+
protected:
// common part of all ctors
void Init();
-
+
+ // override wxWindow methods to take into account tool/menu/statusbars
virtual void DoSetSize(int x, int y,
int width, int height,
int sizeFlags = wxSIZE_AUTO);
virtual void DoSetClientSize(int width, int height);
virtual void DoGetClientSize( int *width, int *height ) const;
-private:
- DECLARE_EVENT_TABLE()
+#if wxUSE_MENUS_NATIVE
+ virtual void DetachMenuBar();
+ virtual void AttachMenuBar(wxMenuBar *menubar);
+#endif // wxUSE_MENUS_NATIVE
+
+ // is the frame currently iconized?
+ bool m_isIconized;
};
#endif // __GTKFRAMEH__