class WXDLLIMPEXP_CORE wxGenericProgressDialog : public wxDialog
{
public:
+ wxGenericProgressDialog();
wxGenericProgressDialog(const wxString& title, const wxString& message,
int maximum = 100,
wxWindow *parent = NULL,
virtual ~wxGenericProgressDialog();
+ bool Create(const wxString& title,
+ const wxString& message,
+ int maximum = 100,
+ wxWindow *parent = NULL,
+ int style = wxPD_APP_MODAL | wxPD_AUTO_HIDE);
+
virtual bool Update(int value, const wxString& newmsg = wxEmptyString, bool *skip = NULL);
virtual bool Pulse(const wxString& newmsg = wxEmptyString, bool *skip = NULL);
};
protected:
- // This ctor is used by the native MSW implementation only.
- wxGenericProgressDialog(wxWindow *parent, int style);
-
- void Create(const wxString& title,
- const wxString& message,
- int maximum,
- wxWindow *parent,
- int style);
-
// Update just the m_maximum field, this is used by public SetRange() but,
// unlike it, doesn't update the controls state. This makes it useful for
// both this class and its derived classes that don't use m_gauge to
// Return the progress dialog style. Prefer to use HasPDFlag() if possible.
int GetPDStyle() const { return m_pdStyle; }
-
+ void SetPDStyle(int pdStyle) { m_pdStyle = pdStyle; }
// Updates estimated times from a given progress bar value and stores the
// results in provided arguments.
static void SetTimeLabel(unsigned long val, wxStaticText *label);
// common part of all ctors
- void Init(wxWindow *parent, int style);
+ void Init();
// create the label with given text and another one to show the time nearby
// as the next windows in the sizer, returns the created control
// wxGenericProgressDialog creation
// ----------------------------------------------------------------------------
-void wxGenericProgressDialog::Init(wxWindow *parent, int style)
+void wxGenericProgressDialog::Init()
{
// we may disappear at any moment, let the others know about it
SetExtraStyle(GetExtraStyle() | wxWS_EX_TRANSIENT);
// Initialize all our members that we always use (even when we don't
// create a valid window in this class).
- m_pdStyle = style;
-
- m_parentTop = wxGetTopLevelParent(parent);
+ m_pdStyle = 0;
+ m_parentTop = NULL;
m_gauge = NULL;
m_msg = NULL;
m_tempEventLoop = NULL;
}
-wxGenericProgressDialog::wxGenericProgressDialog(wxWindow *parent, int style)
+wxGenericProgressDialog::wxGenericProgressDialog()
: wxDialog()
{
- Init(parent, style);
+ Init();
}
wxGenericProgressDialog::wxGenericProgressDialog(const wxString& title,
int style)
: wxDialog()
{
- Init(parent, style);
+ Init();
Create( title, message, maximum, parent, style );
}
-void wxGenericProgressDialog::Create( const wxString& title,
+bool wxGenericProgressDialog::Create( const wxString& title,
const wxString& message,
int maximum,
wxWindow *parent,
int style )
{
- // Notice that GetParentForModalDialog() needs the dialog window style, not
- // our wxProgressDialog-specific style.
+ m_parentTop = wxGetTopLevelParent(parent);
+ m_pdStyle = style;
+
wxWindow* const
realParent = GetParentForModalDialog(parent, GetWindowStyle());
- wxDialog::Create(realParent, wxID_ANY, title);
- SetTitle( title );
+ if (!wxDialog::Create(realParent, wxID_ANY, title))
+ return false;
SetMaximum(maximum);
}
Update();
+ return true;
}
void wxGenericProgressDialog::UpdateTimeEstimates(int value,
int maximum,
wxWindow *parent,
int style )
- : wxGenericProgressDialog(parent, style),
+ : wxGenericProgressDialog(),
m_taskDialogRunner(NULL),
m_sharedData(NULL),
m_message(message),
if ( HasNativeTaskDialog() )
{
SetParent(GetParentForModalDialog(parent, GetWindowStyle()));
+ SetPDStyle(style);
SetMaximum(maximum);
Show();