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

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

?? dev2gif.c

?? 一款最完整的工業(yè)組態(tài)軟源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
#endif /* HAVE_LIBGL_S */
#ifdef HAVE_LIBX11
	case GIF_DUMP_X_WINDOW:
	    XGetWindowAttributes((Display *) ReqGraphMode2,
				 (Window) ReqGraphMode1,
				 &WinAttr);
	    ScreenXMax = WinAttr.width;
	    ScreenYMax = WinAttr.height;

	    XImg = XGetImage((Display *) ReqGraphMode2,
			     (Window) ReqGraphMode1,
			     0, 0, ScreenXMax - 1, ScreenYMax - 1,
			     AllPlanes, XYPixmap);

	    GlblGifBuffer = (GifByteType *) malloc(sizeof(GifByteType) *
						ScreenXMax * ScreenYMax);

	    /* Scan the image for all different colors exists. */
	    for (i = 0; i < 256; i++) XColorTable[i].pixel = 0;
	    k = FALSE;
 	    for (i = 0; i < ScreenXMax; i++)
		for (j = 0; j < ScreenYMax; j++) {
		    XPixel = XGetPixel(XImg, i, j);
		    if (XPixel > 255) {
			if (!k) {
			    /* Make sure we state it once only.*/
			    fprintf(stderr, "X Color table - truncated.\n");
			    k = TRUE;
			}
			XPixel = 255;
		    }
		    XColorTable[XPixel].pixel = XPixel;
		}
	    /* Find the RGB representation of the colors. */
	    XQueryColors((Display *) ReqGraphMode2,
			 (Colormap) ReqGraphMode3,
			 XColorTable,
			 256);
	    /* Count number of active colors (Note color 0 is always in)    */
	    /* and create the Gif color map from it.			    */
	    ColorMap = MakeMapObject(256, ColorMap256);
	    ColorMap->Colors[0].Red = ColorMap->Colors[0].Green = ColorMap->Colors[0].Blue = 0;
	    for (i = j = 1; i < 256; i++)
		if (XColorTable[i].pixel) {
		    ColorMap->Colors[j].Red = XColorTable[i].red / 256;
		    ColorMap->Colors[j].Green = XColorTable[i].green / 256;
		    ColorMap->Colors[j].Blue = XColorTable[i].blue / 256;
		    /* Save the X color index into the Gif table: */
		    XColorTable[i].pixel = j++;
		}
	    /* and set the number of colors in the Gif color map. */
	    for	(ScreenColorBits = 1;
		 (1 << ScreenColorBits) < j && ScreenColorBits < 8;
		 ScreenColorBits++);

	    /* Prepare the Gif image buffer as indices into the Gif color   */
	    /* map from the X image.					    */
	    GlblGifBufferPtr = GlblGifBuffer;
	    for (i = 0; i < ScreenXMax; i++)
		for (j = 0; j < ScreenYMax; j++)
		    *GlblGifBufferPtr++ =
			XColorTable[XGetPixel(XImg, j, i) & 0xff].pixel;
	    XDestroyImage(XImg);

	    GlblGifBufferPtr = GlblGifBuffer;
	    ColorMap = MakeMapObject(256, ColorMap256);
	    break;
#endif /* HAVE_LIBX11 */
	default:
	    return -1;
    }

    ScanLine = (GifPixelType *) malloc(sizeof(GifPixelType) * ScreenXMax);

    GraphDriver = ReqGraphDriver;
    GraphMode = ReqGraphMode1;

    if ((GifFile = EGifOpenFileName(FileName, FALSE)) == NULL ||
	EGifPutScreenDesc(GifFile, ScreenXMax, ScreenYMax, ScreenColorBits,
			  0, ColorMap) == GIF_ERROR ||
	EGifPutImageDesc(GifFile, 0, 0, ScreenXMax, ScreenYMax, FALSE,
			 NULL) == GIF_ERROR) {
	free((char *) ScanLine);
#if defined(HAVE_LIBGL_S) || defined(HAVE_LIBX11)
	free((char *) GlblGifBuffer);
#endif
	return HandleGifError(GifFile);
    }

    for (i = 0; i < ScreenYMax; i++) {
	GetScanLine(ScanLine, i);
	if (EGifPutLine(GifFile, ScanLine, ScreenXMax) == GIF_ERROR) {
	    free((char *) ScanLine);
#if defined(HAVE_LIBGL_S) || defined(HAVE_LIBX11)
	    free((char *) GlblGifBuffer);
#endif
	    return HandleGifError(GifFile);
	}
    }

    if (EGifCloseFile(GifFile) == GIF_ERROR) {
	free((char *) ScanLine);
#if defined(HAVE_LIBGL_S) || defined(HAVE_LIBX11)
	free((char *) GlblGifBuffer);
#endif
	return HandleGifError(GifFile);
    }

    free((char *) ScanLine);
