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

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

?? jdmarker.c

?? DigitalImageProcessing_base_on_Matlab 基于Matlab的數字圖像處理
?? C
?? 第 1 頁 / 共 3 頁
字號:
    for (buffp = 0; buffp < JFIF_LEN; buffp++)
      INPUT_BYTE(cinfo, b[buffp], return FALSE);
    length -= JFIF_LEN;

    if (b[0]==0x4A && b[1]==0x46 && b[2]==0x49 && b[3]==0x46 && b[4]==0) {
      /* Found JFIF APP0 marker: check version */
      /* Major version must be 1, anything else signals an incompatible change.
       * We used to treat this as an error, but now it's a nonfatal warning,
       * because some bozo at Hijaak couldn't read the spec.
       * Minor version should be 0..2, but process anyway if newer.
       */
      if (b[5] != 1)
	WARNMS2(cinfo, JWRN_JFIF_MAJOR, b[5], b[6]);
      else if (b[6] > 2)
	TRACEMS2(cinfo, 1, JTRC_JFIF_MINOR, b[5], b[6]);
      /* Save info */
      cinfo->saw_JFIF_marker = TRUE;
      cinfo->density_unit = b[7];
      cinfo->X_density = (b[8] << 8) + b[9];
      cinfo->Y_density = (b[10] << 8) + b[11];
      TRACEMS3(cinfo, 1, JTRC_JFIF,
	       cinfo->X_density, cinfo->Y_density, cinfo->density_unit);
      if (b[12] | b[13])
	TRACEMS2(cinfo, 1, JTRC_JFIF_THUMBNAIL, b[12], b[13]);
      if (length != ((INT32) b[12] * (INT32) b[13] * (INT32) 3))
	TRACEMS1(cinfo, 1, JTRC_JFIF_BADTHUMBNAILSIZE, (int) length);
    } else {
      /* Start of APP0 does not match "JFIF" */
      TRACEMS1(cinfo, 1, JTRC_APP0, (int) length + JFIF_LEN);
    }
  } else {
    /* Too short to be JFIF marker */
    TRACEMS1(cinfo, 1, JTRC_APP0, (int) length);
  }

  INPUT_SYNC(cinfo);
  if (length > 0)		/* skip any remaining data -- could be lots */
    (*cinfo->src->skip_input_data) (cinfo, (long) length);

  return TRUE;
}


METHODDEF(boolean)
get_app14 (j_decompress_ptr cinfo)
/* Process an APP14 marker */
{
#define ADOBE_LEN 12
  INT32 length;
  UINT8 b[ADOBE_LEN];
  int buffp;
  unsigned int version, flags0, flags1, transform;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  length -= 2;

  /* See if an Adobe APP14 marker is present */

  if (length >= ADOBE_LEN) {
    for (buffp = 0; buffp < ADOBE_LEN; buffp++)
      INPUT_BYTE(cinfo, b[buffp], return FALSE);
    length -= ADOBE_LEN;

    if (b[0]==0x41 && b[1]==0x64 && b[2]==0x6F && b[3]==0x62 && b[4]==0x65) {
      /* Found Adobe APP14 marker */
      version = (b[5] << 8) + b[6];
      flags0 = (b[7] << 8) + b[8];
      flags1 = (b[9] << 8) + b[10];
      transform = b[11];
      TRACEMS4(cinfo, 1, JTRC_ADOBE, version, flags0, flags1, transform);
      cinfo->saw_Adobe_marker = TRUE;
      cinfo->Adobe_transform = (UINT8) transform;
    } else {
      /* Start of APP14 does not match "Adobe" */
      TRACEMS1(cinfo, 1, JTRC_APP14, (int) length + ADOBE_LEN);
    }
  } else {
    /* Too short to be Adobe marker */
    TRACEMS1(cinfo, 1, JTRC_APP14, (int) length);
  }

  INPUT_SYNC(cinfo);
  if (length > 0)		/* skip any remaining data -- could be lots */
    (*cinfo->src->skip_input_data) (cinfo, (long) length);

  return TRUE;
}


