// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "imaggif.h"
#endif
# include "wx/defs.h"
#endif
-#if wxUSE_GIF
+#if wxUSE_IMAGE && wxUSE_GIF
#include "wx/imaggif.h"
#include "wx/gifdecod.h"
#if wxUSE_STREAMS
-bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose, int WXUNUSED(index) )
+bool wxGIFHandler::LoadFile(wxImage *image, wxInputStream& stream,
+ bool verbose, int index)
{
wxGIFDecoder *decod;
int error;
- bool ok;
+ bool ok = TRUE;
+// image->Destroy();
decod = new wxGIFDecoder(&stream, TRUE);
error = decod->ReadGIF();
switch (error)
{
case wxGIF_INVFORMAT:
- wxLogError(_("wxGIFHandler: error in GIF image format."));
+ wxLogError(_("GIF: error in GIF image format."));
break;
case wxGIF_MEMERR:
- wxLogError(_("wxGIFHandler: not enough memory."));
+ wxLogError(_("GIF: not enough memory."));
break;
default:
- wxLogError(_("wxGIFHandler: unknown error!!!"));
+ wxLogError(_("GIF: unknown error!!!"));
break;
}
}
if ((error == wxGIF_TRUNCATED) && verbose)
{
- wxLogWarning(_("wxGIFHandler: data stream seems to be truncated."));
+ wxLogError(_("GIF: data stream seems to be truncated."));
/* go on; image data is OK */
}
- image->Destroy();
- ok = decod->ConvertToImage(image);
+ if (index != -1)
+ {
+ // We're already on index = 0 by default. So no need
+ // to call GoFrame(0) then. On top of that GoFrame doesn't
+ // accept an index of 0. (Instead GoFirstFrame() should be used)
+ // Also if the gif image has only one frame, calling GoFrame(0)
+ // fails because GoFrame() only works with gif animations.
+ // (It fails if IsAnimation() returns FALSE)
+ // All valid reasons to NOT call GoFrame when index equals 0.
+ if (index != 0)
+ {
+ ok = decod->GoFrame(index);
+ }
+ }
+
+ if (ok)
+ {
+ ok = decod->ConvertToImage(image);
+ }
+ else
+ {
+ wxLogError(_("GIF: Invalid gif index."));
+ }
delete decod;
+
return ok;
}
wxOutputStream& WXUNUSED(stream), bool verbose )
{
if (verbose)
- wxLogDebug(wxT("wxGIFHandler is read-only!!"));
+ wxLogDebug(wxT("GIF: the handler is read-only!!"));
return FALSE;
}
bool wxGIFHandler::DoCanRead( wxInputStream& stream )
{
- wxGIFDecoder *decod;
- bool ok;
-
- decod = new wxGIFDecoder(&stream);
- ok = decod->CanRead();
-
- delete decod;
- return ok;
+ wxGIFDecoder decod(&stream);
+ return decod.CanRead();
}
#endif // wxUSE_STREAMS