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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pngwrite.c

?? 一款最完整的工業組態軟源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
      switch (filters & (PNG_ALL_FILTERS | 0x07))
      {
         case 5:
         case 6:
         case 7: png_warning(png_ptr, "Unknown row filter for method 0");
         case PNG_FILTER_VALUE_NONE:  png_ptr->do_filter=PNG_FILTER_NONE; break;
         case PNG_FILTER_VALUE_SUB:   png_ptr->do_filter=PNG_FILTER_SUB;  break;
         case PNG_FILTER_VALUE_UP:    png_ptr->do_filter=PNG_FILTER_UP;   break;
         case PNG_FILTER_VALUE_AVG:   png_ptr->do_filter=PNG_FILTER_AVG;  break;
         case PNG_FILTER_VALUE_PAETH: png_ptr->do_filter=PNG_FILTER_PAETH;break;
         default: png_ptr->do_filter = (png_byte)filters; break;
      }

      /* If we have allocated the row_buf, this means we have already started
       * with the image and we should have allocated all of the filter buffers
       * that have been selected.  If prev_row isn't already allocated, then
       * it is too late to start using the filters that need it, since we
       * will be missing the data in the previous row.  If an application
       * wants to start and stop using particular filters during compression,
       * it should start out with all of the filters, and then add and
       * remove them after the start of compression.
       */
      if (png_ptr->row_buf != NULL)
      {
         if ((png_ptr->do_filter & PNG_FILTER_SUB) && png_ptr->sub_row == NULL)
         {
            png_ptr->sub_row = (png_bytep)png_malloc(png_ptr,
              (png_ptr->rowbytes + 1));
            png_ptr->sub_row[0] = PNG_FILTER_VALUE_SUB;
         }

         if ((png_ptr->do_filter & PNG_FILTER_UP) && png_ptr->up_row == NULL)
         {
            if (png_ptr->prev_row == NULL)
            {
               png_warning(png_ptr, "Can't add Up filter after starting");
               png_ptr->do_filter &= ~PNG_FILTER_UP;
            }
            else
            {
               png_ptr->up_row = (png_bytep)png_malloc(png_ptr,
                  (png_ptr->rowbytes + 1));
               png_ptr->up_row[0] = PNG_FILTER_VALUE_UP;
            }
         }

         if ((png_ptr->do_filter & PNG_FILTER_AVG) && png_ptr->avg_row == NULL)
         {
            if (png_ptr->prev_row == NULL)
            {
               png_warning(png_ptr, "Can't add Average filter after starting");
               png_ptr->do_filter &= ~PNG_FILTER_AVG;
            }
            else
            {
               png_ptr->avg_row = (png_bytep)png_malloc(png_ptr,
                  (png_ptr->rowbytes + 1));
               png_ptr->avg_row[0] = PNG_FILTER_VALUE_AVG;
            }
         }

         if ((png_ptr->do_filter & PNG_FILTER_PAETH) &&
             png_ptr->paeth_row == NULL)
         {
            if (png_ptr->prev_row == NULL)
            {
               png_warning(png_ptr, "Can't add Paeth filter after starting");
               png_ptr->do_filter &= (png_byte)(~PNG_FILTER_PAETH);
            }
            else
            {
               png_ptr->paeth_row = (png_bytep)png_malloc(png_ptr,
                  (png_ptr->rowbytes + 1));
               png_ptr->paeth_row[0] = PNG_FILTER_VALUE_PAETH;
            }
         }

         if (png_ptr->do_filter == PNG_NO_FILTERS)
            png_ptr->do_filter = PNG_FILTER_NONE;
      }
   }
   else
      png_error(png_ptr, "Unknown custom filter method");
}

/* This allows us to influence the way in which libpng chooses the "best"
 * filter for the current scanline.  While the "minimum-sum-of-absolute-
 * differences metric is relatively fast and effective, there is some
 * question as to whether it can be improved upon by trying to keep the
 * filtered data going to zlib more consistent, hopefully resulting in
 * better compression.
 */