LOCAL(boolean)
get_dac (j_decompress_ptr cinfo)
/* Process a DAC marker */
{
  INT32 length;
  int index, val;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  length -= 2;
  
  while (length > 0) {
    INPUT_BYTE(cinfo, index, return FALSE);
    INPUT_BYTE(cinfo, val, return FALSE);

    length -= 2;

    TRACEMS2(cinfo, 1, JTRC_DAC, index, val);

    if (index < 0 || index >= (2*NUM_ARITH_TBLS))
      ERREXIT1(cinfo, JERR_DAC_INDEX, index);

    if (index >= NUM_ARITH_TBLS) { /* define AC table */
      cinfo->arith_ac_K[index-NUM_ARITH_TBLS] = (UINT8) val;
    } else {			/* define DC table */
      cinfo->arith_dc_L[index] = (UINT8) (val & 0x0F);
      cinfo->arith_dc_U[index] = (UINT8) (val >> 4);
      if (cinfo->arith_dc_L[index] > cinfo->arith_dc_U[index])
	ERREXIT1(cinfo, JERR_DAC_VALUE, val);
    }
  }

  INPUT_SYNC(cinfo);
  return TRUE;
}


LOCAL(boolean)
get_dht (j_decompress_ptr cinfo)
/* Process a DHT marker */
{
  INT32 length;
  UINT8 bits[17];
  UINT8 huffval[256];
  int i, index, count;
  JHUFF_TBL **htblptr;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  length -= 2;
  
  while (length > 0) {
    INPUT_BYTE(cinfo, index, return FALSE);

    TRACEMS1(cinfo, 1, JTRC_DHT, index);
      
    bits[0] = 0;
    count = 0;
    for (i = 1; i <= 16; i++) {
      INPUT_BYTE(cinfo, bits[i], return FALSE);
      count += bits[i];
    }

    length -= 1 + 16;

    TRACEMS8(cinfo, 2, JTRC_HUFFBITS,
	     bits[1], bits[2], bits[3], bits[4],
	     bits[5], bits[6], bits[7], bits[8]);
    TRACEMS8(cinfo, 2, JTRC_HUFFBITS,
	     bits[9], bits[10], bits[11], bits[12],
	     bits[13], bits[14], bits[15], bits[16]);

    if (count > 256 || ((INT32) count) > length)
      ERREXIT(cinfo, JERR_DHT_COUNTS);

    for (i = 0; i < count; i++)
      INPUT_BYTE(cinfo, huffval[i], return FALSE);

    length -= count;

    if (index & 0x10) {		/* AC table definition */
      index -= 0x10;
      htblptr = &cinfo->ac_huff_tbl_ptrs[index];
    } else {			/* DC table definition */
      htblptr = &cinfo->dc_huff_tbl_ptrs[index];
    }

    if (index < 0 || index >= NUM_HUFF_TBLS)
      ERREXIT1(cinfo, JERR_DHT_INDEX, index);

    if (*htblptr == NULL)
      *htblptr = jpeg_alloc_huff_table((j_common_ptr) cinfo);
  
    MEMCOPY((*htblptr)->bits, bits, SIZEOF((*htblptr)->bits));
    MEMCOPY((*htblptr)->huffval, huffval, SIZEOF((*htblptr)->huffval));
  }

  INPUT_SYNC(cinfo);
  return TRUE;
}


