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

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

?? pluginpng.cpp

?? 一款最完整的工業(yè)組態(tài)軟源代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
				case PNG_COLOR_TYPE_RGB_ALPHA :
					dib = FreeImage_Allocate(width, height, 32, FI_RGBA_RED_MASK, FI_RGBA_GREEN_MASK, FI_RGBA_BLUE_MASK);
					break;

				case PNG_COLOR_TYPE_PALETTE :
					dib = FreeImage_Allocate(width, height, pixel_depth);

					png_get_PLTE(png_ptr,info_ptr, &png_palette,&palette_entries);

					palette = FreeImage_GetPalette(dib);

					// store the palette

					for (i = 0; i < palette_entries; i++) {
						palette[i].rgbRed   = png_palette[i].red;
						palette[i].rgbGreen = png_palette[i].green;
						palette[i].rgbBlue  = png_palette[i].blue;
					}

					// store the transparency table

					if (png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS))
						FreeImage_SetTransparencyTable(dib, (BYTE *)trans, num_trans);					

					break;

				case PNG_COLOR_TYPE_GRAY:
					dib = FreeImage_AllocateT(image_type, width, height, pixel_depth);

					if(pixel_depth <= 8) {
						palette = FreeImage_GetPalette(dib);
						palette_entries = 1 << pixel_depth;

						for (i = 0; i < palette_entries; i++) {
							palette[i].rgbRed   =
							palette[i].rgbGreen =
							palette[i].rgbBlue  = (i * 255) / (palette_entries - 1);
						}
					}
					// store the transparency table

					if (png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS))
						FreeImage_SetTransparencyTable(dib, (BYTE *)trans, num_trans);					

					break;

				default:
					throw "PNG format not supported";
			}

			// store the background color 
			if(image_background) {
				FreeImage_SetBackgroundColor(dib, &rgbBkColor);
			}

			// get physical resolution

			if (png_get_valid(png_ptr, info_ptr, PNG_INFO_pHYs)) {
				png_uint_32 res_x, res_y;
				
				// we'll overload this var and use 0 to mean no phys data,
				// since if it's not in meters we can't use it anyway

				int res_unit_type = 0;

				png_get_pHYs(png_ptr,info_ptr,&res_x,&res_y,&res_unit_type);

				if (res_unit_type == 1) {
					BITMAPINFOHEADER *bih = FreeImage_GetInfoHeader(dib);

					bih->biXPelsPerMeter = res_x;
					bih->biYPelsPerMeter = res_y;
				}
			}

			// get possible ICC profile

			if (png_get_valid(png_ptr, info_ptr, PNG_INFO_iCCP)) {
				png_charp profile_name = NULL;
				png_charp profile_data = NULL;
				png_uint_32 profile_length = 0;
				int  compression_type;

				png_get_iCCP(png_ptr, info_ptr, &profile_name, &compression_type, &profile_data, &profile_length);

				// copy ICC profile data (must be done after FreeImage_Allocate)

				FreeImage_CreateICCProfile(dib, profile_data, profile_length);
			}


			// set the individual row_pointers to point at the correct offsets

			row_pointers = (png_bytepp)malloc(height * sizeof(png_bytep));

			if (!row_pointers) {
				if (palette)
					png_free(png_ptr, palette);				

				png_destroy_read_struct(&png_ptr, &info_ptr, NULL);

				FreeImage_Unload(dib);
				return NULL;
			}

			// read in the bitmap bits via the pointer table

			for (png_uint_32 k = 0; k < height; k++)				
				row_pointers[height - 1 - k] = FreeImage_GetScanLine(dib, k);			

			png_read_image(png_ptr, row_pointers);

			// check if the bitmap contains transparency, if so enable it in the header

			if (FreeImage_GetBPP(dib) == 32)
				if (FreeImage_GetColorType(dib) == FIC_RGBALPHA)
					FreeImage_SetTransparent(dib, TRUE);
				else
					FreeImage_SetTransparent(dib, FALSE);
				
			// cleanup

			if (row_pointers) {
				free(row_pointers);
				row_pointers = NULL;
			}

			// read the rest of the file, getting any additional chunks in info_ptr

			png_read_end(png_ptr, info_ptr);

			// get possible metadata (it can be located both before and after the image data)

			ReadMetadata(png_ptr, info_ptr, dib);

			if (png_ptr) {
				// clean up after the read, and free any memory allocated - REQUIRED
				png_destroy_read_struct(&png_ptr, &info_ptr, (png_infopp)NULL);
			}

			return dib;
		} catch (const char *text) {
			if (png_ptr)
				png_destroy_read_struct(&png_ptr, &info_ptr, (png_infopp)NULL);
			
			if (row_pointers)
				free(row_pointers);

			if (dib)
				FreeImage_Unload(dib);			

			FreeImage_OutputMessageProc(s_format_id, text);
			
			return NULL;
		}
	}			

	return NULL;
}

