/////////////////////////////////////////////////////////////////////////////
-// Name: tbar95.h
+// Name: wx/msw/tbar95.h
// Purpose: wxToolBar95 (Windows 95 toolbar) class
// Author: Julian Smart
// Modified by:
// Created: 01/02/97
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_TBAR95_H_
#pragma interface "tbar95.h"
#endif
-#if wxUSE_BUTTONBAR && wxUSE_TOOLBAR
-#include "wx/tbarbase.h"
+#if wxUSE_TOOLBAR
-WXDLLEXPORT_DATA(extern const wxChar*) wxToolBarNameStr;
+#include "wx/dynarray.h"
-class WXDLLEXPORT wxToolBar95: public wxToolBarBase
-{
- DECLARE_DYNAMIC_CLASS(wxToolBar95)
- public:
- /*
- * Public interface
- */
+#include "wx/tbarbase.h"
- wxToolBar95();
+class WXDLLEXPORT wxToolBar95 : public wxToolBarBase
+{
+public:
+ wxToolBar95() { Init(); }
- wxToolBar95(wxWindow *parent, wxWindowID id, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
- long style = wxNO_BORDER|wxTB_HORIZONTAL,
- const wxString& name = wxToolBarNameStr)
- {
- Create(parent, id, pos, size, style, name);
- }
- ~wxToolBar95();
+ wxToolBar95(wxWindow *parent,
+ wxWindowID id,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxNO_BORDER | wxTB_HORIZONTAL,
+ const wxString& name = wxToolBarNameStr)
+ {
+ Init();
- bool Create(wxWindow *parent, wxWindowID id, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
- long style = wxNO_BORDER|wxTB_HORIZONTAL,
- const wxString& name = wxToolBarNameStr);
+ Create(parent, id, pos, size, style, name);
+ }
- // Call default behaviour
- void OnMouseEvent(wxMouseEvent& event);
+ ~wxToolBar95();
- // Handle wxToolBar95 events
+ bool Create(wxWindow *parent,
+ wxWindowID id,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxNO_BORDER | wxTB_HORIZONTAL,
+ const wxString& name = wxToolBarNameStr);
- // If pushedBitmap is NULL, a reversed version of bitmap is
- // created and used as the pushed/toggled image.
- // If toggle is TRUE, the button toggles between the two states.
- wxToolBarTool *AddTool(int toolIndex, const wxBitmap& bitmap, const wxBitmap& pushedBitmap = wxNullBitmap,
- bool toggle = FALSE, long xPos = -1, long yPos = -1, wxObject *clientData = NULL,
- const wxString& helpString1 = "", const wxString& helpString2 = "");
+ // override base class virtuals
- // Set default bitmap size
- void SetToolBitmapSize(const wxSize& size);
- void EnableTool(int toolIndex, bool enable); // additional drawing on enabling
- void ToggleTool(int toolIndex, bool toggle); // toggle is TRUE if toggled on
- void ClearTools();
+ virtual wxToolBarTool *AddTool(int toolIndex,
+ const wxBitmap& bitmap,
+ const wxBitmap& pushedBitmap = wxNullBitmap,
+ bool toggle = FALSE,
+ long xPos = -1, long yPos = -1,
+ wxObject *clientData = NULL,
+ const wxString& helpString1 = wxEmptyString,
+ const wxString& helpString2 = wxEmptyString);
+ virtual bool AddControl(wxControl *control);
- // The button size is bigger than the bitmap size
- wxSize GetToolSize() const;
+ virtual bool DeleteTool(int toolIndex);
+ virtual void ClearTools();
- wxSize GetMaxSize() const;
+ virtual bool Realize() { return CreateTools(); };
- void GetSize(int *w, int *y) const;
+ virtual void EnableTool(int toolIndex, bool enable);
+ virtual void ToggleTool(int toolIndex, bool toggle);
- virtual bool GetToolState(int toolIndex) const;
+ virtual void SetToolBitmapSize(const wxSize& size);
+ virtual wxSize GetToolSize() const;
+ virtual wxSize GetMaxSize() const;
- // Add all the buttons: required for Win95.
- virtual bool CreateTools();
- virtual void SetRows(int nRows);
- virtual void LayoutButtons() {}
+ virtual bool GetToolState(int toolIndex) const;
- // The post-tool-addition call
- bool Realize() { return CreateTools(); };
+ virtual bool CreateTools();
+ virtual void SetRows(int nRows);
- // IMPLEMENTATION
- virtual bool MSWCommand(WXUINT param, WXWORD id);
- virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
+ // IMPLEMENTATION
+ virtual bool MSWCommand(WXUINT param, WXWORD id);
+ virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
- // Responds to colour changes
- void OnSysColourChanged(wxSysColourChangedEvent& event);
+ void OnMouseEvent(wxMouseEvent& event);
+ void OnSysColourChanged(wxSysColourChangedEvent& event);
protected:
- WXHBITMAP m_hBitmap;
+ // common part of all ctors
+ void Init();
+
+ // the array storing the id for each index
+ wxArrayInt m_ids;
+
+ // get index from id (returns wxNOT_FOUND if no such button)
+ int GetIndexFromId(int id) const;
-DECLARE_EVENT_TABLE()
+ // the big bitmap containing all bitmaps of the toolbar buttons
+ WXHBITMAP m_hBitmap;
+
+ DECLARE_EVENT_TABLE()
};
-#endif // wxUSE_TOOL/BUTTONBAR
+class WXDLLEXPORT wxToolBar : public wxToolBar95
+{
+public:
+ wxToolBar() { }
+
+ wxToolBar(wxWindow *parent,
+ wxWindowID id,
+ const wxPoint& pos = wxDefaultPosition,
+ const wxSize& size = wxDefaultSize,
+ long style = wxNO_BORDER | wxTB_HORIZONTAL,
+ const wxString& name = wxToolBarNameStr)
+ : wxToolBar95(parent, id, pos, size, style, name)
+ {
+ }
+
+private:
+ DECLARE_DYNAMIC_CLASS(wxToolBar)
+};
+
+#endif // wxUSE_TOOLBAR
+
#endif
// _WX_TBAR95_H_