test indeterminate wxGauge mode (part of patch 1551409)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42256 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -54,6 +54,7 @@ enum
|
|||||||
{
|
{
|
||||||
GaugePage_Reset = wxID_HIGHEST,
|
GaugePage_Reset = wxID_HIGHEST,
|
||||||
GaugePage_Progress,
|
GaugePage_Progress,
|
||||||
|
GaugePage_IndeterminateProgress,
|
||||||
GaugePage_Clear,
|
GaugePage_Clear,
|
||||||
GaugePage_SetValue,
|
GaugePage_SetValue,
|
||||||
GaugePage_SetRange,
|
GaugePage_SetRange,
|
||||||
@@ -61,6 +62,7 @@ enum
|
|||||||
GaugePage_ValueText,
|
GaugePage_ValueText,
|
||||||
GaugePage_RangeText,
|
GaugePage_RangeText,
|
||||||
GaugePage_Timer,
|
GaugePage_Timer,
|
||||||
|
GaugePage_IndeterminateTimer,
|
||||||
GaugePage_Gauge
|
GaugePage_Gauge
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -84,6 +86,7 @@ protected:
|
|||||||
// event handlers
|
// event handlers
|
||||||
void OnButtonReset(wxCommandEvent& event);
|
void OnButtonReset(wxCommandEvent& event);
|
||||||
void OnButtonProgress(wxCommandEvent& event);
|
void OnButtonProgress(wxCommandEvent& event);
|
||||||
|
void OnButtonIndeterminateProgress(wxCommandEvent& event);
|
||||||
void OnButtonClear(wxCommandEvent& event);
|
void OnButtonClear(wxCommandEvent& event);
|
||||||
void OnButtonSetValue(wxCommandEvent& event);
|
void OnButtonSetValue(wxCommandEvent& event);
|
||||||
void OnButtonSetRange(wxCommandEvent& event);
|
void OnButtonSetRange(wxCommandEvent& event);
|
||||||
@@ -97,6 +100,7 @@ protected:
|
|||||||
void OnUpdateUICurValueText(wxUpdateUIEvent& event);
|
void OnUpdateUICurValueText(wxUpdateUIEvent& event);
|
||||||
|
|
||||||
void OnProgressTimer(wxTimerEvent& event);
|
void OnProgressTimer(wxTimerEvent& event);
|
||||||
|
void OnIndeterminateProgressTimer(wxTimerEvent& event);
|
||||||
|
|
||||||
// reset the gauge parameters
|
// reset the gauge parameters
|
||||||
void Reset();
|
void Reset();
|
||||||
@@ -104,8 +108,11 @@ protected:
|
|||||||
// (re)create the gauge
|
// (re)create the gauge
|
||||||
void CreateGauge();
|
void CreateGauge();
|
||||||
|
|
||||||
|
// start progress timer
|
||||||
|
void StartTimer(wxButton*);
|
||||||
|
|
||||||
// stop the progress timer
|
// stop the progress timer
|
||||||
void StopTimer();
|
void StopTimer(wxButton*);
|
||||||
|
|
||||||
// the gauge range
|
// the gauge range
|
||||||
unsigned long m_range;
|
unsigned long m_range;
|
||||||
@@ -115,8 +122,7 @@ protected:
|
|||||||
|
|
||||||
// the checkboxes for styles
|
// the checkboxes for styles
|
||||||
wxCheckBox *m_chkVert,
|
wxCheckBox *m_chkVert,
|
||||||
*m_chkSmooth,
|
*m_chkSmooth;
|
||||||
*m_chkIndeterminate;
|
|
||||||
|
|
||||||
// the gauge itself and the sizer it is in
|
// the gauge itself and the sizer it is in
|
||||||
wxGauge *m_gauge;
|
wxGauge *m_gauge;
|
||||||
@@ -141,6 +147,7 @@ private:
|
|||||||
BEGIN_EVENT_TABLE(GaugeWidgetsPage, WidgetsPage)
|
BEGIN_EVENT_TABLE(GaugeWidgetsPage, WidgetsPage)
|
||||||
EVT_BUTTON(GaugePage_Reset, GaugeWidgetsPage::OnButtonReset)
|
EVT_BUTTON(GaugePage_Reset, GaugeWidgetsPage::OnButtonReset)
|
||||||
EVT_BUTTON(GaugePage_Progress, GaugeWidgetsPage::OnButtonProgress)
|
EVT_BUTTON(GaugePage_Progress, GaugeWidgetsPage::OnButtonProgress)
|
||||||
|
EVT_BUTTON(GaugePage_IndeterminateProgress, GaugeWidgetsPage::OnButtonIndeterminateProgress)
|
||||||
EVT_BUTTON(GaugePage_Clear, GaugeWidgetsPage::OnButtonClear)
|
EVT_BUTTON(GaugePage_Clear, GaugeWidgetsPage::OnButtonClear)
|
||||||
EVT_BUTTON(GaugePage_SetValue, GaugeWidgetsPage::OnButtonSetValue)
|
EVT_BUTTON(GaugePage_SetValue, GaugeWidgetsPage::OnButtonSetValue)
|
||||||
EVT_BUTTON(GaugePage_SetRange, GaugeWidgetsPage::OnButtonSetRange)
|
EVT_BUTTON(GaugePage_SetRange, GaugeWidgetsPage::OnButtonSetRange)
|
||||||
@@ -155,6 +162,7 @@ BEGIN_EVENT_TABLE(GaugeWidgetsPage, WidgetsPage)
|
|||||||
EVT_RADIOBOX(wxID_ANY, GaugeWidgetsPage::OnCheckOrRadioBox)
|
EVT_RADIOBOX(wxID_ANY, GaugeWidgetsPage::OnCheckOrRadioBox)
|
||||||
|
|
||||||
EVT_TIMER(GaugePage_Timer, GaugeWidgetsPage::OnProgressTimer)
|
EVT_TIMER(GaugePage_Timer, GaugeWidgetsPage::OnProgressTimer)
|
||||||
|
EVT_TIMER(GaugePage_IndeterminateTimer, GaugeWidgetsPage::OnIndeterminateProgressTimer)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
@@ -179,8 +187,7 @@ GaugeWidgetsPage::GaugeWidgetsPage(WidgetsBookCtrl *book,
|
|||||||
m_timer = (wxTimer *)NULL;
|
m_timer = (wxTimer *)NULL;
|
||||||
|
|
||||||
m_chkVert =
|
m_chkVert =
|
||||||
m_chkSmooth =
|
m_chkSmooth = (wxCheckBox *)NULL;
|
||||||
m_chkIndeterminate = (wxCheckBox *)NULL;
|
|
||||||
|
|
||||||
m_gauge = (wxGauge *)NULL;
|
m_gauge = (wxGauge *)NULL;
|
||||||
m_sizerGauge = (wxSizer *)NULL;
|
m_sizerGauge = (wxSizer *)NULL;
|
||||||
@@ -197,7 +204,6 @@ void GaugeWidgetsPage::CreateContent()
|
|||||||
|
|
||||||
m_chkVert = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Vertical"));
|
m_chkVert = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Vertical"));
|
||||||
m_chkSmooth = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Smooth"));
|
m_chkSmooth = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Smooth"));
|
||||||
m_chkIndeterminate = CreateCheckBoxAndAddToSizer(sizerLeft, _T("&Indeterminate"));
|
|
||||||
|
|
||||||
sizerLeft->Add(5, 5, 0, wxGROW | wxALL, 5); // spacer
|
sizerLeft->Add(5, 5, 0, wxGROW | wxALL, 5); // spacer
|
||||||
|
|
||||||
@@ -233,6 +239,9 @@ void GaugeWidgetsPage::CreateContent()
|
|||||||
btn = new wxButton(this, GaugePage_Progress, _T("Simulate &progress"));
|
btn = new wxButton(this, GaugePage_Progress, _T("Simulate &progress"));
|
||||||
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
|
btn = new wxButton(this, GaugePage_IndeterminateProgress, _T("Simulate undeterminate job"));
|
||||||
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
btn = new wxButton(this, GaugePage_Clear, _T("&Clear"));
|
btn = new wxButton(this, GaugePage_Clear, _T("&Clear"));
|
||||||
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
sizerMiddle->Add(btn, 0, wxALL | wxGROW, 5);
|
||||||
|
|
||||||
@@ -269,7 +278,6 @@ void GaugeWidgetsPage::Reset()
|
|||||||
{
|
{
|
||||||
m_chkVert->SetValue(false);
|
m_chkVert->SetValue(false);
|
||||||
m_chkSmooth->SetValue(false);
|
m_chkSmooth->SetValue(false);
|
||||||
m_chkIndeterminate->SetValue(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GaugeWidgetsPage::CreateGauge()
|
void GaugeWidgetsPage::CreateGauge()
|
||||||
@@ -298,10 +306,6 @@ void GaugeWidgetsPage::CreateGauge()
|
|||||||
flags);
|
flags);
|
||||||
m_gauge->SetValue(val);
|
m_gauge->SetValue(val);
|
||||||
|
|
||||||
if ( m_chkIndeterminate->GetValue() ){
|
|
||||||
m_gauge->Pulse();
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( flags & wxGA_VERTICAL )
|
if ( flags & wxGA_VERTICAL )
|
||||||
m_sizerGauge->Add(m_gauge, 0, wxGROW | wxALL, 5);
|
m_sizerGauge->Add(m_gauge, 0, wxGROW | wxALL, 5);
|
||||||
else
|
else
|
||||||
@@ -310,6 +314,46 @@ void GaugeWidgetsPage::CreateGauge()
|
|||||||
m_sizerGauge->Layout();
|
m_sizerGauge->Layout();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GaugeWidgetsPage::StartTimer(wxButton *clicked)
|
||||||
|
{
|
||||||
|
static const int INTERVAL = 300;
|
||||||
|
|
||||||
|
wxLogMessage(_T("Launched progress timer (interval = %d ms)"), INTERVAL);
|
||||||
|
|
||||||
|
m_timer = new wxTimer(this,
|
||||||
|
clicked->GetId() == GaugePage_Progress ? GaugePage_Timer : GaugePage_IndeterminateTimer);
|
||||||
|
m_timer->Start(INTERVAL);
|
||||||
|
|
||||||
|
clicked->SetLabel(_T("&Stop timer"));
|
||||||
|
|
||||||
|
if (clicked->GetId() == GaugePage_Progress)
|
||||||
|
FindWindow(GaugePage_IndeterminateProgress)->Disable();
|
||||||
|
else
|
||||||
|
FindWindow(GaugePage_Progress)->Disable();
|
||||||
|
}
|
||||||
|
|
||||||
|
void GaugeWidgetsPage::StopTimer(wxButton *clicked)
|
||||||
|
{
|
||||||
|
wxCHECK_RET( m_timer, _T("shouldn't be called") );
|
||||||
|
|
||||||
|
m_timer->Stop();
|
||||||
|
delete m_timer;
|
||||||
|
m_timer = NULL;
|
||||||
|
|
||||||
|
if (clicked->GetId() == GaugePage_Progress)
|
||||||
|
{
|
||||||
|
clicked->SetLabel(_T("Simulate &progress"));
|
||||||
|
FindWindow(GaugePage_IndeterminateProgress)->Enable();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
clicked->SetLabel(_T("Simulate undeterminate job"));
|
||||||
|
FindWindow(GaugePage_Progress)->Enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
wxLogMessage(_T("Progress finished."));
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// event handlers
|
// event handlers
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -323,21 +367,29 @@ void GaugeWidgetsPage::OnButtonReset(wxCommandEvent& WXUNUSED(event))
|
|||||||
|
|
||||||
void GaugeWidgetsPage::OnButtonProgress(wxCommandEvent& event)
|
void GaugeWidgetsPage::OnButtonProgress(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
|
wxButton *b = (wxButton *)event.GetEventObject();
|
||||||
if ( !m_timer )
|
if ( !m_timer )
|
||||||
{
|
{
|
||||||
static const int INTERVAL = 300;
|
StartTimer(b);
|
||||||
|
|
||||||
wxLogMessage(_T("Launched progress timer (interval = %d ms)"), INTERVAL);
|
|
||||||
|
|
||||||
m_timer = new wxTimer(this, GaugePage_Timer);
|
|
||||||
m_timer->Start(INTERVAL);
|
|
||||||
|
|
||||||
wxButton *btn = (wxButton *)event.GetEventObject();
|
|
||||||
btn->SetLabel(_T("&Stop timer"));
|
|
||||||
}
|
}
|
||||||
else // stop the running timer
|
else // stop the running timer
|
||||||
{
|
{
|
||||||
StopTimer();
|
StopTimer(b);
|
||||||
|
|
||||||
|
wxLogMessage(_T("Stopped the timer."));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void GaugeWidgetsPage::OnButtonIndeterminateProgress(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
wxButton *b = (wxButton *)event.GetEventObject();
|
||||||
|
if ( !m_timer )
|
||||||
|
{
|
||||||
|
StartTimer(b);
|
||||||
|
}
|
||||||
|
else // stop the running timer
|
||||||
|
{
|
||||||
|
StopTimer(b);
|
||||||
|
|
||||||
wxLogMessage(_T("Stopped the timer."));
|
wxLogMessage(_T("Stopped the timer."));
|
||||||
}
|
}
|
||||||
@@ -356,7 +408,6 @@ void GaugeWidgetsPage::OnButtonSetRange(wxCommandEvent& WXUNUSED(event))
|
|||||||
|
|
||||||
m_range = val;
|
m_range = val;
|
||||||
m_gauge->SetRange(val);
|
m_gauge->SetRange(val);
|
||||||
m_chkIndeterminate->SetValue(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GaugeWidgetsPage::OnButtonSetValue(wxCommandEvent& WXUNUSED(event))
|
void GaugeWidgetsPage::OnButtonSetValue(wxCommandEvent& WXUNUSED(event))
|
||||||
@@ -366,7 +417,6 @@ void GaugeWidgetsPage::OnButtonSetValue(wxCommandEvent& WXUNUSED(event))
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
m_gauge->SetValue(val);
|
m_gauge->SetValue(val);
|
||||||
m_chkIndeterminate->SetValue(0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void GaugeWidgetsPage::OnUpdateUIValueButton(wxUpdateUIEvent& event)
|
void GaugeWidgetsPage::OnUpdateUIValueButton(wxUpdateUIEvent& event)
|
||||||
@@ -400,30 +450,22 @@ void GaugeWidgetsPage::OnProgressTimer(wxTimerEvent& WXUNUSED(event))
|
|||||||
}
|
}
|
||||||
else // reached the end
|
else // reached the end
|
||||||
{
|
{
|
||||||
StopTimer();
|
wxButton *btn = (wxButton *)FindWindow(GaugePage_Progress);
|
||||||
|
wxCHECK_RET( btn, _T("no progress button?") );
|
||||||
|
|
||||||
|
StopTimer(btn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GaugeWidgetsPage::OnIndeterminateProgressTimer(wxTimerEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
m_gauge->Pulse();
|
||||||
|
}
|
||||||
|
|
||||||
void GaugeWidgetsPage::OnUpdateUICurValueText(wxUpdateUIEvent& event)
|
void GaugeWidgetsPage::OnUpdateUICurValueText(wxUpdateUIEvent& event)
|
||||||
{
|
{
|
||||||
event.SetText( wxString::Format(_T("%d"), m_gauge->GetValue()));
|
event.SetText( wxString::Format(_T("%d"), m_gauge->GetValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void GaugeWidgetsPage::StopTimer()
|
|
||||||
{
|
|
||||||
wxCHECK_RET( m_timer, _T("shouldn't be called") );
|
|
||||||
|
|
||||||
m_timer->Stop();
|
|
||||||
delete m_timer;
|
|
||||||
m_timer = NULL;
|
|
||||||
|
|
||||||
wxButton *btn = (wxButton *)FindWindow(GaugePage_Progress);
|
|
||||||
wxCHECK_RET( btn, _T("no progress button?") );
|
|
||||||
|
|
||||||
btn->SetLabel(_T("Simulate &progress"));
|
|
||||||
|
|
||||||
wxLogMessage(_T("Progress finished."));
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_GAUGE
|
// wxUSE_GAUGE
|
||||||
|
Reference in New Issue
Block a user