]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/panel.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxPanel 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows license 
   7 ///////////////////////////////////////////////////////////////////////////// 
  12     A panel is a window on which controls are placed. It is usually placed within 
  13     a frame. Its main feature over its parent class wxWindow is code for handling 
  14     child windows and TAB traversal. Since wxWidgets 2.9, there is support both 
  15     for TAB traversal implemented by wxWidgets itself as well as native TAB 
  16     traversal (such as for GTK 2.0). 
  18     @note Tab traversal is implemented through an otherwise undocumented 
  19           intermediate wxControlContainer class from which any class can derive 
  20           in addition to the normal wxWindow base class. Please see @c wx/containr.h 
  21           and @c wx/panel.h to find out how this is achieved. 
  23     @note if not all characters are being intercepted by your OnKeyDown or 
  24           OnChar handler, it may be because you are using the @c wxTAB_TRAVERSAL style, 
  25           which grabs some keypresses for use by child controls. 
  27     @remarks By default, a panel has the same colouring as a dialog. 
  29     @beginEventEmissionTable{wxNavigationKeyEvent} 
  30     @event{EVT_NAVIGATION_KEY(func)} 
  31         Process a navigation key event. 
  39 class wxPanel 
: public wxWindow
 
  54             An identifier for the panel. @c wxID_ANY is taken to mean a default. 
  56             The panel position. The value ::wxDefaultPosition indicates a default position, 
  57             chosen by either the windowing system or wxWidgets, depending on platform. 
  59             The panel size. The value ::wxDefaultSize indicates a default size, chosen by 
  60             either the windowing system or wxWidgets, depending on platform. 
  62             The window style. See wxPanel. 
  68     wxPanel(wxWindow
* parent
, wxWindowID id 
= wxID_ANY
, 
  69             const wxPoint
& pos 
= wxDefaultPosition
, 
  70             const wxSize
& size 
= wxDefaultSize
, 
  71             long style 
= wxTAB_TRAVERSAL
, 
  72             const wxString
& name 
= wxPanelNameStr
); 
  75         Destructor. Deletes any child windows before deleting the physical window. 
  80         This method is overridden from wxWindow::AcceptsFocus() 
  81         and returns @true only if there is no child window in the panel which 
  82         can accept the focus. This is reevaluated each time a child 
  83         window is added or removed from the panel. 
  85     bool AcceptsFocus() const; 
  88         Used for two-step panel construction. See wxPanel() for details. 
  90     bool Create(wxWindow
* parent
, wxWindowID id 
= wxID_ANY
, 
  91                 const wxPoint
& pos 
= wxDefaultPosition
, 
  92                 const wxSize
& size 
= wxDefaultSize
, 
  93                 long style 
= wxTAB_TRAVERSAL
, 
  94                 const wxString
& name 
= wxPanelNameStr
); 
  97         Sends a wxInitDialogEvent, which in turn transfers data to the dialog via 
 100         @see wxInitDialogEvent 
 102     virtual void InitDialog(); 
 105         See wxWindow::SetAutoLayout(): when auto layout is on, this function gets 
 106         called automatically when the window is resized. 
 108     virtual bool Layout(); 
 111         The default handler for wxEVT_SYS_COLOUR_CHANGED. 
 114             The colour change event. 
 116         @remarks Changes the panel's colour to conform to the current settings 
 117                  (Windows only). Add an event table entry for your panel 
 118                  class if you wish the behaviour to be different (such 
 119                  as keeping a user-defined background colour). If you do 
 120                  override this function, call wxEvent::Skip() to propagate 
 121                  the notification to child windows and controls. 
 123         @see wxSysColourChangedEvent 
 125     void OnSysColourChanged(wxSysColourChangedEvent
& event
); 
 128         Overrides wxWindow::SetFocus(). 
 130         This method uses the (undocumented) mix-in class wxControlContainer which manages 
 131         the focus and TAB logic for controls which usually have child controls. 
 133         In practice, if you call this method and the control has at least 
 134         one child window, the focus will be given to the child window. 
 136         @see wxFocusEvent, wxWindow::SetFocus() 
 138     virtual void SetFocus(); 
 141         In contrast to SetFocus() (see above) this will set the focus to the panel 
 142         even if there are child windows in the panel. This is only rarely needed. 
 144     void SetFocusIgnoringChildren();