#if defined(HAVE_LIBGL_S) || defined(HAVE_LIBX11)
    free((char *) GlblGifBuffer);
#endif
    return 0;
}

#ifdef HAVE_LIBGL_S
/******************************************************************************
* Quantize the given 24 bit (8 per RGB) into 256 colors.		      *
******************************************************************************/
static int QuantizeRGBBuffer(int Width, int Height, long *RGBBuffer,
			      GifColorType *ColorMap, GifByteType *GIFBuffer)
{
    int i;
    GifByteType *RedInput, *GreenInput, *BlueInput;

    /* Convert the RGB Buffer into 3 seperated buffers: */
    RedInput = (GifByteType *) malloc(sizeof(GifByteType) * Width * Height);
    GreenInput = (GifByteType *) malloc(sizeof(GifByteType) * Width * Height);
    BlueInput = (GifByteType *) malloc(sizeof(GifByteType) * Width * Height);

    for (i = 0; i < Width * Height; i++) {
	RedInput[i] = RGBBuffer[i] & 0xff;
	GreenInput[i] = (RGBBuffer[i] >> 8) & 0xff;
	BlueInput[i] = (RGBBuffer[i] >> 16) & 0xff;
    }
    for (i = 0; i < 256; i++)
	ColorMap[i].Red = ColorMap[i].Green = ColorMap[i].Blue = 0;

    i = 256;
    QuantizeBuffer(Width, Height, &i,
		   RedInput, GreenInput, BlueInput,
		   GIFBuffer, ColorMap);

    free(RedInput);
    free(GreenInput);
    free(BlueInput);

    return i;			   /* Real number of colors in color table. */
}
#endif /* HAVE_LIBGL_S */

/******************************************************************************
* Update the given scan line buffer with the pixel levels of the Y line.      *
* This routine is device specific, so make sure you know was you are doing    *
******************************************************************************/
static void GetScanLine(GifPixelType *ScanLine, int Y)
{
#ifdef __MSDOS__
    union REGS InRegs, OutRegs;
#endif /* __MSDOS__ */

    switch (GraphDriver) {
#ifdef __MSDOS__
	case HERCMONO:
	    BufferOffset = 0x2000 * (Y % 4) + (Y / 4) * (ScreenXMax / 8);
	    /* In one scan lines we have ScreenXMax / 8 bytes: */
	    for (i = 0, k = 0; i < ScreenXMax / 8; i++) {
		ScreenByte = (unsigned char) peekb(ScreenBase, BufferOffset++);
		for (j = 0, Bit = 0x80; j < 8; j++) {
		    ScanLine[k++] = (ScreenByte & Bit ? 1 : 0);
		    Bit >>= 1;
		}
	    }
	    break;
	case EGA:
	case EGA64:
	case EGAMONO:
	case VGA:
	case SVGA_SPECIAL:
	    InRegs.x.dx = Y;
	    InRegs.h.bh = 0;
    	    InRegs.h.ah = 0x0d;				   /* BIOS Read dot. */
	    for (i = 0; i < ScreenXMax; i++) {
	    	InRegs.x.cx = i;
		int86(0x10, &InRegs, &OutRegs);
	    	ScanLine[i] = OutRegs.h.al;
	    }

	    /* Makr this line as done by putting a xored dot on the left. */
	    InRegs.x.dx = Y;
	    InRegs.h.bh = 0;
	    InRegs.h.ah = 0x0c;		       /* BIOS Write dot (xor mode). */
	    InRegs.h.al = 0x81;			        /* Xor with color 1. */
	    InRegs.x.cx = 0;
	    int86(0x10, &InRegs, &OutRegs);
	    InRegs.x.dx = Y;
	    InRegs.h.bh = 0;
	    InRegs.h.ah = 0x0c;		       /* BIOS Write dot (xor mode). */
	    InRegs.h.al = 0x81;			        /* Xor with color 1. */
	    InRegs.x.cx = 1;
	    int86(0x10, &InRegs, &OutRegs);

	    if (Y == ScreenYMax - 1) {/* Last row - clear all marks we made. */
		for (i = 0; i < ScreenYMax; i++) {
		    InRegs.h.bh = 0;
		    InRegs.h.ah = 0x0c;	       /* BIOS Write dot (xor mode). */
		    InRegs.h.al = 0x81;		   /* Xor back with color 1. */
		    InRegs.x.dx = i;
		    InRegs.x.cx = 0;
		    int86(0x10, &InRegs, &OutRegs);
		    InRegs.h.bh = 0;
		    InRegs.h.ah = 0x0c;	       /* BIOS Write dot (xor mode). */
		    InRegs.h.al = 0x81;		   /* Xor back with color 1. */
		    InRegs.x.dx = i;
		    InRegs.x.cx = 1;
		    int86(0x10, &InRegs, &OutRegs);
                }
	    }
	    break;
#endif /* __MSDOS__ */
#ifdef HAVE_LIBGL_S
	case GIF_DUMP_SGI_WINDOW:
	    memcpy(ScanLine, GlblGifBufferPtr, ScreenXMax * sizeof(GifPixelType));
	    GlblGifBufferPtr -= ScreenXMax;
	    break;
#endif /* HAVE_LIBGL_S */
#ifdef HAVE_LIBX11
	case GIF_DUMP_X_WINDOW:
	    memcpy(ScanLine, GlblGifBufferPtr, ScreenXMax * sizeof(GifPixelType));
	    GlblGifBufferPtr += ScreenXMax;
	    break;
#endif /* HAVE_LIBX11 */
	default:
	    break;
    }
}

