1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/toolbar.h
3 // Purpose: wxToolBar (Windows 95 toolbar) class
4 // Author: Julian Smart
7 // Copyright: (c) Julian Smart
8 // Licence: wxWindows licence
9 /////////////////////////////////////////////////////////////////////////////
11 #ifndef _WX_MSW_TBAR95_H_
12 #define _WX_MSW_TBAR95_H_
16 #include "wx/dynarray.h"
17 #include "wx/imaglist.h"
19 class WXDLLIMPEXP_CORE wxToolBar
: public wxToolBarBase
23 wxToolBar() { Init(); }
25 wxToolBar(wxWindow
*parent
,
27 const wxPoint
& pos
= wxDefaultPosition
,
28 const wxSize
& size
= wxDefaultSize
,
29 long style
= wxTB_HORIZONTAL
,
30 const wxString
& name
= wxToolBarNameStr
)
34 Create(parent
, id
, pos
, size
, style
, name
);
37 bool Create(wxWindow
*parent
,
39 const wxPoint
& pos
= wxDefaultPosition
,
40 const wxSize
& size
= wxDefaultSize
,
41 long style
= wxTB_HORIZONTAL
,
42 const wxString
& name
= wxToolBarNameStr
);
46 // override/implement base class virtuals
47 virtual wxToolBarToolBase
*FindToolForPosition(wxCoord x
, wxCoord y
) const;
49 virtual bool Realize();
51 virtual void SetToolBitmapSize(const wxSize
& size
);
52 virtual wxSize
GetToolSize() const;
54 virtual void SetRows(int nRows
);
56 virtual void SetToolNormalBitmap(int id
, const wxBitmap
& bitmap
);
57 virtual void SetToolDisabledBitmap(int id
, const wxBitmap
& bitmap
);
59 // implementation only from now on
60 // -------------------------------
62 virtual void SetWindowStyleFlag(long style
);
64 virtual bool MSWCommand(WXUINT param
, WXWORD id
);
65 virtual bool MSWOnNotify(int idCtrl
, WXLPARAM lParam
, WXLPARAM
*result
);
67 void OnMouseEvent(wxMouseEvent
& event
);
68 void OnSysColourChanged(wxSysColourChangedEvent
& event
);
69 void OnEraseBackground(wxEraseEvent
& event
);
73 static WXHBITMAP
MapBitmap(WXHBITMAP bitmap
, int width
, int height
);
75 // override WndProc mainly to process WM_SIZE
76 virtual WXLRESULT
MSWWindowProc(WXUINT nMsg
, WXWPARAM wParam
, WXLPARAM lParam
);
78 virtual WXDWORD
MSWGetStyle(long style
, WXDWORD
*exstyle
) const;
80 // returns true if the platform should explicitly apply a theme border
81 virtual bool CanApplyThemeBorder() const { return false; }
83 #ifdef wxHAS_MSW_BACKGROUND_ERASE_HOOK
84 virtual bool MSWEraseBgHook(WXHDC hDC
);
85 virtual WXHBRUSH
MSWGetBgBrushForChild(WXHDC hDC
, wxWindowMSW
*child
);
86 #endif // wxHAS_MSW_BACKGROUND_ERASE_HOOK
88 virtual wxToolBarToolBase
*CreateTool(int id
,
89 const wxString
& label
,
90 const wxBitmap
& bmpNormal
,
91 const wxBitmap
& bmpDisabled
= wxNullBitmap
,
92 wxItemKind kind
= wxITEM_NORMAL
,
93 wxObject
*clientData
= NULL
,
94 const wxString
& shortHelp
= wxEmptyString
,
95 const wxString
& longHelp
= wxEmptyString
);
97 virtual wxToolBarToolBase
*CreateTool(wxControl
*control
,
98 const wxString
& label
);
100 // common part of all ctors
103 // create the native toolbar control
104 bool MSWCreateToolbar(const wxPoint
& pos
, const wxSize
& size
);
106 // recreate the control completely
109 // implement base class pure virtuals
110 virtual bool DoInsertTool(size_t pos
, wxToolBarToolBase
*tool
);
111 virtual bool DoDeleteTool(size_t pos
, wxToolBarToolBase
*tool
);
113 virtual void DoEnableTool(wxToolBarToolBase
*tool
, bool enable
);
114 virtual void DoToggleTool(wxToolBarToolBase
*tool
, bool toggle
);
115 virtual void DoSetToggle(wxToolBarToolBase
*tool
, bool toggle
);
117 // return the appropriate size and flags for the toolbar control
118 virtual wxSize
DoGetBestSize() const;
120 // handlers for various events
121 bool HandleSize(WXWPARAM wParam
, WXLPARAM lParam
);
122 #ifdef wxHAS_MSW_BACKGROUND_ERASE_HOOK
123 bool HandlePaint(WXWPARAM wParam
, WXLPARAM lParam
);
124 #endif // wxHAS_MSW_BACKGROUND_ERASE_HOOK
125 void HandleMouseMove(WXWPARAM wParam
, WXLPARAM lParam
);
127 // should be called whenever the toolbar size changes
130 // create m_disabledImgList (but doesn't fill it), set it to NULL if it is
132 void CreateDisabledImageList();
134 // get the Windows toolbar style of this control
135 long GetMSWToolbarStyle() const;
138 // the big bitmap containing all bitmaps of the toolbar buttons
141 // the image list with disabled images, may be NULL if we use
142 // system-provided versions of them
143 wxImageList
*m_disabledImgList
;
145 // the total number of toolbar elements
148 // the sum of the sizes of the fixed items (i.e. excluding stretchable
149 // spaces) in the toolbar direction
150 int m_totalFixedSize
;
152 // the tool the cursor is in
153 wxToolBarToolBase
*m_pInTool
;
156 // makes sure tool bitmap size is sufficient for all tools
157 void AdjustToolBitmapSize();
159 // update the sizes of stretchable spacers to consume all extra space we
161 void UpdateStretchableSpacersSize();
163 #ifdef wxHAS_MSW_BACKGROUND_ERASE_HOOK
164 // do erase the toolbar background, always do it for the entire control as
165 // the caller sets the clipping region correctly to exclude parts which
166 // should not be erased
167 void MSWDoEraseBackground(WXHDC hDC
);
169 // return the brush to use for erasing the toolbar background
170 WXHBRUSH
MSWGetToolbarBgBrush();
171 #endif // wxHAS_MSW_BACKGROUND_ERASE_HOOK
173 DECLARE_EVENT_TABLE()
174 DECLARE_DYNAMIC_CLASS(wxToolBar
)
175 wxDECLARE_NO_COPY_CLASS(wxToolBar
);
178 #endif // wxUSE_TOOLBAR
180 #endif // _WX_MSW_TBAR95_H_