#if defined(PNG_WRITE_WEIGHTED_FILTER_SUPPORTED)      /* GRR 970116 */
void PNGAPI
png_set_filter_heuristics(png_structp png_ptr, int heuristic_method,
   int num_weights, png_doublep filter_weights,
   png_doublep filter_costs)
{
   int i;

   png_debug(1, "in png_set_filter_heuristics\n");
   if (heuristic_method >= PNG_FILTER_HEURISTIC_LAST)
   {
      png_warning(png_ptr, "Unknown filter heuristic method");
      return;
   }

   if (heuristic_method == PNG_FILTER_HEURISTIC_DEFAULT)
   {
      heuristic_method = PNG_FILTER_HEURISTIC_UNWEIGHTED;
   }

   if (num_weights < 0 || filter_weights == NULL ||
      heuristic_method == PNG_FILTER_HEURISTIC_UNWEIGHTED)
   {
      num_weights = 0;
   }

   png_ptr->num_prev_filters = (png_byte)num_weights;
   png_ptr->heuristic_method = (png_byte)heuristic_method;

   if (num_weights > 0)
   {
      if (png_ptr->prev_filters == NULL)
      {
         png_ptr->prev_filters = (png_bytep)png_malloc(png_ptr,
            (png_uint_32)(png_sizeof(png_byte) * num_weights));

         /* To make sure that the weighting starts out fairly */
         for (i = 0; i < num_weights; i++)
         {
            png_ptr->prev_filters[i] = 255;
         }
      }

      if (png_ptr->filter_weights == NULL)
      {
         png_ptr->filter_weights = (png_uint_16p)png_malloc(png_ptr,
            (png_uint_32)(png_sizeof(png_uint_16) * num_weights));

         png_ptr->inv_filter_weights = (png_uint_16p)png_malloc(png_ptr,
            (png_uint_32)(png_sizeof(png_uint_16) * num_weights));
         for (i = 0; i < num_weights; i++)
         {
            png_ptr->inv_filter_weights[i] =
            png_ptr->filter_weights[i] = PNG_WEIGHT_FACTOR;
         }
      }

      for (i = 0; i < num_weights; i++)
      {
         if (filter_weights[i] < 0.0)
         {
            png_ptr->inv_filter_weights[i] =
            png_ptr->filter_weights[i] = PNG_WEIGHT_FACTOR;
         }
         else
         {
            png_ptr->inv_filter_weights[i] =
               (png_uint_16)((double)PNG_WEIGHT_FACTOR*filter_weights[i]+0.5);
            png_ptr->filter_weights[i] =
               (png_uint_16)((double)PNG_WEIGHT_FACTOR/filter_weights[i]+0.5);
         }
      }
   }

   /* If, in the future, there are other filter methods, this would
    * need to be based on png_ptr->filter.
    */
   if (png_ptr->filter_costs == NULL)
   {
      png_ptr->filter_costs = (png_uint_16p)png_malloc(png_ptr,
         (png_uint_32)(png_sizeof(png_uint_16) * PNG_FILTER_VALUE_LAST));

      png_ptr->inv_filter_costs = (png_uint_16p)png_malloc(png_ptr,
         (png_uint_32)(png_sizeof(png_uint_16) * PNG_FILTER_VALUE_LAST));

      for (i = 0; i < PNG_FILTER_VALUE_LAST; i++)
      {
         png_ptr->inv_filter_costs[i] =
         png_ptr->filter_costs[i] = PNG_COST_FACTOR;
      }
   }

   /* Here is where we set the relative costs of the different filters.  We
    * should take the desired compression level into account when setting
    * the costs, so that Paeth, for instance, has a high relative cost at low
    * compression levels, while it has a lower relative cost at higher
    * compression settings.  The filter types are in order of increasing
    * relative cost, so it would be possible to do this with an algorithm.
    */
   for (i = 0; i < PNG_FILTER_VALUE_LAST; i++)
   {
      if (filter_costs == NULL || filter_costs[i] < 0.0)
      {
         png_ptr->inv_filter_costs[i] =
         png_ptr->filter_costs[i] = PNG_COST_FACTOR;
      }
      else if (filter_costs[i] >= 1.0)
      {
         png_ptr->inv_filter_costs[i] =
            (png_uint_16)((double)PNG_COST_FACTOR / filter_costs[i] + 0.5);
         png_ptr->filter_costs[i] =
            (png_uint_16)((double)PNG_COST_FACTOR * filter_costs[i] + 0.5);
      }
   }
}
#endif /* PNG_WRITE_WEIGHTED_FILTER_SUPPORTED */

