From b931f7ee94f9168cc95f2c360647c172cc169adb Mon Sep 17 00:00:00 2001 From: =?utf8?q?V=C3=A1clav=20Slav=C3=ADk?= Date: Fri, 15 Mar 2002 23:59:09 +0000 Subject: [PATCH] applied patch for seeking in GIF images git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@14624 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- docs/latex/wx/image.tex | 11 ++++++----- src/common/imaggif.cpp | 30 +++++++++++++++++++++++++++--- 2 files changed, 33 insertions(+), 8 deletions(-) diff --git a/docs/latex/wx/image.tex b/docs/latex/wx/image.tex index aa5589fcac..5cdd7d29c2 100644 --- a/docs/latex/wx/image.tex +++ b/docs/latex/wx/image.tex @@ -130,9 +130,9 @@ Loads an image from an input stream. \docparam{mimetype}{MIME type string (for example 'image/jpeg')} \docparam{index}{Index of the image to load in the case that the image file contains multiple images. -This is only used by ICO and TIFF handlers. The default value (-1) means +This is only used by GIF, ICO and TIFF handlers. The default value (-1) means "choose the default image" and is interpreted as the first image (index=0) by -the TIFF handler and as the largest and most colourful one by the ICO handler.} +the GIF and TIFF handler and as the largest and most colourful one by the ICO handler.} \wxheading{Remarks} @@ -570,9 +570,9 @@ Loads an image from an input stream. \docparam{mimetype}{MIME type string (for example 'image/jpeg')} \docparam{index}{Index of the image to load in the case that the image file contains multiple images. -This is only used by ICO and TIFF handlers. The default value (-1) means +This is only used by GIF, ICO and TIFF handlers. The default value (-1) means "choose the default image" and is interpreted as the first image (index=0) by -the TIFF handler and as the largest and most colourful one by the ICO handler.} +the GIF and TIFF handler and as the largest and most colourful one by the ICO handler.} \wxheading{Remarks} @@ -588,7 +588,8 @@ hotspot for loaded cursor file: \wxheading{Return value} -TRUE if the operation succeeded, FALSE otherwise. +TRUE if the operation succeeded, FALSE otherwise. If the optional index parameter is out of range, +FALSE is returned and a call to wxLogError() takes place. \wxheading{See also} diff --git a/src/common/imaggif.cpp b/src/common/imaggif.cpp index b8a5229e23..b2a1cdf793 100644 --- a/src/common/imaggif.cpp +++ b/src/common/imaggif.cpp @@ -38,11 +38,12 @@ IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler) #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); @@ -75,7 +76,30 @@ bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose /* go on; image data is OK */ } - 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; -- 2.45.2