/******************************************************************************
* Handle last GIF error. Try to close the file and free all allocated memory. *
******************************************************************************/
static int HandleGifError(GifFileType *GifFile)
{
    int i = GifLastError();

    if (EGifCloseFile(GifFile) == GIF_ERROR) {
	GifLastError();
    }
    return i;
}









?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美高清视频在线高清观看mv色露露十八 | 亚洲精品免费播放| 91精品国产麻豆| thepron国产精品| 日本中文一区二区三区| 亚洲欧美一区二区视频| 日韩精品一区二区三区swag | 国产一区二区三区在线观看免费视频 | 日韩一区二区三区三四区视频在线观看 | 欧美日韩一区二区三区不卡 | 国产精品一二三四区| 亚欧色一区w666天堂| 国产精品萝li| 久久久久久久免费视频了| 欧美三级资源在线| 91一区一区三区| 国产一区中文字幕| 日日夜夜精品视频免费| 一区二区三区国产| 日韩一区在线免费观看| 国产亚洲一区二区三区在线观看| 欧美日韩国产精品成人| 99国产一区二区三精品乱码| 国产精品69久久久久水密桃 | aaa欧美日韩| 国产精品一二三区在线| 久久99精品久久只有精品| 亚洲成av人片观看| 一区二区免费视频| 亚洲色图欧洲色图| 欧美高清一级片在线观看| 久久综合久久久久88| 精品卡一卡二卡三卡四在线| 日韩美女主播在线视频一区二区三区 | 91视频xxxx| 99精品久久久久久| 色婷婷综合久久久久中文| 一本一道波多野结衣一区二区| aa级大片欧美| 在线观看一区二区视频| 色欧美88888久久久久久影院| 色噜噜狠狠色综合中国| 日本伦理一区二区| 欧美日韩一二三| 777午夜精品视频在线播放| 欧美另类高清zo欧美| 欧美日韩一级二级三级| 制服丝袜国产精品| 欧美精品一区二区在线播放| 久久久久久免费网| 国产精品毛片高清在线完整版| 国产精品不卡一区| 一区二区三区在线免费观看| 亚洲国产欧美一区二区三区丁香婷| 亚洲一区在线观看免费观看电影高清 | 亚洲免费av高清| 一区二区三区在线播放| 亚洲午夜羞羞片| 日本午夜一区二区| 国产精品亚洲一区二区三区在线 | 欧美男同性恋视频网站| 欧美成人a∨高清免费观看| 国产亚洲福利社区一区| 亚洲欧美另类小说| 日韩在线观看一区二区| 国产综合久久久久久久久久久久| 国产精品亚洲一区二区三区妖精| 99久久精品费精品国产一区二区| 欧美人妖巨大在线| 久久久精品中文字幕麻豆发布| 亚洲视频在线一区| 日本午夜精品视频在线观看| 色婷婷av久久久久久久| 8x8x8国产精品| 国产午夜精品福利| 一区二区在线观看视频 | 国产美女精品人人做人人爽| 99久久久久久| 欧美一区二区大片| 国产精品视频免费| 日韩成人av影视| av动漫一区二区| 91精品在线免费观看| 国产女同互慰高潮91漫画| 亚洲国产一区二区三区青草影视| 精品一区二区三区影院在线午夜| 99久久久久免费精品国产| 5858s免费视频成人| 国产精品天美传媒沈樵| 视频精品一区二区| 99视频国产精品| 2023国产精品| 午夜精品一区二区三区电影天堂| 国内偷窥港台综合视频在线播放| 色八戒一区二区三区| 久久婷婷综合激情| 天天爽夜夜爽夜夜爽精品视频| 成人性生交大合| 精品久久久久久综合日本欧美| 亚洲一二三四在线观看| av电影天堂一区二区在线观看| 欧美sm极限捆绑bd| 亚洲国产毛片aaaaa无费看| 成人国产精品视频| 久久综合一区二区| 日韩精品免费专区| 欧美色精品在线视频| 亚洲天堂精品视频| 国产不卡一区视频| 久久亚洲二区三区| 久久国产欧美日韩精品| 欧美视频在线一区| 亚洲女同女同女同女同女同69| 国产精品一区二区在线看| 日韩欧美不卡一区| 日本aⅴ精品一区二区三区 | 成人午夜视频在线观看| 精品国产网站在线观看| 日韩精品一级二级| 在线成人免费视频| 一级中文字幕一区二区| 色天天综合色天天久久| 亚洲天堂网中文字| 99久久综合色| 国产精品久久久久久久裸模 | 日韩一二三区不卡| 亚洲黄色性网站| 色婷婷综合久色| 亚洲乱码精品一二三四区日韩在线| 成人理论电影网| 欧美激情一区二区在线| 东方aⅴ免费观看久久av| 国产欧美va欧美不卡在线| 国产麻豆91精品| 久久久久久夜精品精品免费| 国产尤物一区二区| 久久久久久99久久久精品网站| 韩国精品久久久| 国产欧美一区二区精品忘忧草 | 亚洲欧洲综合另类| 色婷婷久久久久swag精品| 一区二区三区不卡在线观看| 色综合网色综合| 亚洲国产综合91精品麻豆| 欧美美女黄视频| 免费精品视频在线| 精品国产乱码久久久久久老虎| 韩国毛片一区二区三区| 久久久91精品国产一区二区三区| 国产成人免费视频网站高清观看视频 | 午夜精品一区二区三区三上悠亚| 欧美日韩高清不卡| 久久国产精品99久久久久久老狼| 精品国产免费人成在线观看| 久久国产福利国产秒拍| 国产欧美va欧美不卡在线| 91丨porny丨国产入口| 亚洲成人免费av| 精品国产免费一区二区三区四区| 成人午夜视频在线| 一区二区不卡在线视频 午夜欧美不卡在 | 成人av资源在线观看| 亚洲另类一区二区| 91麻豆精品国产无毒不卡在线观看 | 国产精品久久毛片av大全日韩| 99精品一区二区三区| 五月婷婷欧美视频| 久久只精品国产| 99久久久免费精品国产一区二区| 亚洲电影欧美电影有声小说| 欧美一卡2卡三卡4卡5免费| 国产suv精品一区二区6| 一区二区三区成人在线视频| 日韩天堂在线观看| 成人av影院在线| 日本麻豆一区二区三区视频| 亚洲国产经典视频| 欧美日韩一区二区三区四区 | 亚洲欧美视频一区| 国产视频在线观看一区二区三区| 丁香婷婷综合网| 日日摸夜夜添夜夜添精品视频| 久久精品亚洲精品国产欧美 | 欧美日本一道本| 国产91丝袜在线观看| 婷婷综合另类小说色区| 久久精品视频免费观看| 欧美日韩一区二区在线观看视频| 国产精一品亚洲二区在线视频| 亚洲精品你懂的| 久久先锋影音av鲁色资源| 欧美日韩精品一二三区| 成人一区二区在线观看| 麻豆成人91精品二区三区| 亚洲精品国产a久久久久久 | 婷婷国产在线综合| 欧美国产欧美综合| 日韩欧美激情在线| 欧美日韩一区二区欧美激情| 不卡视频在线看|