X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c801d85f158c4cba50b588807daabdcbd0ed3853..d427503c3696486ef84cd0e5081884ccd8d6b434:/include/wx/generic/panelg.h?ds=sidebyside diff --git a/include/wx/generic/panelg.h b/include/wx/generic/panelg.h index 89b117992c..a4c8029462 100644 --- a/include/wx/generic/panelg.h +++ b/include/wx/generic/panelg.h @@ -18,51 +18,67 @@ #include "wx/window.h" -WXDLLEXPORT_DATA(extern const char*) wxPanelNameStr; +WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; -// Dialog boxes -class WXDLLEXPORT wxPanel: public wxWindow + +class WXDLLEXPORT wxPanel : public wxWindow { - DECLARE_DYNAMIC_CLASS(wxPanel) public: + wxPanel(); + + // Old-style constructor (no default values for coordinates to avoid + // ambiguity with the new one) + wxPanel(wxWindow *parent, + int x, int y, int width, int height, + long style = wxTAB_TRAVERSAL | wxNO_BORDER, + const wxString& name = wxPanelNameStr) + { + Create(parent, -1, wxPoint(x, y), wxSize(width, height), style, name); + } + + // Constructor + wxPanel(wxWindow *parent, + wxWindowID id = -1, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = wxTAB_TRAVERSAL | wxNO_BORDER, + const wxString& name = wxPanelNameStr) + { + Create(parent, id, pos, size, style, name); + } - wxPanel(void); - - // Old-style constructor - inline wxPanel(wxWindow *parent, - const int x = -1, const int y= -1, const int width = 500, const int height = 500, - const long style = wxTAB_TRAVERSAL | wxNO_BORDER, - const wxString& name = wxPanelNameStr) - { - Create(parent, -1, wxPoint(x, y), wxSize(width, height), style, name); - } - - // Constructor - inline wxPanel(wxWindow *parent, const wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - const long style = wxTAB_TRAVERSAL | wxNO_BORDER, - const wxString& name = wxPanelNameStr) - { - Create(parent, id, pos, size, style, name); - } - - bool Create(wxWindow *parent, const wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - const long style = wxTAB_TRAVERSAL | wxNO_BORDER, - const wxString& name = wxPanelNameStr); + // Pseudo ctor + bool Create(wxWindow *parent, wxWindowID id, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = wxTAB_TRAVERSAL | wxNO_BORDER, + const wxString& name = wxPanelNameStr); + + // Sends an OnInitDialog event, which in turns transfers data to + // to the dialog via validators. + virtual void InitDialog(); - void OnPaint(wxPaintEvent& event); + // 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); - // Sends an OnInitDialog event, which in turns transfers data to - // to the dialog via validators. - virtual void InitDialog(void); + // called by wxWindow whenever it gets focus + void SetLastFocus(long focus) { m_lastFocus = focus; } + long GetLastFocus() const { return m_lastFocus; } - // Responds to colour changes - void OnSysColourChanged(wxSysColourChangedEvent& event); +protected: + // the child which had the focus last time this panel was activated + long m_lastFocus; -DECLARE_EVENT_TABLE() +private: + DECLARE_DYNAMIC_CLASS(wxPanel) + DECLARE_EVENT_TABLE() }; #endif