2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: propdlg.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxPropertySheetDialog
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxPropertySheetDialog
|
|
|
|
@wxheader{propdlg.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class represents a property sheet dialog: a tabbed dialog
|
|
|
|
for showing settings. It is optimized to show flat tabs
|
|
|
|
on PocketPC devices, and can be customized to use different
|
|
|
|
controllers instead of the default notebook style.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
To use this class, call wxPropertySheetDialog::Create from your own
|
|
|
|
Create function. Then call wxPropertySheetDialog::CreateButtons, and create
|
|
|
|
pages, adding them to the book control.
|
|
|
|
Finally call wxPropertySheetDialog::LayoutDialog.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
For example:
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
|
|
|
bool MyPropertySheetDialog::Create(...)
|
|
|
|
{
|
|
|
|
if (!wxPropertySheetDialog::Create(...))
|
|
|
|
return @false;
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
CreateButtons(wxOK|wxCANCEL|wxHELP);
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
// Add page
|
|
|
|
wxPanel* panel = new wxPanel(GetBookCtrl(), ...);
|
|
|
|
GetBookCtrl()-AddPage(panel, wxT("General"));
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
LayoutDialog();
|
|
|
|
return @true;
|
|
|
|
}
|
|
|
|
@endcode
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
If necessary, override CreateBookCtrl and AddBookCtrl to create and add a
|
|
|
|
different
|
|
|
|
kind of book control. You would then need to use two-step construction for the
|
|
|
|
dialog.
|
|
|
|
Or, change the style of book control by calling
|
2008-03-08 14:43:31 +00:00
|
|
|
wxPropertySheetDialog::SetSheetStyle
|
2008-03-08 13:52:38 +00:00
|
|
|
before calling Create.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The dialogs sample shows this class being used with notebook and toolbook
|
|
|
|
controllers (for
|
|
|
|
Windows-style and Mac-style settings dialogs).
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
To make pages of the dialog scroll when the display is too small to fit the
|
|
|
|
whole dialog, you can switch
|
|
|
|
layout adaptation on globally with wxDialog::EnableLayoutAdaptation or
|
|
|
|
per dialog with wxDialog::SetLayoutAdaptationMode. For more
|
|
|
|
about layout adaptation, see @ref overview_autoscrollingdialogs "Automatic
|
|
|
|
scrolling dialogs".
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxadv}
|
|
|
|
@category{managedwnd}
|
|
|
|
*/
|
|
|
|
class wxPropertySheetDialog : public wxDialog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
*/
|
|
|
|
wxPropertySheetDialog(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxString& title,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxDEFAULT_DIALOG_STYLE,
|
|
|
|
const wxString& name = "dialogBox");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Override this if you wish to add the book control in a way different from the
|
|
|
|
standard way (for example, using different spacing).
|
|
|
|
*/
|
|
|
|
virtual void AddBookCtrl(wxSizer* sizer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Call this from your own Create function, before adding buttons and pages.
|
|
|
|
*/
|
|
|
|
bool Create(wxWindow* parent, wxWindowID id,
|
|
|
|
const wxString& title,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
|
|
|
long style = wxDEFAULT_DIALOG_STYLE,
|
|
|
|
const wxString& name = "dialogBox");
|
|
|
|
|
|
|
|
/**
|
|
|
|
Override this if you wish to create a different kind of book control; by
|
|
|
|
default, the value
|
|
|
|
passed to SetSheetStyle() is used to determine the control.
|
|
|
|
The default behaviour is to create a notebook except on Smartphone, where a
|
|
|
|
choicebook is used.
|
|
|
|
*/
|
|
|
|
virtual wxBookCtrlBase* CreateBookCtrl();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Call this to create the buttons for the dialog. This calls
|
|
|
|
wxDialog::CreateButtonSizer, and
|
|
|
|
the flags are the same. On PocketPC, no buttons are created.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void CreateButtons(int flags = wxOK|wxCANCEL);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the book control that will contain your settings pages.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxBookCtrlBase* GetBookCtrl() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the inner sizer that contains the book control and button sizer.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxSizer* GetInnerSizer() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the sheet style. See SetSheetStyle() for
|
|
|
|
permissable values.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
long GetSheetStyle() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Call this to lay out the dialog. On PocketPC, this does nothing, since the
|
|
|
|
dialog will be shown
|
|
|
|
full-screen, and the layout will be done when the dialog receives a size event.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
void LayoutDialog(int centreFlags = wxBOTH);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the book control used for the dialog. You will normally not need to use
|
|
|
|
this.
|
|
|
|
*/
|
|
|
|
void SetBookCtrl(wxBookCtrlBase* bookCtrl);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the inner sizer that contains the book control and button sizer. You will
|
|
|
|
normally not need to use this.
|
|
|
|
*/
|
|
|
|
void SetInnerSizer(wxSizer* sizer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
You can customize the look and feel of the dialog by setting the sheet style.
|
|
|
|
It is
|
|
|
|
a bit list of the following values:
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_DEFAULT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses the default look and feel for the controller window,
|
|
|
|
normally a notebook except on Smartphone where a choice control is used.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_NOTEBOOK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses a notebook for the controller window.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_TOOLBOOK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses a toolbook for the controller window.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_CHOICEBOOK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses a choicebook for the controller window.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_LISTBOOK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses a listbook for the controller window.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_TREEBOOK
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Uses a treebook for the controller window.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
wxPROPSHEET_SHRINKTOFIT
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Shrinks the dialog window to fit the currently selected page (common behaviour
|
|
|
|
for
|
|
|
|
property sheets on Mac OS X).
|
|
|
|
*/
|
|
|
|
void SetSheetStyle(long style);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|