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

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

?? giftrans.c

?? feret人臉圖象數(shù)據(jù)庫處理代碼
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/*
** GIFtrans v1.11.1
**
** Convert any GIF file into a GIF89a
** Allows for setting the transparent or background color, changing colors,
** adding or removing comments. Also code to analyze GIF contents.
**
** Copyright (c) 24.2.94 by Andreas Ley <ley@rz.uni-karlsruhe.de>
**
** Permission to use, copy, modify, and distribute this software for any
** purpose and without fee is hereby granted, provided that the above
** copyright notice appears in all copies. This software is provided "as is"
** and without any express or implied warranties.
**
** This program has been tested on a HP9000/720 with HP-UX A.08.07
** In this environment, neither lint -u nor gcc -Wall produce any messages.
** If you encounter any errors or need to make any changes to port it
** to another platform, please contact me.
**
** Known bugs:
**	-B flag won't work if there's an Extension between the Global Color
**	Table and the Image Descriptor (or Graphic Control Extension). If -V
**	has been specified, a Warning Message will be displayed.
**	Will be fixed in 2.0
**	Always outputs GIF89a. Shouldn't do this if version is newer.
**	-D option may output changed data instead of original data, use
**	with caution, best only with then -L option.
**
** Version history
**
** Version 1.11.1 - 11.8.94
**	Allows for use of the -g option without the -B option.
**
** Version 1.11 - 21.7.94
**	Moved Plain Text Extension to the Extensions section where it belongs.
**	Accept Unknown Extension Labels.
**	Incorporated MS-DOS port by enzo@hk.net (Enzo Michelangeli).
**	Added -o and -e options to redirect stdout and stderr.
**	Added -D debug flag.
**
** Version 1.10.2 - 22.6.94
**	Support for -DRGBTXT flag.
**
** Version 1.10.1 - 21.6.94
**	Different rgb.txt file FreeBSD/386BSD.
**
** Version 1.10 - 19.6.94
**	Added -g option to change a color in the global color table.
**	Added -B option to change the color for the transparent color index.
**
** Version 1.9.1 - 7.6.94
**	Different rgb.txt files for X11 and Open Windows.
**
** Version 1.9 - 1.6.94
**	Fixed a bug which caused color names to be rejected.
**
** Version 1.8 - 30.5.94
**	Accept #rrggbb style arguments.
**	Do nothing if rgb-color not found in GIF.
**
** Version 1.7 - 16.5.94
**	Added -l option to only list the color table.
**	Added -L option for verbose output without creating a gif.
**	Added -b option to change the background color index.
**	Display all matching color names for color table entries.
**	Fixed a bug which caused bad color names if rgb.txt starts with
**		whitespace.
**	Doesn't use strdup anymore.
**	Fixed =& bug on dec machines.
**
** Version 1.6 - 5.4.94
**	Added color names recognition.
**
** Version 1.5 - 15.3.94
**	Added basic verbose output to analyze GIFs.
**
** Version 1.4 - 8.3.94
**	Fixed off-by-one bug in Local Color table code.
**	Added -c and -C options to add or remove a comment.
**	Transparency is no longer the default.
**
** Thanx for bug reports, ideas and fixes to
**	patricka@cs.kun.nl (Patrick Atoon)
**	wes@msc.edu (Wes Barris)
**	pmfitzge@ingr.com (Patrick M. Fitzgerald)
**	hoesel@chem.rug.nl (Frans van Hoesel)
**	boardman@jerry.sal.wisc.edu (Dan Boardman)
**	krweiss@chip.ucdavis.edu (Ken Weiss)
**	chuck.musciano@harris.com (Chuck Musciano)
**	heycke@camis.stanford.edu (Torsten Heycke)
**	claw@spacsun.rice.edu (Colin Law)
**	jwalker@eos.ncsu.edu (Joseph C. Walker)
**	Bjorn.Borud@alkymi.unit.no (Bjorn Borud)
**	Christopher.Vance@adfa.oz.au (CJS Vance)
**	pederl@norway.hp.com (Peder Langlo)
**	I.Rutson@bradford.ac.uk (Ian Rutson)
**	Nicolas.Pioch@enst.fr (Nicolas Pioch)
**	john@charles.CS.UNLV.EDU (John Kilburg)
**	enzo@hk.net (Enzo Michelangeli)
**	twv@hpwtwe0.cup.hp.com (Terry von Gease)
**
** Original distribution site is
**	ftp://ftp.rz.uni-karlsruhe.de/pub/net/www/tools/giftrans.c
** A man-page by knordlun@fltxa.helsinki.fi (Kai Nordlund) is at
**	ftp://ftp.rz.uni-karlsruhe.de/pub/net/www/tools/giftrans.1
** To compile for MS-DOS, you need getopt:
**	ftp://ftp.rz.uni-karlsruhe.de/pub/net/www/tools/getopt.c
** MS-DOS executable can be found at
**	ftp://ftp.rz.uni-karlsruhe.de/pub/net/www/tools/giftrans.exe
** A template rgb.txt for use with the MS-DOS version can be found at
**	ftp://ftp.rz.uni-karlsruhe.de/pub/net/www/tools/rgb.txt
** Additional info can be found on
**	http://melmac.corp.harris.com/transparent_images.html
*/

