X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1aee06c5b7dfba50484fd9b7779cecfc4ccfe9d7..222ed1d678dff2f5c3c4164321dd05e8f47de487:/include/wx/toolbar.h?ds=sidebyside diff --git a/include/wx/toolbar.h b/include/wx/toolbar.h index e7872223aa..11878e4760 100644 --- a/include/wx/toolbar.h +++ b/include/wx/toolbar.h @@ -12,10 +12,50 @@ #ifndef _WX_TOOLBAR_H_BASE_ #define _WX_TOOLBAR_H_BASE_ -#include "wx/tbarbase.h" // the base class for all toolbars +#include "wx/defs.h" + +// ---------------------------------------------------------------------------- +// wxToolBar style flags +// ---------------------------------------------------------------------------- + +enum +{ + // lay out the toolbar horizontally + wxTB_HORIZONTAL = wxHORIZONTAL, // == 0x0004 + + // lay out the toolbar vertically + wxTB_VERTICAL = wxVERTICAL, // == 0x0008 + + // show 3D buttons (wxToolBarSimple only) + wxTB_3DBUTTONS = 0x0010, + + // "flat" buttons (Win32/GTK only) + wxTB_FLAT = 0x0020, + + // dockable toolbar (GTK only) + wxTB_DOCKABLE = 0x0040, + + // don't show the icons (they're shown by default) + wxTB_NOICONS = 0x0080, + + // show the text (not shown by default) + wxTB_TEXT = 0x0100, + + // don't show the divider between toolbar and the window (Win32 only) + wxTB_NODIVIDER = 0x0200, + + // no automatic alignment (Win32 only, useless) + wxTB_NOALIGN = 0x0400, + + // show the text and the icons alongside, not vertically stacked (Win32/GTK) + wxTB_HORZ_LAYOUT = 0x0800, + wxTB_HORZ_TEXT = wxTB_HORZ_LAYOUT | wxTB_TEXT +}; #if wxUSE_TOOLBAR - #if !wxUSE_TOOLBAR_NATIVE || defined(__WXUNIVERSAL__) + #include "wx/tbarbase.h" // the base class for all toolbars + + #if !wxUSE_TOOLBAR_NATIVE && !defined(__WXUNIVERSAL__) #include "wx/tbarsmpl.h" class WXDLLEXPORT wxToolBar : public wxToolBarSimple @@ -24,18 +64,64 @@ wxToolBar() { } wxToolBar(wxWindow *parent, - wxWindowID id, + wxWindowID winid, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxNO_BORDER | wxTB_HORIZONTAL, const wxString& name = wxToolBarNameStr) - : wxToolBarSimple(parent, id, pos, size, style, name) { } + : wxToolBarSimple(parent, winid, pos, size, style, name) { } + + // the most commonly used version of AddTool() + wxToolBarToolBase *AddTool(int toolid, + const wxBitmap& bitmap, + const wxString& shortHelpString = wxEmptyString, + const wxString& longHelpString = wxEmptyString) + { + return wxToolBarSimple::AddTool(toolid, bitmap, wxNullBitmap, FALSE, -1, -1, NULL, + shortHelpString, longHelpString); + } + + // old form + wxToolBarToolBase *AddTool + ( + int toolid, + const wxBitmap& bitmap, + const wxBitmap& pushedBitmap, + bool toggle, + wxObject *clientData = NULL, + const wxString& shortHelpString = wxEmptyString, + const wxString& longHelpString = wxEmptyString + ) + { + return wxToolBarSimple::AddTool(toolid, bitmap, pushedBitmap, toggle, -1, -1, clientData, + shortHelpString, longHelpString); + } + + // virtual overridden + virtual wxToolBarToolBase *AddTool + ( + int toolid, + const wxBitmap& bitmap, + const wxBitmap& pushedBitmap, + bool toggle, + wxCoord xPos, + wxCoord yPos = -1, + wxObject *clientData = NULL, + const wxString& shortHelpString = wxEmptyString, + const wxString& longHelpString = wxEmptyString + ) + { + return wxToolBarSimple::AddTool(toolid, bitmap, pushedBitmap, toggle, xPos, yPos, clientData, + shortHelpString, longHelpString); + } private: DECLARE_DYNAMIC_CLASS(wxToolBar) }; #else // wxUSE_TOOLBAR_NATIVE - #if defined(__WXMSW__) && defined(__WIN95__) + #if defined(__WXUNIVERSAL__) + #include "wx/univ/toolbar.h" + #elif defined(__WXMSW__) && defined(__WIN95__) #include "wx/msw/tbar95.h" #elif defined(__WXMSW__) #include "wx/msw/tbarmsw.h" @@ -47,8 +133,6 @@ #include "wx/mac/toolbar.h" #elif defined(__WXPM__) #include "wx/os2/toolbar.h" - #elif defined(__WXSTUBS__) - #include "wx/stubs/toolbar.h" #endif #endif // !wxUSE_TOOLBAR_NATIVE/wxUSE_TOOLBAR_NATIVE #endif // wxUSE_TOOLBAR