X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/23a081d436044ea5c827fc677f0e678cd8da4d7d..f96524a0f6e44549b55c5adbbb90c8ee0d5419f1:/src/msw/tbar95.cpp?ds=sidebyside diff --git a/src/msw/tbar95.cpp b/src/msw/tbar95.cpp index b7070ed90a..21ab3d581f 100644 --- a/src/msw/tbar95.cpp +++ b/src/msw/tbar95.cpp @@ -44,6 +44,7 @@ #endif #include "wx/sysopt.h" +#include "wx/dcclient.h" #include "wx/msw/private.h" @@ -954,7 +955,7 @@ bool wxToolBar::Realize() if ( tool->Toggle(false) ) DoToggleTool(tool, false); - prevButton.fsState &= TBSTATE_CHECKED; + prevButton.fsState &= ~TBSTATE_CHECKED; nodePrev = nodePrev->GetPrevious(); prevIndex--; } @@ -1000,8 +1001,6 @@ bool wxToolBar::Realize() // Deal with the controls finally // ------------------------------ - bool hasControls = false; - // adjust the controls size to fit nicely in the toolbar int y = 0; size_t index = 0; @@ -1033,8 +1032,6 @@ bool wxToolBar::Realize() continue; } - hasControls = true; - wxControl *control = tool->GetControl(); wxStaticText * const staticText = tool->GetStaticText(); @@ -1175,13 +1172,6 @@ bool wxToolBar::Realize() InvalidateBestSize(); UpdateSize(); - // Fix a bug on e.g. the Silver theme on WinXP where control backgrounds - // are incorrectly drawn, by forcing the background to a specific colour. - int majorVersion, minorVersion; - wxGetOsVersion(& majorVersion, & minorVersion); - if (majorVersion < 6 && hasControls && !UseBgCol()) - SetBackgroundColour(GetBackgroundColour()); - return true; } @@ -1189,9 +1179,14 @@ bool wxToolBar::Realize() // message handlers // ---------------------------------------------------------------------------- -bool wxToolBar::MSWCommand(WXUINT WXUNUSED(cmd), WXWORD id) +bool wxToolBar::MSWCommand(WXUINT WXUNUSED(cmd), WXWORD id_) { - wxToolBarToolBase *tool = FindById((int)id); + // cast to signed is important as we compare this id with (signed) ints in + // FindById() and without the cast we'd get a positive int from a + // "negative" (i.e. > 32767) WORD + const int id = (signed short)id_; + + wxToolBarToolBase *tool = FindById(id); if ( !tool ) return false; @@ -1213,7 +1208,7 @@ bool wxToolBar::MSWCommand(WXUINT WXUNUSED(cmd), WXWORD id) // OnLeftClick() can veto the button state change - for buttons which // may be toggled only, of couse - if ( !OnLeftClick((int)id, toggled) && tool->CanBeToggled() ) + if ( !OnLeftClick(id, toggled) && tool->CanBeToggled() ) { // revert back tool->Toggle(!toggled); @@ -1234,7 +1229,7 @@ bool wxToolBar::MSWOnNotify(int WXUNUSED(idCtrl), LPNMTOOLBAR tbhdr = (LPNMTOOLBAR)lParam; wxCommandEvent evt(wxEVT_COMMAND_TOOL_DROPDOWN_CLICKED, tbhdr->iItem); - if ( GetEventHandler()->ProcessEvent(evt) ) + if ( HandleWindowEvent(evt) ) { // Event got handled, don't display default popup menu return false; @@ -1542,7 +1537,11 @@ void wxToolBar::OnMouseEvent(wxMouseEvent& event) void wxToolBar::OnEraseBackground(wxEraseEvent& event) { RECT rect = wxGetClientRect(GetHwnd()); - HDC hdc = GetHdcOf((*event.GetDC())); + + wxDC *dc = event.GetDC(); + if (!dc) return; + wxMSWDCImpl *impl = (wxMSWDCImpl*) dc->GetImpl(); + HDC hdc = GetHdcOf(*impl); int majorVersion, minorVersion; wxGetOsVersion(& majorVersion, & minorVersion); @@ -1774,8 +1773,9 @@ bool wxToolBar::HandlePaint(WXWPARAM wParam, WXLPARAM lParam) r.right = clientSize.x; r.top = 0; r.bottom = clientSize.y; - - HRESULT hr = theme->DrawThemeBackground(hTheme, (HDC) dc.GetHDC(), 0, 0, & r, & clipRect); + + wxMSWDCImpl *impl = (wxMSWDCImpl*) dc.GetImpl(); + HRESULT hr = theme->DrawThemeBackground(hTheme, GetHdcOf(*impl), 0, 0, & r, & clipRect); if ( hr == S_OK ) haveRefreshed = true; }