static BOOL DLL_CALLCONV
Save(FreeImageIO *io, FIBITMAP *dib, fi_handle handle, int page, int flags, void *data) {
	png_structp png_ptr;
	png_infop info_ptr;
	png_colorp palette = NULL;
	png_uint_32 width, height;
	BOOL has_alpha_channel = FALSE;

	RGBQUAD *pal;					// pointer to dib palette
	int bit_depth, pixel_depth;		// pixel_depth = bit_depth * channels
	int palette_entries;
	int	interlace_type;

	s_io = io;
	s_handle = handle;

	if ((dib) && (handle)) {
		try {
			// create the chunk manage structure

			png_ptr = png_create_write_struct(PNG_LIBPNG_VER_STRING, (png_voidp)error_handler, error_handler, warning_handler);

			if (!png_ptr)  {
				return FALSE;
			}

			// allocate/initialize the image information data.

			info_ptr = png_create_info_struct(png_ptr);

			if (!info_ptr)  {
				png_destroy_write_struct(&png_ptr,  (png_infopp)NULL);
				return FALSE;
			}

			// Set error handling.  REQUIRED if you aren't supplying your own
			// error handling functions in the png_create_write_struct() call.

			if (setjmp(png_jmpbuf(png_ptr)))  {
				// if we get here, we had a problem reading the file

				png_destroy_write_struct(&png_ptr, &info_ptr);

				return FALSE;
			}

			// init the IO

			png_set_write_fn(png_ptr, info_ptr, _WriteProc, _FlushProc);

			// set physical resolution

			BITMAPINFOHEADER *bih = FreeImage_GetInfoHeader(dib);
			png_uint_32 res_x = bih->biXPelsPerMeter;
			png_uint_32 res_y = bih->biYPelsPerMeter;

			if ((res_x > 0) && (res_y > 0))  {
				png_set_pHYs(png_ptr, info_ptr, res_x, res_y, 1);
			}
	
			// Set the image information here.  Width and height are up to 2^31,
			// bit_depth is one of 1, 2, 4, 8, or 16, but valid values also depend on
			// the color_type selected. color_type is one of PNG_COLOR_TYPE_GRAY,
			// PNG_COLOR_TYPE_GRAY_ALPHA, PNG_COLOR_TYPE_PALETTE, PNG_COLOR_TYPE_RGB,
			// or PNG_COLOR_TYPE_RGB_ALPHA.  interlace is either PNG_INTERLACE_NONE or
			// PNG_INTERLACE_ADAM7, and the compression_type and filter_type MUST
			// currently be PNG_COMPRESSION_TYPE_BASE and PNG_FILTER_TYPE_BASE. REQUIRED

			interlace_type = PNG_INTERLACE_NONE;	// Default value
			width = FreeImage_GetWidth(dib);
			height = FreeImage_GetHeight(dib);
			pixel_depth = FreeImage_GetBPP(dib);	
			if(FreeImage_GetImageType(dib) == FIT_BITMAP) {
				// standard image type
				bit_depth = (pixel_depth > 8) ? 8 : pixel_depth;
			} else {
				// 16-bit greyscale
				bit_depth = pixel_depth;
			}


			switch (FreeImage_GetColorType(dib)) {
				case FIC_MINISWHITE:
					// Invert monochrome files to have 0 as black and 1 as white (no break here)
					png_set_invert_mono(png_ptr);

				case FIC_MINISBLACK:
					png_set_IHDR(png_ptr, info_ptr, width, height, bit_depth, 
						PNG_COLOR_TYPE_GRAY, interlace_type, 
						PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);

					break;

				case FIC_PALETTE:
				{
					png_set_IHDR(png_ptr, info_ptr, width, height, bit_depth, 
						PNG_COLOR_TYPE_PALETTE, interlace_type, 
						PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);

					// set the palette

					palette_entries = 1 << bit_depth;
					palette = (png_colorp)png_malloc(png_ptr, palette_entries * sizeof (png_color));
					pal = FreeImage_GetPalette(dib);

					for (int i = 0; i < palette_entries; i++) {
						palette[i].red   = pal[i].rgbRed;
						palette[i].green = pal[i].rgbGreen;
						palette[i].blue  = pal[i].rgbBlue;
					}
					
					png_set_PLTE(png_ptr, info_ptr, palette, palette_entries);

					// You must not free palette here, because png_set_PLTE only makes a link to
					// the palette that you malloced.  Wait until you are about to destroy
					// the png structure.

					break;
				}

				case FIC_RGBALPHA :
					has_alpha_channel = TRUE;

					png_set_IHDR(png_ptr, info_ptr, width, height, bit_depth, 
						PNG_COLOR_TYPE_RGBA, interlace_type, 
						PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);

#ifndef FREEIMAGE_BIGENDIAN
					// flip BGR pixels to RGB
					png_set_bgr(png_ptr);
#endif
					break;
	
				case FIC_RGB:
					png_set_IHDR(png_ptr, info_ptr, width, height, bit_depth, 
						PNG_COLOR_TYPE_RGB, interlace_type, 
						PNG_COMPRESSION_TYPE_BASE, PNG_FILTER_TYPE_BASE);

#ifndef FREEIMAGE_BIGENDIAN
					// flip BGR pixels to RGB
					png_set_bgr(png_ptr);
#endif
					break;
					
				case FIC_CMYK:
					break;
			}

			// write possible ICC profile

			FIICCPROFILE *iccProfile = FreeImage_GetICCProfile(dib);
			if (iccProfile->size && iccProfile->data) {
				png_set_iCCP(png_ptr, info_ptr, "Embedded Profile", 0, (png_charp)iccProfile->data, iccProfile->size);
			}

			// write metadata

			WriteMetadata(png_ptr, info_ptr, dib);

			// Optional gamma chunk is strongly suggested if you have any guess
			// as to the correct gamma of the image.
			// png_set_gAMA(png_ptr, info_ptr, gamma);

			// set the transparency table

			if ((pixel_depth == 8) && (FreeImage_IsTransparent(dib)) && (FreeImage_GetTransparencyCount(dib) > 0))
				png_set_tRNS(png_ptr, info_ptr, FreeImage_GetTransparencyTable(dib), FreeImage_GetTransparencyCount(dib), NULL);

			// set the background color

			if(FreeImage_HasBackgroundColor(dib)) {
				png_color_16 image_background;
				RGBQUAD rgbBkColor;

				FreeImage_GetBackgroundColor(dib, &rgbBkColor);
				memset(&image_background, 0, sizeof(png_color_16));
				image_background.blue  = rgbBkColor.rgbBlue;
				image_background.green = rgbBkColor.rgbGreen;
				image_background.red   = rgbBkColor.rgbRed;
				image_background.index = rgbBkColor.rgbReserved;

				png_set_bKGD(png_ptr, info_ptr, &image_background);
			}
			
			// Write the file header information.

			png_write_info(png_ptr, info_ptr);

			// write out the image data

#ifndef FREEIMAGE_BIGENDIAN
			if (bit_depth == 16) {
				// turn on 16 bit byte swapping
				png_set_swap(png_ptr);
			}
#endif


			if ((pixel_depth == 32) && (!has_alpha_channel)) {
				BYTE *buffer = (BYTE *)malloc(width * 3);

				// transparent conversion to 24-bit
				for (png_uint_32 k = 0; k < height; k++) {
					FreeImage_ConvertLine32To24(buffer, FreeImage_GetScanLine(dib, height - k - 1), width);

					png_write_row(png_ptr, buffer);
				}

				free(buffer);
			} else {
				for (png_uint_32 k = 0; k < height; k++) {
					png_write_row(png_ptr, FreeImage_GetScanLine(dib, height - k - 1));
				}
			}

			// It is REQUIRED to call this to finish writing the rest of the file
			// Bug with png_flush

			png_write_end(png_ptr, info_ptr);

			// clean up after the write, and free any memory allocated
			if (palette)
				png_free(png_ptr, palette);

			png_destroy_write_struct(&png_ptr, &info_ptr);

			return TRUE;
		} catch (const char *text) {
			FreeImage_OutputMessageProc(s_format_id, text);
		}
	}

	return FALSE;
}