void PNGAPI
png_set_compression_level(png_structp png_ptr, int level)
{
   png_debug(1, "in png_set_compression_level\n");
   png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_LEVEL;
   png_ptr->zlib_level = level;
}

void PNGAPI
png_set_compression_mem_level(png_structp png_ptr, int mem_level)
{
   png_debug(1, "in png_set_compression_mem_level\n");
   png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_MEM_LEVEL;
   png_ptr->zlib_mem_level = mem_level;
}

void PNGAPI
png_set_compression_strategy(png_structp png_ptr, int strategy)
{
   png_debug(1, "in png_set_compression_strategy\n");
   png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_STRATEGY;
   png_ptr->zlib_strategy = strategy;
}

void PNGAPI
png_set_compression_window_bits(png_structp png_ptr, int window_bits)
{
   if (window_bits > 15)
      png_warning(png_ptr, "Only compression windows <= 32k supported by PNG");
   else if (window_bits < 8)
      png_warning(png_ptr, "Only compression windows >= 256 supported by PNG");
#ifndef WBITS_8_OK
   /* avoid libpng bug with 256-byte windows */
   if (window_bits == 8)
     {
       png_warning(png_ptr, "Compression window is being reset to 512");
       window_bits=9;
     }
#endif
   png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_WINDOW_BITS;
   png_ptr->zlib_window_bits = window_bits;
}

void PNGAPI
png_set_compression_method(png_structp png_ptr, int method)
{
   png_debug(1, "in png_set_compression_method\n");
   if (method != 8)
      png_warning(png_ptr, "Only compression method 8 is supported by PNG");
   png_ptr->flags |= PNG_FLAG_ZLIB_CUSTOM_METHOD;
   png_ptr->zlib_method = method;
}

void PNGAPI
png_set_write_status_fn(png_structp png_ptr, png_write_status_ptr write_row_fn)
{
   png_ptr->write_row_fn = write_row_fn;
}

#if defined(PNG_WRITE_USER_TRANSFORM_SUPPORTED)
void PNGAPI
png_set_write_user_transform_fn(png_structp png_ptr, png_user_transform_ptr
   write_user_transform_fn)
{
   png_debug(1, "in png_set_write_user_transform_fn\n");
   png_ptr->transformations |= PNG_USER_TRANSFORM;
   png_ptr->write_user_transform_fn = write_user_transform_fn;
}
#endif


