X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b31eaa5c34b384f0d210d9e06c9159f9fd59ea16..c437b3f4e47b74715a2f2385d4862972babd7802:/src/common/statbar.cpp?ds=inline diff --git a/src/common/statbar.cpp b/src/common/statbar.cpp index a05afa4b1b..d27ddb0a4c 100644 --- a/src/common/statbar.cpp +++ b/src/common/statbar.cpp @@ -191,23 +191,43 @@ wxArrayInt wxStatusBarBase::CalculateAbsWidths(wxCoord widthTotal) const void wxStatusBarBase::PushStatusText(const wxString& text, int number) { - // save current status text in the stack - m_panes[number].m_arrStack.push_back(GetStatusText(number)); + // save the new text (in non-ellipsized form) in the stack + m_panes[number].m_arrStack.push_back(text); SetStatusText(text, number); - // update current status text (eventually also in the native control) + // update current status text (which will possibly be ellipsized) + // also in the native control + + // SetStatusText() typically has an optimization built-in to avoid flickering + // which won't refresh the status bar pane if the current top of the stack + // is identic to the text passed to that function. + // Since this optimization however cannot detect push/pop operations on the stack + // we need to explicitely refresh the status bar pane ourselves: + wxRect rect; + GetFieldRect(number, rect); + Refresh(true, &rect); + Update(); } void wxStatusBarBase::PopStatusText(int number) { - wxASSERT_MSG(m_panes[number].m_arrStack.GetCount() == 1, + wxASSERT_MSG(m_panes[number].m_arrStack.GetCount() > 1, "can't pop any further string"); - wxString text = m_panes[number].m_arrStack.back(); - m_panes[number].m_arrStack.pop_back(); // also remove it from the stack + // the top of the stack is the status text currently shown in the native control; + // remove it + m_panes[number].m_arrStack.pop_back(); - // restore the popped status text in the pane + // restore the previous status text in the native control + const wxString& text = m_panes[number].m_arrStack.back(); SetStatusText(text, number); + + // see comment in wxStatusBarBase::PushStatusText about why we need to explicitely + // refresh the status bar pane + wxRect rect; + GetFieldRect(number, rect); + Refresh(true, &rect); + Update(); } #endif // wxUSE_STATUSBAR