%import controls.i
+//----------------------------------------------------------------------
+%{
+ // Put some wx default wxChar* values into wxStrings.
+ static const wxString wxPyEmptyString(wxT(""));
+%}
//----------------------------------------------------------------------
enum {
wxEVT_WIZARD_PAGE_CHANGED,
wxEVT_WIZARD_PAGE_CHANGING,
wxEVT_WIZARD_CANCEL,
- wxEVT_WIZARD_HELP
+ wxEVT_WIZARD_HELP,
+ wxEVT_WIZARD_FINISHED
};
def EVT_WIZARD_HELP(win, id, func):
win.Connect(id, -1, wxEVT_WIZARD_HELP, func)
+def EVT_WIZARD_FINISHED(win, id, func):
+ win.Connect(id, -1, wxEVT_WIZARD_FINISHED, func)
+
"
//----------------------------------------------------------------------
// const char* resource = NULL);
// %name(wxPreWizardPage)wxWizardPage();
- bool Create(wxWizard *parent,
- const wxBitmap& bitmap = wxNullBitmap,
- const char* resource = NULL);
+ %addmethods {
+ bool Create(wxWizard *parent,
+ const wxBitmap& bitmap = wxNullBitmap,
+ const wxString& resource = wxPyEmptyString) {
+ wxChar* res = NULL;
+ if (resource.Length())
+ res = (wxChar*)resource.c_str();
+ return self->Create(parent, bitmap, res);
+ }
+ }
+
// these functions are used by the wizard to show another page when the
// user chooses "Back" or "Next" button
// of the default one for this wizard (should be of the same size). Notice
// that no other parameters are needed because the wizard will resize and
// reposition the page anyhow
- wxPyWizardPage(wxWizard *parent,
- const wxBitmap& bitmap = wxNullBitmap,
- const char* resource = NULL);
+ %addmethods {
+ wxPyWizardPage(wxWizard *parent,
+ const wxBitmap* bitmap = &wxNullBitmap,
+ const wxString* resource = &wxPyEmptyString) {
+ wxChar* res = NULL;
+ if (resource->Length())
+ res = (wxChar*)resource->c_str();
+ return new wxPyWizardPage(parent, *bitmap, res);
+ }
+ }
+
%name(wxPrePyWizardPage)wxPyWizardPage();
- bool Create(wxWizard *parent,
- const wxBitmap& bitmap = wxNullBitmap,
- const char* resource = NULL);
+ %addmethods {
+ bool Create(wxWizard *parent,
+ const wxBitmap& bitmap = wxNullBitmap,
+ const wxString& resource = wxPyEmptyString) {
+ wxChar* res = NULL;
+ if (resource.Length())
+ res = (wxChar*)resource.c_str();
+ return self->Create(parent, bitmap, res);
+ }
+ }
void _setCallbackInfo(PyObject* self, PyObject* _class);
%pragma(python) addtomethod = "__init__:self._setCallbackInfo(self, wxPyWizardPage)"
int id = -1,
const wxString& title = wxEmptyString,
const wxBitmap& bitmap = wxNullBitmap,
- const wxPoint& pos = wxDefaultPosition);
+ const wxPoint& pos = wxDefaultPosition,
+ long style = wxDEFAULT_DIALOG_STYLE);
%name(wxPreWizard)wxWizard();
%pragma(python) addtomethod = "__init__:self._setOORInfo(self)"
// default)
virtual void FitToPage(const wxWizardPage *firstPage);
+ // Adding pages to page area sizer enlarges wizard
+ virtual wxSizer *GetPageAreaSizer() const;
+
+ // Set border around page area. Default is 0 if you add at least one
+ // page to GetPageAreaSizer and 5 if you don't.
+ virtual void SetBorder(int border);
+
// is the wizard running?
bool IsRunning() const { return m_page != NULL; }
// page first and return FALSE without changing the page if
// TransferDataFromWindow() returns FALSE - otherwise, returns TRUE
bool ShowPage(wxWizardPage *page, bool goingForward = TRUE);
+
+ bool HasNextPage(wxWizardPage* page);
+ bool HasPrevPage(wxWizardPage* page);
};