1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxStatusBar class interface
4 // Author: Vadim Zeitlin
8 // Copyright: (c) Vadim Zeitlin
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_STATUSBR_H_BASE_
13 #define _WX_STATUSBR_H_BASE_
19 #include "wx/window.h"
21 #include "wx/dynarray.h"
23 extern WXDLLIMPEXP_DATA_CORE(const wxChar
) wxStatusBarNameStr
[];
25 WX_DECLARE_LIST(wxString
, wxListString
);
27 // ----------------------------------------------------------------------------
28 // wxStatusBar constants
29 // ----------------------------------------------------------------------------
31 // style flags for fields
32 #define wxSB_NORMAL 0x0000
33 #define wxSB_FLAT 0x0001
34 #define wxSB_RAISED 0x0002
36 // ----------------------------------------------------------------------------
37 // wxStatusBar: a window near the bottom of the frame used for status info
38 // ----------------------------------------------------------------------------
40 class WXDLLEXPORT wxStatusBarBase
: public wxWindow
45 virtual ~wxStatusBarBase();
50 // set the number of fields and call SetStatusWidths(widths) if widths are
52 virtual void SetFieldsCount(int number
= 1, const int *widths
= NULL
);
53 int GetFieldsCount() const { return m_nFields
; }
58 virtual void SetStatusText(const wxString
& text
, int number
= 0) = 0;
59 virtual wxString
GetStatusText(int number
= 0) const = 0;
61 void PushStatusText(const wxString
& text
, int number
= 0);
62 void PopStatusText(int number
= 0);
67 // set status field widths as absolute numbers: positive widths mean that
68 // the field has the specified absolute width, negative widths are
69 // interpreted as the sizer options, i.e. the extra space (total space
70 // minus the sum of fixed width fields) is divided between the fields with
71 // negative width according to the abs value of the width (field with width
72 // -2 grows twice as much as one with width -1 &c)
73 virtual void SetStatusWidths(int n
, const int widths
[]);
78 // Set the field style. Use either wxSB_NORMAL (default) for a standard 3D
79 // border around a field, wxSB_FLAT for no border around a field, so that it
80 // appears flat or wxSB_POPOUT to make the field appear raised.
81 // Setting field styles only works on wxMSW
82 virtual void SetStatusStyles(int n
, const int styles
[]);
87 // Get the position and size of the field's internal bounding rectangle
88 virtual bool GetFieldRect(int i
, wxRect
& rect
) const = 0;
90 // sets the minimal vertical size of the status bar
91 virtual void SetMinHeight(int height
) = 0;
93 // get the dimensions of the horizontal and vertical borders
94 virtual int GetBorderX() const = 0;
95 virtual int GetBorderY() const = 0;
97 // don't want status bars to accept the focus at all
98 virtual bool AcceptsFocus() const { return false; }
100 virtual bool CanBeOutsideClientArea() const { return true; }
103 // set the widths array to NULL
106 // free the status widths arrays
110 void ReinitWidths() { FreeWidths(); InitWidths(); }
112 // same, for field styles
115 void ReinitStyles() { FreeStyles(); InitStyles(); }
117 // same, for text stacks
120 void ReinitStacks() { FreeStacks(); InitStacks(); }
122 // calculate the real field widths for the given total available size
123 wxArrayInt
CalculateAbsWidths(wxCoord widthTotal
) const;
125 // use these functions to access the stacks of field strings
126 wxListString
*GetStatusStack(int i
) const;
127 wxListString
*GetOrCreateStatusStack(int i
);
129 // the current number of fields
132 // the widths of the fields in pixels if !NULL, all fields have the same
136 // the styles of the fields
139 // stacks of previous values for PushStatusText/PopStatusText
140 // this is created on demand, use GetStatusStack/GetOrCreateStatusStack
141 wxListString
**m_statusTextStacks
;
143 DECLARE_NO_COPY_CLASS(wxStatusBarBase
)
146 // ----------------------------------------------------------------------------
147 // include the actual wxStatusBar class declaration
148 // ----------------------------------------------------------------------------
150 #if defined(__WXUNIVERSAL__)
151 #define wxStatusBarUniv wxStatusBar
153 #include "wx/univ/statusbr.h"
154 #elif defined(__WXPALMOS__)
155 #define wxStatusBarPalm wxStatusBar
157 #include "wx/palmos/statusbr.h"
158 #elif defined(__WIN32__) && wxUSE_NATIVE_STATUSBAR
159 #define wxStatusBar95 wxStatusBar
161 #include "wx/msw/statbr95.h"
162 #elif defined(__WXMAC__)
163 #define wxStatusBarMac wxStatusBar
165 #include "wx/generic/statusbr.h"
166 #include "wx/mac/statusbr.h"
168 #define wxStatusBarGeneric wxStatusBar
170 #include "wx/generic/statusbr.h"
173 #endif // wxUSE_STATUSBAR
176 // _WX_STATUSBR_H_BASE_