const wxString& str = statbar->GetStatusText(n);
if (str.empty())
return FALSE;
-
+
gtk_tooltip_set_text(tooltip, wxGTK_CONV_SYS(str));
return TRUE;
}
SetSize(wxDefaultCoord, wxDefaultCoord, wxDefaultCoord, height);
SetFieldsCount(1);
-
+
#if defined( __WXGTK20__ )
#if GTK_CHECK_VERSION(2,12,0)
if (HasFlag(wxSTB_SHOW_TIPS) && !gtk_check_version(2,12,0))
{
- g_object_set(m_widget, "has-tooltip", TRUE, NULL);
- g_signal_connect(m_widget, "query-tooltip",
- G_CALLBACK(statusbar_query_tooltip), this);
+ g_object_set(m_widget, "has-tooltip", TRUE, NULL);
+ g_signal_connect(m_widget, "query-tooltip",
+ G_CALLBACK(statusbar_query_tooltip), this);
}
#endif
#endif
return wxSize(width, height);
}
-void wxStatusBarGeneric::SetFieldsCount(int number, const int *widths)
-{
- wxASSERT_MSG( number >= 0, wxT("negative number of fields in wxStatusBar?") );
-
- // this will result in a call to SetStatusWidths() and thus an update to our
- // m_widthsAbs cache
- wxStatusBarBase::SetFieldsCount(number, widths);
-}
-
-void wxStatusBarGeneric::SetStatusText(const wxString& text, int number)
+void wxStatusBarGeneric::DoUpdateStatusText(int number)
{
- wxCHECK_RET( (number >= 0) && ((size_t)number < m_panes.GetCount()),
- wxT("invalid status bar field index") );
-
- wxString oldText = GetStatusText(number);
- if (oldText != text)
- {
- wxStatusBarBase::SetStatusText(text, number);
-
- wxRect rect;
- GetFieldRect(number, rect);
+ wxRect rect;
+ GetFieldRect(number, rect);
- Refresh(true, &rect);
+ Refresh(true, &rect);
- // it's common to show some text in the status bar before starting a
- // relatively lengthy operation, ensure that the text is shown to the
- // user immediately and not after the lengthy operation end
- Update();
- }
+ // it's common to show some text in the status bar before starting a
+ // relatively lengthy operation, ensure that the text is shown to the
+ // user immediately and not after the lengthy operation end
+ Update();
}
void wxStatusBarGeneric::SetStatusWidths(int n, const int widths_field[])
}
// eventually ellipsize the text so that it fits the field width
-
+
wxEllipsizeMode ellmode = (wxEllipsizeMode)-1;
if (HasFlag(wxSTB_ELLIPSIZE_START)) ellmode = wxELLIPSIZE_START;
else if (HasFlag(wxSTB_ELLIPSIZE_MIDDLE)) ellmode = wxELLIPSIZE_MIDDLE;
text = wxControl::Ellipsize(text, dc,
ellmode,
maxWidth,
- wxELLIPSIZE_EXPAND_TAB);
+ wxELLIPSIZE_FLAGS_EXPAND_TABS);
// Ellipsize() will do something only if necessary
- // update the ellipsization status for this pane; this is used later to
- // decide whether a tooltip should be shown or not for this pane
+ // update the ellipsization status for this pane; this is used later to
+ // decide whether a tooltip should be shown or not for this pane
// (if we have wxSTB_SHOW_TIPS)
SetEllipsizedFlag(i, text != GetStatusText(i));
}
// draw the text
dc.DrawText(text, xpos, ypos);
-
+
if (ellmode == (wxEllipsizeMode)-1)
dc.DestroyClippingRegion();
}
// NOTE: we explicitely don't take in count the borders since they are only
// useful when rendering the status text, not for hit-test computations
-
+
if (pt.y <= 0 || pt.y >= m_lastClientHeight)
return wxNOT_FOUND;
{
if (pt.x > x && pt.x < x+m_widthsAbs[i])
return i;
-
+
x += m_widthsAbs[i];
}