// Name: tbargtk.h
// Purpose: GTK toolbar
// Author: Robert Roebling
-// Modified by:
-// Created: 01/02/97
// RCS-ID: $Id$
// Copyright: (c) Robert Roebling
// Licence: wxWindows licence
#endif
#include "wx/defs.h"
+
+#if wxUSE_TOOLBAR
+
#include "wx/control.h"
+#include "wx/bitmap.h"
+#include "wx/tbarbase.h"
//-----------------------------------------------------------------------------
// classes
// global data
//-----------------------------------------------------------------------------
-extern const char *wxToolBarNameStr;
-
-//-----------------------------------------------------------------------------
-// wxToolBarTool
-//-----------------------------------------------------------------------------
-
-class wxToolBarTool: public wxObject
-{
- DECLARE_DYNAMIC_CLASS(wxToolBarTool)
-
- public:
-
- wxToolBarTool(void) {};
- wxToolBarTool( wxToolBar *owner, int theIndex = 0,
- const wxBitmap& bitmap1 = wxNullBitmap, const wxBitmap& bitmap2 = wxNullBitmap,
- bool toggle = FALSE, wxObject *clientData = NULL,
- const wxString& shortHelpString = "", const wxString& longHelpString = "");
- ~wxToolBarTool(void);
-
- public:
-
- int m_toolStyle;
- wxObject *m_clientData;
- int m_index;
- bool m_toggleState;
- bool m_isToggle;
- bool m_deleteSecondBitmap;
- bool m_enabled;
- wxBitmap m_bitmap1;
- wxBitmap m_bitmap2;
- bool m_isMenuCommand;
- wxString m_shortHelpString;
- wxString m_longHelpString;
- wxToolBar *m_owner;
-};
+extern const wxChar *wxToolBarNameStr;
//-----------------------------------------------------------------------------
// wxToolBar
class wxToolBar: public wxControl
{
- DECLARE_DYNAMIC_CLASS(wxToolBar)
-
- public:
-
- wxToolBar(void);
+public:
+ wxToolBar();
wxToolBar( wxWindow *parent, wxWindowID id,
const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
long style = 0, const wxString& name = wxToolBarNameStr );
- ~wxToolBar(void);
+ ~wxToolBar();
bool Create( wxWindow *parent, wxWindowID id,
const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
// If toggle is TRUE, the button toggles between the two states.
virtual wxToolBarTool *AddTool( int toolIndex, const wxBitmap& bitmap,
const wxBitmap& pushedBitmap = wxNullBitmap, bool toggle = FALSE,
- float xPos = -1, float yPos = -1, wxObject *clientData = NULL,
+ wxCoord xPos = -1, wxCoord yPos = -1, wxObject *clientData = (wxObject *)NULL,
const wxString& helpString1 = "", const wxString& helpString2 = "");
- virtual void AddSeparator(void);
- virtual void ClearTools(void);
+
+ // Add arbitrary control
+ virtual bool AddControl(wxControl *control);
+
+ // Add space
+ virtual void AddSeparator();
+
+ // Delete tool by index (=id)
+ virtual bool DeleteTool(int toolIndex);
+
+ // Delete all tools
+ virtual void ClearTools();
+
+ // Has to be called after adding tools or changing something
+ virtual bool Realize();
virtual void EnableTool(int toolIndex, bool enable);
virtual void ToggleTool(int toolIndex, bool toggle); // toggle is TRUE if toggled on
- virtual void SetToggle(int toolIndex, bool toggle); // Set this to be togglable (or not)
virtual wxObject *GetToolClientData(int index) const;
virtual bool GetToolState(int toolIndex) const;
virtual void SetMargins(int x, int y);
void SetMargins(const wxSize& size) { SetMargins(size.x, size.y); };
+ virtual wxSize GetToolMargins(void) { return wxSize(m_xMargin, m_yMargin); }
+
virtual void SetToolPacking(int packing);
virtual void SetToolSeparation(int separation);
-
- public:
+ virtual int GetToolPacking();
+ virtual int GetToolSeparation();
+
+ virtual wxString GetToolLongHelp(int toolIndex);
+ virtual wxString GetToolShortHelp(int toolIndex);
+
+ virtual void SetToolLongHelp(int toolIndex, const wxString& helpString);
+ virtual void SetToolShortHelp(int toolIndex, const wxString& helpString);
+
+ void OnIdle( wxIdleEvent &ievent );
+
+ // implementation
GtkToolbar *m_toolbar;
+ int m_separation;
wxList m_tools;
-
- DECLARE_EVENT_TABLE()
+
+ GdkColor *m_fg;
+ GdkColor *m_bg;
+ int m_xMargin;
+ int m_yMargin;
+ bool m_hasToolAlready;
+ bool m_blockNextEvent;
+
+ void OnInternalIdle();
+
+private:
+ DECLARE_EVENT_TABLE()
+ DECLARE_DYNAMIC_CLASS(wxToolBar)
};
#endif
- // __TBARGTKH__
+#endif
+ // __TBARGTKH__