1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/toolbar.h
3 // Purpose: wxToolBar (Windows 95 toolbar) class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_MSW_TBAR95_H_
13 #define _WX_MSW_TBAR95_H_
17 #include "wx/dynarray.h"
18 #include "wx/imaglist.h"
20 class WXDLLIMPEXP_CORE wxToolBar
: public wxToolBarBase
24 wxToolBar() { Init(); }
26 wxToolBar(wxWindow
*parent
,
28 const wxPoint
& pos
= wxDefaultPosition
,
29 const wxSize
& size
= wxDefaultSize
,
30 long style
= wxNO_BORDER
| wxTB_HORIZONTAL
,
31 const wxString
& name
= wxToolBarNameStr
)
35 Create(parent
, id
, pos
, size
, style
, name
);
38 bool Create(wxWindow
*parent
,
40 const wxPoint
& pos
= wxDefaultPosition
,
41 const wxSize
& size
= wxDefaultSize
,
42 long style
= wxNO_BORDER
| wxTB_HORIZONTAL
,
43 const wxString
& name
= wxToolBarNameStr
);
47 // override/implement base class virtuals
48 virtual wxToolBarToolBase
*FindToolForPosition(wxCoord x
, wxCoord y
) const;
50 virtual bool Realize();
52 virtual void SetToolBitmapSize(const wxSize
& size
);
53 virtual wxSize
GetToolSize() const;
55 virtual void SetRows(int nRows
);
57 virtual void SetToolNormalBitmap(int id
, const wxBitmap
& bitmap
);
58 virtual void SetToolDisabledBitmap(int id
, const wxBitmap
& bitmap
);
60 // implementation only from now on
61 // -------------------------------
63 virtual void SetWindowStyleFlag(long style
);
65 virtual bool MSWCommand(WXUINT param
, WXWORD id
);
66 virtual bool MSWOnNotify(int idCtrl
, WXLPARAM lParam
, WXLPARAM
*result
);
68 void OnMouseEvent(wxMouseEvent
& event
);
69 void OnSysColourChanged(wxSysColourChangedEvent
& 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_