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

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

?? jpeg.c

?? DigitalImageProcessing_base_on_Matlab 基于Matlab的數(shù)字圖像處理
?? C
字號:
/* jpeg.c - i/o routines for 'jpeg' format pictures */
/* based in part on 'example.c' from the IJG JPEG distribution */
/* based in part on 'xvjpeg.c' from the xv 3.10a */

#include <stdio.h>
#include <stdlib.h>
#include <setjmp.h>
#include "jpeglib.h"
#include "jerror.h"
#include "jpeg.h"

#ifndef size_t
  #define size_t unsigned
#endif

#define SUCCESSED	0
#define FAILED		1

static void *mget_spc(int num,size_t size);
static void **get_img(int wd,int ht,size_t size);
static void free_img(void **pt);

struct my_error_mgr {
  struct jpeg_error_mgr pub;
  jmp_buf               setjmp_buffer;
};

typedef struct my_error_mgr *my_error_ptr;


static void jpeg_error_exit(j_common_ptr cinfo) ;
static void jpeg_error_output(j_common_ptr cinfo) ;



/***************************************************************************/
/* JPEG INTERFACE ROUTINES *************************************************/
/***************************************************************************/



/**************************************************/
static void jpeg_error_exit(j_common_ptr cinfo) 
{
  my_error_ptr myerr;

  myerr = (my_error_ptr) cinfo->err;
  (*cinfo->err->output_message)(cinfo);     /* display error message */
  longjmp(myerr->setjmp_buffer, 1);         /* return from error */
}


/**************************************************/
static void jpeg_error_output(j_common_ptr cinfo) 
{
  my_error_ptr myerr;
  char         buffer[JMSG_LENGTH_MAX];

  myerr = (my_error_ptr) cinfo->err;
  (*cinfo->err->format_message)(cinfo, buffer);
  fprintf(stderr, "%s", buffer);   
}


/***************************************************************************/
/* LOAD ROUTINES ***********************************************************/
/***************************************************************************/


