implement tooltips for wxStatusBar panes whose contents were ellipsized; introduce wxST_SHOW_TIPS and wxST_DEFAULT_STYLE styles
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@60265 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -1769,11 +1769,6 @@ enum wxBorder
|
||||
#define wxTC_MULTILINE 0x0200 /* == wxNB_MULTILINE */
|
||||
#define wxTC_OWNERDRAW 0x0400
|
||||
|
||||
/*
|
||||
* wxStatusBar95 flags
|
||||
*/
|
||||
#define wxST_SIZEGRIP 0x0010
|
||||
|
||||
/*
|
||||
* wxStaticBitmap flags
|
||||
*/
|
||||
|
@@ -17,6 +17,7 @@
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
#include "wx/toplevel.h" // the base class
|
||||
#include "wx/statusbr.h"
|
||||
|
||||
// the default names for various classs
|
||||
extern WXDLLIMPEXP_DATA_CORE(const char) wxStatusLineNameStr[];
|
||||
@@ -103,10 +104,9 @@ public:
|
||||
#if wxUSE_STATUSBAR
|
||||
// create the main status bar by calling OnCreateStatusBar()
|
||||
virtual wxStatusBar* CreateStatusBar(int number = 1,
|
||||
long style = wxST_SIZEGRIP|wxFULL_REPAINT_ON_RESIZE,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
wxWindowID winid = 0,
|
||||
const wxString& name =
|
||||
wxStatusLineNameStr);
|
||||
const wxString& name = wxStatusLineNameStr);
|
||||
// return a new status bar
|
||||
virtual wxStatusBar *OnCreateStatusBar(int number,
|
||||
long style,
|
||||
|
@@ -30,7 +30,7 @@ public:
|
||||
wxStatusBarGeneric() { Init(); }
|
||||
wxStatusBarGeneric(wxWindow *parent,
|
||||
wxWindowID winid = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr)
|
||||
{
|
||||
Init();
|
||||
@@ -41,7 +41,7 @@ public:
|
||||
virtual ~wxStatusBarGeneric();
|
||||
|
||||
bool Create(wxWindow *parent, wxWindowID winid = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr);
|
||||
|
||||
// Create status line
|
||||
@@ -64,6 +64,10 @@ public:
|
||||
virtual int GetBorderY() const { return m_borderY; }
|
||||
|
||||
|
||||
// implementation only (not part of wxStatusBar public API):
|
||||
|
||||
int GetFieldFromPoint(const wxPoint& point) const;
|
||||
|
||||
protected: // event handlers
|
||||
|
||||
void OnPaint(wxPaintEvent& event);
|
||||
@@ -104,6 +108,7 @@ protected:
|
||||
|
||||
int m_borderX;
|
||||
int m_borderY;
|
||||
|
||||
wxPen m_mediumShadowPen;
|
||||
wxPen m_hilightPen;
|
||||
|
||||
|
@@ -23,7 +23,7 @@ public:
|
||||
wxStatusBar();
|
||||
wxStatusBar(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr)
|
||||
{
|
||||
m_pDC = NULL;
|
||||
@@ -32,7 +32,7 @@ public:
|
||||
|
||||
bool Create(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr);
|
||||
|
||||
virtual ~wxStatusBar();
|
||||
|
@@ -19,13 +19,13 @@ class WXDLLIMPEXP_CORE wxStatusBarMac : public wxStatusBarGeneric
|
||||
|
||||
wxStatusBarMac();
|
||||
wxStatusBarMac(wxWindow *parent, wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr);
|
||||
|
||||
virtual ~wxStatusBarMac();
|
||||
|
||||
bool Create(wxWindow *parent, wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxStatusBarNameStr);
|
||||
|
||||
virtual void DrawFieldText(wxDC& dc, const wxRect& rc, int i, int textHeight);
|
||||
|
@@ -21,7 +21,7 @@ public:
|
||||
wxStatusBarPalm();
|
||||
wxStatusBarPalm(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxEmptyString)
|
||||
{
|
||||
(void)Create(parent, id, style, name);
|
||||
@@ -29,7 +29,7 @@ public:
|
||||
|
||||
bool Create(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = wxST_SIZEGRIP,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxEmptyString);
|
||||
|
||||
virtual ~wxStatusBarPalm();
|
||||
|
@@ -26,6 +26,12 @@ extern WXDLLIMPEXP_DATA_CORE(const char) wxStatusBarNameStr[];
|
||||
// wxStatusBar constants
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
// wxStatusBar styles
|
||||
#define wxST_SIZEGRIP 0x0010
|
||||
#define wxST_SHOW_TIPS 0x0020
|
||||
|
||||
#define wxST_DEFAULT_STYLE (wxST_SIZEGRIP|wxST_SHOW_TIPS|wxFULL_REPAINT_ON_RESIZE)
|
||||
|
||||
// style flags for fields
|
||||
#define wxSB_NORMAL 0x0000
|
||||
#define wxSB_FLAT 0x0001
|
||||
@@ -42,7 +48,8 @@ class WXDLLIMPEXP_CORE wxStatusBarPane
|
||||
|
||||
public:
|
||||
wxStatusBarPane(int style = wxSB_NORMAL, size_t width = 0)
|
||||
: m_nStyle(style), m_nWidth(width) { m_arrStack.Add(wxEmptyString); }
|
||||
: m_nStyle(style), m_nWidth(width)
|
||||
{ m_arrStack.Add(wxEmptyString); m_bEllipsized=false; }
|
||||
|
||||
int GetWidth() const
|
||||
{ return m_nWidth; }
|
||||
@@ -52,7 +59,12 @@ public:
|
||||
const wxArrayString& GetStack() const
|
||||
{ return m_arrStack; }
|
||||
|
||||
// use wxStatusBar setter functions to modify a wxStatusBarPane
|
||||
// implementation-only getter:
|
||||
bool IsEllipsized() const
|
||||
{ return m_bEllipsized; }
|
||||
|
||||
// NOTE: there are no setters in wxStatusBarPane;
|
||||
// use wxStatusBar functions to modify a wxStatusBarPane
|
||||
|
||||
protected:
|
||||
int m_nStyle;
|
||||
@@ -61,9 +73,12 @@ protected:
|
||||
// this is the array of the stacked strings of this pane; note that this
|
||||
// stack does include also the string currently displayed in this pane
|
||||
// as the version stored in the native status bar control is possibly
|
||||
// ellipsized; note that arrStack.Last() is the top of the stack
|
||||
// ellipsized; note that m_arrStack.Last() is the top of the stack
|
||||
// (i.e. the string shown in the status bar)
|
||||
wxArrayString m_arrStack;
|
||||
|
||||
// was the m_arrStack.Last() string shown in the status bar control ellipsized?
|
||||
bool m_bEllipsized;
|
||||
};
|
||||
|
||||
WX_DECLARE_OBJARRAY(wxStatusBarPane, wxStatusBarPaneArray);
|
||||
@@ -138,6 +153,9 @@ public:
|
||||
// get the dimensions of the horizontal and vertical borders
|
||||
virtual int GetBorderX() const = 0;
|
||||
virtual int GetBorderY() const = 0;
|
||||
|
||||
wxSize GetBorders() const
|
||||
{ return wxSize(GetBorderX(), GetBorderY()); }
|
||||
|
||||
// miscellaneous
|
||||
// -------------
|
||||
@@ -158,6 +176,11 @@ protected:
|
||||
|
||||
// calculate the real field widths for the given total available size
|
||||
wxArrayInt CalculateAbsWidths(wxCoord widthTotal) const;
|
||||
|
||||
// an internal utility used to keep track of which panes have labels
|
||||
// which were last rendered as ellipsized...
|
||||
void SetEllipsizedFlag(int n, bool ellipsized)
|
||||
{ m_panes[n].m_bEllipsized = ellipsized; }
|
||||
|
||||
// the array with the pane infos:
|
||||
wxStatusBarPaneArray m_panes;
|
||||
|
@@ -27,7 +27,7 @@ public:
|
||||
|
||||
wxStatusBarUniv(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = 0,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxPanelNameStr)
|
||||
{
|
||||
Init();
|
||||
@@ -37,7 +37,7 @@ public:
|
||||
|
||||
bool Create(wxWindow *parent,
|
||||
wxWindowID id = wxID_ANY,
|
||||
long style = 0,
|
||||
long style = wxST_DEFAULT_STYLE,
|
||||
const wxString& name = wxPanelNameStr);
|
||||
|
||||
// set field count/widths
|
||||
|
Reference in New Issue
Block a user