fixed fatal bug in wxStatusBar::SetFieldsCount(), added demo of it to the sample
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5931 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -44,6 +44,7 @@
|
|||||||
#include "wx/statbmp.h"
|
#include "wx/statbmp.h"
|
||||||
#include "wx/menu.h"
|
#include "wx/menu.h"
|
||||||
#include "wx/msgdlg.h"
|
#include "wx/msgdlg.h"
|
||||||
|
#include "wx/textdlg.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/datetime.h"
|
#include "wx/datetime.h"
|
||||||
@@ -82,6 +83,7 @@ public:
|
|||||||
void UpdateClock();
|
void UpdateClock();
|
||||||
|
|
||||||
// event handlers
|
// event handlers
|
||||||
|
void OnTimer(wxTimerEvent& event) { UpdateClock(); }
|
||||||
void OnSize(wxSizeEvent& event);
|
void OnSize(wxSizeEvent& event);
|
||||||
void OnToggleClock(wxCommandEvent& event);
|
void OnToggleClock(wxCommandEvent& event);
|
||||||
|
|
||||||
@@ -95,16 +97,7 @@ private:
|
|||||||
Field_Max
|
Field_Max
|
||||||
};
|
};
|
||||||
|
|
||||||
class MyTimer : public wxTimer
|
wxTimer m_timer;
|
||||||
{
|
|
||||||
public:
|
|
||||||
MyTimer(MyStatusBar *statbar) {m_statbar = statbar; }
|
|
||||||
|
|
||||||
virtual void Notify() { m_statbar->UpdateClock(); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
MyStatusBar *m_statbar;
|
|
||||||
} m_timer;
|
|
||||||
|
|
||||||
wxCheckBox *m_checkbox;
|
wxCheckBox *m_checkbox;
|
||||||
wxStaticBitmap *m_statbmp;
|
wxStaticBitmap *m_statbmp;
|
||||||
@@ -123,6 +116,8 @@ public:
|
|||||||
// event handlers (these functions should _not_ be virtual)
|
// event handlers (these functions should _not_ be virtual)
|
||||||
void OnQuit(wxCommandEvent& event);
|
void OnQuit(wxCommandEvent& event);
|
||||||
void OnAbout(wxCommandEvent& event);
|
void OnAbout(wxCommandEvent& event);
|
||||||
|
|
||||||
|
void OnSetStatusFields(wxCommandEvent& event);
|
||||||
void OnRecreateStatusBar(wxCommandEvent& event);
|
void OnRecreateStatusBar(wxCommandEvent& event);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -151,6 +146,7 @@ enum
|
|||||||
{
|
{
|
||||||
// menu items
|
// menu items
|
||||||
StatusBar_Quit = 1,
|
StatusBar_Quit = 1,
|
||||||
|
StatusBar_SetFields,
|
||||||
StatusBar_Recreate,
|
StatusBar_Recreate,
|
||||||
StatusBar_About,
|
StatusBar_About,
|
||||||
StatusBar_Checkbox = 1000
|
StatusBar_Checkbox = 1000
|
||||||
@@ -168,6 +164,7 @@ static const int BITMAP_SIZE_Y = 15;
|
|||||||
// simple menu events like this the static method is much simpler.
|
// simple menu events like this the static method is much simpler.
|
||||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||||
EVT_MENU(StatusBar_Quit, MyFrame::OnQuit)
|
EVT_MENU(StatusBar_Quit, MyFrame::OnQuit)
|
||||||
|
EVT_MENU(StatusBar_SetFields, MyFrame::OnSetStatusFields)
|
||||||
EVT_MENU(StatusBar_Recreate, MyFrame::OnRecreateStatusBar)
|
EVT_MENU(StatusBar_Recreate, MyFrame::OnRecreateStatusBar)
|
||||||
EVT_MENU(StatusBar_About, MyFrame::OnAbout)
|
EVT_MENU(StatusBar_About, MyFrame::OnAbout)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
@@ -175,6 +172,7 @@ END_EVENT_TABLE()
|
|||||||
BEGIN_EVENT_TABLE(MyStatusBar, wxStatusBar)
|
BEGIN_EVENT_TABLE(MyStatusBar, wxStatusBar)
|
||||||
EVT_SIZE(MyStatusBar::OnSize)
|
EVT_SIZE(MyStatusBar::OnSize)
|
||||||
EVT_CHECKBOX(StatusBar_Checkbox, MyStatusBar::OnToggleClock)
|
EVT_CHECKBOX(StatusBar_Checkbox, MyStatusBar::OnToggleClock)
|
||||||
|
EVT_TIMER(-1, MyStatusBar::OnTimer)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
// Create a new application object: this macro will allow wxWindows to create
|
// Create a new application object: this macro will allow wxWindows to create
|
||||||
@@ -231,6 +229,8 @@ MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size)
|
|||||||
menuFile->Append(StatusBar_Quit, "E&xit\tAlt-X", "Quit this program");
|
menuFile->Append(StatusBar_Quit, "E&xit\tAlt-X", "Quit this program");
|
||||||
|
|
||||||
wxMenu *statbarMenu = new wxMenu;
|
wxMenu *statbarMenu = new wxMenu;
|
||||||
|
statbarMenu->Append(StatusBar_SetFields, "&Set field count\tCtrl-C",
|
||||||
|
"Set the number of status bar fields");
|
||||||
statbarMenu->Append(StatusBar_Recreate, "&Recreate\tCtrl-R",
|
statbarMenu->Append(StatusBar_Recreate, "&Recreate\tCtrl-R",
|
||||||
"Toggle status bar format");
|
"Toggle status bar format");
|
||||||
|
|
||||||
@@ -294,6 +294,44 @@ void MyFrame::DoCreateStatusBar(MyFrame::StatBarKind kind)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// event handlers
|
// event handlers
|
||||||
|
void MyFrame::OnSetStatusFields(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxStatusBar *sb = GetStatusBar();
|
||||||
|
|
||||||
|
long nFields = wxGetNumberFromUser
|
||||||
|
(
|
||||||
|
"Select the number of fields in the status bar",
|
||||||
|
"Fields:",
|
||||||
|
"wxWindows statusbar sample",
|
||||||
|
sb->GetFieldsCount(),
|
||||||
|
1, 5,
|
||||||
|
this
|
||||||
|
);
|
||||||
|
|
||||||
|
// we don't check if the number changed at all on purpose: calling
|
||||||
|
// SetFieldsCount() with the same number of fields should be ok
|
||||||
|
if ( nFields != -1 )
|
||||||
|
{
|
||||||
|
// we set the widths only for 2 of them, otherwise let all the fields
|
||||||
|
// have equal width (the default behaviour)
|
||||||
|
const int *widths = NULL;
|
||||||
|
if ( nFields == 2 )
|
||||||
|
{
|
||||||
|
static const int widthsFor2Fields[2] = { 200, -1 };
|
||||||
|
widths = widthsFor2Fields;
|
||||||
|
}
|
||||||
|
|
||||||
|
sb->SetFieldsCount(nFields, widths);
|
||||||
|
|
||||||
|
wxLogStatus(this,
|
||||||
|
wxString::Format("Status bar now has %ld fields", nFields));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
wxLogStatus(this, "Cancelled");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnRecreateStatusBar(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnRecreateStatusBar(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
DoCreateStatusBar(m_statbarKind == StatBar_Custom ? StatBar_Default
|
DoCreateStatusBar(m_statbarKind == StatBar_Custom ? StatBar_Default
|
||||||
|
@@ -97,29 +97,28 @@ bool wxStatusBarGeneric::Create(wxWindow *parent,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void wxStatusBarGeneric::SetFieldsCount(int number, const int *widths)
|
void wxStatusBarGeneric::SetFieldsCount(int number, const int *widths)
|
||||||
|
{
|
||||||
|
if ( number != m_nFields )
|
||||||
{
|
{
|
||||||
m_nFields = number;
|
m_nFields = number;
|
||||||
|
|
||||||
if ( m_statusWidths )
|
|
||||||
delete[] m_statusWidths;
|
|
||||||
|
|
||||||
if ( m_statusStrings )
|
|
||||||
delete[] m_statusStrings;
|
delete[] m_statusStrings;
|
||||||
|
|
||||||
m_statusStrings = new wxString[number];
|
m_statusStrings = new wxString[number];
|
||||||
|
|
||||||
|
#if 0 // VZ: what is this for?
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < number; i++)
|
for (i = 0; i < number; i++)
|
||||||
m_statusStrings[i] = "";
|
m_statusStrings[i] = "";
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
if ( widths )
|
|
||||||
SetStatusWidths(number, widths);
|
SetStatusWidths(number, widths);
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxStatusBarGeneric::SetStatusText(const wxString& text, int number)
|
void wxStatusBarGeneric::SetStatusText(const wxString& text, int number)
|
||||||
{
|
{
|
||||||
if ((number < 0) || (number >= m_nFields))
|
wxCHECK_RET( (number >= 0) && (number < m_nFields),
|
||||||
return;
|
_T("invalid status bar field index") );
|
||||||
|
|
||||||
m_statusStrings[number] = text;
|
m_statusStrings[number] = text;
|
||||||
|
|
||||||
@@ -137,20 +136,32 @@ wxString wxStatusBarGeneric::GetStatusText(int n) const
|
|||||||
void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[])
|
void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[])
|
||||||
{
|
{
|
||||||
// only set status widths, when n == number of statuswindows
|
// only set status widths, when n == number of statuswindows
|
||||||
if (n == m_nFields)
|
wxCHECK_RET( n == m_nFields, _T("status bar field count mismatch") );
|
||||||
|
|
||||||
|
// delete the old widths in any case - this function may be used to reset
|
||||||
|
// the widths to the default (all equal)
|
||||||
|
delete [] m_statusWidths;
|
||||||
|
|
||||||
|
if ( !widths_field )
|
||||||
{
|
{
|
||||||
// only set status widths,
|
// not an error, see the comment above
|
||||||
// when one window (minimum) is variable (width <= 0)
|
m_statusWidths = (int *)NULL;
|
||||||
bool is_variable = FALSE;
|
|
||||||
int i;
|
return;
|
||||||
for (i = 0; i < m_nFields; i++)
|
|
||||||
{
|
|
||||||
if (widths_field[i] <= 0) is_variable = TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// if there are old widths, delete them
|
int i;
|
||||||
if (m_statusWidths)
|
|
||||||
delete [] m_statusWidths;
|
// VZ: this doesn't do anything as is_variable is unused later
|
||||||
|
#if 0
|
||||||
|
// when one window (minimum) is variable (width <= 0)
|
||||||
|
bool is_variable = FALSE;
|
||||||
|
for (i = 0; i < m_nFields; i++)
|
||||||
|
{
|
||||||
|
if (widths_field[i] <= 0)
|
||||||
|
is_variable = TRUE;
|
||||||
|
}
|
||||||
|
#endif // 0
|
||||||
|
|
||||||
// set widths
|
// set widths
|
||||||
m_statusWidths = new int[n];
|
m_statusWidths = new int[n];
|
||||||
@@ -159,7 +170,6 @@ void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[])
|
|||||||
m_statusWidths[i] = widths_field[i];
|
m_statusWidths[i] = widths_field[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void wxStatusBarGeneric::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
void wxStatusBarGeneric::OnPaint(wxPaintEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user