X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d9af3670ee77b9ff4cc46416137ffc92a9ce973d..a85ad1db05e7d940383fdf75671f1aa69dacbb42:/src/generic/wizard.cpp diff --git a/src/generic/wizard.cpp b/src/generic/wizard.cpp index dcada77450..5fcf9f9207 100644 --- a/src/generic/wizard.cpp +++ b/src/generic/wizard.cpp @@ -682,13 +682,13 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward) DoWizardLayout(); } - if (GetBitmapPlacement()) + if (GetBitmapPlacement() && m_statbmp) { ResizeBitmap(bmp); - + if ( !bmp.IsSameAs(bmpPrev) ) m_statbmp->SetBitmap(bmp); - + if (m_usingSizer) m_sizerPage->RecalcSizes(); } @@ -924,16 +924,16 @@ bool wxWizard::DoLayoutAdaptation() // Create a scrolled window and reparent wxScrolledWindow* scrolledWindow = new wxScrolledWindow(page, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL|wxVSCROLL|wxHSCROLL|wxBORDER_NONE); wxSizer* oldSizer = page->GetSizer(); - + wxSizer* newSizer = new wxBoxSizer(wxVERTICAL); newSizer->Add(scrolledWindow,1, wxEXPAND, 0); - + page->SetSizer(newSizer, false /* don't delete the old sizer */); - + scrolledWindow->SetSizer(oldSizer); - + wxStandardDialogLayoutAdapter::DoReparentControls(page, scrolledWindow); - + pages.Append(page); windows.Append(scrolledWindow); } @@ -958,10 +958,12 @@ bool wxWizard::ResizeBitmap(wxBitmap& bmp) if (bmp.Ok()) { wxSize pageSize = m_sizerPage->GetSize(); + if (pageSize == wxSize(0,0)) + pageSize = GetPageSize(); int bitmapWidth = wxMax(bmp.GetWidth(), GetMinimumBitmapWidth()); int bitmapHeight = pageSize.y; - if (bmp.GetHeight() != bitmapHeight) + if (!m_statbmp->GetBitmap().Ok() || m_statbmp->GetBitmap().GetHeight() != bitmapHeight) { wxBitmap bitmap(bitmapWidth, bitmapHeight); { @@ -981,16 +983,16 @@ bool wxWizard::ResizeBitmap(wxBitmap& bmp) if (GetBitmapPlacement() & wxWIZARD_HALIGN_LEFT) x = 0; else if (GetBitmapPlacement() & wxWIZARD_HALIGN_RIGHT) - x = bitmapWidth - GetBitmap().GetWidth(); + x = bitmapWidth - bmp.GetWidth(); else - x = (bitmapWidth - GetBitmap().GetWidth())/2; + x = (bitmapWidth - bmp.GetWidth())/2; if (GetBitmapPlacement() & wxWIZARD_VALIGN_TOP) y = 0; else if (GetBitmapPlacement() & wxWIZARD_VALIGN_BOTTOM) - y = bitmapHeight - GetBitmap().GetHeight(); + y = bitmapHeight - bmp.GetHeight(); else - y = (bitmapHeight - GetBitmap().GetHeight())/2; + y = (bitmapHeight - bmp.GetHeight())/2; dc.DrawBitmap(bmp, x, y, true); dc.SelectObject(wxNullBitmap);