X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/91c68292f64a7ca83480a639264f4369b80ea1e5..ad9fb0334fbfe5747b67c09ba714c1f00bd40ff8:/src/generic/wizard.cpp diff --git a/src/generic/wizard.cpp b/src/generic/wizard.cpp index 325ff9974c..cd9c3152d0 100644 --- a/src/generic/wizard.cpp +++ b/src/generic/wizard.cpp @@ -280,6 +280,32 @@ void wxWizard::SetPageSize(const wxSize& size) m_sizePage = size; } +void wxWizard::Fit(const wxWizardPage *page) +{ + // otherwise it will have no effect now as it's too late... + wxASSERT_MSG( !WasCreated(), _T("should be called before RunWizard()!") ); + + wxSize sizeMax; + while ( page ) + { + wxSize size = page->GetBestSize(); + + if ( size.x > sizeMax.x ) + sizeMax.x = size.x; + + if ( size.y > sizeMax.y ) + sizeMax.y = size.y; + + page = page->GetNext(); + } + + if ( sizeMax.x > m_sizePage.x ) + m_sizePage.x = sizeMax.x; + + if ( sizeMax.y > m_sizePage.y ) + m_sizePage.y = sizeMax.y; +} + bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) { wxASSERT_MSG( page != m_page, wxT("this is useless") ); @@ -297,8 +323,7 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) // use these labels to determine if we need to change the bitmap // for this page - wxBitmap PreviousBitmap = wxNullBitmap; - wxBitmap ThisBitmap = wxNullBitmap; + wxBitmap bmpPrev, bmpCur; // check for previous page if ( m_page ) @@ -317,9 +342,9 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) btnLabelWasNext = m_page->GetNext() != (wxWizardPage *)NULL; // Get the bitmap of the previous page (if it exists) - if(m_page->GetBitmap().Ok()) - { - PreviousBitmap = m_page->GetBitmap(); + if ( m_page->GetBitmap().Ok() ) + { + bmpPrev = m_page->GetBitmap(); } } @@ -342,12 +367,13 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) (void)m_page->TransferDataToWindow(); m_page->SetSize(m_x, m_y, m_width, m_height); m_page->Show(); + m_page->SetFocus(); // check if bitmap needs to be updated // update default flag as well - if(m_page->GetBitmap().Ok()) + if ( m_page->GetBitmap().Ok() ) { - ThisBitmap = m_page->GetBitmap(); + bmpCur = m_page->GetBitmap(); bmpIsDefault = FALSE; } @@ -355,7 +381,7 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) // 1) a default bitmap was selected in constructor // 2) this page was constructed with a bitmap // 3) this bitmap is not the previous bitmap - if( m_statbmp && (ThisBitmap != PreviousBitmap) ) + if ( m_statbmp && (bmpCur != bmpPrev) ) { wxBitmap bmp; if ( bmpIsDefault )