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

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

?? jcmainct.c

?? DigitalImageProcessing_base_on_Matlab 基于Matlab的數(shù)字圖像處理
?? C
字號(hào):
/*
 * jcmainct.c
 *
 * Copyright (C) 1994-1996, Thomas G. Lane.
 * This file is part of the Independent JPEG Group's software.
 * For conditions of distribution and use, see the accompanying README file.
 *
 * This file contains the main buffer controller for compression.
 * The main buffer lies between the pre-processor and the JPEG
 * compressor proper; it holds downsampled data in the JPEG colorspace.
 */

#define JPEG_INTERNALS
#include "jinclude.h"
#include "jpeglib.h"


/* Note: currently, there is no operating mode in which a full-image buffer
 * is needed at this step.  If there were, that mode could not be used with
 * "raw data" input, since this module is bypassed in that case.  However,
 * we've left the code here for possible use in special applications.
 */
#undef FULL_MAIN_BUFFER_SUPPORTED


/* Private buffer controller object */

typedef struct {
  struct jpeg_c_main_controller pub; /* public fields */

  JDIMENSION cur_iMCU_row;	/* number of current iMCU row */
  JDIMENSION rowgroup_ctr;	/* counts row groups received in iMCU row */
  boolean suspended;		/* remember if we suspended output */
  J_BUF_MODE pass_mode;		/* current operating mode */

  /* If using just a strip buffer, this points to the entire set of buffers
   * (we allocate one for each component).  In the full-image case, this
   * points to the currently accessible strips of the virtual arrays.
   */
  JSAMPARRAY buffer[MAX_COMPONENTS];

#ifdef FULL_MAIN_BUFFER_SUPPORTED
  /* If using full-image storage, this array holds pointers to virtual-array
   * control blocks for each component.  Unused if not full-image storage.
   */
  jvirt_sarray_ptr whole_image[MAX_COMPONENTS];
#endif
} my_main_controller;

typedef my_main_controller * my_main_ptr;


/* Forward declarations */
METHODDEF(void) process_data_simple_main
	JPP((j_compress_ptr cinfo, JSAMPARRAY input_buf,
	     JDIMENSION *in_row_ctr, JDIMENSION in_rows_avail));
#ifdef FULL_MAIN_BUFFER_SUPPORTED
METHODDEF(void) process_data_buffer_main
	JPP((j_compress_ptr cinfo, JSAMPARRAY input_buf,
	     JDIMENSION *in_row_ctr, JDIMENSION in_rows_avail));
#endif


/*
 * Initialize for a processing pass.
 */

METHODDEF(void)
start_pass_main (j_compress_ptr cinfo, J_BUF_MODE pass_mode)
{
  my_main_ptr main = (my_main_ptr) cinfo->main;

  /* Do nothing in raw-data mode. */
  if (cinfo->raw_data_in)
    return;

  main->cur_iMCU_row = 0;	/* initialize counters */
  main->rowgroup_ctr = 0;
  main->suspended = FALSE;
  main->pass_mode = pass_mode;	/* save mode for use by process_data */

  switch (pass_mode) {
  case JBUF_PASS_THRU:
#ifdef FULL_MAIN_BUFFER_SUPPORTED
    if (main->whole_image[0] != NULL)
      ERREXIT(cinfo, JERR_BAD_BUFFER_MODE);
#endif
    main->pub.process_data = process_data_simple_main;
    break;
#ifdef FULL_MAIN_BUFFER_SUPPORTED
  case JBUF_SAVE_SOURCE:
  case JBUF_CRANK_DEST:
  case JBUF_SAVE_AND_PASS:
    if (main->whole_image[0] == NULL)
      ERREXIT(cinfo, JERR_BAD_BUFFER_MODE);
    main->pub.process_data = process_data_buffer_main;
    break;
#endif
  default:
    ERREXIT(cinfo, JERR_BAD_BUFFER_MODE);
    break;
  }
}


/*
 * Process some data.
 * This routine handles the simple pass-through mode,
 * where we have only a strip buffer.
 */