/*******************************************/
int read_JPEG(FILE *infile, struct JPEG_img *jpeg_img)
{

  struct jpeg_decompress_struct    cinfo;
  struct my_error_mgr              jerr;
  JSAMPARRAY                       buffer;
  int                              i, k, m, rowstride;
  unsigned char			   magicno[3];


  fseek(infile, 0, 0);
  if ((i=fread(magicno, (size_t) 1, (size_t) 3, infile)) < 3) return(FAILED);
  if (magicno[0]!=0xff||magicno[1]!=0xd8||magicno[2]!=0xff) return(FAILED);
  fseek(infile, 0, 0);

  /* Step 1: allocate and initialize JPEG compression object */

  cinfo.err = jpeg_std_error(&jerr.pub);
  jerr.pub.error_exit     = jpeg_error_exit;
  jerr.pub.output_message = jpeg_error_output;

  if (setjmp(jerr.setjmp_buffer)) {
    /* if we're here, it blowed up... */
    jpeg_destroy_decompress(&cinfo);
    fclose(infile);
    return FAILED;
  }


  jpeg_create_decompress(&cinfo);

  /* Step 2: specify data destination (eg, a file) */

  jpeg_stdio_src(&cinfo, infile);

  /* Step 3: read file parameters with jpeg_read_header() */

  (void) jpeg_read_header(&cinfo, TRUE);

  /* Step 4: set parameters for decompression */
  /* do various cleverness regarding decompression parameters & such... */

  jpeg_calc_output_dimensions(&cinfo);
  jpeg_img->width  = cinfo.output_width;
  jpeg_img->height = cinfo.output_height;

  if (cinfo.jpeg_color_space == JCS_GRAYSCALE) {
    cinfo.out_color_space = JCS_GRAYSCALE;
    cinfo.quantize_colors = FALSE;
  } else {
    cinfo.out_color_space = JCS_RGB;
    cinfo.quantize_colors = FALSE;     /* default: give 24-bit image to XV */
  }
  
  jpeg_calc_output_dimensions(&cinfo);   /* note colorspace changes... */
  rowstride = cinfo.output_width * cinfo.output_components;
    
  if (cinfo.output_components != 1 && cinfo.output_components != 3) {
    fprintf(stderr, "Can't read %d-plane JPEG file!", cinfo.output_components);
    jpeg_destroy_decompress(&cinfo);
    fclose(infile);
    return FAILED;
  }

  if (cinfo.out_color_space == JCS_GRAYSCALE) {
    jpeg_img->jpeg_type = 'g';
    jpeg_img->mono = (unsigned char **) 
      get_img (jpeg_img->width, jpeg_img->height, sizeof (unsigned char));
  } else {
    jpeg_img->jpeg_type = 'c';
    jpeg_img->color =(unsigned char ***) malloc (sizeof (unsigned char **) * 3);
    for (i = 0; i < 3; i++)
      jpeg_img->color[i] = (unsigned char **) 
	get_img (jpeg_img->width, jpeg_img->height, sizeof (unsigned char));
  }
  

 
  /* Step 5: Start decompressor */

  jpeg_start_decompress(&cinfo);

  /* Step 6: while (scan lines remain to be read) */
  /*           jpeg_read_scanlines(...); */

  /* Make a one-row-high sample array that will go away when done with image */
  buffer = (*cinfo.mem->alloc_sarray)
		((j_common_ptr) &cinfo, JPOOL_IMAGE, rowstride, 1);

  while (cinfo.output_scanline < cinfo.output_height) {
    (void) jpeg_read_scanlines(&cinfo, buffer, 1);
    /* Assume put_scanline_someplace wants a pointer and sample count. */
    if (cinfo.out_color_space == JCS_GRAYSCALE) {
      for (i = 0; i < jpeg_img->width; i++) 
	jpeg_img->mono[cinfo.output_scanline-1][i] = buffer[0][i];
    } else {
      for (i= m = 0; i < jpeg_img->width; i++)
	for (k = 0; k < 3; k++) 
	  jpeg_img->color[k][cinfo.output_scanline-1][i] = buffer[0][m++];
    }
  }

  
  /* Step 7: Finish decompression */

  jpeg_finish_decompress(&cinfo);


  /* Step 8: Release JPEG decompression object */

  jpeg_destroy_decompress(&cinfo);

  return SUCCESSED;
}
  
  
/***************************************************************************/
/* WRITE ROUTINES **********************************************************/
/***************************************************************************/

int write_JPEG(FILE *outfile, struct JPEG_img *jpeg_img, 
	       int quality, int smooth)
{
  struct     jpeg_compress_struct cinfo;
  struct     my_error_mgr         jerr;
  JSAMPARRAY                      buffer;
  int                             i, k, m, rowstride;

  /* Step 1: allocate and initialize JPEG compression object */

  cinfo.err               = jpeg_std_error(&jerr.pub);
  jerr.pub.error_exit     = jpeg_error_exit;
  jerr.pub.output_message = jpeg_error_output;

  if (setjmp(jerr.setjmp_buffer)) {
    /* if we're here, it blowed up... */
    jpeg_destroy_compress(&cinfo);
    return FAILED;
  }

  jpeg_create_compress(&cinfo);

  /* Step 2: specify data destination (eg, a file) */

  jpeg_stdio_dest(&cinfo, outfile);

  /* Step 3: set parameters for compression */

  cinfo.image_width  = jpeg_img->width;
  cinfo.image_height = jpeg_img->height;
  if (jpeg_img->jpeg_type == 'g') {
    cinfo.input_components = 1;
    cinfo.in_color_space = JCS_GRAYSCALE;
  } else {
    cinfo.input_components = 3;
    cinfo.in_color_space = JCS_RGB;
  }
  rowstride = cinfo.image_width * cinfo.input_components;

  jpeg_set_defaults(&cinfo);
  jpeg_set_quality(&cinfo, quality, TRUE);
  cinfo.smoothing_factor = smooth;


  /* Step 4: Start compressor */

  jpeg_start_compress(&cinfo, TRUE);

  /* Step 5: while (scan lines remain to be written) */
  /*           jpeg_write_scanlines(...); */

  /* Make a one-row-high sample array that will go away when done with image */
  buffer = (*cinfo.mem->alloc_sarray)
		((j_common_ptr) &cinfo, JPOOL_IMAGE, rowstride, 1);

  while (cinfo.next_scanline < cinfo.image_height) {
    if (jpeg_img->jpeg_type == 'g') {
      for (i = 0; i < jpeg_img->width; i++) 
	buffer[0][i] = jpeg_img->mono[cinfo.next_scanline][i];
    } else {
      for (i= m = 0; i < jpeg_img->width; i++)
	for (k = 0; k < 3; k++) 
	  buffer[0][m++] = jpeg_img->color[k][cinfo.next_scanline][i];
    }
    (void) jpeg_write_scanlines(&cinfo, buffer, (JDIMENSION) 1);
  }
  
  /* Step 6: Finish compression */

  jpeg_finish_compress(&cinfo);

  /* Step 7: release JPEG compression object */

  jpeg_destroy_compress(&cinfo);

  return SUCCESSED;
}



