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

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

?? bmp.h

?? 下載來的一個看圖軟件的源代碼
?? H
?? 第 1 頁 / 共 3 頁
字號:
%                                                                             %%                                                                             %%                                                                             %%   R e a d B M P I m a g e                                                   %%                                                                             %%                                                                             %%                                                                             %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  Method ReadBMPImage reads a Microsoft Windows bitmap image file and%  returns it.  It allocates the memory necessary for the new Image structure%  and returns a pointer to the new image.%%  The format of the ReadBMPImage method is:%%      image=ReadBMPImage(image_info)%%  A description of each parameter follows:%%    o image:  Method ReadBMPImage returns a pointer to the image after%      reading.  A null image is returned if there is a memory shortage or%      if the image cannot be read.%%    o image_info: Specifies a pointer to an ImageInfo structure.%%    o exception: return any errors or warnings in this structure.%%*/static void ReadBMPImage (wmfAPI* API,wmfBMP* bmp,BMPSource* src){	BMPInfo bmp_info;	BMPData* data = 0;	int byte;	long start_position = 0;	unsigned char packet[4];	unsigned int bytes_per_line;	unsigned int image_size;	unsigned int packet_size;	unsigned int i;	unsigned long u;	size_t bytes_read;	data = (BMPData*) bmp->data;	memset (&bmp_info,0,sizeof (BMPInfo));	bmp_info.ba_offset = 0;	bmp_info.size = ReadBlobLSBLong (src);	if (bmp_info.size == 12)	{	/* OS/2 BMP image file. */		bmp_info.width  = ReadBlobLSBShort (src);		bmp_info.height = ReadBlobLSBShort (src);		bmp_info.planes = ReadBlobLSBShort (src);		bmp_info.bits_per_pixel = ReadBlobLSBShort (src);		bmp_info.x_pixels = 0;		bmp_info.y_pixels = 0;		bmp_info.number_colors = 0;		bmp_info.compression = 0;		bmp_info.image_size = 0;	}	else	{	/* Microsoft Windows BMP image file. */		bmp_info.width  = ReadBlobLSBLong (src);		bmp_info.height = ReadBlobLSBLong (src);		bmp_info.planes = ReadBlobLSBShort (src);		bmp_info.bits_per_pixel = ReadBlobLSBShort (src);		bmp_info.compression = ReadBlobLSBLong (src);		bmp_info.image_size  = ReadBlobLSBLong (src);		bmp_info.x_pixels = ReadBlobLSBLong (src);		bmp_info.y_pixels = ReadBlobLSBLong (src);		bmp_info.number_colors = ReadBlobLSBLong (src);		bmp_info.colors_important = ReadBlobLSBLong (src);		for (u = 0; u < (bmp_info.size - 40); u++) byte = ReadBlobByte (src);		if ( (bmp_info.compression == 3)		  && ((bmp_info.bits_per_pixel == 16) || (bmp_info.bits_per_pixel == 32)) )		{	bmp_info.red_mask   = ReadBlobLSBShort (src);			bmp_info.green_mask = ReadBlobLSBShort (src);			bmp_info.blue_mask  = ReadBlobLSBShort (src);			if (bmp_info.size > 40)			{	/* Read color management information. */				bmp_info.alpha_mask = ReadBlobLSBShort (src);				bmp_info.colorspace = ReadBlobLSBLong (src);				bmp_info.red_primary.x = ReadBlobLSBLong (src);				bmp_info.red_primary.y = ReadBlobLSBLong (src);				bmp_info.red_primary.z = ReadBlobLSBLong (src);				bmp_info.green_primary.x = ReadBlobLSBLong (src);				bmp_info.green_primary.y = ReadBlobLSBLong (src);				bmp_info.green_primary.z = ReadBlobLSBLong (src);				bmp_info.blue_primary.x = ReadBlobLSBLong (src);				bmp_info.blue_primary.y = ReadBlobLSBLong (src);				bmp_info.blue_primary.z = ReadBlobLSBLong (src);				bmp_info.gamma_scale.x = ReadBlobLSBShort (src);				bmp_info.gamma_scale.y = ReadBlobLSBShort (src);				bmp_info.gamma_scale.z = ReadBlobLSBShort (src);			}		}	}	if (bmp_info.height < 0)	{	bmp_info.height = - bmp_info.height;		data->flipped = 1;	}	else	{	data->flipped = 0;	}	/* WMF may change bitmap size without changing bitmap header	 */	if (bmp->width  == 0) bmp->width  = (U16) bmp_info.width;	if (bmp->height == 0) bmp->height = (U16) bmp_info.height;	data->NColors = 0;	if ((bmp_info.number_colors != 0) || (bmp_info.bits_per_pixel < 16))	{	data->NColors = (unsigned int) bmp_info.number_colors;	}	if (data->NColors > 0)	{	/* Read BMP raster colormap. */		data->rgb = (wmfRGB*) wmf_malloc (API,data->NColors * sizeof (wmfRGB));		if (ERR (API))		{	WMF_DEBUG (API,"bailing...");			return;		}		if (bmp_info.size == 12) packet_size = 3;		else                     packet_size = 4;		for (i = 0; i < data->NColors; i++)		{	bytes_read = ReadBlob (src,packet_size,packet);			if (bytes_read < packet_size)			{	WMF_ERROR (API,"Unexpected EOF");				API->err = wmf_E_EOF;				break;			}			data->rgb[i].b = packet[0];			data->rgb[i].g = packet[1];			data->rgb[i].r = packet[2];		}		if (ERR (API))		{	WMF_DEBUG (API,"bailing...");			return;		}	}	while (TellBlob (src) < (long) (start_position + bmp_info.offset_bits))	{	byte = ReadBlobByte (src);	}	/* Read image data. */	if (bmp_info.compression == 2) bmp_info.bits_per_pixel <<= 1;	bytes_per_line = 4 * ((bmp->width * bmp_info.bits_per_pixel + 31) / 32);	image_size = bytes_per_line * bmp->height;	data->image = (unsigned char*) wmf_malloc (API,image_size);	if (ERR (API))	{	WMF_DEBUG (API,"bailing...");		return;	}	if ((bmp_info.compression == 0) || (bmp_info.compression == 3))	{	bytes_read = ReadBlob (src,image_size,data->image);		if (bytes_read < image_size)		{	WMF_ERROR (API,"Unexpected EOF");			API->err = wmf_E_EOF;		}	}	else	{	/* Convert run-length encoded raster pixels. */		DecodeImage (API,bmp,src,(unsigned int) bmp_info.compression,data->image);	}	if (ERR (API))	{	WMF_DEBUG (API,"bailing...");		return;	}	data->bits_per_pixel = bmp_info.bits_per_pixel;	data->bytes_per_line = bytes_per_line;	data->masked = bmp_info.red_mask;}static int ExtractColor (wmfAPI* API,wmfBMP* bmp,wmfRGB* rgb,unsigned int x,unsigned int y){	int status = 0;	BMPData* data = 0;	int bit;	unsigned int color;	unsigned char opacity = WMF_BMP_OPAQUE;	unsigned char* p;	unsigned short word;	data = (BMPData*) bmp->data;	if (data->flipped) y = (bmp->height - 1) - y;	switch (data->bits_per_pixel)	{	case 1:	 {	p = data->image + (y * data->bytes_per_line) + (x >> 3);		bit = 0x80 >> (x & 0x07);		if ((*p) & bit) color = 1;		else            color = 0;		if (data->rgb && (color < data->NColors))		{	(*rgb) = data->rgb[color];		}		else		{	if (color)			{	rgb->r = 0;				rgb->g = 0;				rgb->b = 0;			}			else			{	rgb->r = 0xff;				rgb->g = 0xff;				rgb->b = 0xff;			}		}		break;	 }	case 4:	 {	p = data->image + (y * data->bytes_per_line) + (x >> 1);	 	if (x & 1) color =  (*p)       & 0x0f;	 	else       color = ((*p) >> 4) & 0x0f;		if (data->rgb && (color < data->NColors))		{	(*rgb) = data->rgb[color];		}		else		{	rgb->r = color << 4;			rgb->g = color << 4;			rgb->b = color << 4;		}		break;	 }	case 8:	 {	p = data->image + (y * data->bytes_per_line) + x;		color = (*p);		if (data->rgb && (color < data->NColors))		{	(*rgb) = data->rgb[color];		}		else		{	rgb->r = color;			rgb->g = color;			rgb->b = color;		}		break;	 }	case 16:	 {	p = data->image + (y * data->bytes_per_line) + (x << 1);		word = (unsigned short) p[0] | (((unsigned short) p[1]) << 8);		if (data->masked == 0)		{	rgb->r = ((word >> 10) & 0x1f) << 3;			rgb->g = ((word >>  5) & 0x1f) << 3;			rgb->b = ( word        & 0x1f) << 3;		}		else		{	rgb->r = ((word >> 11) & 0x1f) << 3;			rgb->g = ((word >>  5) & 0x3f) << 2;			rgb->b = ( word        & 0x1f) << 3;		}		break;	 }	case 24:	 {	p = data->image + (y * data->bytes_per_line) + (x + (x << 1));	 	rgb->b = p[0];	 	rgb->g = p[1];	 	rgb->r = p[2];		break;	 }	case 32:	 {	p = data->image + (y * data->bytes_per_line) + (x << 2);	 	rgb->b = p[0];	 	rgb->g = p[1];	 	rgb->r = p[2];	 	opacity = p[3];		break;	 }	default:		if ((API->flags & WMF_OPT_IGNORE_NONFATAL) == 0)		{	WMF_ERROR (API,"Bitmap has bad format (illegal color depth)");			API->err = wmf_E_BadFormat;		}		status = -1;	break;	}	if (status == 0) status = (int) opacity;	return (status);}static void SetColor (wmfAPI* API,wmfBMP* bmp,wmfRGB* rgb,unsigned char opacity,unsigned int x,unsigned int y){	BMPData* data = 0;	unsigned int i;	unsigned int r_diff;	unsigned int g_diff;	unsigned int b_diff;	unsigned int diff;	unsigned int min_diff;	unsigned int color;	unsigned char bit;	unsigned char* p;	unsigned short word;	data = (BMPData*) bmp->data;	if (data->flipped) y = (bmp->height - 1) - y;	switch (data->bits_per_pixel)	{	case 1:	 {	p = data->image + (y * data->bytes_per_line) + (x >> 3);		bit = 0x80 >> (x & 0x07);		if (rgb->r || rgb->g || rgb->b)		{	(*p) |= ( bit & 0xff);		}		else		{	(*p) &= (~bit & 0xff);		}		break;	 }	case 4:	 {	p = data->image + (y * data->bytes_per_line) + (x >> 1);	 	if (data->rgb == 0) break;	 	min_diff = 766;	 	color = 0;	 	for (i = 0; i < data->NColors; i++)	 	{	r_diff = (unsigned int) ABS ((int) rgb->r - (int) data->rgb[i].r);			g_diff = (unsigned int) ABS ((int) rgb->g - (int) data->rgb[i].g);			b_diff = (unsigned int) ABS ((int) rgb->b - (int) data->rgb[i].b);			diff = r_diff + g_diff + b_diff;			if (min_diff > diff)			{	min_diff = diff;				color = i;			}	 	}	 	if (x & 1)		{	(*p) = ( ((unsigned char) color)       | ((*p) & 0x0f));		}	 	else		{	(*p) = ((((unsigned char) color) << 4) | ((*p) & 0xf0));		}		break;	 }	case 8:	 {	p = data->image + (y * data->bytes_per_line) + x;	 	if (data->rgb == 0) break;	 	min_diff = 766;	 	color = 0;	 	for (i = 0; i < data->NColors; i++)	 	{	r_diff = (unsigned int) ABS ((int) rgb->r - (int) data->rgb[i].r);			g_diff = (unsigned int) ABS ((int) rgb->g - (int) data->rgb[i].g);			b_diff = (unsigned int) ABS ((int) rgb->b - (int) data->rgb[i].b);			diff = r_diff + g_diff + b_diff;			if (min_diff > diff)			{	min_diff = diff;				color = i;			}	 	}		(*p) = (unsigned char) color;		break;	 }	case 16:	 {	p = data->image + (y * data->bytes_per_line) + (x << 1);		word = 0;		if (data->masked == 0)		{	word |= (rgb->r >> 3) << 10;			word |= (rgb->g >> 3) <<  5;			word |=  rgb->b >> 3;		}		else		{	word |= (rgb->r >> 3) << 11;			word |= (rgb->g >> 2) <<  5;			word |=  rgb->b >> 3;		}		p[0] = (unsigned char) ( word & 0x00ff      );		p[1] = (unsigned char) ((word & 0xff00) >> 8);		break;	 }	case 24:	 {	p = data->image + (y * data->bytes_per_line) + (x + (x << 1));	 	p[0] = rgb->b;	 	p[1] = rgb->g;	 	p[2] = rgb->r;		break;	 }	case 32:	 {	p = data->image + (y * data->bytes_per_line) + (x << 2);	 	p[0] = rgb->b;	 	p[1] = rgb->g;	 	p[2] = rgb->r;	 	p[3] = opacity;		break;	 }	default:		if ((API->flags & WMF_OPT_IGNORE_NONFATAL) == 0)		{	WMF_ERROR (API,"Bitmap has bad format (illegal color depth)");			API->err = wmf_E_BadFormat;		}	break;	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91丝袜在线播放0| 色欧美片视频在线观看在线视频| 国产精品456| 欧美性受xxxx黑人xyx| 亚洲精品在线观看网站| 亚洲五月六月丁香激情| 国产成人精品亚洲日本在线桃色| 欧美日韩成人综合天天影院| 亚洲欧洲精品成人久久奇米网| 日本在线观看不卡视频| 色天天综合色天天久久| 26uuu精品一区二区在线观看| 亚洲一区二区三区四区不卡| 波多野结衣一区二区三区| 日韩精品一区国产麻豆| 亚洲18色成人| 欧美日韩亚洲国产综合| 亚洲精品一卡二卡| 成人av在线网| 亚洲国产电影在线观看| 国产在线不卡一卡二卡三卡四卡| 欧美一区二区三区在线看| 亚洲电影激情视频网站| 色噜噜狠狠成人网p站| 亚洲欧美激情在线| bt7086福利一区国产| 欧美国产日本韩| 丁香激情综合五月| 欧美国产日韩一二三区| 成人教育av在线| 国产精品日韩精品欧美在线| 国产成人在线色| 国产精品国产三级国产专播品爱网 | 亚洲男同1069视频| 不卡的av在线播放| 成人免费在线视频观看| 东方欧美亚洲色图在线| 国产精品美女久久久久久久| 高清不卡一区二区在线| 中文字幕不卡在线| 91小视频在线| 亚洲午夜影视影院在线观看| 欧美日韩国产一二三| 丝袜a∨在线一区二区三区不卡| 欧美性大战久久久久久久| 午夜精品福利在线| 欧美一级一区二区| 激情五月婷婷综合网| 国产拍揄自揄精品视频麻豆| 成人a免费在线看| 亚洲九九爱视频| 91精品国产高清一区二区三区| 男女性色大片免费观看一区二区| 日韩色视频在线观看| 国产麻豆精品在线观看| 亚洲欧美在线视频| 欧美疯狂做受xxxx富婆| 国内精品在线播放| 国产精品大尺度| 在线免费亚洲电影| 裸体在线国模精品偷拍| 亚洲国产毛片aaaaa无费看| 538prom精品视频线放| 精品一区二区三区的国产在线播放 | 国产亚洲欧美日韩日本| 久久亚洲私人国产精品va媚药| 国产自产v一区二区三区c| 国产精品福利影院| 欧美日韩精品三区| 国产福利精品一区| 亚洲综合图片区| 久久精品亚洲麻豆av一区二区| 91视频在线观看免费| 久久99精品国产麻豆不卡| 亚洲天堂2014| 精品电影一区二区三区| 日本高清不卡一区| 国产在线播放一区三区四| 夜色激情一区二区| 日本一区二区三区国色天香 | 三级欧美在线一区| 中文字幕不卡在线观看| 日韩视频在线永久播放| 99久久亚洲一区二区三区青草 | 一区二区高清视频在线观看| 精品久久国产老人久久综合| 91福利国产成人精品照片| 国产一区二区三区蝌蚪| 日韩中文字幕一区二区三区| 亚洲欧洲三级电影| 久久久久久99精品| 国产精品久久久久久久久快鸭| 欧美区一区二区三区| 91日韩精品一区| 国产成人精品免费网站| 久久国产精品99久久久久久老狼| 亚洲欧美色图小说| 国产精品夫妻自拍| 国产午夜亚洲精品不卡 | 日本精品视频一区二区| 国产成人精品免费网站| 精品一区二区三区的国产在线播放 | 日本在线不卡一区| 亚洲国产综合人成综合网站| 亚洲视频一区在线观看| 中文字幕一区二区三区蜜月| 久久奇米777| 精品美女一区二区| 日韩视频不卡中文| 日韩女优电影在线观看| 欧美一区二区三区啪啪| 欧美猛男超大videosgay| 欧美日韩中文字幕精品| 欧美亚洲综合在线| 欧美午夜寂寞影院| 欧美日韩免费电影| 欧美一区二区在线不卡| 欧美一区二区精品| 欧美成人高清电影在线| 欧美不卡视频一区| 久久一夜天堂av一区二区三区| 精品日产卡一卡二卡麻豆| 欧美大黄免费观看| 久久久99精品久久| 国产精品天天看| 一区二区视频免费在线观看| 亚洲综合激情网| 日韩中文字幕1| 久久99国产精品久久99| 国产毛片精品一区| 91社区在线播放| 欧美精选一区二区| 欧美成人r级一区二区三区| 久久久久久久久久久久久夜| 国产日本欧洲亚洲| 亚洲乱码国产乱码精品精98午夜| 一区二区在线看| 日韩av一级片| 国产成人8x视频一区二区| 精品成人免费观看| 亚洲少妇屁股交4| 亚洲美女少妇撒尿| 美国十次了思思久久精品导航| 国产成a人亚洲精品| 国产资源在线一区| 99久久精品久久久久久清纯| 欧美在线观看视频一区二区| 5566中文字幕一区二区电影| 久久九九全国免费| 亚洲综合网站在线观看| 久久99精品久久久久久国产越南| 国产不卡视频在线播放| 色婷婷综合久久久| 日韩视频国产视频| 亚洲乱码一区二区三区在线观看| 日日嗨av一区二区三区四区| 成人午夜在线播放| 欧美年轻男男videosbes| 欧美激情中文不卡| 日韩精品成人一区二区在线| 成人黄色大片在线观看| 69精品人人人人| 国产精品理伦片| 韩国视频一区二区| 欧美色图一区二区三区| 欧美午夜宅男影院| 精品国产免费视频| 日日夜夜免费精品| 99久久99久久精品免费看蜜桃| 欧美日韩国产精品自在自线| 欧美经典一区二区三区| 爽好久久久欧美精品| 99久久久国产精品| 久久久无码精品亚洲日韩按摩| 伊人色综合久久天天| 成人中文字幕在线| 精品美女一区二区三区| 五月婷婷另类国产| 一本久道久久综合中文字幕| 国产片一区二区| 国产一区二区视频在线播放| 日韩一区二区在线播放| 亚洲成人免费在线| 91成人免费在线| 日韩毛片一二三区| 丁香一区二区三区| 国产拍揄自揄精品视频麻豆| 国内不卡的二区三区中文字幕| 欧美巨大另类极品videosbest| 亚洲欧美日韩精品久久久久| 风流少妇一区二区| 久久综合久久综合九色| 麻豆中文一区二区| 欧美一区2区视频在线观看| 午夜激情一区二区| 精品视频在线免费观看| 亚洲成人高清在线| 欧美伦理视频网站| 日韩成人一级大片| 91麻豆精品国产91久久久使用方法|