X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/456bc6d9b83882a3b0e919fc733898d9d331ecd6..3d4e20dd0baa3399b72b66a12ddcb0f898c43989:/include/wx/generic/panelg.h diff --git a/include/wx/generic/panelg.h b/include/wx/generic/panelg.h index a66dd5b7aa..4aa4c8c988 100644 --- a/include/wx/generic/panelg.h +++ b/include/wx/generic/panelg.h @@ -5,17 +5,13 @@ // Modified by: // Created: 01/02/97 // RCS-ID: $Id$ -// Copyright: (c) +// Copyright: (c) Julian Smart // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_GENERIC_PANEL_H_ #define _WX_GENERIC_PANEL_H_ -#ifdef __GNUG__ - #pragma interface "panelg.h" -#endif - // ---------------------------------------------------------------------------- // headers and forward declarations // ---------------------------------------------------------------------------- @@ -23,16 +19,15 @@ #include "wx/window.h" #include "wx/containr.h" -class WXDLLEXPORT wxButton; -class WXDLLEXPORT wxControlContainer; +class WXDLLIMPEXP_FWD_CORE wxControlContainer; -WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; +extern WXDLLIMPEXP_DATA_CORE(const char) wxPanelNameStr[]; // ---------------------------------------------------------------------------- // wxPanel contains other controls and implements TAB traversal between them // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxPanel : public wxWindow +class WXDLLIMPEXP_CORE wxPanel : public wxWindow { public: wxPanel() { Init(); } @@ -46,12 +41,12 @@ public: { Init(); - Create(parent, -1, wxPoint(x, y), wxSize(width, height), style, name); + Create(parent, wxID_ANY, wxPoint(x, y), wxSize(width, height), style, name); } // Constructor wxPanel(wxWindow *parent, - wxWindowID id = -1, + wxWindowID winid = wxID_ANY, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxTAB_TRAVERSAL | wxNO_BORDER, @@ -59,11 +54,12 @@ public: { Init(); - Create(parent, id, pos, size, style, name); + Create(parent, winid, pos, size, style, name); } // Pseudo ctor - bool Create(wxWindow *parent, wxWindowID id, + bool Create(wxWindow *parent, + wxWindowID winid = wxID_ANY, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxTAB_TRAVERSAL | wxNO_BORDER, @@ -74,15 +70,25 @@ public: // implementation from now on // -------------------------- - // Sends an OnInitDialog event, which in turns transfers data to - // to the dialog via validators. virtual void InitDialog(); - // responds to colour changes - void OnSysColourChanged(wxSysColourChangedEvent& event); +#ifdef __WXUNIVERSAL__ + virtual bool IsCanvasWindow() const { return true; } +#endif - // calls layout for layout constraints and sizers - void OnSize(wxSizeEvent& event); +#ifdef __WXMSW__ + // This is a hack to support inheriting of background through child + // wxPanel: at least wxNotebook needs this under wxMSW as its background + // should apply to its children which are usually wxPanels which normally + // don't have a transparent background. Calling this function allows to + // change this for the panels which are used as notebook pages. + void MSWSetTransparentBackground(bool isTransparent = true) + { + m_isTransparent = isTransparent; + } + + virtual bool HasTransparentBackground() { return m_isTransparent; } +#endif // __WXMSW__ WX_DECLARE_CONTROL_CONTAINER(); @@ -90,11 +96,15 @@ protected: // common part of all ctors void Init(); - // the object which implements the TAB traversal logic - wxControlContainer *m_container; + // choose the default border for this window + virtual wxBorder GetDefaultBorder() const { return wxWindowBase::GetDefaultBorder(); } private: - DECLARE_DYNAMIC_CLASS(wxPanel) +#ifdef __WXMSW__ + bool m_isTransparent; +#endif // __WXMSW__ + + DECLARE_DYNAMIC_CLASS_NO_COPY(wxPanel) DECLARE_EVENT_TABLE() };