LOCAL(boolean)
get_dqt (j_decompress_ptr cinfo)
/* Process a DQT marker */
{
  INT32 length;
  int n, i, prec;
  unsigned int tmp;
  JQUANT_TBL *quant_ptr;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  length -= 2;

  while (length > 0) {
    INPUT_BYTE(cinfo, n, return FALSE);
    prec = n >> 4;
    n &= 0x0F;

    TRACEMS2(cinfo, 1, JTRC_DQT, n, prec);

    if (n >= NUM_QUANT_TBLS)
      ERREXIT1(cinfo, JERR_DQT_INDEX, n);
      
    if (cinfo->quant_tbl_ptrs[n] == NULL)
      cinfo->quant_tbl_ptrs[n] = jpeg_alloc_quant_table((j_common_ptr) cinfo);
    quant_ptr = cinfo->quant_tbl_ptrs[n];

    for (i = 0; i < DCTSIZE2; i++) {
      if (prec)
	INPUT_2BYTES(cinfo, tmp, return FALSE);
      else
	INPUT_BYTE(cinfo, tmp, return FALSE);
      /* We convert the zigzag-order table to natural array order. */
      quant_ptr->quantval[jpeg_natural_order[i]] = (UINT16) tmp;
    }

    if (cinfo->err->trace_level >= 2) {
      for (i = 0; i < DCTSIZE2; i += 8) {
	TRACEMS8(cinfo, 2, JTRC_QUANTVALS,
		 quant_ptr->quantval[i],   quant_ptr->quantval[i+1],
		 quant_ptr->quantval[i+2], quant_ptr->quantval[i+3],
		 quant_ptr->quantval[i+4], quant_ptr->quantval[i+5],
		 quant_ptr->quantval[i+6], quant_ptr->quantval[i+7]);
      }
    }

    length -= DCTSIZE2+1;
    if (prec) length -= DCTSIZE2;
  }

  INPUT_SYNC(cinfo);
  return TRUE;
}


LOCAL(boolean)
get_dri (j_decompress_ptr cinfo)
/* Process a DRI marker */
{
  INT32 length;
  unsigned int tmp;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  
  if (length != 4)
    ERREXIT(cinfo, JERR_BAD_LENGTH);

  INPUT_2BYTES(cinfo, tmp, return FALSE);

  TRACEMS1(cinfo, 1, JTRC_DRI, tmp);

  cinfo->restart_interval = tmp;

  INPUT_SYNC(cinfo);
  return TRUE;
}


METHODDEF(boolean)
skip_variable (j_decompress_ptr cinfo)
/* Skip over an unknown or uninteresting variable-length marker */
{
  INT32 length;
  INPUT_VARS(cinfo);

  INPUT_2BYTES(cinfo, length, return FALSE);
  
  TRACEMS2(cinfo, 1, JTRC_MISC_MARKER, cinfo->unread_marker, (int) length);

  INPUT_SYNC(cinfo);		/* do before skip_input_data */
  (*cinfo->src->skip_input_data) (cinfo, (long) length - 2L);

  return TRUE;
}


/*
 * Find the next JPEG marker, save it in cinfo->unread_marker.
 * Returns FALSE if had to suspend before reaching a marker;
 * in that case cinfo->unread_marker is unchanged.
 *
 * Note that the result might not be a valid marker code,
 * but it will never be 0 or FF.
 */

LOCAL(boolean)
next_marker (j_decompress_ptr cinfo)
{
  int c;
  INPUT_VARS(cinfo);

  for (;;) {
    INPUT_BYTE(cinfo, c, return FALSE);
    /* Skip any non-FF bytes.
     * This may look a bit inefficient, but it will not occur in a valid file.
     * We sync after each discarded byte so that a suspending data source
     * can discard the byte from its buffer.
     */
    while (c != 0xFF) {
      cinfo->marker->discarded_bytes++;
      INPUT_SYNC(cinfo);
      INPUT_BYTE(cinfo, c, return FALSE);
    }
    /* This loop swallows any duplicate FF bytes.  Extra FFs are legal as
     * pad bytes, so don't count them in discarded_bytes.  We assume there
     * will not be so many consecutive FF bytes as to overflow a suspending
     * data source's input buffer.
     */
    do {
      INPUT_BYTE(cinfo, c, return FALSE);
    } while (c == 0xFF);
    if (c != 0)
      break;			/* found a valid marker, exit loop */
    /* Reach here if we found a stuffed-zero data sequence (FF/00).
     * Discard it and loop back to try again.
     */
    cinfo->marker->discarded_bytes += 2;
    INPUT_SYNC(cinfo);
  }

  if (cinfo->marker->discarded_bytes != 0) {
    WARNMS2(cinfo, JWRN_EXTRANEOUS_DATA, cinfo->marker->discarded_bytes, c);
    cinfo->marker->discarded_bytes = 0;
  }

  cinfo->unread_marker = c;

  INPUT_SYNC(cinfo);
  return TRUE;
}


