2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: collpane.h
|
2008-04-10 02:57:09 +00:00
|
|
|
// Purpose: interface of wxCollapsiblePane
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-09-03 01:39:02 +00:00
|
|
|
#define wxCP_DEFAULT_STYLE (wxTAB_TRAVERSAL | wxNO_BORDER)
|
|
|
|
#define wxCP_NO_TLW_RESIZE (0x0002)
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxCollapsiblePaneEvent
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 02:57:09 +00:00
|
|
|
This event class is used for the events generated by wxCollapsiblePane.
|
|
|
|
|
|
|
|
@beginEventTable{wxCollapsiblePaneEvent}
|
|
|
|
@event{EVT_COLLAPSIBLEPANE_CHANGED(id, func)}
|
|
|
|
The user expanded or collapsed the collapsible pane.
|
|
|
|
@endEventTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
2008-04-10 02:57:09 +00:00
|
|
|
@category{events}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxCollapsiblePane
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxCollapsiblePaneEvent : public wxCommandEvent
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
The constructor is not normally used by the user code.
|
|
|
|
*/
|
2008-04-10 02:57:09 +00:00
|
|
|
wxCollapsiblePaneEvent(wxObject* generator, int id, bool collapsed);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the pane has been collapsed.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool GetCollapsed() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-09 12:33:59 +00:00
|
|
|
Sets this as a collapsed pane event (if @a collapsed is @true) or as an
|
2008-04-10 02:57:09 +00:00
|
|
|
expanded pane event (if @a collapsed is @false).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void SetCollapsed(bool collapsed);
|
|
|
|
};
|
|
|
|
|
2011-09-03 01:39:02 +00:00
|
|
|
wxEventType wxEVT_COMMAND_COLLPANE_CHANGED;
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxCollapsiblePane
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 02:57:09 +00:00
|
|
|
A collapsible pane is a container with an embedded button-like control
|
|
|
|
which can be used by the user to collapse or expand the pane's contents.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 02:57:09 +00:00
|
|
|
Once constructed you should use the GetPane() function to access the pane
|
|
|
|
and add your controls inside it (i.e. use the returned pointer from
|
|
|
|
GetPane() as parent for the controls which must go in the pane, @b not the
|
|
|
|
wxCollapsiblePane itself!).
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Note that because of its nature of control which can dynamically (and
|
2008-04-10 02:57:09 +00:00
|
|
|
drastically) change its size at run-time under user-input, when putting
|
|
|
|
wxCollapsiblePane inside a wxSizer you should be careful to add it with a
|
|
|
|
proportion value of zero; this is because otherwise all other windows with
|
|
|
|
non-null proportion values will automatically resize each time the user
|
|
|
|
expands or collapse the pane window usually resulting in a weird,
|
|
|
|
flickering effect.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Usage sample:
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
2009-01-18 21:46:46 +00:00
|
|
|
wxCollapsiblePane *collpane = new wxCollapsiblePane(this, wxID_ANY, "Details:");
|
2008-04-10 02:57:09 +00:00
|
|
|
|
|
|
|
// add the pane with a zero proportion value to the 'sz' sizer which contains it
|
|
|
|
sz->Add(collpane, 0, wxGROW|wxALL, 5);
|
|
|
|
|
|
|
|
// now add a test label in the collapsible pane using a sizer to layout it:
|
|
|
|
wxWindow *win = collpane->GetPane();
|
|
|
|
wxSizer *paneSz = new wxBoxSizer(wxVERTICAL);
|
2009-01-18 21:46:46 +00:00
|
|
|
paneSz->Add(new wxStaticText(win, wxID_ANY, "test!"), 1, wxGROW|wxALL, 2);
|
2008-04-10 02:57:09 +00:00
|
|
|
win->SetSizer(paneSz);
|
|
|
|
paneSz->SetSizeHints(win);
|
2008-03-08 13:52:38 +00:00
|
|
|
@endcode
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
It is only available if @c wxUSE_COLLPANE is set to 1 (the default).
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@beginStyleTable
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxCP_DEFAULT_STYLE}
|
2008-08-29 17:35:30 +00:00
|
|
|
The default style. It includes wxTAB_TRAVERSAL and wxBORDER_NONE.
|
|
|
|
@style{wxCP_NO_TLW_RESIZE}
|
|
|
|
By default wxCollapsiblePane resizes the top level window containing it
|
|
|
|
when its own size changes. This allows to easily implement dialogs
|
|
|
|
containing an optionally shown part, for example, and so is the default
|
|
|
|
behaviour but can be inconvenient in some specific cases -- use this
|
|
|
|
flag to disable this automatic parent resizing then.
|
2008-03-08 13:52:38 +00:00
|
|
|
@endStyleTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2009-02-18 17:58:51 +00:00
|
|
|
@beginEventEmissionTable{wxCollapsiblePaneEvent,wxNavigationKeyEvent}
|
2008-04-10 02:57:09 +00:00
|
|
|
@event{EVT_COLLAPSIBLEPANE_CHANGED(id, func)}
|
2009-02-18 17:58:51 +00:00
|
|
|
The user expanded or collapsed the collapsible pane.
|
|
|
|
@event{EVT_NAVIGATION_KEY(func)}
|
|
|
|
Process a navigation key event.
|
2008-04-10 02:57:09 +00:00
|
|
|
@endEventTable
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{ctrl}
|
2012-11-03 18:32:50 +00:00
|
|
|
@appearance{collapsiblepane}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxPanel, wxCollapsiblePaneEvent
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxCollapsiblePane : public wxControl
|
|
|
|
{
|
|
|
|
public:
|
2008-04-15 08:49:08 +00:00
|
|
|
/**
|
|
|
|
Default constructor.
|
|
|
|
*/
|
|
|
|
wxCollapsiblePane();
|
2008-09-21 23:48:04 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
2008-04-10 02:57:09 +00:00
|
|
|
Initializes the object and calls Create() with all the parameters.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxCollapsiblePane(wxWindow* parent, wxWindowID id,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxString& label,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxCP_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-09-21 23:48:04 +00:00
|
|
|
const wxString& name = wxCollapsiblePaneNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-03-08 14:43:31 +00:00
|
|
|
@param parent
|
2008-03-09 12:33:59 +00:00
|
|
|
Parent window, must not be non-@NULL.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param id
|
2008-03-09 12:33:59 +00:00
|
|
|
The identifier for the control.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param label
|
2008-04-10 02:57:09 +00:00
|
|
|
The initial label shown in the button which allows the user to
|
|
|
|
expand or collapse the pane window.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pos
|
2008-03-09 12:33:59 +00:00
|
|
|
Initial position.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param size
|
2008-03-09 12:33:59 +00:00
|
|
|
Initial size.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param style
|
2008-03-09 12:33:59 +00:00
|
|
|
The window style, see wxCP_* flags.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param validator
|
2008-03-09 12:33:59 +00:00
|
|
|
Validator which can be used for additional date checks.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param name
|
2008-03-09 12:33:59 +00:00
|
|
|
Control name.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-05-11 01:38:53 +00:00
|
|
|
@return @true if the control was successfully created or @false if
|
|
|
|
creation failed.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
bool Create(wxWindow* parent, wxWindowID id,
|
2008-03-08 13:52:38 +00:00
|
|
|
const wxString& label,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxCP_DEFAULT_STYLE,
|
|
|
|
const wxValidator& validator = wxDefaultValidator,
|
2008-09-21 23:48:04 +00:00
|
|
|
const wxString& name = wxCollapsiblePaneNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 02:57:09 +00:00
|
|
|
Collapses or expands the pane window.
|
|
|
|
*/
|
2008-09-22 19:01:17 +00:00
|
|
|
virtual void Collapse(bool collapse = true);
|
2008-04-10 02:57:09 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Same as calling Collapse(@false).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
void Expand();
|
|
|
|
|
|
|
|
/**
|
2008-04-10 02:57:09 +00:00
|
|
|
Returns a pointer to the pane window. Add controls to the returned
|
|
|
|
wxWindow to make them collapsible.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-22 19:01:17 +00:00
|
|
|
virtual wxWindow* GetPane() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the pane window is currently hidden.
|
|
|
|
*/
|
2008-09-22 19:01:17 +00:00
|
|
|
virtual bool IsCollapsed() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the pane window is currently shown.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsExpanded() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|