#define	X11		/* When using X Window System */
#undef	OPENWIN		/* When using Open Windows */
#undef	X386		/* When using FreeBSD/386BSD */
#undef	MSDOS		/* When using Borland C (maybe MSC too) */

char header[]="GIFtrans v1.11.1\n(c) 1994 by Andreas Ley\n";

#ifndef RGBTXT
#ifdef X11
#define	RGBTXT	"/usr/lib/X11/rgb.txt"
#else /* X11 */
#ifdef OPENWIN
#define	RGBTXT	"/usr/openwin/lib/rgb.txt"
#else /* OPENWIN */
#ifdef X386
#define	RGBTXT	"/usr/X386/lib/X11/rgb.txt"
#else /* X386 */
#ifdef MSDOS
#define	RGBTXT	"rgb.txt"
#else /* MSDOS */
#define	RGBTXT	"";
#endif /* MSDOS */
#endif /* X386 */
#endif /* OPENWIN */
#endif /* X11 */
#endif /* RGBTXT */

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#ifndef MSDOS
#include <unistd.h>
#include <sys/param.h>
#else
#include <fcntl.h>
#include "getopt.c"
#endif

#ifndef MAXPATHLEN
#define MAXPATHLEN 256
#endif /* MAXPATHLEN */

#define	FALSE	(0)		/* This is the naked Truth */
#define	TRUE	(1)		/* and this is the Light */

#define	SUCCESS	(0)
#define	FAILURE	(1)

struct entry {
	struct entry	*next;
	char		*name;
	int		red;
	int		green;
	int		blue;
	} *root;

#define	NONE	(-1)
#define	OTHER	(-2)
#define	RGB	(-3)

struct color {
	int		index;
	int		red;
	int		green;
	int		blue;
	} bc,tc,tn,go,gn;

static char	*image,*comment;
static int	skipcomment,list,verbose,output,debug;
static long int	pos;

static char	rgb[] = RGBTXT;
static char	true[] = "True";
static char	false[] = "False";

#define	readword(buffer)	((buffer)[0]+256*(buffer)[1])
#define	readflag(buffer)	((buffer)?true:false)
#define	hex(c)			('a'<=(c)&&(c)<='z'?(c)-'a'+10:'A'<=(c)&&(c)<='Z'?(c)-'A'+10:(c)-'0')