LOCAL(boolean)
first_marker (j_decompress_ptr cinfo)
/* Like next_marker, but used to obtain the initial SOI marker. */
/* For this marker, we do not allow preceding garbage or fill; otherwise,
 * we might well scan an entire input file before realizing it ain't JPEG.
 * If an application wants to process non-JFIF files, it must seek to the
 * SOI before calling the JPEG library.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品免费观看视频| 欧美激情在线一区二区三区| 精品91自产拍在线观看一区| 国产精品理论片在线观看| 亚洲国产一区二区视频| 成人午夜视频在线观看| 69精品人人人人| 亚洲免费观看高清完整| 国产 欧美在线| 欧美成人女星排行榜| 亚洲精品成人悠悠色影视| 国产精品一区二区三区网站| 欧美午夜不卡在线观看免费| 国产精品成人一区二区艾草 | 日本韩国视频一区二区| 久久久久久毛片| 日韩avvvv在线播放| 欧美在线不卡一区| 亚洲美腿欧美偷拍| 成人高清免费在线播放| 久久精品水蜜桃av综合天堂| 免费在线观看精品| 91精品在线一区二区| 亚洲国产aⅴ成人精品无吗| 91亚洲午夜精品久久久久久| 欧美激情一区二区三区全黄 | 欧美mv日韩mv亚洲| 亚洲bt欧美bt精品| 欧美片在线播放| 亚洲午夜免费电影| 欧美日韩卡一卡二| 五月天丁香久久| 欧美日本一区二区| 亚洲电影在线播放| 欧美电影一区二区| 三级亚洲高清视频| 欧美一级免费大片| 蜜桃精品视频在线| 久久欧美中文字幕| 国产a级毛片一区| 国产精品国产三级国产aⅴ原创| 成人午夜av电影| 国产精品短视频| 欧美在线免费视屏| 日韩影院精彩在线| 日韩一区二区在线观看| 久久99热99| 国产三级精品三级| 成人18精品视频| 一区二区三区四区国产精品| 欧美绝品在线观看成人午夜影视| 日韩国产欧美在线播放| 久久久久久久久蜜桃| 成人av在线影院| 亚洲影院免费观看| 欧美一区午夜视频在线观看| 激情深爱一区二区| 综合在线观看色| 91精品国产一区二区三区蜜臀| 蜜桃视频第一区免费观看| 国产日韩欧美精品电影三级在线| 91麻豆精品一区二区三区| 日韩中文字幕麻豆| 国产无一区二区| 欧美三级韩国三级日本一级| 久久福利视频一区二区| 亚洲欧美福利一区二区| 欧美一区二区三区在| 国产成人av电影免费在线观看| 亚洲色图在线视频| 欧美va亚洲va香蕉在线| av亚洲产国偷v产偷v自拍| 日韩黄色小视频| 国产精品剧情在线亚洲| 欧美一区二区三区电影| 成人午夜私人影院| 日韩高清在线观看| 中文幕一区二区三区久久蜜桃| 欧美日韩精品一区二区三区四区| 国产精品中文字幕一区二区三区| 一区二区三区产品免费精品久久75 | 欧美一区二区久久| fc2成人免费人成在线观看播放 | 一区二区三区在线免费播放| 久久综合99re88久久爱| 欧美三电影在线| 国产一区二区看久久| 亚洲成精国产精品女| 一区二区中文字幕在线| 欧美精品一区二区三区四区| 欧美偷拍一区二区| 99精品久久99久久久久| 日韩高清在线不卡| 亚洲乱码国产乱码精品精98午夜| 久久久91精品国产一区二区精品 | 日韩欧美一卡二卡| 欧美性猛片aaaaaaa做受| 成人免费高清在线| 国产大陆亚洲精品国产| 日韩精品一级二级| 亚洲美女视频一区| 亚洲欧美在线另类| 国产午夜亚洲精品不卡 | 欧美日韩一区二区三区四区| av在线不卡观看免费观看| 国产一区二区三区黄视频 | 色综合久久中文字幕| 国产福利电影一区二区三区| 日本中文字幕一区二区有限公司| 一区二区成人在线视频| 亚洲特级片在线| 自拍偷在线精品自拍偷无码专区| 国产欧美精品一区aⅴ影院 | 91精品国产高清一区二区三区蜜臀| 99riav久久精品riav| 懂色中文一区二区在线播放| 国产一区91精品张津瑜| 国产乱码精品1区2区3区| 精品亚洲国内自在自线福利| 裸体健美xxxx欧美裸体表演| 日韩电影在线免费观看| 欧美aa在线视频| 美女国产一区二区| 国产在线视频精品一区| 国产精品影视天天线| 丁香另类激情小说| 不卡的av电影在线观看| 日本道精品一区二区三区| 色av成人天堂桃色av| 色婷婷久久综合| 欧美日韩精品一区二区三区四区| 8v天堂国产在线一区二区| 精品少妇一区二区三区日产乱码| 精品粉嫩aⅴ一区二区三区四区 | 日韩欧美一二三四区| 精品国产露脸精彩对白| 国产日韩欧美高清| 亚洲欧美日韩国产手机在线| 亚洲国产精品久久不卡毛片| 天堂va蜜桃一区二区三区漫画版| 奇米色一区二区| 国产伦精品一区二区三区免费迷| 高清av一区二区| 在线免费观看不卡av| 欧美成人精品高清在线播放| 欧美国产欧美综合| 亚洲精品网站在线观看| 美女网站一区二区| www.色精品| 精品视频一区 二区 三区| 亚洲精品一区在线观看| 国产精品久久久久aaaa| 亚洲成av人片www| 九九视频精品免费| 色综合久久中文字幕| 日韩一区二区免费在线观看| 国产精品第四页| 美国毛片一区二区三区| av在线不卡免费看| 欧美mv日韩mv亚洲| 亚洲午夜久久久久中文字幕久| 精品一区二区国语对白| 欧美午夜精品电影| 国产欧美日本一区二区三区| 日韩av一区二区三区四区| 99久久综合色| 欧美v亚洲v综合ⅴ国产v| 夜夜操天天操亚洲| 国产凹凸在线观看一区二区| 欧美一区二区视频在线观看2020 | 成人一区二区在线观看| 欧美一区二区福利视频| 亚洲欧美另类在线| 国产精品一二三| 日韩一区二区电影网| 亚洲一区免费在线观看| 懂色av噜噜一区二区三区av| 日韩午夜在线观看| 亚洲高清视频在线| 99re热视频这里只精品| 久久影院电视剧免费观看| 日本中文字幕一区| 欧美三级在线视频| 亚洲欧美日韩久久| 波波电影院一区二区三区| 久久久久久久综合色一本| 青青草国产成人99久久| 在线综合视频播放| 亚洲国产精品人人做人人爽| 91麻豆高清视频| 中文字幕日韩一区二区| 国产suv精品一区二区883| 久久久综合视频| 国产乱色国产精品免费视频| 欧美成人精品3d动漫h| 男女男精品视频网| 欧美一级视频精品观看| 免费人成黄页网站在线一区二区| 在线精品亚洲一区二区不卡| 亚洲精品五月天|