Fix item selection/focus drawing in generic wxListCtrl.

Item focus rectangle was not drawn at all under wxGTK as the code doing it was
disabled with a comment saying that it was drawn elsewhere -- but this wasn't
the case.

So remove #ifdefs for wxGTK/Mac from generic wxListCtrl code and do use
wxRendererNative methods for all platforms. This fixes the appearance of the
control under GTK and if it introduces any problems under Mac, they should be
fixed in its wxRendererNative implementation and not by adding #ifdefs here.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@64879 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2010-07-11 10:43:43 +00:00
parent c70ad28733
commit d67fc8b735

View File

@ -737,30 +737,19 @@ void wxListLineData::Draw( wxDC *dc )
wxListItemAttr *attr = GetAttr(); wxListItemAttr *attr = GetAttr();
if ( SetAttributes(dc, attr, highlighted) ) if ( SetAttributes(dc, attr, highlighted) )
#if ( !defined(__WXGTK20__) && !defined(__WXMAC__) )
{
dc->DrawRectangle( m_gi->m_rectHighlight );
}
#else
{ {
int flags = 0;
if (highlighted) if (highlighted)
{ flags |= wxCONTROL_SELECTED;
int flags = wxCONTROL_SELECTED; if (m_owner->HasFocus()
if (m_owner->HasFocus()
#if defined( __WXMAC__ ) && !defined(__WXUNIVERSAL__) && wxOSX_USE_CARBON #if defined( __WXMAC__ ) && !defined(__WXUNIVERSAL__) && wxOSX_USE_CARBON
&& IsControlActive( (ControlRef)m_owner->GetHandle() ) && IsControlActive( (ControlRef)m_owner->GetHandle() )
#endif #endif
) )
flags |= wxCONTROL_FOCUSED; flags |= wxCONTROL_FOCUSED;
wxRendererNative::Get().DrawItemSelectionRect( m_owner, *dc, m_gi->m_rectHighlight, flags ); wxRendererNative::Get().
DrawItemSelectionRect( m_owner, *dc, m_gi->m_rectHighlight, flags );
}
else
{
dc->DrawRectangle( m_gi->m_rectHighlight );
}
} }
#endif
// just for debugging to better see where the items are // just for debugging to better see where the items are
#if 0 #if 0
@ -801,29 +790,16 @@ void wxListLineData::DrawInReportMode( wxDC *dc,
// GetAttr() and move these lines into the loop below // GetAttr() and move these lines into the loop below
wxListItemAttr *attr = GetAttr(); wxListItemAttr *attr = GetAttr();
if ( SetAttributes(dc, attr, highlighted) ) if ( SetAttributes(dc, attr, highlighted) )
#if ( !defined(__WXGTK20__) && !defined(__WXMAC__) )
{
dc->DrawRectangle( rectHL );
wxUnusedVar(current);
}
#else
{ {
int flags = 0;
if (highlighted) if (highlighted)
{ flags |= wxCONTROL_SELECTED;
int flags = wxCONTROL_SELECTED; if (m_owner->HasFocus())
if (m_owner->HasFocus()) flags |= wxCONTROL_FOCUSED;
flags |= wxCONTROL_FOCUSED; if (current)
if (current) flags |= wxCONTROL_CURRENT;
flags |= wxCONTROL_CURRENT; wxRendererNative::Get().DrawItemSelectionRect( m_owner, *dc, rectHL, flags );
wxRendererNative::Get().DrawItemSelectionRect( m_owner, *dc, rectHL, flags );
}
else
{
dc->DrawRectangle( rectHL );
}
} }
#endif
wxCoord x = rect.x + HEADER_OFFSET_X, wxCoord x = rect.x + HEADER_OFFSET_X,
yMid = rect.y + rect.height/2; yMid = rect.y + rect.height/2;
@ -2138,20 +2114,15 @@ void wxListMainWindow::OnPaint( wxPaintEvent &WXUNUSED(event) )
} }
} }
#if !defined( __WXMAC__) && !defined(__WXGTK20__)
// Don't draw rect outline under Mac at all.
// Draw it elsewhere under GTK.
if ( HasCurrent() ) if ( HasCurrent() )
{ {
if ( m_hasFocus ) int flags = 0;
{ if ( IsHighlighted(m_current) )
wxRect rect( GetLineHighlightRect( m_current ) ); flags |= wxCONTROL_SELECTED;
dc.SetPen( *wxBLACK_PEN );
dc.SetBrush( *wxTRANSPARENT_BRUSH ); wxRendererNative::Get().
dc.DrawRectangle( rect ); DrawFocusRect(this, dc, GetLineHighlightRect(m_current), flags);
}
} }
#endif
} }
void wxListMainWindow::HighlightAll( bool on ) void wxListMainWindow::HighlightAll( bool on )