#if defined(PNG_INFO_IMAGE_SUPPORTED)
void PNGAPI
png_write_png(png_structp png_ptr, png_infop info_ptr,
              int transforms, voidp params)
{
#if defined(PNG_WRITE_INVERT_ALPHA_SUPPORTED)
   /* invert the alpha channel from opacity to transparency */
   if (transforms & PNG_TRANSFORM_INVERT_ALPHA)
       png_set_invert_alpha(png_ptr);
#endif

   /* Write the file header information. */
   png_write_info(png_ptr, info_ptr);

   /* ------ these transformations don't touch the info structure ------- */

#if defined(PNG_WRITE_INVERT_SUPPORTED)
   /* invert monochrome pixels */
   if (transforms & PNG_TRANSFORM_INVERT_MONO)
       png_set_invert_mono(png_ptr);
#endif

#if defined(PNG_WRITE_SHIFT_SUPPORTED)
   /* Shift the pixels up to a legal bit depth and fill in
    * as appropriate to correctly scale the image.
    */
   if ((transforms & PNG_TRANSFORM_SHIFT)
               && (info_ptr->valid & PNG_INFO_sBIT))
       png_set_shift(png_ptr, &info_ptr->sig_bit);
#endif

#if defined(PNG_WRITE_PACK_SUPPORTED)
   /* pack pixels into bytes */
   if (transforms & PNG_TRANSFORM_PACKING)
       png_set_packing(png_ptr);
#endif

#if defined(PNG_WRITE_SWAP_ALPHA_SUPPORTED)
   /* swap location of alpha bytes from ARGB to RGBA */
   if (transforms & PNG_TRANSFORM_SWAP_ALPHA)
       png_set_swap_alpha(png_ptr);
#endif

#if defined(PNG_WRITE_FILLER_SUPPORTED)
   /* Get rid of filler (OR ALPHA) bytes, pack XRGB/RGBX/ARGB/RGBA into
    * RGB (4 channels -> 3 channels). The second parameter is not used.
    */
   if (transforms & PNG_TRANSFORM_STRIP_FILLER)
       png_set_filler(png_ptr, 0, PNG_FILLER_BEFORE);
#endif

#if defined(PNG_WRITE_BGR_SUPPORTED)
   /* flip BGR pixels to RGB */
   if (transforms & PNG_TRANSFORM_BGR)
       png_set_bgr(png_ptr);
#endif

#if defined(PNG_WRITE_SWAP_SUPPORTED)
   /* swap bytes of 16-bit files to most significant byte first */
   if (transforms & PNG_TRANSFORM_SWAP_ENDIAN)
       png_set_swap(png_ptr);
#endif

#if defined(PNG_WRITE_PACKSWAP_SUPPORTED)
   /* swap bits of 1, 2, 4 bit packed pixel formats */
   if (transforms & PNG_TRANSFORM_PACKSWAP)
       png_set_packswap(png_ptr);
#endif

   /* ----------------------- end of transformations ------------------- */

   /* write the bits */
   if (info_ptr->valid & PNG_INFO_IDAT)
       png_write_image(png_ptr, info_ptr->row_pointers);

   /* It is REQUIRED to call this to finish writing the rest of the file */
   png_write_end(png_ptr, info_ptr);

   if(transforms == 0 || params == NULL)
      /* quiet compiler warnings */ return;
}
#endif
#endif /* PNG_WRITE_SUPPORTED */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区高清| 国产一区二区三区四| 久久五月婷婷丁香社区| 在线观看亚洲精品| 国产精品一区二区三区99| 亚洲va国产天堂va久久en| 欧美韩国日本一区| 欧美大片免费久久精品三p| 一本大道综合伊人精品热热| 国产一二精品视频| 日韩精彩视频在线观看| 一区二区三区日韩欧美精品| 久久精品男人天堂av| 欧美放荡的少妇| 日本乱人伦aⅴ精品| 成人黄页在线观看| 国产精品系列在线播放| 免费观看日韩av| 三级欧美韩日大片在线看| 亚洲色图清纯唯美| 1024成人网| 中文天堂在线一区| 国产欧美日韩三区| www国产精品av| 日韩精品资源二区在线| 7777精品伊人久久久大香线蕉| 色菇凉天天综合网| 99国产精品国产精品毛片| www.欧美精品一二区| www.亚洲激情.com| 丁香另类激情小说| 丰满少妇在线播放bd日韩电影| 国产一区视频网站| 国产精品一区二区你懂的| 国内精品久久久久影院一蜜桃| 美女视频黄 久久| 久久99这里只有精品| 激情丁香综合五月| 狠狠网亚洲精品| 精品在线一区二区三区| 久久aⅴ国产欧美74aaa| 国产精品伊人色| 色偷偷久久一区二区三区| 懂色av一区二区在线播放| 国产成人午夜精品影院观看视频| 韩国成人在线视频| 国产精品资源网站| 成a人片国产精品| 在线亚洲高清视频| 欧美性大战久久| 欧美精品日韩一本| 精品伦理精品一区| 日本一区二区三区四区在线视频| 国产精品久久久一区麻豆最新章节| 国产精品系列在线| 亚洲精品免费看| 日本伊人精品一区二区三区观看方式| 老司机一区二区| 国产成人免费视频一区| av在线一区二区| 欧美日韩一区高清| 精品国产青草久久久久福利| 国产喷白浆一区二区三区| 中文字幕一区二区三区乱码在线| 亚洲免费av在线| 奇米色一区二区三区四区| 国产麻豆日韩欧美久久| 色视频一区二区| 91.麻豆视频| 久久久三级国产网站| 亚洲人成亚洲人成在线观看图片| 天堂一区二区在线免费观看| 国产在线看一区| 色综合久久久久久久| 欧美一区永久视频免费观看| 久久男人中文字幕资源站| 亚洲精品免费视频| 国产综合色视频| 91欧美激情一区二区三区成人| 欧美电影一区二区| 中文av字幕一区| 日本成人在线视频网站| 成人av片在线观看| 欧美日韩久久久久久| 国产午夜精品福利| 亚洲不卡在线观看| 丰满少妇在线播放bd日韩电影| 欧美日韩国产经典色站一区二区三区 | 国产乱码精品1区2区3区| 91麻豆国产福利在线观看| 日韩一区二区三区高清免费看看| 国产精品久久久久久久久快鸭 | 国产亚洲制服色| 亚洲一二三区在线观看| 国产69精品久久久久毛片 | 欧美久久婷婷综合色| 国产亚洲欧美一区在线观看| 一区二区三区视频在线观看| 欧洲亚洲精品在线| 精品久久久久久久人人人人传媒 | 亚洲天堂免费在线观看视频| 麻豆91在线观看| 色婷婷精品大视频在线蜜桃视频 | 国产精品日韩精品欧美在线| 久久激情五月婷婷| 欧美专区日韩专区| 中文字幕一区日韩精品欧美| 国内成人精品2018免费看| 欧美日韩卡一卡二| 亚洲精品日韩一| 99久久久精品免费观看国产蜜| 精品福利视频一区二区三区| 亚洲国产一区在线观看| 色婷婷亚洲精品| 亚洲日本在线天堂| 成人精品视频一区二区三区尤物| 精品久久久久久久久久久久久久久久久 | 国产一区二区三区免费| 日韩一区二区在线看| 污片在线观看一区二区 | 国产日韩欧美高清| 国产一区二区主播在线| 欧美一区二区久久| 五月综合激情日本mⅴ| 欧美在线高清视频| 亚洲理论在线观看| 色综合中文综合网| 国产sm精品调教视频网站| 久久久亚洲精品石原莉奈| 久久电影网电视剧免费观看| 日韩欧美中文字幕一区| 偷拍日韩校园综合在线| 欧美日韩国产美| 日韩av中文字幕一区二区三区 | 在线欧美日韩国产| 亚洲一级在线观看| 欧美性受xxxx黑人xyx性爽| 亚洲一卡二卡三卡四卡无卡久久| 91久久一区二区| 亚洲最大的成人av| 欧美日韩www| 男人的j进女人的j一区| 欧美大片国产精品| 国产成人免费在线视频| 国产精品狼人久久影院观看方式| 99精品国产热久久91蜜凸| 亚洲激情在线播放| 欧美日韩你懂得| 日本不卡视频在线| 久久噜噜亚洲综合| hitomi一区二区三区精品| 亚洲九九爱视频| 欧美人狂配大交3d怪物一区| 美日韩一区二区三区| 337p日本欧洲亚洲大胆精品| 日本韩国精品在线| 日本成人在线不卡视频| 26uuu久久天堂性欧美| av一区二区不卡| 午夜精品久久久久久| 久久你懂得1024| 色综合中文字幕国产 | 日韩一二三区视频| 国产精品1区二区.| 亚洲精品欧美激情| 日韩欧美精品在线| www.欧美日韩| 日一区二区三区| 久久久www成人免费毛片麻豆 | 九九精品一区二区| 亚洲视频在线一区| 日韩视频一区二区三区在线播放| 国产精品资源在线| 亚洲一区二区在线观看视频| 亚洲精品一区二区三区蜜桃下载| 成人av资源站| 日本大胆欧美人术艺术动态| 国产精品欧美极品| 3751色影院一区二区三区| 国产美女主播视频一区| 艳妇臀荡乳欲伦亚洲一区| 久久一区二区视频| 欧美男男青年gay1069videost| 国产精品一二三区在线| 亚洲成国产人片在线观看| 国产亚洲综合av| 欧美美女一区二区| av不卡在线观看| 久久91精品国产91久久小草| 亚洲视频在线一区观看| 久久久影院官网| 91精品国产综合久久精品性色| 成人黄色片在线观看| 精品一区二区影视| 亚洲一区二区三区四区五区中文| 久久久午夜精品| 欧美一级欧美三级在线观看 | 欧美日韩一区二区在线观看视频| 国产成人av一区二区三区在线| 午夜av一区二区三区|