1 //////////////////////////////////////////////////// 
   3 // Purpose:     wxProgressDialog class 
   4 // Author:      Karsten Ballüder 
   8 // Copyright:   (c) Karsten Ballüder 
   9 // Licence:     wxWindows licence 
  10 //////////////////////////////////////////////////// 
  12 #ifndef __PROGDLGH_G__ 
  13 #define __PROGDLGH_G__ 
  15 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) 
  16 #pragma interface "progdlgg.h" 
  23 #include "wx/dialog.h" 
  25 class WXDLLEXPORT wxButton
; 
  26 class WXDLLEXPORT wxGauge
; 
  27 class WXDLLEXPORT wxStaticText
; 
  29 /* Progress dialog which shows a moving progress bar. 
  30     Taken from the Mahogany project.*/ 
  32 class WXDLLEXPORT wxProgressDialog 
: public wxDialog
 
  34 DECLARE_DYNAMIC_CLASS(wxProgressDialog
) 
  36    /* Creates and displays dialog, disables event handling for other 
  37        frames or parent frame to avoid recursion problems. 
  38        @param title title for window 
  39        @param message message to display in window 
  40        @param maximum value for status bar, if <= 0, no bar is shown 
  41        @param parent window or NULL 
  42        @param style is the bit mask of wxPD_XXX constants from wx/defs.h 
  44    wxProgressDialog(const wxString 
&title
, wxString 
const &message
, 
  46                     wxWindow 
*parent 
= NULL
, 
  47                     int style 
= wxPD_APP_MODAL 
| wxPD_AUTO_HIDE
); 
  49        Re-enables event handling for other windows. 
  53    /* Update the status bar to the new value. 
  54        @param value new value 
  55        @param newmsg if used, new message to display 
  56        @returns true if ABORT button has not been pressed 
  58    virtual bool Update(int value
, const wxString
& newmsg 
= wxT("")); 
  60    /* Can be called to continue after the cancel button has been pressed, but 
  61        the program decided to continue the operation (e.g., user didn't 
  66    bool Show( bool show 
= TRUE 
); 
  69    // callback for optional abort button 
  70    void OnCancel(wxCommandEvent
& event
); 
  72    // callback to disable "hard" window closing 
  73    void OnClose(wxCloseEvent
& event
); 
  75    // must be called to reenable the other windows temporarily disabled while 
  76    // the dialog was shown 
  77    void ReenableOtherWindows(); 
  80    // create the label with given text and another one to show the time nearby 
  81    // under the lastWindow and modify it to be the same as the control created 
  82    // (which is returned) 
  83    wxStaticText 
*CreateLabel(const wxString
& text
, wxWindow 
**lastWindow
); 
  87    // the message displayed 
  89    // displayed elapsed, estimated, remaining time 
  90    class wxStaticText 
*m_elapsed
, 
  93    // time when the dialog was created 
  94    unsigned long m_timeStart
; 
  96    // parent top level window (may be NULL) 
  97    wxWindow 
*m_parentTop
; 
  99    // continue processing or not (return value for Update()) 
 102       Uncancelable 
= -1,   // dialog can't be canceled 
 103       Canceled
,            // can be cancelled and, in fact, was 
 104       Continue
,            // can be cancelled but wasn't 
 105       Finished             
// finished, waiting to be removed from screen 
 108    // the abort button (or NULL if none) 
 109    wxButton 
*m_btnAbort
; 
 114 #if defined(__WXMSW__ ) || defined(__WXPM__) 
 115    // the factor we use to always keep the value in 16 bit range as the native 
 116    // control only supports ranges from 0 to 65,535 
 120    // for wxPD_APP_MODAL case 
 121    class WXDLLEXPORT wxWindowDisabler 
*m_winDisabler
; 
 123    DECLARE_EVENT_TABLE() 
 125     // Virtual function hiding supression 
 126     virtual void Update() { wxDialog::Update(); } 
 128     DECLARE_NO_COPY_CLASS(wxProgressDialog
)