// ==========================================================
//   Init
// ==========================================================

void DLL_CALLCONV
InitPNG(Plugin *plugin, int format_id) {
	s_format_id = format_id;

	plugin->format_proc = Format;
	plugin->description_proc = Description;
	plugin->extension_proc = Extension;
	plugin->regexpr_proc = RegExpr;
	plugin->open_proc = NULL;
	plugin->close_proc = NULL;
	plugin->pagecount_proc = NULL;
	plugin->pagecapability_proc = NULL;
	plugin->load_proc = Load;
	plugin->save_proc = Save;
	plugin->validate_proc = Validate;
	plugin->mime_proc = MimeType;
	plugin->supports_export_bpp_proc = SupportsExportDepth;
	plugin->supports_export_type_proc = SupportsExportType;
	plugin->supports_icc_profiles_proc = SupportsICCProfiles;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品高潮久久久久无| 久久蜜桃av一区二区天堂| 91论坛在线播放| 亚洲人成精品久久久久久| 国产主播一区二区| 欧美色涩在线第一页| 亚洲精品乱码久久久久久日本蜜臀| 久国产精品韩国三级视频| 欧美久久久久久久久| 午夜精品久久久久久久| 欧美日本韩国一区二区三区视频| 奇米综合一区二区三区精品视频| 欧美写真视频网站| 欧美一区二区三区婷婷月色| 日韩精品电影在线观看| 欧美日韩中文字幕一区| 一区二区三区成人| 成人午夜短视频| 中文字幕乱码一区二区免费| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 国产成人亚洲综合a∨婷婷图片| 欧美一区二区三区在线电影| 亚洲国产精品久久久久秋霞影院| 色综合色综合色综合| 亚洲男人天堂av网| 色综合久久88色综合天天6| 午夜精品福利一区二区三区av| 日本二三区不卡| 亚洲综合男人的天堂| 欧美日韩中文字幕一区二区| 亚洲超碰97人人做人人爱| 欧美日韩一区不卡| 久久国内精品自在自线400部| 欧美一级专区免费大片| 天堂在线亚洲视频| 日韩欧美一级精品久久| 秋霞av亚洲一区二区三| 久久奇米777| av在线一区二区三区| 亚洲国产成人高清精品| 26uuu久久天堂性欧美| 国产精品一区2区| 欧美va亚洲va| 大美女一区二区三区| 亚洲欧洲成人精品av97| 99久久精品国产一区二区三区| 国产精品久久久久三级| 色就色 综合激情| 看片网站欧美日韩| 国产精品激情偷乱一区二区∴| 成人app软件下载大全免费| 一区二区免费看| 欧美一区二区三区视频在线| 精品一区二区三区视频在线观看 | 久久电影国产免费久久电影| 精品少妇一区二区三区视频免付费 | 国产一区二区调教| 亚洲色图在线视频| 欧美va在线播放| 91色九色蝌蚪| 国产精品一品二品| 亚洲va国产天堂va久久en| 久久天天做天天爱综合色| 欧美自拍偷拍午夜视频| 国产激情精品久久久第一区二区| 精品成人一区二区三区| 欧美网站大全在线观看| 国内成人精品2018免费看| 欧美国产精品劲爆| 欧美卡1卡2卡| 粉嫩嫩av羞羞动漫久久久| 亚洲三级在线免费| 精品三级在线观看| 波多野结衣一区二区三区| 亚洲国产视频一区| 亚洲国产精品成人久久综合一区| 91在线播放网址| 国产一区二区三区香蕉| 亚洲二区视频在线| 亚洲精品国产a| 国产偷国产偷亚洲高清人白洁| 欧美亚洲禁片免费| 欧日韩精品视频| 99国产精品久久久久久久久久 | 日日摸夜夜添夜夜添国产精品| 国产精品丝袜在线| 国产精品系列在线| 精品蜜桃在线看| 欧美美女激情18p| 欧美日韩另类一区| 欧美在线观看视频在线| 五月激情综合网| 视频一区欧美精品| 日日摸夜夜添夜夜添国产精品| 亚洲精品五月天| 国产精品第13页| 久久影院视频免费| 久久蜜桃香蕉精品一区二区三区| 欧美一区二区在线视频| 欧美亚洲综合色| 欧美日韩一区二区三区不卡| 99麻豆久久久国产精品免费| 成人激情小说网站| 国产精品一区二区免费不卡| 国产综合久久久久影院| 国产成人综合在线观看| 精品一区二区三区免费观看| 亚洲成人黄色影院| 日本午夜一区二区| 蜜桃av噜噜一区| 国产一区二区调教| 国产suv一区二区三区88区| 国产一区二区伦理片| 91麻豆精品在线观看| 色婷婷av一区二区三区大白胸| 日本韩国一区二区三区视频| 91行情网站电视在线观看高清版| 99久久婷婷国产综合精品电影| 色欲综合视频天天天| 91小视频在线观看| 成人激情图片网| 欧美日本一区二区三区四区| 欧美日韩一区精品| xnxx国产精品| 中文字幕日韩一区| 亚洲主播在线播放| 久久不见久久见中文字幕免费| 五月天精品一区二区三区| 久久av中文字幕片| 国产sm精品调教视频网站| 91天堂素人约啪| 欧美日韩精品福利| 欧美本精品男人aⅴ天堂| 精品国产乱码久久久久久免费| www激情久久| 136国产福利精品导航| 日韩av在线免费观看不卡| 极品美女销魂一区二区三区| 福利一区二区在线| 欧美日本国产视频| 欧美精品一区二| 一区二区三区四区亚洲| 美女国产一区二区三区| 国产成人av影院| 8x8x8国产精品| 国产精品网站在线播放| 亚洲欧美韩国综合色| 国产又黄又大久久| 99精品久久久久久| 久久综合九色综合久久久精品综合| 中文字幕一区不卡| 亚洲一区欧美一区| 高清免费成人av| 色天天综合色天天久久| 国产欧美中文在线| 亚洲mv在线观看| 国产不卡一区视频| 精品国产sm最大网站免费看 | 亚洲精品视频在线看| 蜜臀av性久久久久av蜜臀妖精| 99久久精品免费精品国产| 欧美xfplay| 亚洲国产精品一区二区久久恐怖片| 国产99精品国产| 久久久亚洲综合| 美女国产一区二区三区| 7777女厕盗摄久久久| 亚洲欧美成aⅴ人在线观看| 美日韩一区二区| 欧洲亚洲国产日韩| 国产日本欧美一区二区| 18成人在线观看| 国模少妇一区二区三区| 91精品国产91久久综合桃花| 亚洲同性gay激情无套| 91偷拍与自偷拍精品| 麻豆国产一区二区| 成a人片亚洲日本久久| 亚洲三级久久久| 不卡一区二区在线| 精品国产三级电影在线观看| 久久激情五月激情| 精品精品国产高清a毛片牛牛| 亚洲成人动漫一区| 欧美人妇做爰xxxⅹ性高电影| 91网站在线播放| 亚洲国产一二三| 9191久久久久久久久久久| 视频一区二区三区在线| 欧美一区二区三区婷婷月色| 麻豆91在线播放免费| 精品国产免费人成电影在线观看四季 | 懂色av一区二区三区蜜臀| 国产欧美视频一区二区| 成人性生交大片免费| 亚洲欧美中日韩| 欧美日韩精品欧美日韩精品| 香蕉影视欧美成人| 欧美一级艳片视频免费观看| 国产一区二区三区不卡在线观看|