2006-10-22 22:28:37 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%% Name: collpane.tex
|
|
|
|
%% Purpose: wxCollapsiblePane documentation
|
|
|
|
%% Author: Francesco Montorsi
|
|
|
|
%% Created: 2006-10-14
|
|
|
|
%% RCS-ID: $Id$
|
|
|
|
%% Copyright: (c) 2006 Francesco Montorsi
|
|
|
|
%% License: wxWindows license
|
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
\section{\class{wxCollapsiblePane}}\label{wxcollapsiblepane}
|
|
|
|
|
2006-11-11 20:06:20 +00:00
|
|
|
A collapsible pane is a container with an embedded button-like control which can be
|
2006-10-22 22:28:37 +00:00
|
|
|
used by the user to collapse or expand the pane's contents.
|
|
|
|
|
2006-11-11 20:06:20 +00:00
|
|
|
Once constructed you should use the \helpref{GetPane}{wxcollapsiblepanegetpane}
|
|
|
|
function to access the pane and add your controls inside it (i.e. use the
|
|
|
|
\helpref{GetPane}{wxcollapsiblepanegetpane}'s returned pointer as parent for the
|
|
|
|
controls which must go in the pane, NOT the wxCollapsiblePane itself!).
|
|
|
|
|
2006-10-30 20:08:17 +00:00
|
|
|
Note that because of its nature of control which can dynamically (and drastically)
|
|
|
|
change its size at run-time under user-input, when putting wxCollapsiblePane inside
|
|
|
|
a \helpref{wxSizer}{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
|
2006-11-11 20:06:20 +00:00
|
|
|
would automatically get resized each time the user expands or collapse the pane window
|
|
|
|
resulting usually in a weird, flickering effect.
|
|
|
|
|
|
|
|
Usage sample:
|
2006-11-12 12:09:52 +00:00
|
|
|
|
2006-11-11 20:06:20 +00:00
|
|
|
\begin{verbatim}
|
|
|
|
wxCollapsiblePane *collpane = new wxCollapsiblePane(this, wxID_ANY, wxT("Details:"));
|
|
|
|
|
|
|
|
// 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);
|
|
|
|
paneSz->Add(new wxStaticText(win, wxID_ANY, wxT("test!")), 1, wxGROW|wxALL, 2);
|
|
|
|
win->SetSizer(paneSz);
|
|
|
|
paneSz->SetSizeHints(win);
|
|
|
|
|
|
|
|
\end{verbatim}
|
|
|
|
|
2006-10-30 20:08:17 +00:00
|
|
|
|
|
|
|
It is only available if \texttt{wxUSE\_COLLPANE} is set to $1$ (the default).
|
|
|
|
|
2006-10-22 22:28:37 +00:00
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
\helpref{wxControl}{wxcontrol}\\
|
|
|
|
\helpref{wxWindow}{wxwindow}\\
|
|
|
|
\helpref{wxEvtHandler}{wxevthandler}\\
|
|
|
|
\helpref{wxObject}{wxobject}
|
|
|
|
|
|
|
|
\wxheading{Include files}
|
|
|
|
|
|
|
|
<wx/collpane.h>
|
|
|
|
|
|
|
|
\wxheading{Window styles}
|
|
|
|
|
2006-10-30 20:08:17 +00:00
|
|
|
\twocolwidtha{5cm}%
|
|
|
|
\begin{twocollist}\itemsep=0pt
|
|
|
|
\twocolitem{\windowstyle{wxCP\_DEFAULT\_STYLE}}{The default style: 0.}
|
|
|
|
\end{twocollist}
|
|
|
|
|
|
|
|
\wxheading{Event handling}
|
|
|
|
|
2006-11-26 18:48:36 +00:00
|
|
|
To process a collapsible pane event, use these event handler macros to direct input to member
|
|
|
|
functions that take a \helpref{wxCollapsiblePaneEvent}{wxcollapsiblepaneevent} argument.
|
|
|
|
|
2006-10-30 20:08:17 +00:00
|
|
|
\twocolwidtha{7cm}%
|
|
|
|
\begin{twocollist}\itemsep=0pt
|
|
|
|
\twocolitem{{\bf EVT\_COLLAPSIBLEPANE\_CHANGED(id, func)}}{The user showed or hidden the collapsible pane. }
|
|
|
|
\end{twocollist}
|
2006-10-22 22:28:37 +00:00
|
|
|
|
|
|
|
|
|
|
|
\wxheading{See also}
|
|
|
|
|
2006-11-26 18:48:36 +00:00
|
|
|
\helpref{wxPanel}{wxpanel},\\
|
|
|
|
\helpref{wxCollapsiblePaneEvent}{wxcollapsiblepaneevent}
|
2006-10-22 22:28:37 +00:00
|
|
|
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePane::wxCollapsiblePane}\label{wxcollapsiblepane}
|
|
|
|
|
|
|
|
\func{}{wxCollapsiblePane}{\param{wxWindow *}{parent},\rtfsp
|
|
|
|
\param{wxWindowID}{ id},\rtfsp
|
|
|
|
\param{const wxString\& }{label},\rtfsp
|
|
|
|
\param{const wxPoint\& }{pos = wxDefaultPosition},\rtfsp
|
|
|
|
\param{const wxSize\& }{size = wxDefaultSize},\rtfsp
|
|
|
|
\param{long}{ style = wxCP\_DEFAULT\_STYLE},\rtfsp
|
|
|
|
\param{const wxValidator\& }{validator = wxDefaultValidator},
|
|
|
|
\param{const wxString\& }{name = ``collapsiblePane"}}
|
|
|
|
|
|
|
|
Initializes the object and calls \helpref{Create}{wxcollapsiblepanecreate} with
|
|
|
|
all the parameters.
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePane::Create}\label{wxcollapsiblepanecreate}
|
|
|
|
|
|
|
|
\func{bool}{Create}{\param{wxWindow *}{parent},\rtfsp
|
|
|
|
\param{wxWindowID}{ id},\rtfsp
|
|
|
|
\param{const wxString\& }{label},\rtfsp
|
|
|
|
\param{const wxPoint\& }{pos = wxDefaultPosition},\rtfsp
|
|
|
|
\param{const wxSize\& }{size = wxDefaultSize},\rtfsp
|
|
|
|
\param{long}{ style = wxCP\_DEFAULT\_STYLE},\rtfsp
|
|
|
|
\param{const wxValidator\& }{validator = wxDefaultValidator},
|
|
|
|
\param{const wxString\& }{name = ``colourpickerctrl"}}
|
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{parent}{Parent window, must not be non-\texttt{NULL}.}
|
|
|
|
|
|
|
|
\docparam{id}{The identifier for the control.}
|
|
|
|
|
|
|
|
\docparam{label}{The initial label shown in the button which allows the user to expand or collapse the pane window.}
|
|
|
|
|
|
|
|
\docparam{pos}{Initial position.}
|
|
|
|
|
|
|
|
\docparam{size}{Initial size.}
|
|
|
|
|
|
|
|
\docparam{style}{The window style, see {\tt wxCP\_*} flags.}
|
|
|
|
|
|
|
|
\docparam{validator}{Validator which can be used for additional date checks.}
|
|
|
|
|
|
|
|
\docparam{name}{Control name.}
|
|
|
|
|
|
|
|
\wxheading{Return value}
|
|
|
|
|
|
|
|
\true if the control was successfully created or \false if creation failed.
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePane::IsCollapsed}\label{wxcollapsiblepaneiscollapsed}
|
|
|
|
|
|
|
|
\constfunc{bool}{IsCollapsed}{\void}
|
|
|
|
|
|
|
|
Returns \true if the pane window is currently hidden.
|
|
|
|
|
|
|
|
|
2006-10-22 23:10:07 +00:00
|
|
|
\membersection{wxCollapsiblePane::IsExpanded}\label{wxcollapsiblepaneisexpanded}
|
|
|
|
|
|
|
|
\constfunc{bool}{IsExpanded}{\void}
|
|
|
|
|
|
|
|
Returns \true if the pane window is currently shown.
|
|
|
|
|
2006-10-22 22:28:37 +00:00
|
|
|
|
|
|
|
\membersection{wxCollapsiblePane::Collapse}\label{wxcollapsiblepanecollapse}
|
|
|
|
|
|
|
|
\func{void}{Collapse}{\param{bool }{collapse = true}}
|
|
|
|
|
|
|
|
Collapses or expands the pane window.
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePane::Expand}\label{wxcollapsiblepaneexpand}
|
|
|
|
|
|
|
|
\func{void}{Expand}{\void}
|
|
|
|
|
2006-10-22 23:10:07 +00:00
|
|
|
Same as \texttt{\helpref{Collapse}{wxcollapsiblepanecollapse}(false)}.
|
2006-10-22 22:28:37 +00:00
|
|
|
|
|
|
|
|
2006-11-11 20:06:20 +00:00
|
|
|
\membersection{wxCollapsiblePane::GetPane}\label{wxcollapsiblepanegetpane}
|
|
|
|
|
|
|
|
\constfunc{wxWindow *}{GetPane}{\void}
|
|
|
|
|
|
|
|
Returns a pointer to the pane window. Add controls to the returned \helpref{wxWindow}{wxwindow}
|
|
|
|
to make them collapsible.
|
2006-11-12 12:09:52 +00:00
|
|
|
|
2006-11-26 18:48:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%% wxCollapsiblePaneEvent documentation
|
|
|
|
|
|
|
|
\section{\class{wxCollapsiblePaneEvent}}\label{wxcollapsiblepaneevent}
|
|
|
|
|
|
|
|
This event class is used for the events generated by
|
|
|
|
\helpref{wxCollapsiblePane}{wxcollapsiblepane}.
|
|
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
\helpref{wxCommandEvent}{wxcommandevent}\\
|
|
|
|
\helpref{wxEvent}{wxevent}\\
|
|
|
|
\helpref{wxObject}{wxobject}
|
|
|
|
|
|
|
|
\wxheading{Include files}
|
|
|
|
|
|
|
|
<wx/collpane.h>
|
|
|
|
|
|
|
|
\wxheading{Event handling}
|
|
|
|
|
|
|
|
To process input from a wxCollapsiblePane, use one of these event handler macros to
|
|
|
|
direct input to member function that take a
|
|
|
|
\helpref{wxCollapsiblePaneEvent}{wxcollapsiblepaneevent} argument:
|
|
|
|
|
|
|
|
\twocolwidtha{7cm}
|
|
|
|
\begin{twocollist}
|
|
|
|
\twocolitem{{\bf EVT\_COLLAPSIBLEPANE\_CHANGED(id, func)}}{The user showed or hidden the collapsible pane.}
|
|
|
|
\end{twocollist}%
|
|
|
|
|
|
|
|
|
|
|
|
\wxheading{See also}
|
|
|
|
|
|
|
|
\helpref{wxCollapsiblePane}{wxcollapsiblepane}
|
|
|
|
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePaneEvent::wxCollapsiblePaneEvent}\label{wxcollapsiblepaneeventctor}
|
|
|
|
|
|
|
|
\func{}{wxCollapsiblePaneEvent}{\param{wxObject *}{ generator}, \param{int}{ id}, \param{bool}{ collapsed}}
|
|
|
|
|
|
|
|
The constructor is not normally used by the user code.
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePaneEvent::GetCollapsed}\label{wxcollapsiblepaneeventgetcollapsed}
|
|
|
|
|
|
|
|
\constfunc{bool}{GetCollapsed}{\void}
|
|
|
|
|
|
|
|
Returns \true if the pane has been collapsed.
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxCollapsiblePaneEvent::SetCollapsed}\label{wxcollapsiblepaneeventsetcollapsed}
|
|
|
|
|
|
|
|
\func{void}{SetCollapsed}{\param{bool}{ collapsed}}
|
|
|
|
|
|
|
|
Sets this as a collapsed pane event (if \arg{collapsed} is \true) or as an expanded
|
|
|
|
pane event (if \arg{collapsed} is \false).
|
|
|
|
|