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

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

?? djpeg.c

?? JPEG source code converts the image into compressed format
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
 * djpeg.c
 *
 * Copyright (C) 1991-1997, 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 a command-line user interface for the JPEG decompressor.
 * It should work on any system with Unix- or MS-DOS-style command lines.
 *
 * Two different command line styles are permitted, depending on the
 * compile-time switch TWO_FILE_COMMANDLINE:
 *	djpeg [options]  inputfile outputfile
 *	djpeg [options]  [inputfile]
 * In the second style, output is always to standard output, which you'd
 * normally redirect to a file or pipe to some other program.  Input is
 * either from a named file or from standard input (typically redirected).
 * The second style is convenient on Unix but is unhelpful on systems that
 * don't support pipes.  Also, you MUST use the first style if your system
 * doesn't do binary I/O to stdin/stdout.
 * To simplify script writing, the "-outfile" switch is provided.  The syntax
 *	djpeg [options]  -outfile outputfile  inputfile
 * works regardless of which command line style is used.
 */

#include "cdjpeg.h"		/* Common decls for cjpeg/djpeg applications */
#include "jversion.h"		/* for version message */

#include <ctype.h>		/* to declare isprint() */

#ifdef USE_CCOMMAND		/* command-line reader for Macintosh */
#ifdef __MWERKS__
#include <SIOUX.h>              /* Metrowerks needs this */
#include <console.h>		/* ... and this */
#endif
#ifdef THINK_C
#include <console.h>		/* Think declares it here */
#endif
#endif


/* Create the add-on message string table. */

#define JMESSAGE(code,string)	string ,

static const char * const cdjpeg_message_table[] = {
#include "cderror.h"
  NULL
};


/*
 * This list defines the known output image formats
 * (not all of which need be supported by a given version).
 * You can change the default output format by defining DEFAULT_FMT;
 * indeed, you had better do so if you undefine PPM_SUPPORTED.
 */

typedef enum {
	FMT_BMP,		/* BMP format (Windows flavor) */
	FMT_GIF,		/* GIF format */
	FMT_OS2,		/* BMP format (OS/2 flavor) */
	FMT_PPM,		/* PPM/PGM (PBMPLUS formats) */
	FMT_RLE,		/* RLE format */
	FMT_TARGA,		/* Targa format */
	FMT_TIFF		/* TIFF format */
} IMAGE_FORMATS;

#ifndef DEFAULT_FMT		/* so can override from CFLAGS in Makefile */
#define DEFAULT_FMT	FMT_PPM
#endif

static IMAGE_FORMATS requested_fmt;


/*
 * Argument-parsing code.
 * The switch parser is designed to be useful with DOS-style command line
 * syntax, ie, intermixed switches and file names, where only the switches
 * to the left of a given file name affect processing of that file.
 * The main program in this file doesn't actually use this capability...
 */


static const char * progname;	/* program name for error messages */
static char * outfilename;	/* for -outfile switch */


