#include "wx/settings.h"
#include "wx/dcclient.h"
#include "wx/toplevel.h"
+ #include "wx/control.h"
#endif
#ifdef __WXGTK20__
{
wxASSERT_MSG( number >= 0, _T("negative number of fields in wxStatusBar?") );
- // enlarge the m_statusStrings array if needed:
- for (size_t i = m_panes.GetCount(); i < (size_t)number; ++i)
- m_statusStrings.Add( wxEmptyString );
-
- // shrink the m_statusStrings array if needed:
- for (int j = (int)m_panes.GetCount() - 1; j >= number; --j)
- m_statusStrings.RemoveAt(j);
-
- // forget the old cached pixel widths
- m_widthsAbs.Empty();
-
+ // this will result in a call to SetStatusWidths() and thus an update to our
+ // m_widthsAbs cache
wxStatusBarBase::SetFieldsCount(number, widths);
-
- wxASSERT_MSG( m_panes.GetCount() == m_statusStrings.GetCount(),
- _T("This really should never happen, can we do away with m_panes.GetCount() here?") );
}
void wxStatusBarGeneric::SetStatusText(const wxString& text, int number)
wxCHECK_RET( (number >= 0) && ((size_t)number < m_panes.GetCount()),
_T("invalid status bar field index") );
- wxString oldText = m_statusStrings[number];
+ wxString oldText = GetStatusText(number);
if (oldText != text)
{
- m_statusStrings[number] = text;
+ wxStatusBarBase::SetStatusText(text, number);
wxRect rect;
GetFieldRect(number, rect);
}
}
-wxString wxStatusBarGeneric::GetStatusText(int n) const
-{
- wxCHECK_MSG( (n >= 0) && ((size_t)n < m_panes.GetCount()), wxEmptyString,
- _T("invalid status bar field index") );
-
- return m_statusStrings[n];
-}
-
void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[])
{
// only set status widths when n == number of statuswindows
wxCHECK_RET( (size_t)n == m_panes.GetCount(), _T("status bar field count mismatch") );
- // forget the old cached pixel widths
- m_widthsAbs.Empty();
-
wxStatusBarBase::SetStatusWidths(n, widths_field);
+
+ // update cache
+ int width;
+ GetClientSize(&width, &m_lastClientHeight);
+ m_widthsAbs = CalculateAbsWidths(width);
}
bool wxStatusBarGeneric::ShowsSizeGrip() const
if (rect.GetWidth() <= 0)
return; // happens when the status bar is shrinked in a very small area!
- int style = m_panes[i].nStyle;
+ int style = m_panes[i].GetStyle();
if (style != wxSB_FLAT)
{
// Draw border
void wxStatusBarGeneric::InitColours()
{
#if defined(__WXPM__)
- m_mediumShadowPen = wxPen(wxColour(127, 127, 127), 1, wxSOLID);
+ m_mediumShadowPen = wxPen(wxColour(127, 127, 127));
m_hilightPen = *wxWHITE_PEN;
SetBackgroundColour(*wxLIGHT_GREY);