METHODDEF(void)
process_data_simple_main (j_compress_ptr cinfo,
			  JSAMPARRAY input_buf, JDIMENSION *in_row_ctr,
			  JDIMENSION in_rows_avail)
{
  my_main_ptr main = (my_main_ptr) cinfo->main;

  while (main->cur_iMCU_row < cinfo->total_iMCU_rows) {
    /* Read input data if we haven't filled the main buffer yet */
    if (main->rowgroup_ctr < DCTSIZE)
      (*cinfo->prep->pre_process_data) (cinfo,
					input_buf, in_row_ctr, in_rows_avail,
					main->buffer, &main->rowgroup_ctr,
					(JDIMENSION) DCTSIZE);

    /* If we don't have a full iMCU row buffered, return to application for
     * more data.  Note that preprocessor will always pad to fill the iMCU row
     * at the bottom of the image.
     */
    if (main->rowgroup_ctr != DCTSIZE)
      return;

    /* Send the completed row to the compressor */
    if (! (*cinfo->coef->compress_data) (cinfo, main->buffer)) {
      /* If compressor did not consume the whole row, then we must need to
       * suspend processing and return to the application.  In this situation
       * we pretend we didn't yet consume the last input row; otherwise, if
       * it happened to be the last row of the image, the application would
       * think we were done.
       */
      if (! main->suspended) {
	(*in_row_ctr)--;
	main->suspended = TRUE;
      }
      return;
    }
    /* We did finish the row.  Undo our little suspension hack if a previous
     * call suspended; then mark the main buffer empty.
     */
    if (main->suspended) {
      (*in_row_ctr)++;
      main->suspended = FALSE;
    }
    main->rowgroup_ctr = 0;
    main->cur_iMCU_row++;
  }
}


#ifdef FULL_MAIN_BUFFER_SUPPORTED

/*
 * Process some data.
 * This routine handles all of the modes that use a full-size buffer.
 */

METHODDEF(void)
process_data_buffer_main (j_compress_ptr cinfo,
			  JSAMPARRAY input_buf, JDIMENSION *in_row_ctr,
			  JDIMENSION in_rows_avail)
{
  my_main_ptr main = (my_main_ptr) cinfo->main;
  int ci;
  jpeg_component_info *compptr;
  boolean writing = (main->pass_mode != JBUF_CRANK_DEST);

  while (main->cur_iMCU_row < cinfo->total_iMCU_rows) {
    /* Realign the virtual buffers if at the start of an iMCU row. */
    if (main->rowgroup_ctr == 0) {
      for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
	   ci++, compptr++) {
	main->buffer[ci] = (*cinfo->mem->access_virt_sarray)
	  ((j_common_ptr) cinfo, main->whole_image[ci],
	   main->cur_iMCU_row * (compptr->v_samp_factor * DCTSIZE),
	   (JDIMENSION) (compptr->v_samp_factor * DCTSIZE), writing);
      }
      /* In a read pass, pretend we just read some source data. */
      if (! writing) {
	*in_row_ctr += cinfo->max_v_samp_factor * DCTSIZE;
	main->rowgroup_ctr = DCTSIZE;
      }
    }

    /* If a write pass, read input data until the current iMCU row is full. */
    /* Note: preprocessor will pad if necessary to fill the last iMCU row. */
    if (writing) {
      (*cinfo->prep->pre_process_data) (cinfo,
					input_buf, in_row_ctr, in_rows_avail,
					main->buffer, &main->rowgroup_ctr,
					(JDIMENSION) DCTSIZE);
      /* Return to application if we need more data to fill the iMCU row. */
      if (main->rowgroup_ctr < DCTSIZE)
	return;
    }

    /* Emit data, unless this is a sink-only pass. */
    if (main->pass_mode != JBUF_SAVE_SOURCE) {
      if (! (*cinfo->coef->compress_data) (cinfo, main->buffer)) {
	/* If compressor did not consume the whole row, then we must need to
	 * suspend processing and return to the application.  In this situation
	 * we pretend we didn't yet consume the last input row; otherwise, if
	 * it happened to be the last row of the image, the application would
	 * think we were done.
	 */
	if (! main->suspended) {
	  (*in_row_ctr)--;
	  main->suspended = TRUE;
	}
	return;
      }
      /* We did finish the row.  Undo our little suspension hack if a previous
       * call suspended; then mark the main buffer empty.
       */
      if (main->suspended) {
	(*in_row_ctr)++;
	main->suspended = FALSE;
      }
    }

    /* If get here, we are done with this iMCU row.  Mark buffer empty. */
    main->rowgroup_ctr = 0;
    main->cur_iMCU_row++;
  }
}

