Commit 1e26b23a authored by Olivier Teulière's avatar Olivier Teulière

* skins2/src/generic_layout.cpp: Fixed a resizing bug (the invisible controls

   were drawn when resizing the layout)
parent 986744e6
...@@ -144,11 +144,6 @@ void GenericLayout::onControlUpdate( const CtrlGeneric &rCtrl, ...@@ -144,11 +144,6 @@ void GenericLayout::onControlUpdate( const CtrlGeneric &rCtrl,
void GenericLayout::resize( int width, int height ) void GenericLayout::resize( int width, int height )
{ {
if( width == m_width && height == m_height )
{
return;
}
// Check boundaries // Check boundaries
if( width < m_minWidth ) if( width < m_minWidth )
{ {
...@@ -167,6 +162,11 @@ void GenericLayout::resize( int width, int height ) ...@@ -167,6 +162,11 @@ void GenericLayout::resize( int width, int height )
height = m_maxHeight; height = m_maxHeight;
} }
if( width == m_width && height == m_height )
{
return;
}
// Update the window size // Update the window size
m_width = width; m_width = width;
m_height = height; m_height = height;
...@@ -183,12 +183,12 @@ void GenericLayout::resize( int width, int height ) ...@@ -183,12 +183,12 @@ void GenericLayout::resize( int width, int height )
list<LayeredControl>::const_iterator iter; list<LayeredControl>::const_iterator iter;
for( iter = m_controlList.begin(); iter != m_controlList.end(); iter++ ) for( iter = m_controlList.begin(); iter != m_controlList.end(); iter++ )
{ {
(*iter).m_pControl->onResize(); iter->m_pControl->onResize();
const Position *pPos = (*iter).m_pControl->getPosition(); const Position *pPos = iter->m_pControl->getPosition();
if( pPos ) if( pPos && iter->m_pControl->isVisible() )
{ {
(*iter).m_pControl->draw( *m_pImage, pPos->getLeft(), iter->m_pControl->draw( *m_pImage, pPos->getLeft(),
pPos->getTop() ); pPos->getTop() );
} }
} }
...@@ -223,7 +223,7 @@ void GenericLayout::refreshRect( int x, int y, int width, int height ) ...@@ -223,7 +223,7 @@ void GenericLayout::refreshRect( int x, int y, int width, int height )
{ {
CtrlGeneric *pCtrl = (*iter).m_pControl; CtrlGeneric *pCtrl = (*iter).m_pControl;
const Position *pPos = pCtrl->getPosition(); const Position *pPos = pCtrl->getPosition();
if( pCtrl->isVisible() && pPos ) if( pPos && pCtrl->isVisible() )
{ {
pCtrl->draw( *m_pImage, pPos->getLeft(), pPos->getTop() ); pCtrl->draw( *m_pImage, pPos->getLeft(), pPos->getTop() );
// Remember the video control (we assume there is at most one video // Remember the video control (we assume there is at most one video
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment