// Author: Vadim Zeitlin
// Modified by:
// Created: 20.07.2003
-// RCS-ID: $Id$
// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwindows.org>
// Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
// native hot-tracking line (on XP)
const int penwidth = 3;
int y = rect.y + rect.height + 1 - penwidth;
- wxColour c = (params && params->m_selectionColour.Ok()) ?
+ wxColour c = (params && params->m_selectionColour.IsOk()) ?
params->m_selectionColour : wxColour(0x66, 0x66, 0x66);
wxPen pen(c, penwidth);
pen.SetCap(wxCAP_BUTT);
triPt[2].y = ar.height;
}
- wxColour c = (params && params->m_arrowColour.Ok()) ?
+ wxColour c = (params && params->m_arrowColour.IsOk()) ?
params->m_arrowColour : wxSystemSettings::GetColour(wxSYS_COLOUR_3DSHADOW);
wxDCPenChanger setPen(dc, c);
int bmpWidth = 0;
// draw the bitmap if there is one
- if ( params && params->m_labelBitmap.Ok() )
+ if ( params && params->m_labelBitmap.IsOk() )
{
int w = params->m_labelBitmap.GetWidth();
int h = params->m_labelBitmap.GetHeight();
const int margin = 5; // number of pixels to reserve on either side of the label
labelWidth += 2*margin;
- wxFont font = params->m_labelFont.Ok() ?
+ wxFont font = params->m_labelFont.IsOk() ?
params->m_labelFont : win->GetFont();
- wxColour clr = params->m_labelColour.Ok() ?
+ wxColour clr = params->m_labelColour.IsOk() ?
params->m_labelColour : win->GetForegroundColour();
wxString label( params->m_labelText );
dc.DrawRectangle(rect);
+ // Make sure that the sign is properly centered by always using an
+ // odd-sized rectangle for it.
+ wxRect signRect(rect);
+ if ( !(signRect.x % 2) )
+ signRect.x--;
+ if ( !(signRect.y % 2) )
+ signRect.y--;
+
// black lines
- const wxCoord xMiddle = rect.x + rect.width/2;
- const wxCoord yMiddle = rect.y + rect.height/2;
+ const wxCoord xMiddle = signRect.x + signRect.width/2;
+ const wxCoord yMiddle = signRect.y + signRect.height/2;
// half of the length of the horz lines in "-" and "+"
- const wxCoord halfWidth = rect.width/2 - 2;
+ const wxCoord halfWidth = signRect.width/2 - 2;
dc.SetPen(*wxBLACK_PEN);
dc.DrawLine(xMiddle - halfWidth, yMiddle,
xMiddle + halfWidth + 1, yMiddle);
if ( !(flags & wxCONTROL_EXPANDED) )
{
// turn "-" into "+"
- const wxCoord halfHeight = rect.height/2 - 2;
+ const wxCoord halfHeight = signRect.height/2 - 2;
dc.DrawLine(xMiddle, yMiddle - halfHeight,
xMiddle, yMiddle + halfHeight + 1);
}