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

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

?? bmp.h

?? 下載來的一個看圖軟件的源代碼
?? H
?? 第 1 頁 / 共 3 頁
字號:
/* libwmf ("ipa/ipa/bmp.h"): library for wmf conversion   Copyright (C) 2000 - various; see CREDITS, ChangeLog, and sources   The libwmf Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Library General Public License as   published by the Free Software Foundation; either version 2 of the   License, or (at your option) any later version.   The libwmf Library is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   Library General Public License for more details.   You should have received a copy of the GNU Library General Public   License along with the libwmf Library; see the file COPYING.  If not,   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,   Boston, MA 02111-1307, USA.  */#ifndef HAVE_GD/* png stuff below adapted from stuff sent to me [fjf] by Lennard D. Rosenthal; * probably used in ImageMagick and may not be covered, therefore, by the LGPL - (fjf) *  * utility routine for saving a pixbuf to a png file. * This was adapted from Iain Holmes' code in gnome-iconedit, and probably * should be in a utility library, possibly in gdk-pixbuf itself. */static void ldr_bmp_png (wmfAPI* API,wmfBMP_Draw_t* bmp_draw,FILE* out){#ifdef HAVE_LIBPNG	wmfRGB rgb;	png_structp png_ptr = 0;	png_infop info_ptr = 0;	png_text text[2];	int i;	int j;	int x;	int y;	int width  = (int) bmp_draw->crop.w;	int height = (int) bmp_draw->crop.h;	int depth = 8; /* ?? bit depth (bits per sample) */	int opacity;	char* ptr = 0;	char* buffer = (char*) wmf_malloc (API,4 * width);	if (ERR (API))	{	WMF_DEBUG (API,"bailing...");		return;	}	png_ptr = png_create_write_struct (PNG_LIBPNG_VER_STRING,0,0,0);	if (png_ptr == 0) 	{	WMF_DEBUG (API,"Failed to write bitmap as PNG! (png_create_write_struct failed)");		wmf_free (API,buffer);		return;	}	info_ptr = png_create_info_struct (png_ptr);	if (info_ptr == 0)	{	WMF_DEBUG (API,"Failed to write bitmap as PNG! (png_create_info_struct failed)");		png_destroy_write_struct (&png_ptr,0);		wmf_free (API,buffer);		return;	}	if (setjmp (png_ptr->jmpbuf))	{	WMF_DEBUG (API,"Failed to write bitmap as PNG! (setjmp failed)");		png_destroy_write_struct (&png_ptr,&info_ptr);		wmf_free (API,buffer);		return;	}	png_init_io (png_ptr,out);	png_set_IHDR (png_ptr,info_ptr,width,height,depth,		      PNG_COLOR_TYPE_RGB_ALPHA,PNG_INTERLACE_NONE,PNG_COMPRESSION_TYPE_DEFAULT,PNG_FILTER_TYPE_DEFAULT);	/* Some text to go with the png image */	text[0].key = "Title";	text[0].text = "A converted bitmap";	text[0].compression = PNG_TEXT_COMPRESSION_NONE;	text[1].key = "Software";	text[1].text = "libwmf2";	text[1].compression = PNG_TEXT_COMPRESSION_NONE;	png_set_text (png_ptr,info_ptr,text,2);	/* Write header data	 */	png_write_info (png_ptr,info_ptr);	/* pump the raster data into libpng, one scan line at a time	 */		x = (int) bmp_draw->crop.x;	y = (int) bmp_draw->crop.y;	for (j = 0; j < height; j++)	{	ptr = buffer;		for (i = 0; i < width; i++)		{	opacity = wmf_ipa_bmp_color (API,&(bmp_draw->bmp),&rgb,x+i,y+j);			*ptr++ = (char) rgb.r;			*ptr++ = (char) rgb.g;			*ptr++ = (char) rgb.b;			*ptr++ = (char) ((unsigned char) (opacity & 0xff));		}		png_write_row (png_ptr,(png_bytep) buffer);			}		png_write_end (png_ptr,info_ptr);	png_destroy_write_struct (&png_ptr,&info_ptr);	wmf_free (API,buffer);#else /* HAVE_LIBPNG */	WMF_ERROR (API,"Glitch? No PNG support!");	API->err = wmf_E_Glitch;#endif /* HAVE_LIBPNG */	return;}#endif /* ! HAVE_GD */#ifdef HAVE_GDstatic int ipa_b64_sink (void* context,const char* buffer,int length){	ipa_b64_t* b64 = (ipa_b64_t*) context;	int i = 0;	while (i < length)	{	b64->buffer[b64->length] = buffer[i];		i++;		b64->length++;		if (b64->length == IPA_B64_BUFLEN) ipa_b64_flush (context);	}	return (i);}#endif /* HAVE_GD */#ifdef HAVE_GDstatic void ipa_b64_flush (void* context){	ipa_b64_t* b64 = (ipa_b64_t*) context;	static char B64[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";	char buffer[IPA_B64_LEQUIV];	unsigned long ulc1;	unsigned long ulc2;	unsigned long ulc3;	unsigned long ulc;	int triplets = (b64->length + 2) / 3;	int triplen;	int i;	char* ptr = b64->buffer;	char* btr = buffer;	if (b64->length == 0) return;	triplen = triplets * 3;	for (i = b64->length; i < triplen; i++) b64->buffer[i] = 0;	(*btr) = '\n';	btr++;	for (i = 0; i < triplets; i++)	{	ulc1 = (unsigned long) ((unsigned char) (*ptr));		ptr++;		ulc2 = (unsigned long) ((unsigned char) (*ptr));		ptr++;		ulc3 = (unsigned long) ((unsigned char) (*ptr));		ptr++;		ulc = (ulc1 << 16) | (ulc2 << 8) | ulc3;		ulc1 = (ulc & (0x3f << 18)) >> 18;		ulc2 = (ulc & (0x3f << 12)) >> 12;		ulc3 = (ulc & (0x3f <<  6)) >>  6;		ulc &= 0x3f;		(*btr) = B64[ulc1];		btr++;		(*btr) = B64[ulc2];		btr++;		(*btr) = B64[ulc3];		btr++;		(*btr) = B64[ulc ];		btr++;	}	if ((triplen - b64->length) > 1) (*(btr-2)) = '=';	if ((triplen - b64->length) > 0) (*(btr-1)) = '=';	(*btr) = '\0';	wmf_stream_printf (b64->API,b64->out,buffer);	b64->length = 0;}#endif /* HAVE_GD */void wmf_ipa_bmp_b64 (wmfAPI* API,wmfBMP_Draw_t* bmp_draw,wmfStream* out){#ifdef HAVE_GD	gdImage* image = 0;	gdSink sink;	ipa_b64_t b64;	WMF_DEBUG (API,"~~~~~~~~wmf_ipa_bmp_b64");#ifndef HAVE_LIBPNG	WMF_DEBUG (API,"No support for PNG, sorry!");	API->err = wmf_E_DeviceError;	return;#endif /* HAVE_LIBPNG */	image = ipa_bmp_gd (API,bmp_draw);	if (image == 0) return;	b64.API = API;	b64.out = out;	b64.length = 0;	sink.context = (void*) (&b64);	sink.sink = ipa_b64_sink;	gdImagePngToSink (image,&sink);	gdImageDestroy (image);	ipa_b64_flush (sink.context);#endif /* HAVE_GD */}void wmf_ipa_bmp_png (wmfAPI* API,wmfBMP_Draw_t* bmp_draw,char* name){	FILE* file = 0;#ifdef HAVE_GD	gdImage* image = 0;#endif /* HAVE_GD */	WMF_DEBUG (API,"~~~~~~~~wmf_ipa_bmp_png");#ifndef HAVE_LIBPNG	WMF_DEBUG (API,"No support for PNG, sorry!");	API->err = wmf_E_DeviceError;	return;#endif /* HAVE_LIBPNG */	file = fopen (name,"wb");	if (file == 0)	{	WMF_ERROR (API,"Failed to open file to write GD image!");		return;	}#ifdef HAVE_GD	image = ipa_bmp_gd (API,bmp_draw);	if (image)	{	gdImagePng (image,file);		gdImageDestroy (image);	}#else /* HAVE_GD */	ldr_bmp_png (API,bmp_draw,file);	#endif /* HAVE_GD */	fclose (file);}void wmf_ipa_bmp_jpg (wmfAPI* API,wmfBMP_Draw_t* bmp_draw,char* name){#ifdef HAVE_GD	FILE* file = 0;	gdImage* image = 0;	WMF_DEBUG (API,"~~~~~~~~wmf_ipa_bmp_jpg");#ifndef HAVE_LIBJPEG	WMF_DEBUG (API,"No support for JPEG, sorry!");	API->err = wmf_E_DeviceError;	return;#endif /* HAVE_LIBJPEG */	file = fopen (name,"wb");	if (file == 0)	{	WMF_ERROR (API,"Failed to open file to write GD image!");		return;	}	image = ipa_bmp_gd (API,bmp_draw);	if (image)	{	gdImageJpeg (image,file,-1); /* Default quality. */		gdImageDestroy (image);	}	fclose (file);#endif /* HAVE_GD */}#ifdef HAVE_GDstatic gdImage* ipa_bmp_gd (wmfAPI* API,wmfBMP_Draw_t* bmp_draw){	wmfRGB rgb;	int color;	unsigned int ui_x;	unsigned int ui_y;	unsigned int i;	unsigned int j;	gdImage* image = 0;	WMF_DEBUG (API,"~~~~~~~~ipa_bmp_gd");	if (bmp_draw->bmp.data == 0)	{	WMF_ERROR (API,"Glitch! Attempt to write non-existant bitmap.");		API->err = wmf_E_Glitch;		return (0);	}	image = gdImageCreateTrueColor ((int) bmp_draw->crop.w,(int) bmp_draw->crop.h);	if (image == 0)	{	WMF_ERROR (API,"Failed to create GD image!");		API->err = wmf_E_DeviceError;		return (0);	}	ui_x = (unsigned int) bmp_draw->crop.x;	ui_y = (unsigned int) bmp_draw->crop.y;	for (j = 0; j < (unsigned int) bmp_draw->crop.h; j++)	{	for (i = 0; i < (unsigned int) bmp_draw->crop.w; i++)		{	wmf_ipa_bmp_color (API,&(bmp_draw->bmp),&rgb,ui_x+i,ui_y+j);			color = gdImageColorResolve (image,rgb.r,rgb.g,rgb.b);			gdImageSetPixel (image,(int) i,(int) (bmp_draw->crop.h-1-j),color);		}	}	return (image);}#endif /* HAVE_GD */void wmf_ipa_bmp_eps (wmfAPI* API,wmfBMP_Draw_t* bmp_draw,char* name){	wmfRGB rgb;	unsigned int i;	unsigned int j;	unsigned int k;	unsigned int ui_x;	unsigned int ui_y;	unsigned int width;	unsigned int height;	static char hex[16] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};	char buffer[80];	FILE* file = 0;	WMF_DEBUG (API,"~~~~~~~~wmf_ipa_bmp_eps");	if (bmp_draw->bmp.data == 0)	{	WMF_ERROR (API,"Glitch! Attempt to write non-existant bitmap.");		API->err = wmf_E_Glitch;		return;	}	file = fopen (name,"w");	if (file == 0)	{	WMF_ERROR (API,"Failed to open file to write EPS image!");		API->err = wmf_E_BadFile;		return;	}	ui_x = (unsigned int) bmp_draw->crop.x;	ui_y = (unsigned int) bmp_draw->crop.y;	width  = (unsigned int) bmp_draw->crop.w;	height = (unsigned int) bmp_draw->crop.h;	/* Output as an embedded eps */	fputs ("%!PS-Adobe-2.0 EPSF-2.0\n",file);	fputs ("%%BoundingBox: ",file);	fprintf (file," 0 0 %u %u\n",width,height);		fprintf (file," 0 %d translate\n",1);	fprintf (file," %u %u scale\n",width,height);	/* I'm going to assume it's a color image - TODO: monochrome */	fprintf (file," /picstr %u 3 mul string def\n",width);	fprintf (file," %u %u 8\n",width,height);	fprintf (file," [ %u 0 0 %u 0 0 ]\n",width,height);	fputs (" { currentfile picstr readhexstring pop } false 3\n",file);	fputs (" colorimage\n",file);				for (j = 0; j < height; j++)	{	k = 0;		for (i = 0; i < width; i++)		{	if (k == 78)			{	buffer[k++] = '\n';				buffer[k] = 0;				fputs (buffer,file);				k = 0;			}			wmf_ipa_bmp_color (API,&(bmp_draw->bmp),&rgb,ui_x+i,ui_y+j);			buffer[k++] = hex[(rgb.r & 0xf0) >> 4];			buffer[k++] = hex[ rgb.r & 0x0f      ];			buffer[k++] = hex[(rgb.g & 0xf0) >> 4];			buffer[k++] = hex[ rgb.g & 0x0f      ];			buffer[k++] = hex[(rgb.b & 0xf0) >> 4];			buffer[k++] = hex[ rgb.b & 0x0f      ];		}		if (k > 0)		{	buffer[k++] = '\n';			buffer[k] = 0;			fputs (buffer,file);		}	}	fputs ("showpage\n",file);	fclose (file);	return;}void wmf_ipa_bmp_read (wmfAPI* API,wmfBMP_Read_t* bmp_read){	wmfBMP* bmp = 0;	BMPSource source;	BMPData* data;	WMF_DEBUG (API,"~~~~~~~~wmf_[ipa_]bmp_read");	bmp = &(bmp_read->bmp);	bmp->data = 0;	data = (BMPData*) wmf_malloc (API,sizeof (BMPData));	if (ERR (API))	{	if (API->flags & WMF_OPT_IGNORE_NONFATAL)		{	API->err = wmf_E_None;			bmp->data = 0;		}		WMF_DEBUG (API,"bailing...");		return;	}	data->NColors = 0;	data->rgb = 0;	data->image = 0;	bmp->width  = bmp_read->width;	bmp->height = bmp_read->height;	bmp->data = (void*) data;	source.begin = bmp_read->buffer;	source.end   = bmp_read->buffer + bmp_read->length;	source.ptr   = bmp_read->buffer;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二三区好的| 久久精品视频在线免费观看 | 亚洲精品久久久久久国产精华液| 日韩精品一区二区三区在线 | 欧美va日韩va| 日韩一级片网站| 欧美mv和日韩mv的网站| 日韩女优电影在线观看| 日韩三级视频在线看| 精品国免费一区二区三区| 精品国产一区二区三区久久久蜜月| 日韩一区二区不卡| 欧美mv和日韩mv的网站| 国产欧美日韩综合| 国产精品动漫网站| 亚洲一区二区美女| 日韩电影在线观看网站| 久色婷婷小香蕉久久| 国产精品一卡二卡在线观看| 国产精品系列在线播放| aaa国产一区| 91麻豆国产香蕉久久精品| 欧美色倩网站大全免费| 91精品中文字幕一区二区三区| 日韩精品最新网址| 中文字幕av资源一区| 亚洲日本在线天堂| 丝袜诱惑制服诱惑色一区在线观看 | 99久久夜色精品国产网站| 色综合天天性综合| 日韩一区国产二区欧美三区| 国产三级精品三级| 一区二区三区视频在线观看| 奇米精品一区二区三区四区| 大陆成人av片| 91精品国产aⅴ一区二区| 精品欧美久久久| 亚洲乱码中文字幕| 91色|porny| 精久久久久久久久久久| 成人污污视频在线观看| 91.com视频| 国产精品久久久久一区二区三区 | 爽好多水快深点欧美视频| 国产综合久久久久影院| 欧美在线一二三| 久久综合久久综合久久| 亚洲国产一区二区三区青草影视| 国产在线精品视频| 欧美美女一区二区在线观看| 国产精品人人做人人爽人人添| 亚洲一区二区综合| jlzzjlzz欧美大全| 26uuu亚洲婷婷狠狠天堂| 亚洲高清视频中文字幕| 色综合久久中文字幕| 国产亚洲一区二区在线观看| 亚洲成人动漫av| 色婷婷综合久久久中文字幕| 久久久久久**毛片大全| 免费观看在线色综合| 精品污污网站免费看| 国产精品对白交换视频| 国产成人亚洲精品青草天美| 日韩精品中文字幕一区| 日本成人中文字幕| 欧美日本一区二区| 一区二区激情小说| 99精品欧美一区| 日韩美女精品在线| 欧美日韩国产123区| 男人的天堂亚洲一区| 91蜜桃在线观看| 国产精品久久久久婷婷| 国产不卡视频一区二区三区| 久久久精品影视| 国产精品一区在线| 久久久激情视频| www.性欧美| 亚洲欧美成人一区二区三区| 色综合天天综合给合国产| 亚洲久本草在线中文字幕| 色婷婷精品久久二区二区蜜臂av | 国产福利一区二区三区视频| 久久久久国产精品厨房| 丁香婷婷深情五月亚洲| 中文字幕一区在线观看| 色悠悠亚洲一区二区| 亚洲自拍偷拍九九九| 欧美日韩亚洲高清一区二区| 五月天激情综合| 久久综合九色综合欧美就去吻| 国产一区二区看久久| 国产精品拍天天在线| 色悠悠亚洲一区二区| 日韩精品一二三四| 国产精品系列在线| 毛片av一区二区| 欧美xxxx在线观看| 国产美女精品在线| 亚洲欧洲av在线| 欧美无人高清视频在线观看| 日韩国产一区二| 久久人人超碰精品| 色狠狠一区二区| 日韩 欧美一区二区三区| 久久亚洲免费视频| 99re成人在线| 美日韩一区二区三区| 欧美激情在线一区二区三区| 欧美影院精品一区| 韩国av一区二区| 亚洲欧美激情一区二区| 日韩欧美精品在线| 一本色道久久加勒比精品| 久久精品国产精品亚洲精品| 亚洲欧洲日韩在线| 成人18视频在线播放| 91精品国产91久久久久久一区二区| 精品中文av资源站在线观看| 国产精品成人午夜| 7777精品伊人久久久大香线蕉经典版下载 | 国产精一区二区三区| 亚洲精品v日韩精品| 精品国精品国产| 欧美综合欧美视频| 成人免费视频app| 免费看黄色91| 亚洲bdsm女犯bdsm网站| 中文字幕成人av| 精品剧情在线观看| 欧美猛男男办公室激情| 91免费版在线| 成人免费精品视频| 激情都市一区二区| 精品人在线二区三区| 国产一区不卡视频| 亚洲国产日产av| 亚洲免费资源在线播放| 久久久久国产精品厨房| 欧美成人一区二区| 91精品国产美女浴室洗澡无遮挡| 色8久久精品久久久久久蜜| 成人18视频在线播放| 国产成人在线观看免费网站| 韩国午夜理伦三级不卡影院| 人人爽香蕉精品| 日韩经典中文字幕一区| 性久久久久久久久久久久| 亚洲资源在线观看| 亚洲一区二区三区四区在线免费观看| 国产精品的网站| 亚洲欧洲国产专区| 亚洲欧洲另类国产综合| 亚洲色大成网站www久久九九| 国产精品青草综合久久久久99| 久久先锋影音av鲁色资源| 精品乱码亚洲一区二区不卡| 日韩精品一区二区三区四区| 精品欧美黑人一区二区三区| 成人教育av在线| 高清国产一区二区三区| 国产成人精品影院| 不卡在线视频中文字幕| 不卡高清视频专区| 日本高清无吗v一区| 欧美综合亚洲图片综合区| 欧美精品乱人伦久久久久久| 69堂国产成人免费视频| 日韩一区二区在线免费观看| 精品国产乱码久久久久久久| 2020国产精品久久精品美国| 中文在线一区二区| 亚洲欧美日韩国产手机在线 | 欧美日韩精品电影| 欧美一区二区三区思思人| 精品理论电影在线观看| 国产农村妇女精品| 一区二区三区四区不卡在线| 图片区小说区区亚洲影院| 老司机精品视频在线| 东方欧美亚洲色图在线| 在线欧美日韩精品| 欧美电视剧在线看免费| 欧美一区二区三区视频在线观看| 91精品国产一区二区| xnxx国产精品| 亚洲美女精品一区| 激情小说欧美图片| 91搞黄在线观看| 精品奇米国产一区二区三区| 国产精品乱码一区二区三区软件| 亚洲一区在线视频| 国产乱码精品一区二区三区忘忧草 | 一级做a爱片久久| 精品亚洲免费视频| 91电影在线观看| 国产日韩精品一区二区三区| 亚洲.国产.中文慕字在线| 成人av在线看|