void dump(adr,data,len)
long int	adr;
unsigned char	*data;
size_t		len;
{
	int	i;

	while (len>0) {
		(void)fprintf(stderr,"%08lx:%*s",adr,(int)((adr%16)*3+(adr%16>8?1:0)),"");
		for (i=adr%16;i<16&&len>0;i++,adr++,data++,len--)
			(void)fprintf(stderr,"%s%02x",i==8?"  ":" ",*data);
		(void)fprintf(stderr,"\n");
	}
}



void writedata(dest,data,len)
FILE		*dest;
unsigned char	*data;
size_t		len;
{
	unsigned char	size;

	while (len) {
		size=len<256?len:255;
		(void)fwrite((void *)&size,1,1,dest);
		(void)fwrite((void *)data,(size_t)size,1,dest);
		data+=size;
		len-=size;
	}
	size=0;
	(void)fwrite((void *)&size,1,1,dest);
}


void skipdata(src)
FILE	*src;
{
	unsigned char	size,buffer[256];

	do {
		pos=ftell(src);
		(void)fread((void *)&size,1,1,src);
		if (debug)
			dump(pos,&size,1);
		if (debug) {
			pos=ftell(src);
			(void)fread((void *)buffer,(size_t)size,1,src);
			dump(pos,buffer,(size_t)size);
		}
		else
			(void)fseek(src,(long int)size,SEEK_CUR);
	} while (!feof(src)&&size>0);
}


void transblock(src,dest)
FILE	*src;
FILE	*dest;
{
	unsigned char	size,buffer[256];

	pos=ftell(src);
	(void)fread((void *)&size,1,1,src);
	if (debug)
		dump(pos,&size,1);
	if (output)
		(void)fwrite((void *)&size,1,1,dest);
	pos=ftell(src);
	(void)fread((void *)buffer,(size_t)size,1,src);
	if (debug)
		dump(pos,buffer,(size_t)size);
	if (output)
		(void)fwrite((void *)buffer,(size_t)size,1,dest);
}


void transdata(src,dest)
FILE	*src;
FILE	*dest;
{
	unsigned char	size,buffer[256];

	do {
		pos=ftell(src);
		(void)fread((void *)&size,1,1,src);
		if (debug)
			dump(pos,&size,1);
		if (output)
			(void)fwrite((void *)&size,1,1,dest);
		pos=ftell(src);
		(void)fread((void *)buffer,(size_t)size,1,src);
		if (debug)
			dump(pos,buffer,(size_t)size);
		if (output)
			(void)fwrite((void *)buffer,(size_t)size,1,dest);
	} while (!feof(src)&&size>0);
}