void free_JPEG (struct JPEG_img *img)

{
  int			i;

  if (img->jpeg_type == 'g') {
    free_img ((void **)img->mono);
  }
  else {
    if (img->jpeg_type == 'c') {
      for (i = 0; i < 3; i++) free_img ((void **)img->color[i]);
      free((void *)img->color);
    }
    else
      fprintf(stderr,"\nWarning: input structure to free routine is invalid\n");
  }
}


void get_JPEG (struct JPEG_img *img, int height, int width, char jpeg_type)

{
  int			i;

  img->height = height;
  img->width = width;
  img->jpeg_type = jpeg_type; 
  
  if (img->jpeg_type == 'g') {
    img->mono = 
         (unsigned char **)get_img(img->width, img->height, sizeof(char));
  }
  else {
    if (img->jpeg_type == 'c') {
      img->color = mget_spc(3,sizeof(void *));
      for (i = 0; i < 3; i++)
        img->color[i] = 
             (unsigned char **)get_img(img->width, img->height, sizeof(char));
    }
    else
      fprintf(stderr,"\nWarning: input structure to get_JPEG routine is invalid\n");
  }

}

static void *mget_spc(int num,size_t size)
{
	void *pt;

	if( (pt=malloc((size_t)(num*size))) == NULL ) {
		fprintf(stderr, "==> malloc() error\n");
		exit(-1);
		}
	return(pt);
}

static void **get_img(int wd,int ht,size_t size)
{
	int i;
	void  **ppt;
	char   *pt;

	ppt = (void **)mget_spc(ht,sizeof(void *));
	pt = (char *)mget_spc(wd*ht,size);

	for(i=0; i<ht; i++) ppt[i] = pt + i*wd*size;

	return(ppt);
}

static void free_img(void **pt)
{
	free( (void *)pt[0]);
	free( (void *)pt);
}


