X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c9fcf5817fe8079ebf2f7a51aef8035ca25ab52e..532c773634cccf5c19f42aac5d2425ed3e7bb12a:/src/common/imagpng.cpp diff --git a/src/common/imagpng.cpp b/src/common/imagpng.cpp index bdbe0c5267..151d3c9986 100644 --- a/src/common/imagpng.cpp +++ b/src/common/imagpng.cpp @@ -11,7 +11,7 @@ // declarations // ============================================================================ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "imagpng.h" #endif @@ -74,7 +74,7 @@ enum Transparency // return the kind of transparency needed for this image assuming that it does // have transparent pixels, i.e. either Transparency_Alpha or Transparency_Mask static Transparency -CheckTransparency(const unsigned char *ptr, +CheckTransparency(unsigned char **lines, png_uint_32 x, png_uint_32 y, png_uint_32 w, png_uint_32 h, size_t numColBytes); @@ -210,30 +210,30 @@ PNGLINKAGEMODE wx_png_warning(png_structp png_ptr, png_const_charp message) // need a full blown alpha channel in wxImage // // parameters: -// ptr the start of the data to examine +// lines raw PNG data // x, y starting position // w, h size of the image // numColBytes number of colour bytes (1 for grey scale, 3 for RGB) // (NB: alpha always follows the colour bytes) Transparency -CheckTransparency(const unsigned char *ptr, +CheckTransparency(unsigned char **lines, png_uint_32 x, png_uint_32 y, png_uint_32 w, png_uint_32 h, size_t numColBytes) { - // we start from (x + 1, y) - x++; - // suppose that a mask will suffice and check all the remaining alpha // values to see if it does - unsigned const char *ptr2 = ptr; - for ( png_uint_32 y2 = y; y2 < h; y2++ ) + for ( ; y < h; y++ ) { + // each pixel is numColBytes+1 bytes, offset into the current line by + // the current x position + unsigned const char *ptr = lines[y] + (x * (numColBytes + 1)); + for ( png_uint_32 x2 = x; x2 < w; x2++ ) { // skip the grey or colour byte(s) - ptr2 += numColBytes; + ptr += numColBytes; - unsigned char a2 = *ptr2++; + unsigned char a2 = *ptr++; if ( !IsTransparent(a2) && !IsOpaque(a2) ) { @@ -365,7 +365,7 @@ void CopyDataFromPNG(wxImage *image, // only, otherwisewe need the latter transparency = CheckTransparency ( - ptrSrc, + lines, x, y, width, height, 1 @@ -437,7 +437,7 @@ void CopyDataFromPNG(wxImage *image, { transparency = CheckTransparency ( - ptrSrc, + lines, x, y, width, height, 3