X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/274b7a40ef7abdd6324c545578be96a529ec8eb9..9d5507f7a2701395e1d5c121bd877bb9066ee6ea:/src/mac/carbon/imaglist.cpp diff --git a/src/mac/carbon/imaglist.cpp b/src/mac/carbon/imaglist.cpp index 466cc56ce1..054cdeb734 100644 --- a/src/mac/carbon/imaglist.cpp +++ b/src/mac/carbon/imaglist.cpp @@ -1,25 +1,27 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: generic/imaglist.cpp +// Name: src/mac/carbon/imaglist.cpp // Purpose: // Author: Robert Roebling -// Id: $id$ +// RCS_ID: $Id$ // Copyright: (c) 1998 Robert Roebling // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #include "wx/wxprec.h" -#if wxUSE_IMAGLIST - #ifdef __BORLANDC__ #pragma hdrstop #endif -#include "wx/defs.h" +#if wxUSE_IMAGLIST + #include "wx/imaglist.h" -#include "wx/icon.h" -#include "wx/image.h" -#include "wx/dc.h" + +#ifndef WX_PRECOMP + #include "wx/dc.h" + #include "wx/icon.h" + #include "wx/image.h" +#endif IMPLEMENT_DYNAMIC_CLASS(wxImageList, wxObject) @@ -72,12 +74,27 @@ int wxImageList::Add( const wxIcon &bitmap ) int wxImageList::Add( const wxBitmap &bitmap ) { - wxASSERT_MSG( (bitmap.GetWidth() == m_width && bitmap.GetHeight() == m_height) + wxASSERT_MSG( (bitmap.GetWidth() >= m_width && bitmap.GetHeight() == m_height) || (m_width == 0 && m_height == 0), _T("invalid bitmap size in wxImageList: this might work ") _T("on this platform but definitely won't under Windows.") ); - m_images.Append( new wxBitmap( bitmap ) ); + // Mimic behavior of Windows ImageList_Add that automatically breaks up the added + // bitmap into sub-images of the correct size + if (m_width > 0 && bitmap.GetWidth() > m_width && bitmap.GetHeight() >= m_height) + { + int numImages = bitmap.GetWidth() / m_width; + for (int subIndex = 0; subIndex < numImages; subIndex++) + { + wxRect rect(m_width * subIndex, 0, m_width, m_height); + wxBitmap tmpBmp = bitmap.GetSubBitmap(rect); + m_images.Append( new wxBitmap(tmpBmp) ); + } + } + else + { + m_images.Append( new wxBitmap(bitmap) ); + } if (m_width == 0 && m_height == 0) { @@ -192,6 +209,34 @@ bool wxImageList::Replace( int index, const wxIcon &bitmap ) return true; } +bool wxImageList::Replace( int index, const wxBitmap &bitmap, const wxBitmap &mask ) +{ + wxList::compatibility_iterator node = m_images.Item( index ); + + wxCHECK_MSG( node, false, wxT("wrong index in image list") ); + + wxBitmap* newBitmap = new wxBitmap(bitmap); + + if (index == (int) m_images.GetCount() - 1) + { + delete node->GetData(); + m_images.Erase( node ); + m_images.Append( newBitmap ); + } + else + { + wxList::compatibility_iterator next = node->GetNext(); + delete node->GetData(); + m_images.Erase( node ); + m_images.Insert( next, newBitmap ); + } + + if (mask.Ok()) + newBitmap->SetMask(new wxMask(mask)); + + return true; +} + bool wxImageList::Remove( int index ) { wxList::compatibility_iterator node = m_images.Item( index ); @@ -262,4 +307,3 @@ bool wxImageList::Draw( } #endif // wxUSE_IMAGLIST -