if ( item->GetWindow() )
item->GetWindow()->SetContainingSizer( this );
+ if ( item->GetSizer() )
+ item->GetSizer()->SetContainingWindow( m_containingWindow );
+
return item;
}
AdjustForGrowables(sz);
wxSizerItemList::const_iterator i = m_children.begin();
+ const wxSizerItemList::const_iterator end = m_children.end();
+
int y = 0;
for ( int r = 0; r < nrows; r++ )
{
{
// this row is entirely hidden, skip it
for ( int c = 0; c < ncols; c++ )
+ {
+ if ( i == end )
+ return;
+
++i;
+ }
continue;
}
h = hrow;
int x = 0;
- for ( int c = 0; c < ncols; c++, ++i )
+ for ( int c = 0; c < ncols && i != end; c++, ++i )
{
const int wcol = m_colWidths[c];
if ( wcol == -1 )
continue;
- // check if there are any remaining children: it may happen that
- // the last row is incomplete
- if ( i == m_children.end() )
- {
- wxASSERT_MSG( r == nrows - 1, _T("too few items") );
-
- return;
- }
-
int w = sz.x - x; // max possible value, ensure we don't overflow
if ( wcol < w )
w = wcol;
x += wcol + m_hgap;
}
+ if ( i == end )
+ return;
+
y += hrow + m_vgap;
}
}
// the amount of free space which we should redistribute among the
// stretchable items (i.e. those with non zero proportion)
- const int delta = SizeInMajorDir(m_size) - SizeInMajorDir(m_minSize);
+ int delta = SizeInMajorDir(m_size) - SizeInMajorDir(m_minSize);
// the position at which we put the next child
wxPoint pt(m_position);
const wxCoord totalMinorSize = SizeInMinorDir(m_size);
+ int totalProportion = m_totalProportion;
for ( wxSizerItemList::const_iterator i = m_children.begin();
i != m_children.end();
++i )
// adjust the size in the major direction using the proportion
wxCoord majorSize = SizeInMajorDir(sizeThis);
- if ( item->GetProportion() )
+ const int propItem = item->GetProportion();
+ if ( propItem )
{
- // as at least one visible item has non-zero proportion the total
- // proportion must be non zero
- majorSize += (delta * item->GetProportion()) / m_totalProportion;
+ const int deltaItem = (delta * propItem) / totalProportion;
+
+ majorSize += deltaItem;
+
+ delta -= deltaItem;
+ totalProportion -= propItem;
}
Add((wxWindow*)m_buttonNegative, 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3);
}
- // according to HIG, in explicit apply windows the order is:
+ // according to HIG, in explicit apply windows the order is:
// [ Help Apply Cancel OK ]
if (m_buttonApply)
Add((wxWindow*)m_buttonApply, 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3);