亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pngread.c

?? qtopia-phone-2.2.0下png工具庫源代碼實現(xiàn)。
?? C
?? 第 1 頁 / 共 3 頁
字號:
   png_read_transform_info(png_ptr, info_ptr);}/* Initialize palette, background, etc, after transformations * are set, but before any reading takes place.  This allows * the user to obtain a gamma-corrected palette, for example. * If the user doesn't call this, we will do it ourselves. */void PNGAPIpng_start_read_image(png_structp png_ptr){   png_debug(1, "in png_start_read_image\n");   /* save jump buffer and error functions */   if (!(png_ptr->flags & PNG_FLAG_ROW_INIT))      png_read_start_row(png_ptr);}void PNGAPIpng_read_row(png_structp png_ptr, png_bytep row, png_bytep dsp_row){#ifdef PNG_USE_LOCAL_ARRAYS   PNG_IDAT;   const int png_pass_dsp_mask[7] = {0xff, 0x0f, 0xff, 0x33, 0xff, 0x55, 0xff};   const int png_pass_mask[7] = {0x80, 0x08, 0x88, 0x22, 0xaa, 0x55, 0xff};#endif   int ret;   png_debug2(1, "in png_read_row (row %lu, pass %d)\n",      png_ptr->row_number, png_ptr->pass);   /* save jump buffer and error functions */   if (!(png_ptr->flags & PNG_FLAG_ROW_INIT))      png_read_start_row(png_ptr);   if (png_ptr->row_number == 0 && png_ptr->pass == 0)   {   /* check for transforms that have been set but were defined out */#if defined(PNG_WRITE_INVERT_SUPPORTED) && !defined(PNG_READ_INVERT_SUPPORTED)   if (png_ptr->transformations & PNG_INVERT_MONO)      png_warning(png_ptr, "PNG_READ_INVERT_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_FILLER_SUPPORTED) && !defined(PNG_READ_FILLER_SUPPORTED)   if (png_ptr->transformations & PNG_FILLER)      png_warning(png_ptr, "PNG_READ_FILLER_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_PACKSWAP_SUPPORTED) && !defined(PNG_READ_PACKSWAP_SUPPORTED)   if (png_ptr->transformations & PNG_PACKSWAP)      png_warning(png_ptr, "PNG_READ_PACKSWAP_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_PACK_SUPPORTED) && !defined(PNG_READ_PACK_SUPPORTED)   if (png_ptr->transformations & PNG_PACK)      png_warning(png_ptr, "PNG_READ_PACK_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_SHIFT_SUPPORTED) && !defined(PNG_READ_SHIFT_SUPPORTED)   if (png_ptr->transformations & PNG_SHIFT)      png_warning(png_ptr, "PNG_READ_SHIFT_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_BGR_SUPPORTED) && !defined(PNG_READ_BGR_SUPPORTED)   if (png_ptr->transformations & PNG_BGR)      png_warning(png_ptr, "PNG_READ_BGR_SUPPORTED is not defined.");#endif#if defined(PNG_WRITE_SWAP_SUPPORTED) && !defined(PNG_READ_SWAP_SUPPORTED)   if (png_ptr->transformations & PNG_SWAP_BYTES)      png_warning(png_ptr, "PNG_READ_SWAP_SUPPORTED is not defined.");#endif   }#if defined(PNG_READ_INTERLACING_SUPPORTED)   /* if interlaced and we do not need a new row, combine row and return */   if (png_ptr->interlaced && (png_ptr->transformations & PNG_INTERLACE))   {      switch (png_ptr->pass)      {         case 0:            if (png_ptr->row_number & 0x07)            {               if (dsp_row != NULL)                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 1:            if ((png_ptr->row_number & 0x07) || png_ptr->width < 5)            {               if (dsp_row != NULL)                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 2:            if ((png_ptr->row_number & 0x07) != 4)            {               if (dsp_row != NULL && (png_ptr->row_number & 4))                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 3:            if ((png_ptr->row_number & 3) || png_ptr->width < 3)            {               if (dsp_row != NULL)                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 4:            if ((png_ptr->row_number & 3) != 2)            {               if (dsp_row != NULL && (png_ptr->row_number & 2))                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 5:            if ((png_ptr->row_number & 1) || png_ptr->width < 2)            {               if (dsp_row != NULL)                  png_combine_row(png_ptr, dsp_row,                     png_pass_dsp_mask[png_ptr->pass]);               png_read_finish_row(png_ptr);               return;            }            break;         case 6:            if (!(png_ptr->row_number & 1))            {               png_read_finish_row(png_ptr);               return;            }            break;      }   }#endif   if (!(png_ptr->mode & PNG_HAVE_IDAT))      png_error(png_ptr, "Invalid attempt to read row data");   png_ptr->zstream.next_out = png_ptr->row_buf;   png_ptr->zstream.avail_out = (uInt)png_ptr->irowbytes;   do   {      if (!(png_ptr->zstream.avail_in))      {         while (!png_ptr->idat_size)         {            png_byte chunk_length[4];            png_crc_finish(png_ptr, 0);            png_read_data(png_ptr, chunk_length, 4);            png_ptr->idat_size = png_get_uint_32(chunk_length);            png_reset_crc(png_ptr);            png_crc_read(png_ptr, png_ptr->chunk_name, 4);            if (png_memcmp(png_ptr->chunk_name, png_IDAT, 4))               png_error(png_ptr, "Not enough image data");         }         png_ptr->zstream.avail_in = (uInt)png_ptr->zbuf_size;         png_ptr->zstream.next_in = png_ptr->zbuf;         if (png_ptr->zbuf_size > png_ptr->idat_size)            png_ptr->zstream.avail_in = (uInt)png_ptr->idat_size;         png_crc_read(png_ptr, png_ptr->zbuf,            (png_size_t)png_ptr->zstream.avail_in);         png_ptr->idat_size -= png_ptr->zstream.avail_in;      }      ret = inflate(&png_ptr->zstream, Z_PARTIAL_FLUSH);      if (ret == Z_STREAM_END)      {         if (png_ptr->zstream.avail_out || png_ptr->zstream.avail_in ||            png_ptr->idat_size)            png_error(png_ptr, "Extra compressed data");         png_ptr->mode |= PNG_AFTER_IDAT;         png_ptr->flags |= PNG_FLAG_ZLIB_FINISHED;         break;      }      if (ret != Z_OK)         png_error(png_ptr, png_ptr->zstream.msg ? png_ptr->zstream.msg :                   "Decompression error");   } while (png_ptr->zstream.avail_out);   png_ptr->row_info.color_type = png_ptr->color_type;   png_ptr->row_info.width = png_ptr->iwidth;   png_ptr->row_info.channels = png_ptr->channels;   png_ptr->row_info.bit_depth = png_ptr->bit_depth;   png_ptr->row_info.pixel_depth = png_ptr->pixel_depth;   png_ptr->row_info.rowbytes = ((png_ptr->row_info.width *      (png_uint_32)png_ptr->row_info.pixel_depth + 7) >> 3);   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_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);}/* 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.0.9 */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");   /* save jump buffer and error functions */   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, NULL);         rp++;      }   else if(dp != NULL)      for (i = 0; i < num_rows; i++)      {         png_bytep dptr = *dp;         png_read_row(png_ptr, NULL, dptr);         dp++;      }}/* 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.0.9 */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");   /* save jump buffer and error functions */#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, NULL);         rp++;      }   }}/* 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");   /* save jump buffer and error functions */   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_GLOBAL_ARRAYS */      png_read_data(png_ptr, chunk_length, 4);      length = png_get_uint_32(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)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合咪咪久久| 欧美视频你懂的| 国产一区二区不卡在线| 久久机这里只有精品| 麻豆久久一区二区| 久久精品久久99精品久久| 免费欧美在线视频| 麻豆精品一区二区三区| 精品午夜一区二区三区在线观看 | 国产一区二区调教| 国模娜娜一区二区三区| 激情文学综合插| 国产在线精品不卡| 国产风韵犹存在线视精品| 国产激情偷乱视频一区二区三区| 国产成人精品亚洲午夜麻豆| 岛国精品在线观看| 成人av小说网| 欧美影视一区二区三区| 欧美剧情片在线观看| 日韩欧美国产综合| 国产亚洲精品超碰| 亚洲图片另类小说| 视频一区国产视频| 国产一区二区在线观看免费| 成人app在线观看| 91成人看片片| 日韩一区二区三区电影| 国产无遮挡一区二区三区毛片日本| 国产精品嫩草影院com| 亚洲伊人色欲综合网| 天天色综合成人网| 国产老肥熟一区二区三区| 97久久久精品综合88久久| 欧美日韩国产不卡| 久久久久久久久蜜桃| 18成人在线视频| 日韩有码一区二区三区| 国产乱码精品1区2区3区| 日本韩国一区二区| 欧美大片在线观看一区二区| 中文字幕 久热精品 视频在线| 亚洲免费观看高清完整版在线 | 福利一区福利二区| 欧美自拍偷拍午夜视频| 精品国产网站在线观看| 亚洲婷婷综合色高清在线| 丝袜a∨在线一区二区三区不卡| 国产一区二区中文字幕| 欧美午夜视频网站| 国产欧美综合色| 肉肉av福利一精品导航| 国产激情一区二区三区桃花岛亚洲| 91视频一区二区| 欧美成人vr18sexvr| 日韩理论在线观看| 国产真实乱对白精彩久久| 欧美曰成人黄网| 久久久精品影视| 视频一区二区中文字幕| 91碰在线视频| 久久夜色精品国产欧美乱极品| 一区二区三区日韩欧美| 国产成人综合在线观看| 欧美日韩国产123区| 中文字幕亚洲一区二区av在线| 蜜桃视频在线观看一区| 在线免费观看视频一区| 国产精品丝袜久久久久久app| 久久精品国产久精国产爱| 欧美性受xxxx黑人xyx| 国产精品国产三级国产a| 麻豆精品国产91久久久久久| 欧美综合色免费| 日韩美女啊v在线免费观看| 国产一区高清在线| 日韩一区二区免费电影| 亚洲最大的成人av| 99在线精品观看| 国产欧美一区二区精品婷婷 | 欧美蜜桃一区二区三区| 亚洲少妇中出一区| 成人精品一区二区三区中文字幕| 精品免费一区二区三区| 天天做天天摸天天爽国产一区 | 99亚偷拍自图区亚洲| 国产日韩欧美激情| 国产一区二区三区免费| 日韩欧美久久久| 久久精品国产一区二区三区免费看| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 国产婷婷一区二区| 国产乱码一区二区三区| 精品播放一区二区| 激情深爱一区二区| 欧美精品一区二区精品网| 另类成人小视频在线| 日韩一区二区三区免费观看| 免费成人在线视频观看| 日韩欧美不卡在线观看视频| 日本aⅴ免费视频一区二区三区 | 亚洲精品视频一区| 日本乱人伦一区| 亚洲主播在线观看| 欧美亚洲尤物久久| 亚洲国产精品一区二区久久 | 欧美日本韩国一区| 亚洲成人免费电影| 欧美巨大另类极品videosbest | 91成人国产精品| 亚洲午夜一区二区| 欧美精品在线观看播放| 日本在线播放一区二区三区| 欧美一级片免费看| 国产真实乱子伦精品视频| 国产欧美日本一区二区三区| 成人影视亚洲图片在线| 中文字幕日本不卡| 色婷婷久久99综合精品jk白丝| 一区二区三区四区高清精品免费观看 | 成人性生交大片免费看视频在线| 国产精品入口麻豆九色| 色婷婷狠狠综合| 五月天网站亚洲| 日韩免费电影网站| 国产成人av网站| 亚洲摸摸操操av| 欧美久久久影院| 韩国午夜理伦三级不卡影院| 国产农村妇女毛片精品久久麻豆| 99久精品国产| 天天免费综合色| 久久噜噜亚洲综合| 91久久精品一区二区三| 蜜臀av性久久久久蜜臀aⅴ流畅| www成人在线观看| 97se亚洲国产综合自在线不卡| 亚洲午夜一区二区| 久久久国产一区二区三区四区小说 | 欧美色图天堂网| 另类小说综合欧美亚洲| 国产精品不卡在线| 3d动漫精品啪啪1区2区免费| 国产精选一区二区三区| 亚洲欧美另类综合偷拍| 日韩欧美综合一区| 97国产精品videossex| 奇米色777欧美一区二区| 国产人伦精品一区二区| 欧美裸体bbwbbwbbw| 国产成人精品一区二| 午夜影院在线观看欧美| 国产欧美综合在线观看第十页| 欧美色精品在线视频| 高清视频一区二区| 视频一区视频二区中文| 中文字幕在线观看不卡视频| 日韩欧美亚洲一区二区| 色哟哟一区二区在线观看| 狠狠色丁香婷综合久久| 亚洲国产aⅴ天堂久久| 国产丝袜欧美中文另类| 91精品蜜臀在线一区尤物| av在线不卡网| 韩国三级中文字幕hd久久精品| 亚洲一区二区三区四区的| 国产精品午夜在线| 欧美一区二区高清| 欧美在线观看一区| 福利一区二区在线| 精品一区二区三区不卡| 亚洲午夜激情网站| 自拍视频在线观看一区二区| 久久精品人人做人人综合| 欧美日韩国产一区二区三区地区| 成人综合婷婷国产精品久久蜜臀 | 精品一区二区三区在线观看国产 | 美女在线视频一区| 一区二区欧美视频| 国产精品污www在线观看| 精品欧美一区二区久久| 欧美乱妇20p| 欧洲生活片亚洲生活在线观看| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 国产精品美女久久久久久久久| 日韩免费观看高清完整版| 欧美老人xxxx18| 在线观看欧美精品| 91麻豆精品秘密| 成人av片在线观看| 高清国产一区二区| 国产麻豆精品视频| 精彩视频一区二区三区| 日本少妇一区二区| 亚洲成人av免费| 一区二区三区在线视频播放| 亚洲欧洲精品一区二区三区| 欧美激情一区二区在线| 久久精品男人天堂av| 久久久国产精品不卡|