#endif /* FULL_MAIN_BUFFER_SUPPORTED */


/*
 * Initialize main buffer controller.
 */

GLOBAL(void)
jinit_c_main_controller (j_compress_ptr cinfo, boolean need_full_buffer)
{
  my_main_ptr main;
  int ci;
  jpeg_component_info *compptr;

  main = (my_main_ptr)
    (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
				SIZEOF(my_main_controller));
  cinfo->main = (struct jpeg_c_main_controller *) main;
  main->pub.start_pass = start_pass_main;

  /* We don't need to create a buffer in raw-data mode. */
  if (cinfo->raw_data_in)
    return;

  /* Create the buffer.  It holds downsampled data, so each component
   * may be of a different size.
   */
  if (need_full_buffer) {
#ifdef FULL_MAIN_BUFFER_SUPPORTED
    /* Allocate a full-image virtual array for each component */
    /* Note we pad the bottom to a multiple of the iMCU height */
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
	 ci++, compptr++) {
      main->whole_image[ci] = (*cinfo->mem->request_virt_sarray)
	((j_common_ptr) cinfo, JPOOL_IMAGE, FALSE,
	 compptr->width_in_blocks * DCTSIZE,
	 (JDIMENSION) jround_up((long) compptr->height_in_blocks,
				(long) compptr->v_samp_factor) * DCTSIZE,
	 (JDIMENSION) (compptr->v_samp_factor * DCTSIZE));
    }
#else
    ERREXIT(cinfo, JERR_BAD_BUFFER_MODE);
#endif
  } else {
#ifdef FULL_MAIN_BUFFER_SUPPORTED
    main->whole_image[0] = NULL; /* flag for no virtual arrays */
#endif
    /* Allocate a strip buffer for each component */
    for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
	 ci++, compptr++) {
      main->buffer[ci] = (*cinfo->mem->alloc_sarray)
	((j_common_ptr) cinfo, JPOOL_IMAGE,
	 compptr->width_in_blocks * DCTSIZE,
	 (JDIMENSION) (compptr->v_samp_factor * DCTSIZE));
    }
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲蜜臀av乱码久久精品| 午夜激情综合网| 亚洲午夜激情网页| 国产白丝网站精品污在线入口| 一本久道久久综合中文字幕| 精品国产一区二区亚洲人成毛片| 中文字幕一区二区三中文字幕| 日本va欧美va欧美va精品| 粉嫩嫩av羞羞动漫久久久| 在线91免费看| 亚洲一区在线观看免费观看电影高清| 国产精品影音先锋| 日韩欧美精品三级| 午夜精品视频一区| 在线观看日韩国产| 日韩毛片一二三区| 丰满岳乱妇一区二区三区| 久久综合九色欧美综合狠狠| 无吗不卡中文字幕| 欧美在线free| 一区二区国产盗摄色噜噜| 成人黄色国产精品网站大全在线免费观看 | 久久成人久久爱| 欧美日韩国产一级| 亚洲一区在线免费观看| 在线观看www91| 亚洲精品欧美专区| 91麻豆国产福利在线观看| 国产精品久99| av不卡在线观看| 国产精品情趣视频| av亚洲精华国产精华精华| 国产欧美视频一区二区三区| 国产精品一区二区视频| 国产清纯美女被跳蛋高潮一区二区久久w | 蜜臀av国产精品久久久久| 欧美丰满嫩嫩电影| 日韩激情在线观看| 91精品国产综合久久久久久久| 亚洲成人免费av| 欧美一区二区精品久久911| 免费一级片91| 久久午夜电影网| 国产一区二区三区美女| 国产日韩欧美a| 成人美女视频在线观看18| 中文字幕一区二区三区在线不卡| 91年精品国产| 亚洲123区在线观看| 欧美一区二区三区在线观看 | 成人网在线免费视频| 亚洲情趣在线观看| 7777精品伊人久久久大香线蕉完整版| 琪琪久久久久日韩精品| 欧美精品一区二区精品网| 丁香一区二区三区| 一区二区三区美女| 日韩一区二区三免费高清| 国产九色精品成人porny| 亚洲欧洲精品一区二区精品久久久| 91亚洲精品久久久蜜桃| 日韩精品色哟哟| 国产日韩精品一区二区三区| av电影在线观看不卡| 午夜视频在线观看一区| 欧美精品一区二区三区很污很色的| 成人免费看黄yyy456| 亚洲国产精品影院| 久久这里只有精品视频网| 色综合久久久久久久久久久| 美女视频黄免费的久久 | 国产精品一区久久久久| 综合久久一区二区三区| 日韩午夜在线影院| 99久久夜色精品国产网站| 日本欧美一区二区三区乱码 | 成人av在线网站| 日日摸夜夜添夜夜添精品视频| 久久综合五月天婷婷伊人| 在线看日韩精品电影| 国内精品伊人久久久久av影院 | 欧美日韩国产经典色站一区二区三区| 老司机精品视频在线| 亚洲最新视频在线观看| 久久婷婷国产综合精品青草 | 国产色91在线| 精品久久久久久无| 欧美在线免费视屏| 高清成人免费视频| 美女高潮久久久| 亚洲影视资源网| 国产精品亲子乱子伦xxxx裸| 日韩亚洲欧美综合| 欧美色国产精品| 91精彩视频在线观看| 成人国产视频在线观看| 国内成人精品2018免费看| 日本v片在线高清不卡在线观看| 樱花草国产18久久久久| 日本一区二区三区高清不卡| 日韩视频在线一区二区| 欧美日韩国产影片| 欧美视频完全免费看| 91碰在线视频| 99re这里都是精品| 成人av网站大全| 高清不卡一区二区| 国产.精品.日韩.另类.中文.在线.播放 | 国产制服丝袜一区| 日韩影院免费视频| 肉肉av福利一精品导航| 午夜精品福利一区二区三区蜜桃| 亚洲三级小视频| 亚洲欧美国产毛片在线| 亚洲欧美偷拍三级| 亚洲靠逼com| 亚洲天堂av一区| 亚洲日本在线看| 综合色中文字幕| 日韩专区中文字幕一区二区| 亚洲第一福利一区| 青椒成人免费视频| 国产在线不卡一区| 国产精品一区久久久久| 成人午夜激情影院| 色香色香欲天天天影视综合网| 91麻豆免费观看| 欧美性一二三区| 91精品国产91热久久久做人人| 91精品中文字幕一区二区三区| 91精品国产免费| 精品国产乱码久久久久久久久 | 欧美亚洲图片小说| 欧美伦理视频网站| 精品少妇一区二区三区免费观看 | 欧美一区二区三区四区在线观看| 日韩丝袜美女视频| 国产日韩欧美a| 亚洲国产欧美在线人成| 免费在线一区观看| 国产不卡视频一区| 欧美色精品在线视频| 欧美va天堂va视频va在线| 国产日韩精品一区| 亚洲成人免费av| 国产原创一区二区| 色欧美乱欧美15图片| 欧美一区二区不卡视频| 久久女同性恋中文字幕| 一区二区三区不卡视频| 另类中文字幕网| 色哟哟国产精品| 2017欧美狠狠色| 亚洲男人的天堂在线观看| 琪琪一区二区三区| 色综合天天综合给合国产| 欧美一级专区免费大片| 国产精品视频第一区| 日韩二区三区四区| 国产不卡视频一区二区三区| 欧美久久久影院| 国产精品久久久久天堂| 奇米色一区二区| 一本一道久久a久久精品| 日韩欧美123| 亚洲国产一区二区a毛片| 国产一区二区三区蝌蚪| 欧美精品乱人伦久久久久久| 国产精品视频麻豆| 激情欧美一区二区三区在线观看| 91小视频在线| 国产午夜亚洲精品理论片色戒| 夜夜精品浪潮av一区二区三区| 国产精品综合在线视频| 4438成人网| 亚洲精品中文在线影院| 国产麻豆视频一区二区| 91精品国产欧美一区二区| 亚洲一区二区不卡免费| 成人国产精品视频| 2022国产精品视频| 免费视频最近日韩| 欧美美女激情18p| 亚洲综合一区二区三区| 99久久精品免费看| 国产日产欧产精品推荐色| 久久国产免费看| 日韩一区二区电影网| 视频精品一区二区| 欧美日韩一本到| 亚洲综合色视频| 色综合天天视频在线观看 | 精品国产精品一区二区夜夜嗨| 亚洲国产精品欧美一二99 | proumb性欧美在线观看| 久久精品视频在线免费观看| 国产在线看一区| 精品久久久久av影院| 极品少妇一区二区| 精品国产乱码久久久久久图片|