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

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

?? tkimggif.c

?? linux系統下的音頻通信
?? C
?? 第 1 頁 / 共 2 頁
字號:
     int *transparent;{    static unsigned char buf[256];    int count;    switch (label) {	case 0x01:      /* Plain Text Extension */	    break;	    	case 0xff:      /* Application Extension */	    break;	case 0xfe:      /* Comment Extension */	    do {		count = GetDataBlock(chan, (unsigned char*) buf);	    } while (count > 0);	    return count;	case 0xf9:      /* Graphic Control Extension */	    count = GetDataBlock(chan, (unsigned char*) buf);	    if (count < 0) {		return 1;	    }	    if ((buf[0] & 0x1) != 0) {		*transparent = buf[3];	    }	    do {		count = GetDataBlock(chan, (unsigned char*) buf);	    } while (count > 0);	    return count;    }    do {	count = GetDataBlock(chan, (unsigned char*) buf);    } while (count > 0);    return count;}static int ZeroDataBlock = 0;static intGetDataBlock(chan, buf)     Tcl_Channel chan;     unsigned char *buf;{    unsigned char count;    if (! ReadOK(chan, &count,1)) {	return -1;    }    ZeroDataBlock = count == 0;    if ((count != 0) && (! ReadOK(chan, buf, count))) {	return -1;    }    return count;}static intReadImage(interp, imagePtr, chan, len, rows, cmap,	width, height, srcX, srcY, interlace, transparent)     Tcl_Interp *interp;     char *imagePtr;     Tcl_Channel chan;     int len, rows;     unsigned char cmap[MAXCOLORMAPSIZE][4];     int width, height;     int srcX, srcY;     int interlace;     int transparent;{    unsigned char c;    int v;    int xpos = 0, ypos = 0, pass = 0;    char *pixelPtr;    /*     *  Initialize the Compression routines     */    if (! ReadOK(chan, &c, 1))  {	Tcl_AppendResult(interp, "error reading GIF image: ",		Tcl_PosixError(interp), (char *) NULL);	return TCL_ERROR;    }    if (LWZReadByte(chan, 1, c) < 0) {	interp->result = "format error in GIF image";	return TCL_ERROR;    }    if (transparent!=-1) {	cmap[transparent][CM_RED] = 0;	cmap[transparent][CM_GREEN] = 0;	cmap[transparent][CM_BLUE] = 0;	cmap[transparent][CM_ALPHA] = 0;    }    pixelPtr = imagePtr;    while ((v = LWZReadByte(chan, 0, c)) >= 0 ) {	if ((xpos>=srcX) && (xpos<srcX+len) &&		(ypos>=srcY) && (ypos<srcY+rows)) {	    *pixelPtr++ = cmap[v][CM_RED];	    *pixelPtr++ = cmap[v][CM_GREEN];	    *pixelPtr++ = cmap[v][CM_BLUE];	    *pixelPtr++ = cmap[v][CM_ALPHA];	}	++xpos;	if (xpos == width) {	    xpos = 0;	    if (interlace) {		switch (pass) {		    case 0:		    case 1:			ypos += 8; break;		    case 2:			ypos += 4; break;		    case 3:			ypos += 2; break;		}				while (ypos >= height) {		    ++pass;		    switch (pass) {			case 1:			    ypos = 4; break;			case 2:			    ypos = 2; break;			case 3:			    ypos = 1; break;			default:			    return TCL_OK;		    }		}	    } else {		++ypos;	    }	    pixelPtr = imagePtr + (ypos-srcY) * len * 4;	}	if (ypos >= height)	    break;    }    return TCL_OK;}static intLWZReadByte(chan, flag, input_code_size)     Tcl_Channel chan;     int flag;     int input_code_size;{    static int  fresh = 0;    int code, incode;    static int code_size, set_code_size;    static int max_code, max_code_size;    static int firstcode, oldcode;    static int clear_code, end_code;    static int table[2][(1<< MAX_LWZ_BITS)];    static int stack[(1<<(MAX_LWZ_BITS))*2], *sp;    register int    i;    if (flag) {	set_code_size = input_code_size;	code_size = set_code_size+1;	clear_code = 1 << set_code_size ;	end_code = clear_code + 1;	max_code_size = 2*clear_code;	max_code = clear_code+2;	GetCode(chan, 0, 1);	fresh = 1;	for (i = 0; i < clear_code; ++i) {	    table[0][i] = 0;	    table[1][i] = i;	}	for (; i < (1<<MAX_LWZ_BITS); ++i) {	    table[0][i] = table[1][0] = 0;	}	sp = stack;	return 0;    } else if (fresh) {	fresh = 0;	do {	    firstcode = oldcode = GetCode(chan, code_size, 0);	} while (firstcode == clear_code);	return firstcode;    }    if (sp > stack) {	return *--sp;    }    while ((code = GetCode(chan, code_size, 0)) >= 0) {	if (code == clear_code) {	    for (i = 0; i < clear_code; ++i) {		table[0][i] = 0;		table[1][i] = i;	    }	    	    for (; i < (1<<MAX_LWZ_BITS); ++i) {		table[0][i] = table[1][i] = 0;	    }	    code_size = set_code_size+1;	    max_code_size = 2*clear_code;	    max_code = clear_code+2;	    sp = stack;	    firstcode = oldcode = GetCode(chan, code_size, 0);	    return firstcode;	} else if (code == end_code) {	    int count;	    unsigned char buf[260];	    if (ZeroDataBlock) {		return -2;	    }	    	    while ((count = GetDataBlock(chan, buf)) > 0)		/* Empty body */;	    if (count != 0) {		return -2;	    }	}	incode = code;	if (code >= max_code) {	    *sp++ = firstcode;	    code = oldcode;	}	while (code >= clear_code) {	    *sp++ = table[1][code];	    if (code == table[0][code]) {		return -2;		/*		 * Used to be this instead, Steve Ball suggested		 * the change to just return.		 printf("circular table entry BIG ERROR\n");		 */	    }	    code = table[0][code];	}	*sp++ = firstcode = table[1][code];	if ((code = max_code) <(1<<MAX_LWZ_BITS)) {	    table[0][code] = oldcode;	    table[1][code] = firstcode;	    ++max_code;	    if ((max_code>=max_code_size) && (max_code_size < (1<<MAX_LWZ_BITS))) {		max_code_size *= 2;		++code_size;	    }	}	oldcode = incode;	if (sp > stack)	    return *--sp;	}	return code;}static intGetCode(chan, code_size, flag)     Tcl_Channel chan;     int code_size;     int flag;{    static unsigned char buf[280];    static int curbit, lastbit, done, last_byte;    int i, j, ret;    unsigned char count;    if (flag) {	curbit = 0;	lastbit = 0;	done = 0;	return 0;    }    if ( (curbit+code_size) >= lastbit) {	if (done) {	    /* ran off the end of my bits */	    return -1;	}	if (last_byte >= 2) {	    buf[0] = buf[last_byte-2];	}	if (last_byte >= 1) {	    buf[1] = buf[last_byte-1];	}	if ((count = GetDataBlock(chan, &buf[2])) == 0) {	    done = 1;	}	last_byte = 2 + count;	curbit = (curbit - lastbit) + 16;	lastbit = (2+count)*8 ;    }    ret = 0;    for (i = curbit, j = 0; j < code_size; ++i, ++j) {	ret |= ((buf[ i / 8 ] & (1 << (i % 8))) != 0) << j;    }    curbit += code_size;    return ret;}/* *---------------------------------------------------------------------- * * Minit -- -- * *  This procedure initializes a base64 decoder handle * * Results: *  none * * Side effects: *  the base64 handle is initialized * *---------------------------------------------------------------------- */static voidmInit(string, handle)   unsigned char *string;	/* string containing initial mmencoded data */   MFile *handle;		/* mmdecode "file" handle */{   handle->data = string;   handle->state = 0;}/* *---------------------------------------------------------------------- * * Mread -- * *	This procedure is invoked by the GIF file reader as a  *	temporary replacement for "fread", to get GIF data out *	of a string (using Mgetc). * * Results: *	The return value is the number of characters "read" * * Side effects: *	The base64 handle will change state. * *---------------------------------------------------------------------- */static intMread(dst, chunkSize, numChunks, handle)     unsigned char *dst;	/* where to put the result */   size_t chunkSize;	/* size of each transfer */   size_t numChunks;	/* number of chunks */   MFile *handle;	/* mmdecode "file" handle */{   register int i, c;   int count = chunkSize * numChunks;   for(i=0; i<count && (c=Mgetc(handle)) != GIF_DONE; i++) {	*dst++ = c;   }   return i;}/* * get the next decoded character from an mmencode handle * This causes at least 1 character to be "read" from the encoded string *//* *---------------------------------------------------------------------- * * Mgetc -- * *  This procedure decodes and returns the next byte from a base64 *  encoded string. * * Results: *  The next byte (or GIF_DONE) is returned. * * Side effects: *  The base64 handle will change state. * *---------------------------------------------------------------------- */static intMgetc(handle)   MFile *handle;		/* Handle containing decoder data and state. */{    int c;    int result = 0;		/* Initialization needed only to prevent				 * gcc compiler warning. */         if (handle->state == GIF_DONE) {	return(GIF_DONE);    }    do {	c = char64(*handle->data);	handle->data++;    } while (c==GIF_SPACE);    if (c>GIF_SPECIAL) {	handle->state = GIF_DONE;	return(handle->state ? handle->c : GIF_DONE);    }    switch (handle->state++) {	case 0:	   handle->c = c<<2;	   result = Mgetc(handle);	   break;	case 1:	   result = handle->c | (c>>4);	   handle->c = (c&0xF)<<4;	   break;	case 2:	   result = handle->c | (c>>2);	   handle->c = (c&0x3) << 6;	   break;	case 3:	   result = handle->c | c;	   handle->state = 0;	   break;    }    return(result);}/* *---------------------------------------------------------------------- * * char64 -- * *	This procedure converts a base64 ascii character into its binary *	equivalent.  This code is a slightly modified version of the *	char64 proc in N. Borenstein's metamail decoder. * * Results: *	The binary value, or an error code. * * Side effects: *	None. *---------------------------------------------------------------------- */static intchar64(c)int c;{    switch(c) {        case 'A': return(0);  case 'B': return(1);  case 'C': return(2);        case 'D': return(3);  case 'E': return(4);  case 'F': return(5);        case 'G': return(6);  case 'H': return(7);  case 'I': return(8);        case 'J': return(9);  case 'K': return(10); case 'L': return(11);        case 'M': return(12); case 'N': return(13); case 'O': return(14);        case 'P': return(15); case 'Q': return(16); case 'R': return(17);        case 'S': return(18); case 'T': return(19); case 'U': return(20);        case 'V': return(21); case 'W': return(22); case 'X': return(23);        case 'Y': return(24); case 'Z': return(25); case 'a': return(26);        case 'b': return(27); case 'c': return(28); case 'd': return(29);        case 'e': return(30); case 'f': return(31); case 'g': return(32);        case 'h': return(33); case 'i': return(34); case 'j': return(35);        case 'k': return(36); case 'l': return(37); case 'm': return(38);        case 'n': return(39); case 'o': return(40); case 'p': return(41);        case 'q': return(42); case 'r': return(43); case 's': return(44);        case 't': return(45); case 'u': return(46); case 'v': return(47);        case 'w': return(48); case 'x': return(49); case 'y': return(50);        case 'z': return(51); case '0': return(52); case '1': return(53);        case '2': return(54); case '3': return(55); case '4': return(56);        case '5': return(57); case '6': return(58); case '7': return(59);        case '8': return(60); case '9': return(61); case '+': return(62);        case '/': return(63);	case ' ': case '\t': case '\n': case '\r': case '\f': return(GIF_SPACE);	case '=':  return(GIF_PAD);	case '\0': return(GIF_DONE);	default: return(GIF_BAD);    }}/* *---------------------------------------------------------------------- * * Fread -- * *  This procedure calls either fread or Mread to read data *  from a file or a base64 encoded string. * * Results: - same as fread * *---------------------------------------------------------------------- */static intFread(dst, hunk, count, chan)    unsigned char *dst;		/* where to put the result */    size_t hunk,count;		/* how many */    Tcl_Channel chan;{    if (fromData) {	return(Mread(dst, hunk, count, (MFile *) chan));    } else {	return Tcl_Read(chan, (char *) dst, (int) (hunk * count));    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产98色在线|日韩| 在线观看一区二区视频| 亚洲欧美日韩一区| 91精品黄色片免费大全| 高清成人免费视频| 美国十次了思思久久精品导航| 国产精品电影一区二区| 欧美电影免费观看高清完整版在| 色婷婷久久99综合精品jk白丝 | 久久99九九99精品| 亚洲男人的天堂一区二区| 久久综合九色综合欧美亚洲| 在线视频一区二区三区| 国产乱理伦片在线观看夜一区| 偷窥少妇高潮呻吟av久久免费| 国产精品超碰97尤物18| 久久久久国色av免费看影院| 在线不卡欧美精品一区二区三区| 国产欧美精品在线观看| 99国产精品一区| 国产成人高清视频| 美女尤物国产一区| 天天做天天摸天天爽国产一区| 亚洲色大成网站www久久九九| 2021中文字幕一区亚洲| 日韩欧美中文字幕一区| 宅男噜噜噜66一区二区66| 色综合久久综合网欧美综合网| 国产成人99久久亚洲综合精品| 久久国产日韩欧美精品| 蜜桃精品视频在线观看| 日韩在线播放一区二区| 日韩中文字幕一区二区三区| 亚洲国产人成综合网站| 亚洲一区在线观看免费| 亚洲精品高清视频在线观看| 中文字幕一区视频| 成人免费小视频| 中文字幕不卡在线观看| 中日韩免费视频中文字幕| 国产视频视频一区| 国产校园另类小说区| 国产视频一区二区在线| 日本一区二区三级电影在线观看| 久久久国际精品| 久久精品人人做人人综合| 国产欧美日韩亚州综合| 亚洲欧美怡红院| 亚洲精品国产一区二区三区四区在线 | 国模一区二区三区白浆| 精品午夜久久福利影院| 国模无码大尺度一区二区三区| 国产中文字幕一区| 懂色一区二区三区免费观看| www.欧美.com| 色综合色狠狠天天综合色| 在线欧美日韩国产| 欧美一区二区三区四区高清| 日韩欧美电影在线| 国产午夜精品福利| 亚洲免费资源在线播放| 亚洲一区二区综合| 日本伊人色综合网| 国内精品国产成人国产三级粉色| 懂色中文一区二区在线播放| 日本乱人伦一区| 在线不卡的av| 精品国产乱码久久久久久老虎| 国产精品日日摸夜夜摸av| 亚洲精品亚洲人成人网| 日本美女一区二区| 丁香六月久久综合狠狠色| 色先锋资源久久综合| 日韩一区二区视频| 国产精品天美传媒沈樵| 亚洲一区在线观看免费 | 久久久精品日韩欧美| 国产精品久久777777| 亚洲va欧美va天堂v国产综合| 久久精品国产一区二区三 | 亚洲国产精品一区二区www| 日韩高清不卡一区二区| 国产成人aaa| 欧美丰满美乳xxx高潮www| 26uuu国产日韩综合| 亚洲狼人国产精品| 看电影不卡的网站| 99久久国产综合精品麻豆| 日韩午夜激情电影| 综合激情网...| 玖玖九九国产精品| 91麻豆免费在线观看| 欧美成人一区二区三区| 亚洲免费在线播放| 国产精品18久久久| 欧美日韩国产电影| 国产精品乱码人人做人人爱| 丝袜a∨在线一区二区三区不卡| 国产成人99久久亚洲综合精品| 欧美欧美午夜aⅴ在线观看| 中文字幕精品在线不卡| 青青草97国产精品免费观看| 97久久超碰精品国产| 精品国内二区三区| 午夜欧美视频在线观看| 99久久精品国产毛片| 精品国产百合女同互慰| 石原莉奈在线亚洲二区| 日本高清免费不卡视频| 国产精品午夜免费| 国产一区二区美女诱惑| 777午夜精品免费视频| 亚洲色图在线播放| 国产91对白在线观看九色| 欧美成人一区二区三区| 日韩av网站免费在线| 91国产精品成人| 国产精品久久毛片| 成人免费视频app| 欧美精品一区二区精品网| 青草av.久久免费一区| 91福利资源站| 亚洲资源在线观看| 色先锋资源久久综合| 国产精品久久久久精k8| 成人网在线免费视频| 国产午夜亚洲精品不卡| 国产精品一品二品| 26uuu精品一区二区| 国内精品伊人久久久久av影院| 欧美岛国在线观看| 蜜臀久久久久久久| 51精品国自产在线| 日韩激情视频在线观看| 欧美精品亚洲一区二区在线播放| 亚洲伊人色欲综合网| 日本久久精品电影| 亚洲一区二区三区精品在线| 色综合天天性综合| 日韩欧美的一区| 精彩视频一区二区| 久久你懂得1024| 夫妻av一区二区| 亚洲婷婷综合色高清在线| 97久久超碰精品国产| 亚洲激情自拍视频| 欧美性猛交xxxx黑人交| 调教+趴+乳夹+国产+精品| 91精品国产综合久久久久久| 偷拍一区二区三区四区| 日韩欧美一区电影| 九一九一国产精品| 中文字幕免费观看一区| 成人av电影免费观看| 亚洲精品国产品国语在线app| 在线观看区一区二| 日韩综合小视频| www一区二区| 色综合一个色综合亚洲| 午夜精品一区在线观看| 精品国产一区二区三区久久影院| 国产精品 日产精品 欧美精品| 国产精品私人自拍| 在线观看91视频| 卡一卡二国产精品| 亚洲欧美综合网| 91精品国产综合久久久久久久 | 午夜亚洲福利老司机| 精品国精品自拍自在线| 99久久久久久99| 香蕉久久夜色精品国产使用方法 | 一区二区三区在线看| 欧美福利视频导航| 国产精品伊人色| 亚洲精选视频免费看| 91.com视频| 成人综合在线观看| 亚洲超丰满肉感bbw| 久久久久久久久蜜桃| 一本色道**综合亚洲精品蜜桃冫 | 一本久久精品一区二区| 日韩电影网1区2区| 中文字幕亚洲电影| 日韩一级视频免费观看在线| 成人精品在线视频观看| 丝袜a∨在线一区二区三区不卡| 久久免费偷拍视频| 欧美视频一区二区三区四区| 国产一区二区成人久久免费影院| 一区二区三区欧美| 久久女同精品一区二区| 欧美日韩精品久久久| 成人国产亚洲欧美成人综合网| 天天色图综合网| 亚洲欧美色综合| 久久久久久久久久美女| 制服视频三区第一页精品| 色综合久久88色综合天天| 韩国v欧美v日本v亚洲v| 婷婷夜色潮精品综合在线|