* Fix EDA_LIST_DIALOG which had incorrect wxWidgets version check in

column sizing. Now the columns are sized to fit either the headers or
  items, depending on which is widest
This commit is contained in:
Brian Sidebotham 2015-06-02 23:34:55 +01:00
parent 064e8a82e1
commit 8afeba3325
1 changed files with 4 additions and 42 deletions

View File

@ -89,50 +89,12 @@ void EDA_LIST_DIALOG::initDialog( const wxArrayString& aItemHeaders,
for( unsigned col = 0; col < aItemHeaders.Count(); ++col ) for( unsigned col = 0; col < aItemHeaders.Count(); ++col )
{ {
m_listBox->SetColumnWidth( col, wxLIST_AUTOSIZE ); m_listBox->SetColumnWidth( col, wxLIST_AUTOSIZE );
int columnwidth = m_listBox->GetColumnWidth( col );
#if !wxCHECK_VERSION( 2, 9, 0 ) m_listBox->SetColumnWidth( col, wxLIST_AUTOSIZE_USEHEADER );
// include the column header in the width decision, wx 2.8 forgets this: int headerwidth = m_listBox->GetColumnWidth( col );
wxListItem col_info; m_listBox->SetColumnWidth( col, std::max( columnwidth, headerwidth ) );
m_listBox->GetColumn( col, col_info );
wxString header = col_info.GetText();
int headerz = GetTextSize( header, m_listBox ).x;
// A reasonable column header has about 14 pixels of whitespace
// in addition to the width of the text itself.
headerz += 14;
if( headerz > col_info.GetWidth() )
{
col_info.SetWidth( headerz );
m_listBox->SetColumn( col, col_info );
}
#endif
} }
#if !wxCHECK_VERSION( 2, 9, 0 )
// wx 2.8.x has bug in wxListCtrl WRT honoring the omission of wxHSCROLL, at least
// on gtk2. Fix by setting minimum width so horizontal wxListCtrl scrolling is
// not needed on 2.8.x because of minumum visible width setting:
{
int width = 0;
for( unsigned col = 0; col < aItemHeaders.Count(); ++col )
{
width += m_listBox->GetColumnWidth( col ) + 2;
}
wxSize sz = m_listBox->GetSize();
sz.SetWidth( width );
m_listBox->SetMinSize( sz );
}
#endif
if( !!aSelection ) if( !!aSelection )
{ {
for( unsigned row = 0; row < m_itemsListCp->size(); ++row ) for( unsigned row = 0; row < m_itemsListCp->size(); ++row )