X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f80bf901946b8b8013b98b51c2c2fd2bd195fe80..67d7821742674d740f1a14e300ea5f446310fd17:/src/generic/wizard.cpp diff --git a/src/generic/wizard.cpp b/src/generic/wizard.cpp index 4192ced088..eed6e10755 100644 --- a/src/generic/wizard.cpp +++ b/src/generic/wizard.cpp @@ -86,13 +86,15 @@ wxWizardPage::wxWizardPage(wxWizard *parent, { if ( resource != NULL ) { +#if wxUSE_RESOURCES if ( !LoadFromResource(this, resource) ) { wxFAIL_MSG(wxT("wxWizardPage LoadFromResource failed!!!!")); } +#endif // wxUSE_RESOURCES } - m_PageBitmap = bitmap; + m_bitmap = bitmap; // initially the page is hidden, it's shown only when it becomes current Hide(); @@ -131,6 +133,7 @@ bool wxWizard::Create(wxWindow *parent, { m_posWizard = pos; m_bitmap = bitmap ; + // just create the dialog itself here, the controls will be created in // DoCreateControls() called later when we know our final size m_page = (wxWizardPage *)NULL; @@ -264,9 +267,19 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) // button or not (initially the label is "Next") bool btnLabelWasNext = TRUE; - // and this tells us whether we already had the default bitmap before - int bmpWasDefault; + // Modified 10-20-2001 Robert Cavanaugh. + // Fixed bug for displaying a new bitmap + // in each *consecutive* page + + // flag to indicate if this page uses a new bitmap + bool bmpIsDefault = TRUE; + + // use these labels to determine if we need to change the bitmap + // for this page + wxBitmap PreviousBitmap = wxNullBitmap; + wxBitmap ThisBitmap = wxNullBitmap; + // check for previous page if ( m_page ) { // send the event to the old page @@ -281,15 +294,15 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) m_page->Hide(); btnLabelWasNext = m_page->GetNext() != (wxWizardPage *)NULL; - bmpWasDefault = !m_page->GetBitmap().Ok(); - } - else // no previous page + + // Get the bitmap of the previous page (if it exists) + if(m_page->GetBitmap().Ok()) { - // always set the bitmap - bmpWasDefault = -1; + PreviousBitmap = m_page->GetBitmap(); + } } - // set the new one + // set the new page m_page = page; // is this the end? @@ -297,11 +310,10 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) { // terminate successfully EndModal(wxID_OK); - return TRUE; } - // send the event to the new page now + // send the change event to the new page now wxWizardEvent event(wxEVT_WIZARD_PAGE_CHANGED, GetId(), goingForward); (void)m_page->GetEventHandler()->ProcessEvent(event); @@ -310,9 +322,19 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) m_page->SetSize(m_x, m_y, m_width, m_height); m_page->Show(); - // change the bitmap if necessary (and if we have it at all) - int bmpIsDefault = !m_page->GetBitmap().Ok(); - if ( m_statbmp && (bmpIsDefault != bmpWasDefault) ) + // check if bitmap needs to be updated + // update default flag as well + if(m_page->GetBitmap().Ok()) + { + ThisBitmap = m_page->GetBitmap(); + bmpIsDefault = FALSE; + } + + // change the bitmap if: + // 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) ) { wxBitmap bmp; if ( bmpIsDefault )