LOCAL(void)
usage (void)
/* complain about bad command line */
{
  fprintf(stderr, "usage: %s [switches] ", progname);
#ifdef TWO_FILE_COMMANDLINE
  fprintf(stderr, "inputfile outputfile\n");
#else
  fprintf(stderr, "[inputfile]\n");
#endif

  fprintf(stderr, "Switches (names may be abbreviated):\n");
  fprintf(stderr, "  -colors N      Reduce image to no more than N colors\n");
  fprintf(stderr, "  -fast          Fast, low-quality processing\n");
  fprintf(stderr, "  -grayscale     Force grayscale output\n");
#ifdef IDCT_SCALING_SUPPORTED
  fprintf(stderr, "  -scale M/N     Scale output image by fraction M/N, eg, 1/8\n");
#endif
#ifdef BMP_SUPPORTED
  fprintf(stderr, "  -bmp           Select BMP output format (Windows style)%s\n",
	  (DEFAULT_FMT == FMT_BMP ? " (default)" : ""));
#endif
#ifdef GIF_SUPPORTED
  fprintf(stderr, "  -gif           Select GIF output format%s\n",
	  (DEFAULT_FMT == FMT_GIF ? " (default)" : ""));
#endif
#ifdef BMP_SUPPORTED
  fprintf(stderr, "  -os2           Select BMP output format (OS/2 style)%s\n",
	  (DEFAULT_FMT == FMT_OS2 ? " (default)" : ""));
#endif
#ifdef PPM_SUPPORTED
  fprintf(stderr, "  -pnm           Select PBMPLUS (PPM/PGM) output format%s\n",
	  (DEFAULT_FMT == FMT_PPM ? " (default)" : ""));
#endif
#ifdef RLE_SUPPORTED
  fprintf(stderr, "  -rle           Select Utah RLE output format%s\n",
	  (DEFAULT_FMT == FMT_RLE ? " (default)" : ""));
#endif
#ifdef TARGA_SUPPORTED
  fprintf(stderr, "  -targa         Select Targa output format%s\n",
	  (DEFAULT_FMT == FMT_TARGA ? " (default)" : ""));
#endif
  fprintf(stderr, "Switches for advanced users:\n");
#ifdef DCT_ISLOW_SUPPORTED
  fprintf(stderr, "  -dct int       Use integer DCT method%s\n",
	  (JDCT_DEFAULT == JDCT_ISLOW ? " (default)" : ""));
#endif
#ifdef DCT_IFAST_SUPPORTED
  fprintf(stderr, "  -dct fast      Use fast integer DCT (less accurate)%s\n",
	  (JDCT_DEFAULT == JDCT_IFAST ? " (default)" : ""));
#endif
#ifdef DCT_FLOAT_SUPPORTED
  fprintf(stderr, "  -dct float     Use floating-point DCT method%s\n",
	  (JDCT_DEFAULT == JDCT_FLOAT ? " (default)" : ""));
#endif
  fprintf(stderr, "  -dither fs     Use F-S dithering (default)\n");
  fprintf(stderr, "  -dither none   Don't use dithering in quantization\n");
  fprintf(stderr, "  -dither ordered  Use ordered dither (medium speed, quality)\n");
#ifdef QUANT_2PASS_SUPPORTED
  fprintf(stderr, "  -map FILE      Map to colors used in named image file\n");
#endif
  fprintf(stderr, "  -nosmooth      Don't use high-quality upsampling\n");
#ifdef QUANT_1PASS_SUPPORTED
  fprintf(stderr, "  -onepass       Use 1-pass quantization (fast, low quality)\n");
#endif
  fprintf(stderr, "  -maxmemory N   Maximum memory to use (in kbytes)\n");
  fprintf(stderr, "  -outfile name  Specify name for output file\n");
  fprintf(stderr, "  -verbose  or  -debug   Emit debug output\n");
  exit(EXIT_FAILURE);
}


LOCAL(int)
parse_switches (j_decompress_ptr cinfo, int argc, char **argv,
		int last_file_arg_seen, boolean for_real)
