2008-03-08 08:52:38 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: progdlg.h
|
2008-03-10 11:24:38 -04:00
|
|
|
// Purpose: interface of wxProgressDialog
|
2008-03-08 08:52:38 -05:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxProgressDialog
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
This class represents a dialog that shows a short message and a
|
2009-02-18 14:32:00 -05:00
|
|
|
progress bar. Optionally, it can display ABORT and SKIP buttons, and
|
2008-03-08 08:52:38 -05:00
|
|
|
the elapsed, remaining and estimated time for the end of the progress.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2009-02-18 14:32:00 -05:00
|
|
|
Note that you must be aware that wxProgressDialog internally calls
|
|
|
|
wxEventLoopBase::YieldFor with @c wxEVT_CATEGORY_UI and @c wxEVT_CATEGORY_USER_INPUT
|
|
|
|
and this may cause unwanted re-entrancies or the out-of-order processing
|
|
|
|
of pending events (to help preventing the last problem if you're using
|
|
|
|
wxProgressDialog in a multi-threaded application you should be sure to use
|
|
|
|
wxThreadEvent for your inter-threads communications).
|
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@beginStyleTable
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_APP_MODAL}
|
2008-03-08 08:52:38 -05:00
|
|
|
Make the progress dialog modal. If this flag is not given, it is
|
|
|
|
only "locally" modal - that is the input to the parent window is
|
|
|
|
disabled, but not to the other ones.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_AUTO_HIDE}
|
2008-03-08 08:52:38 -05:00
|
|
|
Causes the progress dialog to disappear from screen as soon as the
|
|
|
|
maximum value of the progress meter has been reached.
|
2009-03-08 08:08:39 -04:00
|
|
|
If this style is not present, the dialog will become a modal dialog
|
|
|
|
(see wxDialog::ShowModal) once the maximum value has been reached;
|
|
|
|
this results in processing of pending events and may cause
|
|
|
|
unwanted re-entrancies.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_SMOOTH}
|
2009-03-08 08:08:39 -04:00
|
|
|
Causes smooth progress of the gauge control (uses a wxGauge with the
|
|
|
|
@c wxGA_SMOOTH style).
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_CAN_ABORT}
|
2008-03-08 08:52:38 -05:00
|
|
|
This flag tells the dialog that it should have a "Cancel" button
|
|
|
|
which the user may press. If this happens, the next call to
|
|
|
|
Update() will return @false.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_CAN_SKIP}
|
2008-03-08 08:52:38 -05:00
|
|
|
This flag tells the dialog that it should have a "Skip" button
|
|
|
|
which the user may press. If this happens, the next call to
|
|
|
|
Update() will return @true in its skip parameter.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_ELAPSED_TIME}
|
2008-03-08 08:52:38 -05:00
|
|
|
This flag tells the dialog that it should show elapsed time (since
|
|
|
|
creating the dialog).
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_ESTIMATED_TIME}
|
2008-03-08 08:52:38 -05:00
|
|
|
This flag tells the dialog that it should show estimated time.
|
2008-04-06 10:43:04 -04:00
|
|
|
@style{wxPD_REMAINING_TIME}
|
2008-03-08 08:52:38 -05:00
|
|
|
This flag tells the dialog that it should show remaining time.
|
|
|
|
@endStyleTable
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxbase}
|
|
|
|
@category{cmndlg}
|
|
|
|
*/
|
|
|
|
class wxProgressDialog : public wxDialog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor. Creates the dialog, displays it and disables user input
|
2008-04-10 17:16:38 -04:00
|
|
|
for other windows, or, if @c wxPD_APP_MODAL flag is not given, for its
|
|
|
|
parent window only.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2008-03-08 09:43:31 -05:00
|
|
|
@param title
|
2008-03-09 08:33:59 -04:00
|
|
|
Dialog title to show in titlebar.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param message
|
2008-03-09 08:33:59 -04:00
|
|
|
Message displayed above the progress bar.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param maximum
|
2008-03-09 08:33:59 -04:00
|
|
|
Maximum value for the progress bar.
|
2008-12-02 13:35:24 -05:00
|
|
|
In the generic implementation the progress bar is constructed
|
|
|
|
only if this value is greater than zero.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param parent
|
2008-03-09 08:33:59 -04:00
|
|
|
Parent window.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param style
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog style. See wxProgressDialog.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
wxProgressDialog(const wxString& title, const wxString& message,
|
|
|
|
int maximum = 100,
|
2008-03-09 08:33:59 -04:00
|
|
|
wxWindow* parent = NULL,
|
2008-03-08 08:52:38 -05:00
|
|
|
int style = wxPD_AUTO_HIDE | wxPD_APP_MODAL);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor. Deletes the dialog and enables all top level windows.
|
|
|
|
*/
|
2008-09-27 07:21:10 -04:00
|
|
|
virtual ~wxProgressDialog();
|
2008-03-08 08:52:38 -05:00
|
|
|
|
2008-12-02 13:35:24 -05:00
|
|
|
/**
|
|
|
|
Returns the last value passed to the Update() function or
|
|
|
|
@c wxNOT_FOUND if the dialog has no progress bar.
|
|
|
|
|
|
|
|
@since 2.9.0
|
|
|
|
*/
|
|
|
|
int GetValue() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the maximum value of the progress meter, as passed to
|
|
|
|
the constructor or @c wxNOT_FOUND if the dialog has no progress bar.
|
|
|
|
|
|
|
|
@since 2.9.0
|
|
|
|
*/
|
|
|
|
int GetRange() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the last message passed to the Update() function;
|
|
|
|
if you always passed wxEmptyString to Update() then the message
|
|
|
|
set through the constructor is returned.
|
|
|
|
|
|
|
|
@since 2.9.0
|
|
|
|
*/
|
|
|
|
wxString GetMessage() const;
|
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
/**
|
2009-03-23 08:31:26 -04:00
|
|
|
Like Update() but makes the gauge control run in indeterminate mode.
|
|
|
|
|
|
|
|
In indeterminate mode the remaining and the estimated time labels (if
|
|
|
|
present) are set to to "Unknown" or to @a newmsg (if it's non-empty).
|
|
|
|
Each call to this function moves the progress bar a bit to indicate
|
|
|
|
that some progress was done.
|
|
|
|
|
|
|
|
@see wxGauge::Pulse(), Update()
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-10-28 11:36:26 -04:00
|
|
|
virtual bool Pulse(const wxString& newmsg = wxEmptyString, bool* skip = NULL);
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
2008-04-10 17:16:38 -04:00
|
|
|
Can be used to continue with the dialog, after the user had clicked the "Abort" button.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
void Resume();
|
|
|
|
|
2009-06-01 19:19:25 -04:00
|
|
|
/**
|
|
|
|
Changes the maximum value of the progress meter given in the constructor.
|
|
|
|
This function can only be called (with a positive value) if the value passed
|
|
|
|
in the constructor was positive.
|
|
|
|
|
|
|
|
@since 2.9.1
|
|
|
|
*/
|
|
|
|
void SetRange(int maximum);
|
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
/**
|
2009-03-23 08:31:26 -04:00
|
|
|
Updates the dialog, setting the progress bar to the new value and
|
|
|
|
updating the message if new one is specified.
|
|
|
|
|
|
|
|
Returns @true unless the "Cancel" button has been pressed.
|
2008-04-10 17:16:38 -04:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
If @false is returned, the application can either immediately destroy the
|
2008-04-10 17:16:38 -04:00
|
|
|
dialog or ask the user for the confirmation and if the abort is not confirmed
|
|
|
|
the dialog may be resumed with Resume() function.
|
2008-03-20 09:45:17 -04:00
|
|
|
|
2009-03-23 08:31:26 -04:00
|
|
|
Notice that you may want to call Fit() to change the dialog size to
|
|
|
|
conform to the length of the new message if desired. The dialog does
|
|
|
|
not do this automatically.
|
|
|
|
|
2008-03-08 09:43:31 -05:00
|
|
|
@param value
|
2008-04-10 17:16:38 -04:00
|
|
|
The new value of the progress meter. It should be less than or equal to
|
2009-03-08 08:08:39 -04:00
|
|
|
the maximum value given to the constructor.
|
|
|
|
See @c wxPD_AUTO_HIDE style for more info about the behaviour of
|
|
|
|
wxProgressDialog when @a value is the maximum value given in the ctor.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param newmsg
|
2008-03-09 08:33:59 -04:00
|
|
|
The new messages for the progress dialog text, if it is
|
|
|
|
empty (which is the default) the message is not changed.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param skip
|
2008-04-10 17:16:38 -04:00
|
|
|
If "Skip" button was pressed since last Update() call,
|
|
|
|
this is set to @true.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-11-13 16:32:53 -05:00
|
|
|
virtual bool Update(int value, const wxString& newmsg = wxEmptyString,
|
2008-03-09 08:33:59 -04:00
|
|
|
bool* skip = NULL);
|
2008-03-08 08:52:38 -05:00
|
|
|
};
|
2008-03-10 11:24:38 -04:00
|
|
|
|