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:
parent
c70ad28733
commit
d67fc8b735
@ -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 )
|
||||||
|
Loading…
Reference in New Issue
Block a user