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

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

?? pngwtran.c

?? 一款最完整的工業組態軟源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:

/* pngwtran.c - transforms the data in a row for PNG writers
 *
 * libpng version 1.2.7 - September 12, 2004
 * For conditions of distribution and use, see copyright notice in png.h
 * Copyright (c) 1998-2004 Glenn Randers-Pehrson
 * (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
 * (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
 */

#define PNG_INTERNAL
#include "png.h"
#ifdef PNG_WRITE_SUPPORTED

/* Transform the data according to the user's wishes.  The order of
 * transformations is significant.
 */
void /* PRIVATE */
png_do_write_transformations(png_structp png_ptr)
{
   png_debug(1, "in png_do_write_transformations\n");

   if (png_ptr == NULL)
      return;

#if defined(PNG_WRITE_USER_TRANSFORM_SUPPORTED)
   if (png_ptr->transformations & PNG_USER_TRANSFORM)
      if(png_ptr->write_user_transform_fn != NULL)
        (*(png_ptr->write_user_transform_fn)) /* user write transform function */
          (png_ptr,                    /* png_ptr */
           &(png_ptr->row_info),       /* row_info:     */
             /*  png_uint_32 width;          width of row */
             /*  png_uint_32 rowbytes;       number of bytes in row */
             /*  png_byte color_type;        color type of pixels */
             /*  png_byte bit_depth;         bit depth of samples */
             /*  png_byte channels;          number of channels (1-4) */
             /*  png_byte pixel_depth;       bits per pixel (depth*channels) */
           png_ptr->row_buf + 1);      /* start of pixel data for row */
#endif
#if defined(PNG_WRITE_FILLER_SUPPORTED)
   if (png_ptr->transformations & PNG_FILLER)
      png_do_strip_filler(&(png_ptr->row_info), png_ptr->row_buf + 1,
         png_ptr->flags);
#endif
#if defined(PNG_WRITE_PACKSWAP_SUPPORTED)
   if (png_ptr->transformations & PNG_PACKSWAP)
      png_do_packswap(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
#if defined(PNG_WRITE_PACK_SUPPORTED)
   if (png_ptr->transformations & PNG_PACK)
      png_do_pack(&(png_ptr->row_info), png_ptr->row_buf + 1,
         (png_uint_32)png_ptr->bit_depth);
#endif
#if defined(PNG_WRITE_SWAP_SUPPORTED)
   if (png_ptr->transformations & PNG_SWAP_BYTES)
      png_do_swap(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
#if defined(PNG_WRITE_SHIFT_SUPPORTED)
   if (png_ptr->transformations & PNG_SHIFT)
      png_do_shift(&(png_ptr->row_info), png_ptr->row_buf + 1,
         &(png_ptr->shift));
#endif
#if defined(PNG_WRITE_INVERT_ALPHA_SUPPORTED)
   if (png_ptr->transformations & PNG_INVERT_ALPHA)
      png_do_write_invert_alpha(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
#if defined(PNG_WRITE_SWAP_ALPHA_SUPPORTED)
   if (png_ptr->transformations & PNG_SWAP_ALPHA)
      png_do_write_swap_alpha(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
#if defined(PNG_WRITE_BGR_SUPPORTED)
   if (png_ptr->transformations & PNG_BGR)
      png_do_bgr(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
#if defined(PNG_WRITE_INVERT_SUPPORTED)
   if (png_ptr->transformations & PNG_INVERT_MONO)
      png_do_invert(&(png_ptr->row_info), png_ptr->row_buf + 1);
#endif
}

#if defined(PNG_WRITE_PACK_SUPPORTED)
/* Pack pixels into bytes.  Pass the true bit depth in bit_depth.  The
 * row_info bit depth should be 8 (one pixel per byte).  The channels
 * should be 1 (this only happens on grayscale and paletted images).
 */
void /* PRIVATE */
png_do_pack(png_row_infop row_info, png_bytep row, png_uint_32 bit_depth)
{
   png_debug(1, "in png_do_pack\n");
   if (row_info->bit_depth == 8 &&
#if defined(PNG_USELESS_TESTS_SUPPORTED)
       row != NULL && row_info != NULL &&
#endif
      row_info->channels == 1)
   {
      switch ((int)bit_depth)
      {
         case 1:
         {
            png_bytep sp, dp;
            int mask, v;
            png_uint_32 i;
            png_uint_32 row_width = row_info->width;

            sp = row;
            dp = row;
            mask = 0x80;
            v = 0;

            for (i = 0; i < row_width; i++)
            {
               if (*sp != 0)
                  v |= mask;
               sp++;
               if (mask > 1)
                  mask >>= 1;
               else
               {
                  mask = 0x80;
                  *dp = (png_byte)v;
                  dp++;
                  v = 0;
               }
            }
            if (mask != 0x80)
               *dp = (png_byte)v;
            break;
         }
         case 2:
         {
            png_bytep sp, dp;
            int shift, v;
            png_uint_32 i;
            png_uint_32 row_width = row_info->width;

            sp = row;
            dp = row;
            shift = 6;
            v = 0;
            for (i = 0; i < row_width; i++)
            {
               png_byte value;

               value = (png_byte)(*sp & 0x03);
               v |= (value << shift);
               if (shift == 0)
               {
                  shift = 6;
                  *dp = (png_byte)v;
                  dp++;
                  v = 0;
               }
               else
                  shift -= 2;
               sp++;
            }
            if (shift != 6)
               *dp = (png_byte)v;
            break;
         }
         case 4:
         {
            png_bytep sp, dp;
            int shift, v;
            png_uint_32 i;
            png_uint_32 row_width = row_info->width;

            sp = row;
            dp = row;
            shift = 4;
            v = 0;
            for (i = 0; i < row_width; i++)
            {
               png_byte value;

               value = (png_byte)(*sp & 0x0f);
               v |= (value << shift);

               if (shift == 0)
               {
                  shift = 4;
                  *dp = (png_byte)v;
                  dp++;
                  v = 0;
               }
               else
                  shift -= 4;

               sp++;
            }
            if (shift != 4)
               *dp = (png_byte)v;
            break;
         }
      }
      row_info->bit_depth = (png_byte)bit_depth;
      row_info->pixel_depth = (png_byte)(bit_depth * row_info->channels);
      row_info->rowbytes = PNG_ROWBYTES(row_info->pixel_depth,
         row_info->width);
   }
}
#endif

#if defined(PNG_WRITE_SHIFT_SUPPORTED)
/* Shift pixel values to take advantage of whole range.  Pass the
 * true number of bits in bit_depth.  The row should be packed
 * according to row_info->bit_depth.  Thus, if you had a row of
 * bit depth 4, but the pixels only had values from 0 to 7, you
 * would pass 3 as bit_depth, and this routine would translate the
 * data to 0 to 15.
 */
void /* PRIVATE */
png_do_shift(png_row_infop row_info, png_bytep row, png_color_8p bit_depth)
{
   png_debug(1, "in png_do_shift\n");
#if defined(PNG_USELESS_TESTS_SUPPORTED)
   if (row != NULL && row_info != NULL &&
#else
   if (
#endif
      row_info->color_type != PNG_COLOR_TYPE_PALETTE)
   {
      int shift_start[4], shift_dec[4];
      int channels = 0;

      if (row_info->color_type & PNG_COLOR_MASK_COLOR)
      {
         shift_start[channels] = row_info->bit_depth - bit_depth->red;
         shift_dec[channels] = bit_depth->red;
         channels++;
         shift_start[channels] = row_info->bit_depth - bit_depth->green;
         shift_dec[channels] = bit_depth->green;
         channels++;
         shift_start[channels] = row_info->bit_depth - bit_depth->blue;
         shift_dec[channels] = bit_depth->blue;
         channels++;
      }
      else
      {
         shift_start[channels] = row_info->bit_depth - bit_depth->gray;
         shift_dec[channels] = bit_depth->gray;
         channels++;
      }
      if (row_info->color_type & PNG_COLOR_MASK_ALPHA)
      {
         shift_start[channels] = row_info->bit_depth - bit_depth->alpha;
         shift_dec[channels] = bit_depth->alpha;
         channels++;
      }

      /* with low row depths, could only be grayscale, so one channel */
      if (row_info->bit_depth < 8)
      {
         png_bytep bp = row;
         png_uint_32 i;
         png_byte mask;
         png_uint_32 row_bytes = row_info->rowbytes;

         if (bit_depth->gray == 1 && row_info->bit_depth == 2)
            mask = 0x55;
         else if (row_info->bit_depth == 4 && bit_depth->gray == 3)
            mask = 0x11;
         else
            mask = 0xff;

         for (i = 0; i < row_bytes; i++, bp++)
         {
            png_uint_16 v;
            int j;

            v = *bp;
            *bp = 0;
            for (j = shift_start[0]; j > -shift_dec[0]; j -= shift_dec[0])
            {
               if (j > 0)
                  *bp |= (png_byte)((v << j) & 0xff);
               else
                  *bp |= (png_byte)((v >> (-j)) & mask);
            }
         }
      }
      else if (row_info->bit_depth == 8)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人免费视频精品含羞草妖精 | 理论电影国产精品| 国产亚洲短视频| 91.com视频| 色综合中文综合网| 欧美精品精品一区| av爱爱亚洲一区| 国模少妇一区二区三区| 午夜视频一区二区三区| 亚洲三级理论片| 国产调教视频一区| 日韩免费看的电影| 欧美剧在线免费观看网站| 色综合色综合色综合色综合色综合| 国产一区二区精品久久99| 日韩国产一二三区| 亚洲午夜av在线| 国产精品美女久久久久久久 | 久久精品国产免费| 亚洲资源中文字幕| **欧美大码日韩| 国产婷婷精品av在线| 日韩久久久久久| 日韩一级免费观看| 欧美日韩免费观看一区二区三区| 91在线观看高清| 成人av动漫网站| 粉嫩绯色av一区二区在线观看 | 91精品福利在线| 91在线观看视频| 99久久99久久精品免费观看 | 97精品超碰一区二区三区| 国产麻豆精品视频| 国精产品一区一区三区mba视频| 免费的国产精品| 麻豆91精品91久久久的内涵| 免费在线观看日韩欧美| 奇米精品一区二区三区在线观看一| 亚洲在线中文字幕| 亚洲va欧美va天堂v国产综合| 一区二区三区中文在线观看| 一区二区在线观看免费视频播放| 一区二区三区四区在线免费观看 | eeuss鲁片一区二区三区在线观看| 国产一区二区成人久久免费影院| 男女男精品网站| 精品在线免费视频| 国产电影一区二区三区| 成人h精品动漫一区二区三区| 本田岬高潮一区二区三区| 91美女视频网站| 欧美日韩精品免费| 欧美成人bangbros| 国产精品亲子伦对白| 亚洲欧美日韩国产手机在线 | 国产成人亚洲综合a∨婷婷图片 | 日韩欧美一区在线观看| 精品国免费一区二区三区| 国产亚洲欧美日韩在线一区| 亚洲视频一区在线观看| 亚洲最大成人综合| 日韩成人午夜精品| 国产乱码精品一区二区三区av| 国产成人av电影免费在线观看| 成人国产视频在线观看| 欧美中文字幕久久 | 亚洲男人电影天堂| 日韩在线观看一区二区| 精品一区二区三区免费观看| av成人免费在线| 欧美一区二区三区视频| 欧美高清在线精品一区| 亚洲无线码一区二区三区| 精品亚洲aⅴ乱码一区二区三区| 成人看片黄a免费看在线| 欧美性大战久久久久久久蜜臀| 精品国产乱码久久久久久闺蜜| 国产精品超碰97尤物18| 亚洲h精品动漫在线观看| 国产精品亚洲午夜一区二区三区 | 日韩一级片网站| 国产精品毛片高清在线完整版| 亚洲成av人影院在线观看网| 国产一区二区免费在线| 欧美色精品在线视频| 国产欧美日韩精品a在线观看| 亚洲综合色自拍一区| 国产精品一二二区| 欧美精品 国产精品| 亚洲欧洲精品天堂一级 | 秋霞电影一区二区| 高清久久久久久| 91精品婷婷国产综合久久性色| 国产精品色哟哟| 美国精品在线观看| 91久久一区二区| 国产视频一区二区在线观看| 亚洲成av人片在线| 99久久精品免费看| 久久久久久久久久久久久久久99 | 国产一区福利在线| 欧美少妇一区二区| 国产亚洲精品bt天堂精选| 91在线精品一区二区三区| 日韩视频在线一区二区| 日韩影院免费视频| 欧美无乱码久久久免费午夜一区 | 成人在线综合网| 国产精品亚洲一区二区三区在线| 欧美精品日韩精品| 一区二区久久久久久| 国产91在线观看丝袜| 久久久另类综合| 国产精品一卡二卡在线观看| 日韩精品在线一区| 黄网站免费久久| 久久久久久免费网| 国产综合久久久久久久久久久久| 666欧美在线视频| 秋霞av亚洲一区二区三| 777奇米四色成人影色区| 免费观看一级欧美片| 国产欧美日韩卡一| av电影在线不卡| 亚洲高清免费视频| 精品免费99久久| 成人做爰69片免费看网站| 亚洲欧洲av一区二区三区久久| 99久久国产综合精品女不卡| 1000部国产精品成人观看| 精品日韩99亚洲| 一本大道久久a久久精二百| 日韩在线播放一区二区| 欧洲日韩一区二区三区| 国产福利精品一区二区| 91美女片黄在线观看91美女| 在线播放一区二区三区| 老司机精品视频在线| 日韩视频国产视频| 久久精品72免费观看| 国产精品视频观看| 国产传媒一区在线| 国产精品灌醉下药二区| 99精品热视频| 国产精品九色蝌蚪自拍| 亚洲免费观看高清完整| 免费观看一级特黄欧美大片| 在线精品视频免费播放| 日韩视频免费观看高清完整版| 国产日韩高清在线| 夜夜精品视频一区二区| 国产麻豆精品theporn| 欧美自拍偷拍午夜视频| 精品日本一线二线三线不卡| 欧美福利视频一区| 久久久亚洲国产美女国产盗摄 | 激情综合一区二区三区| 丝袜美腿一区二区三区| 亚洲青青青在线视频| 欧美国产日本韩| 2021中文字幕一区亚洲| 欧美精品777| 精品久久久久久久人人人人传媒| 国产午夜亚洲精品羞羞网站| 日韩视频一区在线观看| 亚洲精品视频在线观看免费| 一区二区三区四区高清精品免费观看 | 欧美日韩美少妇| 色婷婷av一区二区| 欧美系列亚洲系列| 欧美成人综合网站| 国产精品久久久久久户外露出 | 亚洲午夜三级在线| 国产九色精品成人porny| 精品视频在线看| 中文字幕一区二区在线播放| 理论电影国产精品| 在线视频中文字幕一区二区| 久久久久久久久久久久久夜| 日韩av中文字幕一区二区| 99视频精品免费视频| 国产亚洲一区字幕| 美女看a上一区| 91论坛在线播放| 精品久久人人做人人爰| 日本美女一区二区| 欧洲一区在线电影| 亚洲一区成人在线| 欧美性猛交xxxx黑人交| 亚洲最大色网站| 欧美日韩一区二区三区高清| 亚洲色大成网站www久久九九| 国产成人午夜99999| 久久网这里都是精品| 国产精品小仙女| 欧美va亚洲va在线观看蝴蝶网| 亚洲午夜在线视频| 欧美三级日韩三级国产三级| 蜜臀久久久久久久| 亚洲精品在线三区|