X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9b5f1895643cf94b38ac19a4c1151e259310852e..eea4d01c65f9b29baa1193db762b4c6b8144af24:/src/common/imagpnm.cpp?ds=sidebyside diff --git a/src/common/imagpnm.cpp b/src/common/imagpnm.cpp index 86884d7d09..731220450b 100644 --- a/src/common/imagpnm.cpp +++ b/src/common/imagpnm.cpp @@ -11,17 +11,18 @@ #include "wx/wxprec.h" #ifdef __BORLANDC__ -#pragma hdrstop -#endif - -#ifndef WX_PRECOMP + #pragma hdrstop #endif #if wxUSE_IMAGE && wxUSE_PNM #include "wx/imagpnm.h" -#include "wx/log.h" -#include "wx/intl.h" + +#ifndef WX_PRECOMP + #include "wx/intl.h" + #include "wx/log.h" +#endif + #include "wx/txtstrm.h" //----------------------------------------------------------------------------- @@ -68,7 +69,10 @@ bool wxPNMHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose case wxT('5'): // RAW Grey case wxT('6'): break; default: - if (verbose) wxLogError(_("PNM: File format is not recognized.")); + if (verbose) + { + wxLogError(_("PNM: File format is not recognized.")); + } return false; } @@ -84,7 +88,9 @@ bool wxPNMHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose if (!ptr) { if (verbose) + { wxLogError( _("PNM: Couldn't allocate memory.") ); + } return false; } @@ -95,12 +101,17 @@ bool wxPNMHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose for (wxUint32 i=0; i<size; ++i) { value=text_stream.Read32(); + if ( maxval != 255 ) + value = (255 * value)/maxval; *ptr++=(unsigned char)value; // R *ptr++=(unsigned char)value; // G *ptr++=(unsigned char)value; // B if ( !buf_stream ) { - if (verbose) wxLogError(_("PNM: File seems truncated.")); + if (verbose) + { + wxLogError(_("PNM: File seems truncated.")); + } return false; } } @@ -113,11 +124,16 @@ bool wxPNMHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose //this is very slow !!! //I wonder how we can make any better ? value=text_stream.Read32(); + if ( maxval != 255 ) + value = (255 * value)/maxval; *ptr++=(unsigned char)value; if ( !buf_stream ) { - if (verbose) wxLogError(_("PNM: File seems truncated.")); + if (verbose) + { + wxLogError(_("PNM: File seems truncated.")); + } return false; } } @@ -129,18 +145,31 @@ bool wxPNMHandler::LoadFile( wxImage *image, wxInputStream& stream, bool verbose for (wxUint32 i=0; i<size; ++i) { buf_stream.Read(&value,1); + if ( maxval != 255 ) + value = (255 * value)/maxval; *ptr++=value; // R *ptr++=value; // G *ptr++=value; // B if ( !buf_stream ) { - if (verbose) wxLogError(_("PNM: File seems truncated.")); + if (verbose) + { + wxLogError(_("PNM: File seems truncated.")); + } return false; } } } - if (c=='6') // Raw RGB - buf_stream.Read( ptr, 3*width*height ); + + if ( c=='6' ) // Raw RGB + { + buf_stream.Read(ptr, 3*width*height); + if ( maxval != 255 ) + { + for ( unsigned i = 0; i < 3*width*height; i++ ) + ptr[i] = (255 * ptr[i])/maxval; + } + } image->SetMask( false ); @@ -165,6 +194,7 @@ bool wxPNMHandler::DoCanRead( wxInputStream& stream ) { Skip_Comment(stream); + // it's ok to modify the stream position here if ( stream.GetC() == 'P' ) { switch ( stream.GetC() ) @@ -183,4 +213,4 @@ bool wxPNMHandler::DoCanRead( wxInputStream& stream ) #endif // wxUSE_STREAMS -#endif // wxUSE_PNM +#endif // wxUSE_IMAGE && wxUSE_PNM