// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifndef __TBARBASEH__
-#define __TBARBASEH__
+#ifndef _WX_TBARBASE_H_
+#define _WX_TBARBASE_H_
#ifdef __GNUG__
#pragma interface "tbarbase.h"
#endif
+#include "wx/setup.h"
#include "wx/defs.h"
-#if USE_TOOLBAR
-
#include "wx/bitmap.h"
#include "wx/list.h"
#include "wx/control.h"
-WXDLLEXPORT_DATA(extern const char*) wxToolBarNameStr;
+WXDLLEXPORT_DATA(extern const wxChar*) wxToolBarNameStr;
WXDLLEXPORT_DATA(extern const wxSize) wxDefaultSize;
WXDLLEXPORT_DATA(extern const wxPoint) wxDefaultPosition;
#define wxTOOL_STYLE_BUTTON 1
#define wxTOOL_STYLE_SEPARATOR 2
+#ifdef __WXGTK__
+class WXDLLEXPORT wxToolBar;
+#endif
+
class WXDLLEXPORT wxToolBarTool: public wxObject
{
DECLARE_DYNAMIC_CLASS(wxToolBarTool)
public:
- wxToolBarTool(int theIndex = 0, const wxBitmap& bitmap1 = wxNullBitmap, const wxBitmap& bitmap2 = wxNullBitmap,
+ wxToolBarTool() {}
+#ifdef __WXGTK__
+ wxToolBarTool(wxToolBar *owner,
+ int theIndex = 0, const wxBitmap& bitmap1 = wxNullBitmap, const wxBitmap& bitmap2 = wxNullBitmap,
+ bool toggle = FALSE, wxObject *clientData = (wxObject *) NULL,
+ const wxString& shortHelpString = "", const wxString& longHelpString = "",
+ GtkWidget *pixmap = (GtkWidget *) NULL );
+#else
+ wxToolBarTool(int theIndex, const wxBitmap& bitmap1 = wxNullBitmap, const wxBitmap& bitmap2 = wxNullBitmap,
bool toggle = FALSE, long xPos = -1, long yPos = -1,
- const wxString& shortHelpString = "", const wxString& longHelpString = "");
+ const wxString& shortHelpString = wxEmptyString, const wxString& longHelpString = wxEmptyString);
+#endif
~wxToolBarTool ();
inline void SetSize( long w, long h ) { m_width = w; m_height = h; }
inline long GetWidth () const { return m_width; }
bool m_isMenuCommand;
wxString m_shortHelpString;
wxString m_longHelpString;
+#ifdef __WXGTK__
+ wxToolBar *m_owner;
+ GtkWidget *m_item;
+ GtkWidget *m_pixmap;
+#endif
};
class WXDLLEXPORT wxToolBarBase : public wxControl
DECLARE_ABSTRACT_CLASS(wxToolBarBase)
public:
- wxToolBarBase(void);
- ~wxToolBarBase(void);
+ wxToolBarBase();
+ ~wxToolBarBase();
// Handle wxToolBar events
// 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, long xPos = -1, long yPos = -1, wxObject *clientData = NULL,
- const wxString& helpString1 = "", const wxString& helpString2 = "");
- virtual void AddSeparator(void);
- virtual void ClearTools(void);
+ const wxString& helpString1 = wxEmptyString, const wxString& helpString2 = wxEmptyString);
+ virtual void AddSeparator();
+ virtual void ClearTools();
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;
- inline wxList& GetTools(void) const { return (wxList&) m_tools; }
+ inline wxList& GetTools() const { return (wxList&) m_tools; }
// After the toolbar has initialized, this is the size the tools take up
#if WXWXIN_COMPATIBILITY
virtual void SetToolPacking(int packing);
virtual void SetToolSeparation(int separation);
- inline virtual wxSize GetToolMargins(void) { return wxSize(m_xMargin, m_yMargin); }
- inline virtual int GetToolPacking(void) { return m_toolPacking; }
- inline virtual int GetToolSeparation(void) { return m_toolSeparation; }
+ inline virtual wxSize GetToolMargins() { return wxSize(m_xMargin, m_yMargin); }
+ inline virtual int GetToolPacking() { return m_toolPacking; }
+ inline virtual int GetToolSeparation() { return m_toolSeparation; }
virtual void SetToolBitmapSize(const wxSize& size) { m_defaultWidth = size.x; m_defaultHeight = size.y; };
- virtual wxSize GetToolBitmapSize(void) const { return wxSize(m_defaultWidth, m_defaultHeight); }
+ virtual wxSize GetToolBitmapSize() const { return wxSize(m_defaultWidth, m_defaultHeight); }
// The button size (in some implementations) is bigger than the bitmap size: this returns
// the total button size.
- virtual wxSize GetToolSize(void) const { return wxSize(m_defaultWidth, m_defaultHeight); } ;
+ virtual wxSize GetToolSize() const { return wxSize(m_defaultWidth, m_defaultHeight); } ;
// Compatibility
#if WXWIN_COMPATIBILITY
- inline void SetDefaultSize(int w, int h) { SetDefaultSize(wxSize(w, h)); }
- inline long GetDefaultWidth(void) const { return m_defaultWidth; }
- inline long GetDefaultHeight(void) const { return m_defaultHeight; }
- inline int GetDefaultButtonWidth(void) const { return (int) GetDefaultButtonSize().x; };
- inline int GetDefaultButtonHeight(void) const { return (int) GetDefaultButtonSize().y; };
+ void SetDefaultSize(int w, int h) { SetDefaultSize(wxSize(w, h)); }
+ long GetDefaultWidth() const { return m_defaultWidth; }
+ long GetDefaultHeight() const { return m_defaultHeight; }
+ int GetDefaultButtonWidth() const { return (int) GetDefaultButtonSize().x; };
+ int GetDefaultButtonHeight() const { return (int) GetDefaultButtonSize().y; };
virtual void SetDefaultSize(const wxSize& size) { SetToolBitmapSize(size); }
- virtual wxSize GetDefaultSize(void) const { return GetToolBitmapSize(); }
- virtual wxSize GetDefaultButtonSize(void) const { return GetToolSize(); }
+ virtual wxSize GetDefaultSize() const { return GetToolBitmapSize(); }
+ virtual wxSize GetDefaultButtonSize() const { return GetToolSize(); }
#endif
// Lay the tools out
- virtual void Layout(void);
-
+ virtual void LayoutTools();
+
// Add all the buttons: required for Win95.
- virtual bool CreateTools(void) { return TRUE; }
+ virtual bool CreateTools() { return TRUE; }
// Calls the appropriate function after tools have been created.
// E.g. Layout, or CreateTools.
virtual void Scroll(int x_pos, int y_pos);
virtual void GetScrollPixelsPerUnit(int *x_unit, int *y_unit) const;
virtual void EnableScrolling(bool x_scrolling, bool y_scrolling);
- virtual void AdjustScrollbars(void);
+ virtual void AdjustScrollbars();
// Prepare the DC by translating it according to the current scroll position
virtual void PrepareDC(wxDC& dc);
virtual void GetVirtualSize(int *x, int *y) const;
// Do the toolbar button updates (check for EVT_UPDATE_UI handlers)
- virtual void DoToolbarUpdates(void);
+ virtual void DoToolbarUpdates();
inline void SetMaxRowsCols(int rows, int cols) { m_maxRows = rows; m_maxCols = cols; }
inline int GetMaxRows() const { return m_maxRows; }
void OnSize(wxSizeEvent& event);
void OnIdle(wxIdleEvent& event);
- // Required to force normal cursor-setting behaviour in Windows
-#ifdef __WXMSW__
- virtual void MSWOnMouseMove(int x, int y, WXUINT flags);
-#endif
-
protected:
wxList m_tools;
// int m_tilingDirection;
int m_yMargin;
int m_toolPacking;
int m_toolSeparation;
- long m_defaultWidth;
- long m_defaultHeight;
+
+ wxCoord m_defaultWidth;
+ wxCoord m_defaultHeight;
public:
////////////////////////////////////////////////////////////////////////
//// IMPLEMENTATION
-
+
// Calculate scroll increment
virtual int CalcScrollInc(wxScrollEvent& event);
DECLARE_EVENT_TABLE()
};
-#endif // USE_TOOLBAR
#endif
- // __TBARBASEH__
+ // _WX_TBARBASE_H_