/* Parse optional switches.
 * Returns argv[] index of first file-name argument (== argc if none).
 * Any file names with indexes <= last_file_arg_seen are ignored;
 * they have presumably been processed in a previous iteration.
 * (Pass 0 for last_file_arg_seen on the first or only iteration.)
 * for_real is FALSE on the first (dummy) pass; we may skip any expensive
 * processing.
 */
{
  int argn;
  char * arg;

  /* Set up default JPEG parameters. */
  requested_fmt = DEFAULT_FMT;	/* set default output file format */
  outfilename = NULL;
  cinfo->err->trace_level = 0;

  /* Scan command line options, adjust parameters */

  for (argn = 1; argn < argc; argn++) {
    arg = argv[argn];
    if (*arg != '-') {
      /* Not a switch, must be a file name argument */
      if (argn <= last_file_arg_seen) {
	outfilename = NULL;	/* -outfile applies to just one input file */
	continue;		/* ignore this name if previously processed */
      }
      break;			/* else done parsing switches */
    }
    arg++;			/* advance past switch marker character */

    if (keymatch(arg, "bmp", 1)) {
      /* BMP output format. */
      requested_fmt = FMT_BMP;

    } else if (keymatch(arg, "colors", 1) || keymatch(arg, "colours", 1) ||
	       keymatch(arg, "quantize", 1) || keymatch(arg, "quantise", 1)) {
      /* Do color quantization. */
      int val;

      if (++argn >= argc)	/* advance to next argument */
	usage();
      if (sscanf(argv[argn], "%d", &val) != 1)
	usage();
      cinfo->desired_number_of_colors = val;
      cinfo->quantize_colors = TRUE;

    } else if (keymatch(arg, "dct", 2)) {
      /* Select IDCT algorithm. */
      if (++argn >= argc)	/* advance to next argument */
	usage();
      if (keymatch(argv[argn], "int", 1)) {
	cinfo->dct_method = JDCT_ISLOW;
      } else if (keymatch(argv[argn], "fast", 2)) {
	cinfo->dct_method = JDCT_IFAST;
      } else if (keymatch(argv[argn], "float", 2)) {
	cinfo->dct_method = JDCT_FLOAT;
      } else
	usage();

    } else if (keymatch(arg, "dither", 2)) {
      /* Select dithering algorithm. */
      if (++argn >= argc)	/* advance to next argument */
	usage();
      if (keymatch(argv[argn], "fs", 2)) {
	cinfo->dither_mode = JDITHER_FS;
      } else if (keymatch(argv[argn], "none", 2)) {
	cinfo->dither_mode = JDITHER_NONE;
      } else if (keymatch(argv[argn], "ordered", 2)) {
	cinfo->dither_mode = JDITHER_ORDERED;
      } else
	usage();

    } else if (keymatch(arg, "debug", 1) || keymatch(arg, "verbose", 1)) {
      /* Enable debug printouts. */
      /* On first -d, print version identification */
      static boolean printed_version = FALSE;

      if (! printed_version) {
	fprintf(stderr, "Independent JPEG Group's DJPEG, version %s\n%s\n",
		JVERSION, JCOPYRIGHT);
	printed_version = TRUE;
      }
      cinfo->err->trace_level++;

    } else if (keymatch(arg, "fast", 1)) {
      /* Select recommended processing options for quick-and-dirty output. */
      cinfo->two_pass_quantize = FALSE;
      cinfo->dither_mode = JDITHER_ORDERED;
      if (! cinfo->quantize_colors) /* don't override an earlier -colors */
	cinfo->desired_number_of_colors = 216;
      cinfo->dct_method = JDCT_FASTEST;
      cinfo->do_fancy_upsampling = FALSE;

    } else if (keymatch(arg, "gif", 1)) {
      /* GIF output format. */
      requested_fmt = FMT_GIF;

    } else if (keymatch(arg, "grayscale", 2) || keymatch(arg, "greyscale",2)) {
      /* Force monochrome output. */
      cinfo->out_color_space = JCS_GRAYSCALE;

    } else if (keymatch(arg, "map", 3)) {
      /* Quantize to a color map taken from an input file. */
      if (++argn >= argc)	/* advance to next argument */
	usage();
      if (for_real) {		/* too expensive to do twice! */
#ifdef QUANT_2PASS_SUPPORTED	/* otherwise can't quantize to supplied map */
	FILE * mapfile;

	if ((mapfile = fopen(argv[argn], READ_BINARY)) == NULL) {
	  fprintf(stderr, "%s: can't open %s\n", progname, argv[argn]);
	  exit(EXIT_FAILURE);
	}
	read_color_map(cinfo, mapfile);
	fclose(mapfile);
	cinfo->quantize_colors = TRUE;
#else
	ERREXIT(cinfo, JERR_NOT_COMPILED);
#endif
      }

    } else if (keymatch(arg, "maxmemory", 3)) {
      /* Maximum memory in Kb (or Mb with 'm'). */
      long lval;
      char ch = 'x';

      if (++argn >= argc)	/* advance to next argument */
	usage();
      if (sscanf(argv[argn], "%ld%c", &lval, &ch) < 1)
	usage();
      if (ch == 'm' || ch == 'M')
	lval *= 1000L;
      cinfo->mem->max_memory_to_use = lval * 1000L;

    } else if (keymatch(arg, "nosmooth", 3)) {
      /* Suppress fancy upsampling */
      cinfo->do_fancy_upsampling = FALSE;

    } else if (keymatch(arg, "onepass", 3)) {
      /* Use fast one-pass quantization. */
      cinfo->two_pass_quantize = FALSE;

    } else if (keymatch(arg, "os2", 3)) {
      /* BMP output format (OS/2 flavor). */
      requested_fmt = FMT_OS2;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品成人在线观看| 国产一区999| 91福利视频在线| 国产午夜精品一区二区| 偷拍一区二区三区| 国产成都精品91一区二区三| 久久亚洲二区三区| 韩国av一区二区| 精品精品国产高清a毛片牛牛| 日本亚洲免费观看| 欧美精品在线观看一区二区| 一区二区三区高清在线| 欧洲一区在线观看| 亚洲成av人片一区二区三区| 欧美精品色综合| 日韩福利电影在线| 欧美一激情一区二区三区| 全部av―极品视觉盛宴亚洲| 日韩欧美国产一区二区三区| 免费成人在线观看| 久久综合久久久久88| 国产一区二区三区不卡在线观看| 亚洲精品一区二区三区99| 黑人巨大精品欧美一区| 久久精品亚洲国产奇米99| 国产精品影视天天线| 国产欧美一区二区三区鸳鸯浴| 成人黄色a**站在线观看| 国产精品天天看| 在线观看欧美日本| 日韩av电影免费观看高清完整版| 精品国产一区二区三区忘忧草| 精品一区二区三区在线播放| 久久精品亚洲国产奇米99| av色综合久久天堂av综合| 一区二区三区国产精品| 日韩一区二区三区视频在线观看| 国产成人亚洲综合色影视| 亚洲人成网站影音先锋播放| 欧美精品第一页| 国产精品一卡二卡| 中文字幕亚洲一区二区va在线| 在线视频欧美区| 久久精品国产网站| 精品剧情v国产在线观看在线| 不卡的av在线播放| 亚洲国产精品尤物yw在线观看| 日韩欧美一区中文| av在线一区二区| 日本亚洲三级在线| 中文字幕亚洲区| 欧美大度的电影原声| 成人伦理片在线| 亚洲曰韩产成在线| 久久综合av免费| 欧美三级韩国三级日本一级| 国产一区二区三区免费播放| 亚洲一区在线观看免费观看电影高清| 精品欧美一区二区三区精品久久| 91亚洲国产成人精品一区二区三| 日韩精品成人一区二区在线| 亚洲欧美成人一区二区三区| wwww国产精品欧美| 在线观看亚洲一区| 国产 日韩 欧美大片| 天堂影院一区二区| 亚洲精品在线观看视频| 欧美日韩在线三区| 99精品视频一区二区三区| 麻豆91精品91久久久的内涵| 一区二区三区产品免费精品久久75| 久久天堂av综合合色蜜桃网| 欧美日韩国产色站一区二区三区| 成人动漫在线一区| 国产大片一区二区| 中文字幕字幕中文在线中不卡视频| 欧美日韩国产系列| 在线亚洲免费视频| 成人高清在线视频| 国产精品77777| 久久福利资源站| 秋霞影院一区二区| 亚洲h动漫在线| 国产精品国模大尺度视频| 久久久高清一区二区三区| 日韩欧美一区中文| 69精品人人人人| 欧美色男人天堂| 欧美午夜精品久久久久久孕妇| 国产精品99久久久久久有的能看| 精品一区中文字幕| 亚洲一二三四久久| 亚洲午夜精品一区二区三区他趣| 综合久久综合久久| 国产精品久久久久久久久免费桃花 | 不卡一区二区在线| 国产成人h网站| 成人精品电影在线观看| 麻豆精品一区二区av白丝在线| 日韩精品福利网| 久久成人免费网| 国产一区福利在线| 国产成人免费视频精品含羞草妖精| 久久超碰97中文字幕| 激情都市一区二区| 国产毛片精品视频| 国产精品18久久久久| 国产成人免费在线观看| 成人av动漫在线| 成人午夜在线视频| 99热国产精品| 欧美在线影院一区二区| 欧美日韩第一区日日骚| 欧美久久久久久久久久| 欧美一区二区三区成人| 精品不卡在线视频| 日本一二三不卡| 亚洲美女屁股眼交3| 亚洲一区二区三区四区在线观看 | 国产欧美日韩综合| 国产精品免费丝袜| 亚洲乱码中文字幕综合| 亚洲sss视频在线视频| 日韩一区二区免费在线观看| 亚洲精品一区二区三区精华液| 亚洲免费观看高清在线观看| 美国十次综合导航| 色哟哟一区二区在线观看 | 在线观看日韩国产| 久久精品一区二区三区av| 亚洲第一激情av| 成人黄色在线看| 日韩欧美第一区| 亚洲激情中文1区| 国产毛片精品一区| 欧美日韩国产精选| 日本一区二区三区四区| 一区二区三区精品视频在线| 成人永久免费视频| 日韩一级成人av| 亚洲精品成人悠悠色影视| 国产精品一区一区| 日韩亚洲欧美一区| 亚洲第一电影网| 欧洲中文字幕精品| ●精品国产综合乱码久久久久| 国产在线精品一区二区| 欧美一级专区免费大片| 一区二区高清免费观看影视大全 | 久久久亚洲国产美女国产盗摄 | av亚洲精华国产精华| 久久精品亚洲乱码伦伦中文| 九九精品一区二区| 91精品黄色片免费大全| 亚洲h精品动漫在线观看| 欧美在线观看视频在线| 亚洲视频一二区| 99国产精品一区| 亚洲欧美综合色| 成人国产在线观看| 国产精品久久久久久久久图文区| 成人晚上爱看视频| 国产日产亚洲精品系列| 国产精品一二三| 久久久美女毛片| 国产精品影视天天线| 国产视频不卡一区| 国产成人亚洲综合a∨婷婷 | 在线观看91视频| 亚洲国产综合人成综合网站| 欧美在线播放高清精品| 一区二区三区日韩在线观看| 欧美视频自拍偷拍| 亚洲福利国产精品| 91精品婷婷国产综合久久竹菊| 奇米精品一区二区三区在线观看 | 亚洲福利视频三区| 欧美挠脚心视频网站| 午夜日韩在线观看| 欧美一级高清片| 国产一区二区毛片| 久久这里只有精品首页| 国产高清不卡一区| 国产精品美女久久久久aⅴ| aaa欧美色吧激情视频| 一区二区三区91| 日韩视频国产视频| 国产精品资源站在线| 国产精品萝li| 欧美三级三级三级| 免费不卡在线观看| 久久精品日韩一区二区三区| av一区二区三区黑人| 亚洲h在线观看| 久久精品日韩一区二区三区| 91女人视频在线观看| 天天影视网天天综合色在线播放| 精品国产一区二区三区av性色 | www.日本不卡| 日本欧美久久久久免费播放网|