int giftrans(src,dest)
FILE	*src;
FILE	*dest;
{
	unsigned char	buffer[3*256],lsd[7],gct[3*256],gce[5];
	unsigned int	cnt,cols,size,gct_size,gct_delay,gce_present;
	struct entry	*rgbptr;


	/* Header */
	pos=ftell(src);
	(void)fread((void *)buffer,6,1,src);
	if (strncmp((char *)buffer,"GIF",3)) {
		(void)fprintf(stderr,"No GIF file!\n");
		return(1);
	}
	if (verbose) {
		buffer[6]='\0';
		(void)fprintf(stderr,"Header: \"%s\"\n",buffer);
	}
	if (debug)
		dump(pos,buffer,6);
	if (output)
		(void)fputs("GIF89a",dest);

	/* Logical Screen Descriptor */
	pos=ftell(src);
	(void)fread((void *)lsd,7,1,src);
	if (verbose) {
		(void)fprintf(stderr,"Logical Screen Descriptor:\n");
		(void)fprintf(stderr,"\tLogical Screen Width: %d pixels\n",readword(lsd));
		(void)fprintf(stderr,"\tLogical Screen Height: %d pixels\n",readword(lsd+2));
		(void)fprintf(stderr,"\tGlobal Color Table Flag: %s\n",readflag(lsd[4]&0x80));
		(void)fprintf(stderr,"\tColor Resolution: %d bits\n",(lsd[4]&0x70>>4)+1);
		if (lsd[4]&0x80) {
			(void)fprintf(stderr,"\tSort Flag: %s\n",readflag(lsd[4]&0x8));
			(void)fprintf(stderr,"\tSize of Global Color Table: %d colors\n",2<<(lsd[4]&0x7));
			(void)fprintf(stderr,"\tBackground Color Index: %d\n",lsd[5]);
		}
		if (lsd[6])
			(void)fprintf(stderr,"\tPixel Aspect Ratio: %d (Aspect Ratio %f)\n",lsd[6],((double)lsd[6]+15)/64);
	}
	if (debug)
		dump(pos,lsd,7);

	/* Global Color Table */
	gct_delay=FALSE;
	if (lsd[4]&0x80) {
		gct_size=2<<(lsd[4]&0x7);
		pos=ftell(src);
		(void)fread((void *)gct,gct_size,3,src);
		if (go.index==RGB)
			for(cnt=0;cnt<gct_size&&go.index==RGB;cnt++)
				if (gct[3*cnt]==go.red&&gct[3*cnt+1]==go.green&&gct[3*cnt+2]==go.blue)
					go.index=cnt;
		if (go.index>=0) {
			if (gn.index>=0) {
				gn.red=gct[3*gn.index];
				gn.green=gct[3*gn.index+1];
				gn.blue=gct[3*gn.index+2];
			}
			gct[3*go.index]=gn.red;
			gct[3*go.index+1]=gn.green;
			gct[3*go.index+2]=gn.blue;
		}
		if (bc.index==RGB)
			for(cnt=0;cnt<gct_size&&bc.index==RGB;cnt++)
				if (gct[3*cnt]==bc.red&&gct[3*cnt+1]==bc.green&&gct[3*cnt+2]==bc.blue)
					bc.index=cnt;
		if (bc.index>=0)
			lsd[5]=bc.index;
		if (tc.index==RGB)
			for(cnt=0;cnt<gct_size&&tc.index==RGB;cnt++)
				if (gct[3*cnt]==tc.red&&gct[3*cnt+1]==tc.green&&gct[3*cnt+2]==tc.blue)
					tc.index=cnt;
		if (tc.index==OTHER)
			tc.index=lsd[5];
		if (tn.index>=0) {
			tn.red=gct[3*tn.index];
			tn.green=gct[3*tn.index+1];
			tn.blue=gct[3*tn.index+2];
		}
		if (tn.index!=NONE)
			gct_delay=TRUE;
	}
	if (output)
		(void)fwrite((void *)lsd,7,1,dest);
	if (lsd[4]&0x80) {
		if (list||verbose) {
			(void)fprintf(stderr,"Global Color Table:\n");
			for(cnt=0;cnt<gct_size;cnt++) {
				(void)fprintf(stderr,"\tColor %d: Red %d, Green %d, Blue %d",cnt,gct[3*cnt],gct[3*cnt+1],gct[3*cnt+2]);
				(void)fprintf(stderr,", #%02x%02x%02x",gct[3*cnt],gct[3*cnt+1],gct[3*cnt+2]);
				for (rgbptr=root,cols=0;rgbptr;rgbptr=rgbptr->next)
					if (rgbptr->red==gct[3*cnt]&&rgbptr->green==gct[3*cnt+1]&&rgbptr->blue==gct[3*cnt+2])
						(void)fprintf(stderr,"%s%s",cols++?", ":" (",rgbptr->name);
				(void)fprintf(stderr,"%s\n",cols?")":"");
			}
		}
		if (debug)
			dump(pos,gct,gct_size*3);
		if (output&&(!gct_delay))
			(void)fwrite((void *)gct,gct_size,3,dest);
	}

	gce_present=FALSE;
	do {
		pos=ftell(src);
		(void)fread((void *)buffer,1,1,src);
		switch (buffer[0]) {
		case 0x2c:	/* Image Descriptor */
			if (verbose)
				(void)fprintf(stderr,"Image Descriptor:\n");
			(void)fread((void *)(buffer+1),9,1,src);
			/* Write Graphic Control Extension */
			if (tc.index>=0||gce_present) {
				if (!gce_present) {
					gce[0]=0;
					gce[1]=0;
					gce[2]=0;
				}
				if (tc.index>=0) {
					gce[0]|=0x01;	/* Set Transparent Color Flag */
					gce[3]=tc.index;	/* Set Transparent Color Index */
				}
				else if (gce[0]&0x01)
					tc.index=gce[3];	/* Remember Transparent Color Index */
				gce[4]=0;
				if (tc.index>=0&&(!(buffer[8]&0x80))) { /* Transparent Color Flag set and no Local Color Table */
					gct[3*tc.index]=tn.red;
					gct[3*tc.index+1]=tn.green;
					gct[3*tc.index+2]=tn.blue;
				}
				if (output&&gct_delay) {
					(void)fwrite((void *)gct,gct_size,3,dest);
					gct_delay=FALSE;
				}
				if (output) {
					(void)fputs("\041\371\004",dest);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看亚洲精品视频| 粉嫩aⅴ一区二区三区四区| 国产成人免费视频网站高清观看视频| 成人av资源站| 日韩一级二级三级| 日韩一区日韩二区| 久久精品国产一区二区三| 色播五月激情综合网| 久久新电视剧免费观看| 丝袜美腿亚洲色图| 色综合久久99| 国产精品午夜春色av| 国产制服丝袜一区| 国产精品三级电影| 国产精品家庭影院| 黄页视频在线91| 欧美日韩电影一区| 亚洲欧美偷拍三级| 久久er精品视频| 欧美日韩精品一区二区三区四区 | av电影一区二区| 在线视频你懂得一区二区三区| 久久女同精品一区二区| 日韩在线卡一卡二| 欧美日韩中文字幕一区| 中文字幕精品综合| 国产精品18久久久久久vr| 日韩亚洲欧美成人一区| 777奇米成人网| 91精品欧美久久久久久动漫| 欧美成人女星排名| 欧美国产在线观看| 国产在线精品免费| 欧美日韩成人高清| 婷婷国产v国产偷v亚洲高清| 国产激情一区二区三区四区 | 亚洲综合色丁香婷婷六月图片| 国产91精品一区二区| 久久久蜜桃精品| 国产一区二区三区免费观看| 日韩欧美成人激情| 免费人成黄页网站在线一区二区| 欧美日韩国产色站一区二区三区| 亚洲国产精品一区二区久久 | 韩国女主播一区| 欧美电影精品一区二区| 免费成人深夜小野草| 欧美一区二区三区视频免费| 丝袜亚洲另类欧美| 91超碰这里只有精品国产| 日韩高清一区在线| 91精品国产综合久久精品| 午夜电影网亚洲视频| 欧美精品vⅰdeose4hd| 日本成人在线电影网| 日韩欧美中文字幕制服| 精品午夜久久福利影院 | 91视频免费看| 亚洲精品日韩专区silk| 日本久久电影网| 亚洲va韩国va欧美va| 欧美精品少妇一区二区三区| 美女任你摸久久| 国产日韩欧美制服另类| av一区二区三区黑人| 一区二区三区不卡在线观看| 欧美猛男男办公室激情| 另类小说综合欧美亚洲| 国产喂奶挤奶一区二区三区| av一区二区三区在线| 亚洲一二三四久久| 欧美一区二区视频观看视频| 九九久久精品视频| 国产精品国产精品国产专区不蜜 | 韩国视频一区二区| 欧美高清一级片在线观看| 色婷婷综合久久久久中文 | 欧美经典一区二区| 91久久精品一区二区二区| 午夜精品久久久久久不卡8050| 精品人在线二区三区| 成人黄色一级视频| 亚洲成av人影院在线观看网| 日韩欧美电影一区| 91在线播放网址| 日本亚洲天堂网| 国产精品每日更新在线播放网址| 在线观看亚洲专区| 国模冰冰炮一区二区| 一区二区在线观看av| 日韩三级精品电影久久久| 成人免费高清在线| 天天综合色天天| 欧美精品一区二区三区在线| 99久久99精品久久久久久| 亚洲成人在线免费| 欧美va天堂va视频va在线| 日韩福利电影在线| 中文子幕无线码一区tr| 在线电影院国产精品| 成人午夜视频在线| 日韩电影一区二区三区四区| 久久精品这里都是精品| 欧美三电影在线| 粉嫩av亚洲一区二区图片| 天堂一区二区在线| 欧美综合在线视频| 国产精品亚洲成人| 日韩va亚洲va欧美va久久| 国产精品久久久久久久久免费樱桃 | 日韩高清在线观看| 成人免费一区二区三区在线观看| 日韩亚洲欧美成人一区| 91黄色在线观看| 国产v综合v亚洲欧| 青青草原综合久久大伊人精品优势| 国产精品久久毛片av大全日韩| 3d成人动漫网站| 91视频一区二区三区| 国产成人精品免费在线| 日本不卡123| 亚洲最新视频在线观看| 国产精品欧美精品| 26uuu久久天堂性欧美| 欧美裸体bbwbbwbbw| 色综合久久久久综合体| 国产99一区视频免费| 老汉av免费一区二区三区 | 国产精品久久久久久久久搜平片| 精品久久久久香蕉网| 欧美日韩二区三区| 在线观看网站黄不卡| av中文字幕一区| 国产精品一区二区久久不卡 | 日韩成人免费电影| 一区二区欧美视频| 18成人在线观看| 中文字幕二三区不卡| 久久日韩精品一区二区五区| 91精品国产欧美一区二区成人| 欧美性猛交xxxx乱大交退制版 | 菠萝蜜视频在线观看一区| 国产一区二区久久| 久久精品国产99国产精品| 日韩成人dvd| 日本女人一区二区三区| 日韩中文字幕av电影| 五月婷婷另类国产| 五月天久久比比资源色| 亚洲欧美日韩人成在线播放| 国产精品久久久久aaaa| 国产精品久久久久三级| 国产精品国产三级国产aⅴ原创 | 国产午夜精品一区二区| 国产午夜精品在线观看| 国产亚洲污的网站| 国产亚洲午夜高清国产拍精品| 国产情人综合久久777777| 国产亚洲精久久久久久| 国产亚洲精品7777| 国产精品久久久久久久久快鸭| 中文幕一区二区三区久久蜜桃| 国产清纯白嫩初高生在线观看91| 国产视频一区二区在线观看| 精品人在线二区三区| 国产视频一区二区三区在线观看| 国产欧美一区二区三区在线看蜜臀| 国产色一区二区| 国产肉丝袜一区二区| 中文字幕av在线一区二区三区| 国产精品理论在线观看| ●精品国产综合乱码久久久久| 亚洲女同ⅹxx女同tv| 亚洲国产一区二区a毛片| 午夜精品视频在线观看| 日本vs亚洲vs韩国一区三区二区| 九色综合狠狠综合久久| 国产一区视频在线看| 国产suv精品一区二区三区| bt7086福利一区国产| 欧美性感一类影片在线播放| 欧美老肥妇做.爰bbww| 欧美zozozo| 国产精品情趣视频| 一个色综合av| 蜜桃视频一区二区三区| 国产一区二区三区在线观看精品| k8久久久一区二区三区| 99精品视频在线免费观看| 欧美视频一区二区三区在线观看| 欧美一区二区免费| 国产欧美综合在线| 亚洲免费观看在线视频| 日韩国产欧美视频| 国产91在线|亚洲| 91国模大尺度私拍在线视频| 91精品国产91久久久久久最新毛片| 久久天堂av综合合色蜜桃网| 亚洲天堂精品视频| 免费av网站大全久久|