⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pngread.c

📁 GIS系统支持库Geospatial Data Abstraction Library代码.GDAL is a translator library for raster geospatial dat
💻 C
📖 第 1 页 / 共 4 页
字号:
   if(png_ptr->row_buf[0])   png_read_filter_row(png_ptr, &(png_ptr->row_info),      png_ptr->row_buf + 1, png_ptr->prev_row + 1,      (int)(png_ptr->row_buf[0]));   png_memcpy_check(png_ptr, png_ptr->prev_row, png_ptr->row_buf,      png_ptr->rowbytes + 1);   #if defined(PNG_MNG_FEATURES_SUPPORTED)   if((png_ptr->mng_features_permitted & PNG_FLAG_MNG_FILTER_64) &&      (png_ptr->filter_type == PNG_INTRAPIXEL_DIFFERENCING))   {      /* Intrapixel differencing */      png_do_read_intrapixel(&(png_ptr->row_info), png_ptr->row_buf + 1);   }#endif   if (png_ptr->transformations || (png_ptr->flags&PNG_FLAG_STRIP_ALPHA))      png_do_read_transformations(png_ptr);#if defined(PNG_READ_INTERLACING_SUPPORTED)   /* blow up interlaced rows to full size */   if (png_ptr->interlaced &&      (png_ptr->transformations & PNG_INTERLACE))   {      if (png_ptr->pass < 6)/*       old interface (pre-1.0.9):         png_do_read_interlace(&(png_ptr->row_info),            png_ptr->row_buf + 1, png_ptr->pass, png_ptr->transformations); */         png_do_read_interlace(png_ptr);      if (dsp_row != NULL)         png_combine_row(png_ptr, dsp_row,            png_pass_dsp_mask[png_ptr->pass]);      if (row != NULL)         png_combine_row(png_ptr, row,            png_pass_mask[png_ptr->pass]);   }   else#endif   {      if (row != NULL)         png_combine_row(png_ptr, row, 0xff);      if (dsp_row != NULL)         png_combine_row(png_ptr, dsp_row, 0xff);   }   png_read_finish_row(png_ptr);   if (png_ptr->read_row_fn != NULL)      (*(png_ptr->read_row_fn))(png_ptr, png_ptr->row_number, png_ptr->pass);}#endif /* PNG_NO_SEQUENTIAL_READ_SUPPORTED */#ifndef PNG_NO_SEQUENTIAL_READ_SUPPORTED/* Read one or more rows of image data.  If the image is interlaced, * and png_set_interlace_handling() has been called, the rows need to * contain the contents of the rows from the previous pass.  If the * image has alpha or transparency, and png_handle_alpha()[*] has been * called, the rows contents must be initialized to the contents of the * screen. * * "row" holds the actual image, and pixels are placed in it * as they arrive.  If the image is displayed after each pass, it will * appear to "sparkle" in.  "display_row" can be used to display a * "chunky" progressive image, with finer detail added as it becomes * available.  If you do not want this "chunky" display, you may pass * NULL for display_row.  If you do not want the sparkle display, and * you have not called png_handle_alpha(), you may pass NULL for rows. * If you have called png_handle_alpha(), and the image has either an * alpha channel or a transparency chunk, you must provide a buffer for * rows.  In this case, you do not have to provide a display_row buffer * also, but you may.  If the image is not interlaced, or if you have * not called png_set_interlace_handling(), the display_row buffer will * be ignored, so pass NULL to it. * * [*] png_handle_alpha() does not exist yet, as of libpng version 1.2.8 */void PNGAPIpng_read_rows(png_structp png_ptr, png_bytepp row,   png_bytepp display_row, png_uint_32 num_rows){   png_uint_32 i;   png_bytepp rp;   png_bytepp dp;   png_debug(1, "in png_read_rows\n");   rp = row;   dp = display_row;   if (rp != NULL && dp != NULL)      for (i = 0; i < num_rows; i++)      {         png_bytep rptr = *rp++;         png_bytep dptr = *dp++;         png_read_row(png_ptr, rptr, dptr);      }   else if(rp != NULL)      for (i = 0; i < num_rows; i++)      {         png_bytep rptr = *rp;         png_read_row(png_ptr, rptr, png_bytep_NULL);         rp++;      }   else if(dp != NULL)      for (i = 0; i < num_rows; i++)      {         png_bytep dptr = *dp;         png_read_row(png_ptr, png_bytep_NULL, dptr);         dp++;      }}#endif /* PNG_NO_SEQUENTIAL_READ_SUPPORTED */#ifndef PNG_NO_SEQUENTIAL_READ_SUPPORTED/* Read the entire image.  If the image has an alpha channel or a tRNS * chunk, and you have called png_handle_alpha()[*], you will need to * initialize the image to the current image that PNG will be overlaying. * We set the num_rows again here, in case it was incorrectly set in * png_read_start_row() by a call to png_read_update_info() or * png_start_read_image() if png_set_interlace_handling() wasn't called * prior to either of these functions like it should have been.  You can * only call this function once.  If you desire to have an image for * each pass of a interlaced image, use png_read_rows() instead. * * [*] png_handle_alpha() does not exist yet, as of libpng version 1.2.8 */void PNGAPIpng_read_image(png_structp png_ptr, png_bytepp image){   png_uint_32 i,image_height;   int pass, j;   png_bytepp rp;   png_debug(1, "in png_read_image\n");#ifdef PNG_READ_INTERLACING_SUPPORTED   pass = png_set_interlace_handling(png_ptr);#else   if (png_ptr->interlaced)      png_error(png_ptr,        "Cannot read interlaced image -- interlace handler disabled.");   pass = 1;#endif   image_height=png_ptr->height;   png_ptr->num_rows = image_height; /* Make sure this is set correctly */   for (j = 0; j < pass; j++)   {      rp = image;      for (i = 0; i < image_height; i++)      {         png_read_row(png_ptr, *rp, png_bytep_NULL);         rp++;      }   }}#endif /* PNG_NO_SEQUENTIAL_READ_SUPPORTED */#ifndef PNG_NO_SEQUENTIAL_READ_SUPPORTED/* Read the end of the PNG file.  Will not read past the end of the * file, will verify the end is accurate, and will read any comments * or time information at the end of the file, if info is not NULL. */void PNGAPIpng_read_end(png_structp png_ptr, png_infop info_ptr){   png_byte chunk_length[4];   png_uint_32 length;   png_debug(1, "in png_read_end\n");   png_crc_finish(png_ptr, 0); /* Finish off CRC from last IDAT chunk */   do   {#ifdef PNG_USE_LOCAL_ARRAYS      PNG_IHDR;      PNG_IDAT;      PNG_IEND;      PNG_PLTE;#if defined(PNG_READ_bKGD_SUPPORTED)      PNG_bKGD;#endif#if defined(PNG_READ_cHRM_SUPPORTED)      PNG_cHRM;#endif#if defined(PNG_READ_gAMA_SUPPORTED)      PNG_gAMA;#endif#if defined(PNG_READ_hIST_SUPPORTED)      PNG_hIST;#endif#if defined(PNG_READ_iCCP_SUPPORTED)      PNG_iCCP;#endif#if defined(PNG_READ_iTXt_SUPPORTED)      PNG_iTXt;#endif#if defined(PNG_READ_oFFs_SUPPORTED)      PNG_oFFs;#endif#if defined(PNG_READ_pCAL_SUPPORTED)      PNG_pCAL;#endif#if defined(PNG_READ_pHYs_SUPPORTED)      PNG_pHYs;#endif#if defined(PNG_READ_sBIT_SUPPORTED)      PNG_sBIT;#endif#if defined(PNG_READ_sCAL_SUPPORTED)      PNG_sCAL;#endif#if defined(PNG_READ_sPLT_SUPPORTED)      PNG_sPLT;#endif#if defined(PNG_READ_sRGB_SUPPORTED)      PNG_sRGB;#endif#if defined(PNG_READ_tEXt_SUPPORTED)      PNG_tEXt;#endif#if defined(PNG_READ_tIME_SUPPORTED)      PNG_tIME;#endif#if defined(PNG_READ_tRNS_SUPPORTED)      PNG_tRNS;#endif#if defined(PNG_READ_zTXt_SUPPORTED)      PNG_zTXt;#endif#endif /* PNG_USE_LOCAL_ARRAYS */      png_read_data(png_ptr, chunk_length, 4);      length = png_get_uint_31(png_ptr,chunk_length);      png_reset_crc(png_ptr);      png_crc_read(png_ptr, png_ptr->chunk_name, 4);      png_debug1(0, "Reading %s chunk.\n", png_ptr->chunk_name);      if (!png_memcmp(png_ptr->chunk_name, png_IHDR, 4))         png_handle_IHDR(png_ptr, info_ptr, length);      else if (!png_memcmp(png_ptr->chunk_name, png_IEND, 4))         png_handle_IEND(png_ptr, info_ptr, length);#ifdef PNG_HANDLE_AS_UNKNOWN_SUPPORTED      else if (png_handle_as_unknown(png_ptr, png_ptr->chunk_name))      {         if (!png_memcmp(png_ptr->chunk_name, png_IDAT, 4))         {            if (length > 0 || png_ptr->mode & PNG_AFTER_IDAT)               png_error(png_ptr, "Too many IDAT's found");         }         else            png_ptr->mode |= PNG_AFTER_IDAT;         png_handle_unknown(png_ptr, info_ptr, length);         if (!png_memcmp(png_ptr->chunk_name, png_PLTE, 4))            png_ptr->mode |= PNG_HAVE_PLTE;      }#endif      else if (!png_memcmp(png_ptr->chunk_name, png_IDAT, 4))      {         /* Zero length IDATs are legal after the last IDAT has been          * read, but not after other chunks have been read.          */         if (length > 0 || png_ptr->mode & PNG_AFTER_IDAT)            png_error(png_ptr, "Too many IDAT's found");         png_crc_finish(png_ptr, length);      }      else if (!png_memcmp(png_ptr->chunk_name, png_PLTE, 4))         png_handle_PLTE(png_ptr, info_ptr, length);#if defined(PNG_READ_bKGD_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_bKGD, 4))         png_handle_bKGD(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_cHRM_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_cHRM, 4))         png_handle_cHRM(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_gAMA_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_gAMA, 4))         png_handle_gAMA(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_hIST_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_hIST, 4))         png_handle_hIST(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_oFFs_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_oFFs, 4))         png_handle_oFFs(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_pCAL_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_pCAL, 4))         png_handle_pCAL(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_sCAL_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_sCAL, 4))         png_handle_sCAL(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_pHYs_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_pHYs, 4))         png_handle_pHYs(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_sBIT_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_sBIT, 4))         png_handle_sBIT(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_sRGB_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_sRGB, 4))         png_handle_sRGB(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_iCCP_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_iCCP, 4))         png_handle_iCCP(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_sPLT_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_sPLT, 4))         png_handle_sPLT(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_tEXt_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_tEXt, 4))         png_handle_tEXt(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_tIME_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_tIME, 4))         png_handle_tIME(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_tRNS_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_tRNS, 4))         png_handle_tRNS(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_zTXt_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_zTXt, 4))         png_handle_zTXt(png_ptr, info_ptr, length);#endif#if defined(PNG_READ_iTXt_SUPPORTED)      else if (!png_memcmp(png_ptr->chunk_name, png_iTXt, 4))         png_handle_iTXt(png_ptr, info_ptr, length);#endif      else         png_handle_unknown(png_ptr, info_ptr, length);   } while (!(png_ptr->mode & PNG_HAVE_IEND));}#endif /* PNG_NO_SEQUENTIAL_READ_SUPPORTED *//* free all memory used by the read */void PNGAPIpng_destroy_read_struct(png_structpp png_ptr_ptr, png_infopp info_ptr_ptr,   png_infopp end_info_ptr_ptr){   png_structp png_ptr = NULL;   png_infop info_ptr = NULL, end_info_ptr = NULL;#ifdef PNG_USER_MEM_SUPPORTED   png_free_ptr free_fn;   png_voidp mem_ptr;#endif   png_debug(1, "in png_destroy_read_struct\n");   if (png_ptr_ptr != NULL)      png_ptr = *png_ptr_ptr;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -