Revert last change moving wxFloodFill from imagfill.cpp to dcbase.cpp, which broke compilation across the board when wxUSE_IMAGE is defined.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32542 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
4a10132773
commit
f842e673f6
@ -984,38 +984,3 @@ void wxDCBase::CalculateEllipticPoints( wxList* points,
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
bool wxDoFloodFill(wxDC *dc, wxCoord x, wxCoord y,
|
|
||||||
const wxColour& col, int style)
|
|
||||||
{
|
|
||||||
#if wxUSE_IMAGE
|
|
||||||
if (dc->GetBrush().GetStyle() == wxTRANSPARENT)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
int height = 0;
|
|
||||||
int width = 0;
|
|
||||||
dc->GetSize(&width, &height);
|
|
||||||
|
|
||||||
//it would be nice to fail if we don't get a sensible size...
|
|
||||||
wxCHECK_MSG(width >= 1 && height >= 1, false,
|
|
||||||
wxT("In FloodFill, dc.GetSize routine failed, method not supported by this DC"));
|
|
||||||
|
|
||||||
//this is much faster than doing the individual pixels
|
|
||||||
wxMemoryDC memdc;
|
|
||||||
wxBitmap bitmap(width, height);
|
|
||||||
memdc.SelectObject(bitmap);
|
|
||||||
memdc.Blit(0, 0, width, height, dc, 0, 0);
|
|
||||||
memdc.SelectObject(wxNullBitmap);
|
|
||||||
|
|
||||||
wxImage image = bitmap.ConvertToImage();
|
|
||||||
wxImageFloodFill(&image, x,y, dc->GetBrush(), col, style,
|
|
||||||
dc->GetLogicalFunction());
|
|
||||||
bitmap = wxBitmap(image);
|
|
||||||
memdc.SelectObject(bitmap);
|
|
||||||
dc->Blit(0, 0, width, height, &memdc, 0, 0);
|
|
||||||
memdc.SelectObject(wxNullBitmap);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
#else
|
|
||||||
return false;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
@ -273,6 +273,37 @@ wxImageFloodFill(wxImage *image,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool wxDoFloodFill(wxDC *dc, wxCoord x, wxCoord y,
|
||||||
|
const wxColour& col, int style)
|
||||||
|
{
|
||||||
|
if (dc->GetBrush().GetStyle() == wxTRANSPARENT)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
int height = 0;
|
||||||
|
int width = 0;
|
||||||
|
dc->GetSize(&width, &height);
|
||||||
|
|
||||||
|
//it would be nice to fail if we don't get a sensible size...
|
||||||
|
wxCHECK_MSG(width >= 1 && height >= 1, false,
|
||||||
|
wxT("In FloodFill, dc.GetSize routine failed, method not supported by this DC"));
|
||||||
|
|
||||||
|
//this is much faster than doing the individual pixels
|
||||||
|
wxMemoryDC memdc;
|
||||||
|
wxBitmap bitmap(width, height);
|
||||||
|
memdc.SelectObject(bitmap);
|
||||||
|
memdc.Blit(0, 0, width, height, dc, 0, 0);
|
||||||
|
memdc.SelectObject(wxNullBitmap);
|
||||||
|
|
||||||
|
wxImage image = bitmap.ConvertToImage();
|
||||||
|
wxImageFloodFill(&image, x,y, dc->GetBrush(), col, style,
|
||||||
|
dc->GetLogicalFunction());
|
||||||
|
bitmap = wxBitmap(image);
|
||||||
|
memdc.SelectObject(bitmap);
|
||||||
|
dc->Blit(0, 0, width, height, &memdc, 0, 0);
|
||||||
|
memdc.SelectObject(wxNullBitmap);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // wxUSE_IMAGE
|
#endif // wxUSE_IMAGE
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user