X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/341c92a8b4c813cbfb606687937dcdf5d8c3c2fe..dad5f99acb6b3400ff73562c03db2f3f21b658cd:/include/wx/generic/panelg.h diff --git a/include/wx/generic/panelg.h b/include/wx/generic/panelg.h index d3d45a7c65..a66dd5b7aa 100644 --- a/include/wx/generic/panelg.h +++ b/include/wx/generic/panelg.h @@ -1,31 +1,42 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: panelg.h -// Purpose: wxPanel: similar to wxWindows but is coloured as for a dialog +// Name: wx/generic/panelg.h +// Purpose: wxPanel: a container for child controls // Author: Julian Smart // Modified by: // Created: 01/02/97 // RCS-ID: $Id$ // Copyright: (c) -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifndef __PANELH_G__ -#define __PANELH_G__ +#ifndef _WX_GENERIC_PANEL_H_ +#define _WX_GENERIC_PANEL_H_ #ifdef __GNUG__ -#pragma interface "panelg.h" + #pragma interface "panelg.h" #endif +// ---------------------------------------------------------------------------- +// headers and forward declarations +// ---------------------------------------------------------------------------- + #include "wx/window.h" +#include "wx/containr.h" + +class WXDLLEXPORT wxButton; +class WXDLLEXPORT wxControlContainer; -WXDLLEXPORT_DATA(extern const char*) wxPanelNameStr; +WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; +// ---------------------------------------------------------------------------- +// wxPanel contains other controls and implements TAB traversal between them +// ---------------------------------------------------------------------------- class WXDLLEXPORT wxPanel : public wxWindow { public: - wxPanel(); - + wxPanel() { Init(); } + // Old-style constructor (no default values for coordinates to avoid // ambiguity with the new one) wxPanel(wxWindow *parent, @@ -33,9 +44,11 @@ public: long style = wxTAB_TRAVERSAL | wxNO_BORDER, const wxString& name = wxPanelNameStr) { + Init(); + Create(parent, -1, wxPoint(x, y), wxSize(width, height), style, name); } - + // Constructor wxPanel(wxWindow *parent, wxWindowID id = -1, @@ -44,6 +57,8 @@ public: long style = wxTAB_TRAVERSAL | wxNO_BORDER, const wxString& name = wxPanelNameStr) { + Init(); + Create(parent, id, pos, size, style, name); } @@ -53,27 +68,30 @@ public: const wxSize& size = wxDefaultSize, long style = wxTAB_TRAVERSAL | wxNO_BORDER, const wxString& name = wxPanelNameStr); - + + virtual ~wxPanel(); + + // implementation from now on + // -------------------------- + // Sends an OnInitDialog event, which in turns transfers data to // to the dialog via validators. virtual void InitDialog(); - // implementation // responds to colour changes void OnSysColourChanged(wxSysColourChangedEvent& event); - - // process a keyboard navigation message (Tab traversal) - void OnNavigationKey(wxNavigationKeyEvent& event); - - // set the focus to the first child if we get it - void OnFocus(wxFocusEvent& event); - // called by wxWindow whenever it gets focus - void SetLastFocus(wxWindow *focus) { m_lastFocus = focus; } + // calls layout for layout constraints and sizers + void OnSize(wxSizeEvent& event); + + WX_DECLARE_CONTROL_CONTAINER(); protected: - // the child which had the focus last time this panel was activated - wxWindow *m_lastFocus; + // common part of all ctors + void Init(); + + // the object which implements the TAB traversal logic + wxControlContainer *m_container; private: DECLARE_DYNAMIC_CLASS(wxPanel) @@ -81,4 +99,4 @@ private: }; #endif - // __PANELH_G__ + // _WX_GENERIC_PANEL_H_