#ifdef TESTJPEG
int main(int argc, char **argv)
{
  FILE *fin, *fout;
  struct JPEG_img img_in, img_out;
  int i,j,m,n;

  if (argc != 3) {
    fprintf(stderr, "\nUsage: %s infile outfile\n", argv[0]);
    exit(-1);
  }

  if((fin = fopen(argv[1], "rb")) == NULL) {
    fprintf(stderr, "\nError: can't read from %s\n", argv[1]); 
    exit(-1);
  }

  if (read_JPEG(fin, &img_in) == FAILED) {
    fprintf(stderr, "\nError: JPEG read failed\n"); 
    fclose(fin);
    exit(-1);
  }
  fclose(fin);

  if( img_in.jpeg_type == 'g') {
    /* set up structure for output image */
    get_JPEG ( &img_out, 2*img_in.height, 2*img_in.width, 'g' );

    /* pixel replication */
    for ( i = 0; i < img_in.height; i++ )
    for ( j = 0; j < img_in.width; j++ )
      for ( m = 0; m < 2; m++ )
      for ( n = 0; n < 2; n++ ) {
        img_out.mono[2*i+m][2*j+n] = img_in.mono[i][j];
      }


  } if( (img_in.jpeg_type == 'c') ) {
    /* set up structure for output image */
    get_JPEG ( &img_out, 2*img_in.height, 2*img_in.width, 'c' );

    /* pixel replication */
    for ( i = 0; i < img_in.height; i++ )
    for ( j = 0; j < img_in.width; j++ )
      for ( m = 0; m < 2; m++ )
      for ( n = 0; n < 2; n++ ) {
        img_out.color[0][2*i+m][2*j+n] = img_in.color[0][i][j];
        img_out.color[1][2*i+m][2*j+n] = img_in.color[1][i][j];
        img_out.color[2][2*i+m][2*j+n] = img_in.color[2][i][j];
      }


  } else {
    fprintf(stderr, "\nUnknown Image type\n");
    exit(-1);
  }

  if((fout = fopen(argv[2], "wb"))==NULL) {
    fprintf(stderr,"\nError: can't write to %s\n", argv[2]); 
    exit(-1);
  }

  if( write_JPEG(fout, &img_out, 95, 0) == FAILED) { /* quality=95, smooth=0 */
     fprintf(stderr,"\nError: can't write to JPEG image %s\n", argv[2]); 
     fclose(fout);
     exit(-1);
  }
  fclose(fout);

}

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜亚洲精品午夜鲁丝片| 色综合一个色综合亚洲| 国产精品香蕉一区二区三区| 粉嫩av亚洲一区二区图片| 91丝袜国产在线播放| 欧美日本在线播放| 精品国产一区a| 国产精品国模大尺度视频| 一级女性全黄久久生活片免费| 日韩有码一区二区三区| 国产精品原创巨作av| 91网页版在线| 日韩欧美精品三级| 国产精品麻豆欧美日韩ww| 亚洲高清久久久| 国产精品一区二区三区网站| 91久久香蕉国产日韩欧美9色| 日韩女优电影在线观看| 国产精品美女久久久久aⅴ| 亚洲国产aⅴ成人精品无吗| 国产激情视频一区二区三区欧美 | 欧美精选午夜久久久乱码6080| 日韩情涩欧美日韩视频| 国产精品久久久一本精品 | eeuss鲁片一区二区三区| 欧美精品tushy高清| 国产精品免费久久| 亚洲福利电影网| 大白屁股一区二区视频| 制服.丝袜.亚洲.中文.综合| 国产喷白浆一区二区三区| 香蕉久久一区二区不卡无毒影院| 粉嫩av一区二区三区| 91精品黄色片免费大全| 国产精品欧美一级免费| 秋霞国产午夜精品免费视频| 一本大道av伊人久久综合| 26uuu另类欧美亚洲曰本| 亚洲国产综合视频在线观看| 国产成人在线网站| 91精品国产乱码| 一区二区三区中文在线| 成人亚洲一区二区一| 欧美xxxx在线观看| 亚洲午夜影视影院在线观看| 成人av网站在线观看| 精品国产髙清在线看国产毛片| 亚洲香蕉伊在人在线观| 99久久国产免费看| 国产无遮挡一区二区三区毛片日本| 日本欧美在线观看| 欧美日韩一区三区| 亚洲欧美一区二区三区极速播放 | 在线一区二区视频| 国产精品国产三级国产aⅴ入口| 久久精品国产网站| 正在播放一区二区| 午夜精品久久久久影视| 色综合久久综合网欧美综合网| 中文在线一区二区| 国产一区二区免费视频| 日韩一区二区三区av| 午夜电影网亚洲视频| 欧美在线制服丝袜| 亚洲美女偷拍久久| 97久久精品人人做人人爽50路| 亚洲国产电影在线观看| 国产乱对白刺激视频不卡| 精品美女被调教视频大全网站| 奇米影视在线99精品| 欧美一级专区免费大片| 日韩影院在线观看| 欧美一区午夜视频在线观看 | 在线播放视频一区| 亚洲6080在线| 欧美午夜精品电影| 亚洲电影第三页| 精品视频免费在线| 亚洲午夜久久久久久久久久久 | 一区二区三区不卡视频| 91麻豆精东视频| 一区二区三区四区在线免费观看| 99麻豆久久久国产精品免费| 自拍偷拍欧美激情| 日本精品视频一区二区三区| 一区二区三区四区亚洲| 欧美午夜免费电影| 秋霞av亚洲一区二区三| 欧美不卡123| 国产精品一区二区不卡| 国产精品免费免费| 91国产丝袜在线播放| 一区二区三区成人在线视频| 欧美乱妇一区二区三区不卡视频| 日韩不卡一区二区三区| 日韩欧美久久一区| 国产成人亚洲精品狼色在线| 亚洲欧洲一区二区在线播放| 色拍拍在线精品视频8848| 亚洲国产一区二区视频| 日韩欧美一级片| 国产成人鲁色资源国产91色综| 国产精品美女久久久久久久| 在线观看av一区| 青青草91视频| 国产欧美一区二区精品性色超碰 | 最近日韩中文字幕| 欧美日韩一本到| 久久综合综合久久综合| 国产人妖乱国产精品人妖| 91香蕉视频黄| 日韩av高清在线观看| 国产日韩v精品一区二区| 色国产综合视频| 蜜桃视频一区二区| 国产精品久久久久一区二区三区 | 国产精品久久毛片av大全日韩| 在线观看免费成人| 精品中文字幕一区二区小辣椒| 欧美激情资源网| 在线精品亚洲一区二区不卡| 蜜桃视频在线一区| 国产精品人人做人人爽人人添| 欧美美女直播网站| 国产大陆精品国产| 亚洲v中文字幕| 中文字幕高清一区| 91精品在线免费| 成人免费高清视频在线观看| 天天做天天摸天天爽国产一区 | 国产一区二区免费在线| 亚洲精品成人天堂一二三| 欧美一区二区精品在线| 91网站最新地址| 国内外成人在线| 亚洲一本大道在线| 日本一区二区不卡视频| 91精品国产综合久久久蜜臀粉嫩 | 日韩一区二区电影在线| 97久久精品人人做人人爽| 久久电影网电视剧免费观看| 亚洲精品少妇30p| 久久婷婷综合激情| 制服丝袜中文字幕亚洲| 色天使色偷偷av一区二区| 国产一级精品在线| 日本亚洲三级在线| 亚洲美女精品一区| 国产视频一区二区三区在线观看| 欧美日韩国产综合草草| 91麻豆国产在线观看| 国产成人精品亚洲午夜麻豆| 日韩黄色小视频| 亚洲一区二区综合| 国产精品久久久久影院色老大 | 国产在线不卡一卡二卡三卡四卡| 亚洲成国产人片在线观看| 国产精品初高中害羞小美女文| 精品国产亚洲在线| 日韩一区二区三区在线观看| 欧日韩精品视频| www.亚洲免费av| 国产激情偷乱视频一区二区三区| 奇米色777欧美一区二区| 亚洲一区视频在线| 一区视频在线播放| 欧美激情一区二区三区不卡| 精品少妇一区二区三区视频免付费| 精品1区2区3区| 一本色道久久加勒比精品| 成人av网站免费| 粉嫩aⅴ一区二区三区四区| 国产一二精品视频| 国内精品免费**视频| 人人狠狠综合久久亚洲| 日韩成人一区二区三区在线观看| 一区2区3区在线看| 亚洲精品一二三四区| 最新日韩av在线| 国产精品视频你懂的| 国产精品乱人伦| 国产欧美日韩另类视频免费观看| 久久久www成人免费无遮挡大片| 欧美变态口味重另类| 日韩欧美电影一区| 日韩精品中文字幕一区 | 久99久精品视频免费观看| 免费在线观看一区二区三区| 奇米色一区二区| 久久99这里只有精品| 精彩视频一区二区三区| 久久成人av少妇免费| 久久精品国产精品亚洲红杏| 麻豆精品久久精品色综合| 蜜臀av性久久久久av蜜臀妖精| 久久精品久久久精品美女| 国产一区二三区好的| 丁香亚洲综合激情啪啪综合| 粉嫩在线一区二区三区视频| av在线播放不卡|