X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d331afb7c87db08114c53fd6f2c737afb6709360..bbda1088f7995eec084f450141d1071052473106:/src/generic/statusbr.cpp?ds=inline diff --git a/src/generic/statusbr.cpp b/src/generic/statusbr.cpp index f268c43724..a65e6c1e5c 100644 --- a/src/generic/statusbr.cpp +++ b/src/generic/statusbr.cpp @@ -31,10 +31,8 @@ #include "wx/statusbr.h" -#ifdef __WXMSW__ -#include -#include "wx/msw/winundef.h" -#endif +// with wxUSE_NATIVE_STATUSBAR it is not included from wx/statusbr.h +#include "wx/generic/statusbr.h" IMPLEMENT_DYNAMIC_CLASS(wxStatusBarGeneric, wxWindow) @@ -82,6 +80,7 @@ bool wxStatusBarGeneric::Create(wxWindow *parent, m_nFields = 0; m_borderX = wxTHICK_LINE_BORDER; m_borderY = wxTHICK_LINE_BORDER; + m_themeEnabled = TRUE; bool success = wxWindow::Create(parent, id, wxDefaultPosition, wxDefaultSize, @@ -98,34 +97,33 @@ bool wxStatusBarGeneric::Create(wxWindow *parent, return success; } -void wxStatusBarGeneric::SetFieldsCount(int number, const int widths[]) +void wxStatusBarGeneric::SetFieldsCount(int number, const int *widths) { - m_nFields = number; - - if ( m_statusWidths ) - delete[] m_statusWidths; + if ( number != m_nFields ) + { + m_nFields = number; - if ( m_statusStrings ) delete[] m_statusStrings; + m_statusStrings = new wxString[number]; - m_statusStrings = new wxString[number]; - - int i; - for (i = 0; i < number; i++) - m_statusStrings[i] = ""; +#if 0 // VZ: what is this for? + int i; + for (i = 0; i < number; i++) + m_statusStrings[i] = ""; +#endif + } - if ( widths ) - SetStatusWidths(number, widths); + SetStatusWidths(number, widths); } void wxStatusBarGeneric::SetStatusText(const wxString& text, int number) { - if ((number < 0) || (number >= m_nFields)) - return; + wxCHECK_RET( (number >= 0) && (number < m_nFields), + _T("invalid status bar field index") ); - m_statusStrings[number] = text; + m_statusStrings[number] = text; - Refresh(); + Refresh(); } wxString wxStatusBarGeneric::GetStatusText(int n) const @@ -138,29 +136,40 @@ wxString wxStatusBarGeneric::GetStatusText(int n) const void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[]) { - // only set status widths, when n == number of statuswindows - if (n == m_nFields) - { - // only set status widths, + // only set status widths, when n == number of statuswindows + 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 ) + { + // not an error, see the comment above + m_statusWidths = (int *)NULL; + + return; + } + + int i; + + // 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; - int i; for (i = 0; i < m_nFields; i++) { - if (widths_field[i] <= 0) is_variable = TRUE; + if (widths_field[i] <= 0) + is_variable = TRUE; } - - // if there are old widths, delete them - if (m_statusWidths) - delete [] m_statusWidths; +#endif // 0 // set widths m_statusWidths = new int[n]; for (i = 0; i < m_nFields; i++) { - m_statusWidths[i] = widths_field[i]; + m_statusWidths[i] = widths_field[i]; } - } } void wxStatusBarGeneric::OnPaint(wxPaintEvent& WXUNUSED(event) ) @@ -171,6 +180,7 @@ void wxStatusBarGeneric::OnPaint(wxPaintEvent& WXUNUSED(event) ) if ( GetFont().Ok() ) dc.SetFont(GetFont()); dc.SetBackgroundMode(wxTRANSPARENT); + dc.SetTextForeground(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_WINDOWTEXT)); for ( i = 0; i < m_nFields; i ++ ) DrawField(dc, i); @@ -312,7 +322,7 @@ bool wxStatusBarGeneric::GetFieldRect(int n, wxRect& rect) const void wxStatusBarGeneric::InitColours() { // Shadow colours -#if defined(__WIN95__) +#ifndef __WIN16__ wxColour mediumShadowColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_3DSHADOW)); m_mediumShadowPen = wxPen(mediumShadowColour, 1, wxSOLID);