X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/330043b46d2d7fc6ff855f0073ad33d3d637a289..cad1a197e5a31d40104fd979a2c583aa8f725c93:/include/wx/generic/statusbr.h diff --git a/include/wx/generic/statusbr.h b/include/wx/generic/statusbr.h index ce2d4ae642..c36a0c7cdc 100644 --- a/include/wx/generic/statusbr.h +++ b/include/wx/generic/statusbr.h @@ -1,51 +1,71 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: statusbr.h -// Purpose: wxStatusBar class +// Name: wx/generic/statusbr.h +// Purpose: wxStatusBarGeneric class // Author: Julian Smart -// Modified by: +// Modified by: VZ at 05.02.00 to derive from wxStatusBarBase // Created: 01/02/97 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem -// Licence: wxWindows license +// Copyright: (c) Julian Smart +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifndef __STATUSBRH_G__ -#define __STATUSBRH_G__ +#ifndef _WX_GENERIC_STATUSBR_H_ +#define _WX_GENERIC_STATUSBR_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "statusbr.h" #endif -#include "wx/window.h" +#include "wx/pen.h" +#include "wx/font.h" +#include "wx/statusbr.h" +#include "wx/arrstr.h" -WXDLLEXPORT_DATA(extern const char*) wxPanelNameStr; +WXDLLEXPORT_DATA(extern const wxChar*) wxPanelNameStr; -class WXDLLEXPORT wxStatusBar: public wxWindow +class WXDLLEXPORT wxStatusBarGeneric : public wxStatusBarBase { - DECLARE_DYNAMIC_CLASS(wxStatusBar) - public: - wxStatusBar(void); - inline wxStatusBar(wxWindow *parent, wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - long style = 0, - const wxString& name = wxPanelNameStr) + wxStatusBarGeneric() { Init(); } + wxStatusBarGeneric(wxWindow *parent, + wxWindowID winid, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = 0, + const wxString& name = wxPanelNameStr) { - Create(parent, id, pos, size, style, name); + Init(); + + Create(parent, winid, pos, size, style, name); + } + wxStatusBarGeneric(wxWindow *parent, + wxWindowID winid, + long style, + const wxString& name = wxPanelNameStr) + { + Init(); + + Create(parent, winid, style, name); } - ~wxStatusBar(); + virtual ~wxStatusBarGeneric(); - bool Create(wxWindow *parent, wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - long style = 0, - const wxString& name = wxPanelNameStr); + bool Create(wxWindow *parent, wxWindowID winid, + const wxPoint& WXUNUSED(pos) = wxDefaultPosition, + const wxSize& WXUNUSED(size) = wxDefaultSize, + long style = 0, + const wxString& name = wxPanelNameStr) + { + return Create(parent, winid, style, name); + } + + bool Create(wxWindow *parent, wxWindowID winid, + long style, + const wxString& name = wxPanelNameStr); // Create status line - virtual void SetFieldsCount(int number=1, const int widths[] = NULL); - inline int GetFieldsCount() const { return m_nFields; } + virtual void SetFieldsCount(int number = 1, + const int *widths = (const int *) NULL); // Set status line text virtual void SetStatusText(const wxString& text, int number = 0); @@ -54,21 +74,28 @@ public: // Set status line widths virtual void SetStatusWidths(int n, const int widths_field[]); - virtual void DrawFieldText(wxDC& dc, int i); - virtual void DrawField(wxDC& dc, int i); - // Get the position and size of the field's internal bounding rectangle - virtual bool GetFieldRect(int i, wxRectangle& rect) const; + virtual bool GetFieldRect(int i, wxRect& rect) const; + + // sets the minimal vertical size of the status bar + virtual void SetMinHeight(int height); - inline int GetBorderX() const { return m_borderX; } - inline int GetBorderY() const { return m_borderY; } - inline void SetBorderX(int x); - inline void SetBorderY(int y); + virtual int GetBorderX() const { return m_borderX; } + virtual int GetBorderY() const { return m_borderY; } //////////////////////////////////////////////////////////////////////// // Implementation + virtual void DrawFieldText(wxDC& dc, int i); + virtual void DrawField(wxDC& dc, int i); + + void SetBorderX(int x); + void SetBorderY(int y); + void OnPaint(wxPaintEvent& event); + + void OnLeftDown(wxMouseEvent& event); + void OnRightDown(wxMouseEvent& event); virtual void InitColours(); @@ -76,17 +103,26 @@ public: void OnSysColourChanged(wxSysColourChangedEvent& event); protected: - int * m_statusWidths; - int m_nFields; - wxString * m_statusStrings; + // common part of all ctors + void Init(); + + wxArrayString m_statusStrings; + + // the last known width of the client rect (used to rebuild cache) + int m_lastClientWidth; + // the widths of the status bar panes in pixels + wxArrayInt m_widthsAbs; + int m_borderX; int m_borderY; wxFont m_defaultStatusBarFont; wxPen m_mediumShadowPen; wxPen m_hilightPen; +private: DECLARE_EVENT_TABLE() + DECLARE_DYNAMIC_CLASS_NO_COPY(wxStatusBarGeneric) }; #endif - // __STATUSBRH_G__ + // _WX_GENERIC_STATUSBR_H_