/////////////////////////////////////////////////////////////////////////////
// Name: toolbar.h
// Purpose: wxToolBar class
-// Author: AUTHOR
+// Author: David Webster
// Modified by:
-// Created: ??/??/98
+// Created: 10/17/98
// RCS-ID: $Id$
-// Copyright: (c) AUTHOR
-// Licence: wxWindows licence
+// Copyright: (c) David Webster
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_TOOLBAR_H_
#define _WX_TOOLBAR_H_
-#ifdef __GNUG__
-#pragma interface "toolbar.h"
-#endif
-
+#if wxUSE_TOOLBAR
#include "wx/tbarbase.h"
-WXDLLEXPORT_DATA(extern const char*) wxToolBarNameStr;
-
class WXDLLEXPORT wxToolBar: public wxToolBarBase
{
- DECLARE_DYNAMIC_CLASS(wxToolBar)
- public:
- /*
- * Public interface
- */
-
- wxToolBar();
-
- inline wxToolBar(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);
- }
- ~wxToolBar();
-
- 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 = "");
-
- // 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();
-
- // The button size is bigger than the bitmap size
- wxSize GetToolSize() const;
-
- wxSize GetMaxSize() const;
-
- // Add all the buttons
- virtual bool CreateTools();
- virtual bool Layout() {return TRUE;}
-
- // The post-tool-addition call. TODO: do here whatever's
- // necessary for completing the toolbar construction.
- bool Realize() { return CreateTools(); };
+public:
+ /*
+ * Public interface
+ */
+
+ wxToolBar() { Init(); }
+
+ inline wxToolBar( wxWindow* pParent
+ ,wxWindowID vId
+ ,const wxPoint& rPos = wxDefaultPosition
+ ,const wxSize& rSize = wxDefaultSize
+ ,long lStyle = wxNO_BORDER|wxTB_HORIZONTAL
+ ,const wxString& rName = wxToolBarNameStr
+ )
+ {
+ Create( pParent
+ ,vId
+ ,rPos
+ ,rSize
+ ,lStyle
+ ,rName
+ );
+ }
+ bool Create( wxWindow* pParent
+ ,wxWindowID vId
+ ,const wxPoint& rPos = wxDefaultPosition
+ ,const wxSize& rSize = wxDefaultSize
+ ,long lStyle = wxNO_BORDER|wxTB_HORIZONTAL
+ ,const wxString& rName = wxToolBarNameStr
+ );
+
+ virtual ~wxToolBar();
+
+ // override/implement base class virtuals
+ virtual wxToolBarToolBase* FindToolForPosition( wxCoord x
+ ,wxCoord y
+ ) const;
+
+ // The post-tool-addition call
+ virtual bool Realize(void);
+
+ virtual void SetToolBitmapSize(const wxSize& rSize);
+ virtual wxSize GetToolSize(void) const;
+
+ virtual void SetRows(int nRows);
+
+ // IMPLEMENTATION
+ virtual bool OS2Command( WXUINT uParam
+ ,WXWORD wId
+ );
+ virtual bool OS2OnNotify( int nCtrl
+ ,WXLPARAM lParam
+ ,WXLPARAM* pResult
+ );
+ void OnMouseEvent(wxMouseEvent& rEvent);
+ void OnSysColourChanged(wxSysColourChangedEvent& rEvent);
protected:
-
-DECLARE_EVENT_TABLE()
+ void Init(void);
+ // implement base class pure virtuals
+ virtual bool DoInsertTool(size_t pos, wxToolBarToolBase *tool);
+ virtual bool DoDeleteTool(size_t pos, wxToolBarToolBase *tool);
+
+ virtual void DoEnableTool(wxToolBarToolBase *tool, bool enable);
+ virtual void DoToggleTool(wxToolBarToolBase *tool, bool toggle);
+ virtual void DoSetToggle(wxToolBarToolBase *tool, bool toggle);
+
+ virtual wxToolBarToolBase* CreateTool( int vId
+ ,const wxString& rsLabel
+ ,const wxBitmap& rBitmapNormal
+ ,const wxBitmap& rBitmapDisabled
+ ,wxItemKind vKind
+ ,wxObject* pClientData
+ ,const wxString& rShortHelpString
+ ,const wxString& rLongHelpString
+ );
+ virtual wxToolBarToolBase* CreateTool(wxControl* pControl);
+
+ // should be called whenever the toolbar size changes
+ void UpdateSize(void);
+
+ // override WndProc to process WM_SIZE
+ virtual MRESULT OS2WindowProc( WXUINT ulMsg
+ ,WXWPARAM wParam
+ ,WXLPARAM lParam
+ );
+
+ // the big bitmap containing all bitmaps of the toolbar buttons
+ WXHBITMAP m_hBitmap;
+
+ // the total number of toolbar elements
+ size_t m_nButtons;
+
+private:
+ DECLARE_EVENT_TABLE()
+ DECLARE_DYNAMIC_CLASS(wxToolBar)
};
+#endif // wxUSE_TOOLBAR
+
#endif
// _WX_TOOLBAR_H_