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

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

?? conversion4.cpp

?? 一款最完整的工業(yè)組態(tài)軟源代碼
?? CPP
字號(hào):
// ==========================================================
// Bitmap conversion routines
//
// Design and implementation by
// - Riley McNiff (rmcniff@marexgroup.com)
//
// This file is part of FreeImage 3
//
// COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY
// OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES
// THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE
// OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED
// CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT
// THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY
// SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL
// PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER
// THIS DISCLAIMER.
//
// Use at your own risk!
// ==========================================================

#include "FreeImage.h"
#include "Utilities.h"

// ----------------------------------------------------------
//  internal conversions X to 4 bits
// ----------------------------------------------------------

void DLL_CALLCONV
FreeImage_ConvertLine1To4(BYTE *target, BYTE *source, int width_in_pixels) {
	BOOL hinibble = TRUE;
	for (int cols = 0; cols < width_in_pixels; cols++){
		if (hinibble == TRUE){
			target[cols >> 1] = ((source[cols >> 3] & (0x80 >> (cols & 0x07))) != 0 ? 15 : 0) << 4;
		} 
		else {
			target[cols >> 1] |= ((source[cols >> 3] & (0x80 >> (cols & 0x07))) != 0 ? 15 : 0);
		}

		hinibble = !hinibble;
	}
}

void DLL_CALLCONV
FreeImage_ConvertLine8To4(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette) {
	BOOL hinibble = TRUE;
	BYTE index;

	for (int cols = 0; cols < width_in_pixels; cols++){
		index = GREY(palette[source[cols]].rgbRed, palette[source[cols]].rgbGreen, palette[source[cols]].rgbBlue);
		if (hinibble) {
			target[cols >> 1] = (index & 0xF0);
		} else {
			target[cols >> 1] |= (index >> 4);
		}

		hinibble = !hinibble;
	}
}

void DLL_CALLCONV
FreeImage_ConvertLine16To4_555(BYTE *target, BYTE *source, int width_in_pixels) {
	WORD *bits = (WORD *)source;
	BOOL hinibble = TRUE;

	for (int cols = 0; cols < width_in_pixels; cols++) {
		if (hinibble) {
			target[cols >> 1] = GREY((((bits[cols] & FI16_555_RED_MASK) >> FI16_555_RED_SHIFT) * 0xFF) / 0x1F,
								(((bits[cols] & FI16_555_GREEN_MASK) >> FI16_555_GREEN_SHIFT) * 0xFF) / 0x1F,
								(((bits[cols] & FI16_555_BLUE_MASK) >> FI16_555_BLUE_SHIFT) * 0xFF) / 0x1F)
								& 0xF0;
		} else {
			target[cols >> 1] |= GREY((((bits[cols] & FI16_555_RED_MASK) >> FI16_555_RED_SHIFT) * 0xFF) / 0x1F,
								(((bits[cols] & FI16_555_GREEN_MASK) >> FI16_555_GREEN_SHIFT) * 0xFF) / 0x1F,
								(((bits[cols] & FI16_555_BLUE_MASK) >> FI16_555_BLUE_SHIFT) * 0xFF) / 0x1F)
								>> 4;
		}
		
		hinibble = !hinibble;
	}
}

void DLL_CALLCONV
FreeImage_ConvertLine16To4_565(BYTE *target, BYTE *source, int width_in_pixels) {
	WORD *bits = (WORD *)source;
	BOOL hinibble = TRUE;

	for (int cols = 0; cols < width_in_pixels; cols++) {
		if (hinibble) {
			target[cols >> 1] = GREY((((bits[cols] & FI16_565_RED_MASK) >> FI16_565_RED_SHIFT) * 0xFF) / 0x1F,
				        (((bits[cols] & FI16_565_GREEN_MASK) >> FI16_565_GREEN_SHIFT) * 0xFF) / 0x3F,
						(((bits[cols] & FI16_565_BLUE_MASK) >> FI16_565_BLUE_SHIFT) * 0xFF) / 0x1F)
						& 0xF0;
		} else {
			target[cols >> 1] |= GREY((((bits[cols] & FI16_565_RED_MASK) >> FI16_565_RED_SHIFT) * 0xFF) / 0x1F,
				        (((bits[cols] & FI16_565_GREEN_MASK) >> FI16_565_GREEN_SHIFT) * 0xFF) / 0x3F,
						(((bits[cols] & FI16_565_BLUE_MASK) >> FI16_565_BLUE_SHIFT) * 0xFF) / 0x1F)
						>> 4;
		}

		hinibble = !hinibble;
	}
}

void DLL_CALLCONV
FreeImage_ConvertLine24To4(BYTE *target, BYTE *source, int width_in_pixels) {
	BOOL hinibble = TRUE;

	for (int cols = 0; cols < width_in_pixels; cols++) {
		if (hinibble) {
			target[cols >> 1] = GREY(source[FI_RGBA_RED], source[FI_RGBA_GREEN], source[FI_RGBA_BLUE]) & 0xF0;
		} else {
			target[cols >> 1] |= GREY(source[FI_RGBA_RED], source[FI_RGBA_GREEN], source[FI_RGBA_BLUE]) >> 4;
		}

		source += 3;
		hinibble = !hinibble;
	}
}

void DLL_CALLCONV
FreeImage_ConvertLine32To4(BYTE *target, BYTE *source, int width_in_pixels) {
	BOOL hinibble = TRUE;

	for (int cols = 0; cols < width_in_pixels; cols++) {
		if (hinibble) {
			target[cols >> 1] = GREY(source[FI_RGBA_RED], source[FI_RGBA_GREEN], source[FI_RGBA_BLUE]) & 0xF0;
		} else {
			target[cols >> 1] |= GREY(source[FI_RGBA_RED], source[FI_RGBA_GREEN], source[FI_RGBA_BLUE]) >> 4;
		}

		source += 4;
		hinibble = !hinibble;
	}
}

// ----------------------------------------------------------
//   smart convert X to 4 bits
// ----------------------------------------------------------

FIBITMAP * DLL_CALLCONV
FreeImage_ConvertTo4Bits(FIBITMAP *dib) {
	if(!dib) return NULL;

	int bpp = FreeImage_GetBPP(dib);

	if(bpp != 4) {
		int width  = FreeImage_GetWidth(dib);
		int height = FreeImage_GetHeight(dib);
		FIBITMAP *new_dib = FreeImage_Allocate(width, height, 4);

		if(new_dib == NULL) {
			return NULL;
		}

		// Build a greyscale palette (*always* needed for image processing)

		RGBQUAD *new_pal = FreeImage_GetPalette(new_dib);

		for(int i = 0; i < 16; i++) {
			new_pal[i].rgbRed	= (i << 4) + i;
			new_pal[i].rgbGreen = (i << 4) + i;
			new_pal[i].rgbBlue	= (i << 4) + i;
		}

		switch(bpp) {
			case 1:
			{
				if(FreeImage_GetColorType(dib) == FIC_PALETTE) {

					// Copy the palette

					RGBQUAD *old_pal = FreeImage_GetPalette(dib);
					memcpy(&new_pal[0], &old_pal[0], sizeof(RGBQUAD));
					memcpy(&new_pal[15], &old_pal[1], sizeof(RGBQUAD));

				}
				else if(FreeImage_GetColorType(dib) == FIC_MINISWHITE) {
					
					// Reverse the grayscale palette

					for(int i = 0; i < 16; i++) {
						new_pal[i].rgbRed = new_pal[i].rgbGreen = new_pal[i].rgbBlue = 255 - ((i << 4) + i);
					}
				}

				// Expand and copy the bitmap data

				for (int rows = 0; rows < height; rows++)
					FreeImage_ConvertLine1To4(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width);
					
				return new_dib;
			}

			case 8 :
			{
				// Expand and copy the bitmap data

				for (int rows = 0; rows < height; rows++)
					FreeImage_ConvertLine8To4(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width, FreeImage_GetPalette(dib));

				return new_dib;
			}

			case 16 :
			{
				// Expand and copy the bitmap data

				for (int rows = 0; rows < height; rows++) {
					if ((FreeImage_GetRedMask(dib) == FI16_565_RED_MASK) && (FreeImage_GetGreenMask(dib) == FI16_565_GREEN_MASK) && (FreeImage_GetBlueMask(dib) == FI16_565_BLUE_MASK)) {
						FreeImage_ConvertLine16To4_565(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width);
					} else {
						FreeImage_ConvertLine16To4_555(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width);
					}
				}
				
				return new_dib;
			}

			case 24 :
			{
				// Expand and copy the bitmap data

				for (int rows = 0; rows < height; rows++)
					FreeImage_ConvertLine24To4(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width);					

				return new_dib;
			}

			case 32 :
			{
				// Expand and copy the bitmap data

				for (int rows = 0; rows < height; rows++)
					FreeImage_ConvertLine32To4(FreeImage_GetScanLine(new_dib, rows), FreeImage_GetScanLine(dib, rows), width);
				
				return new_dib;
			}
		}
	}

	return FreeImage_Clone(dib);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费人成网站在线观看欧美高清| 国产美女在线观看一区| 一区二区三区在线免费| 中文字幕中文字幕在线一区| 国产欧美日韩在线| 中文字幕成人网| 亚洲欧美在线aaa| 亚洲欧洲中文日韩久久av乱码| 国产精品毛片久久久久久久| 亚洲色图一区二区三区| 亚洲视频一区在线观看| 亚洲色图第一区| 亚洲国产一区视频| 婷婷丁香久久五月婷婷| 免费日韩伦理电影| 国产乱码精品一区二区三| 国产成人综合在线播放| 99国产精品久久久久久久久久| 成人av资源在线观看| 色偷偷一区二区三区| 欧美日韩午夜精品| 日韩三级视频中文字幕| 久久久亚洲高清| 国产精品每日更新在线播放网址| 综合久久一区二区三区| 亚瑟在线精品视频| 日韩av电影免费观看高清完整版| 男女激情视频一区| 成人午夜视频网站| 在线免费观看日本欧美| 欧美一二三四区在线| 久久久久久综合| 日韩一区欧美一区| 日韩av电影一区| 高清在线不卡av| 欧美性色黄大片| 久久综合九色综合欧美就去吻| 中文字幕永久在线不卡| 亚洲成av人片一区二区梦乃| 久久精品国产77777蜜臀| 岛国一区二区三区| 欧美日韩一区二区三区视频| 精品国产伦理网| 国产精品久久久久久亚洲毛片 | 欧美日韩精品一区视频| 欧美videossexotv100| 亚洲欧洲三级电影| 免费成人美女在线观看.| 丁香婷婷综合色啪| 在线播放国产精品二区一二区四区| 26uuu久久综合| 亚洲一二三四在线| 国产乱国产乱300精品| 欧洲激情一区二区| 国产免费成人在线视频| 日韩精品欧美精品| 99天天综合性| 精品国产乱码久久久久久1区2区| 综合亚洲深深色噜噜狠狠网站| 蜜臀av亚洲一区中文字幕| 99久久精品免费看| 亚洲精品一区在线观看| 亚洲一区二区中文在线| 国产精品18久久久久久久久 | 91精品国产全国免费观看 | 国产一区二区在线观看视频| 91国产免费观看| 欧美精品一区二区三| 亚洲成人动漫精品| 91丝袜国产在线播放| 国产亚洲欧美激情| 日韩黄色在线观看| 色呦呦一区二区三区| 欧美极品xxx| 国产一区在线看| 日韩欧美一二三四区| 亚洲成人在线免费| 色综合久久六月婷婷中文字幕| 国产亚洲人成网站| 九色综合国产一区二区三区| 欧美精品日韩一本| 亚洲激情av在线| www.欧美亚洲| 中文字幕免费观看一区| 国产永久精品大片wwwapp| 91精品国产色综合久久久蜜香臀| 亚洲综合在线第一页| 91色在线porny| 国产精品视频一二三| 国产精品一区二区黑丝| 欧美精品一区二区三区蜜桃 | 国产成人精品一区二区三区网站观看| 91精品国产色综合久久不卡电影| 亚洲成人动漫精品| 欧美日韩国产美女| 亚洲国产欧美一区二区三区丁香婷| 99视频在线观看一区三区| 国产农村妇女精品| 国产精品77777竹菊影视小说| 精品日韩欧美在线| 美女网站在线免费欧美精品| 欧美一区二区三区色| 日韩1区2区日韩1区2区| 91精品国产麻豆国产自产在线 | 日韩一区日韩二区| 色综合天天综合给合国产| 亚洲欧洲精品一区二区三区不卡| 成人一区二区三区视频在线观看| 国产喂奶挤奶一区二区三区| 成人午夜在线播放| 亚洲女子a中天字幕| 欧美日韩免费高清一区色橹橹| 午夜精品久久久久久久蜜桃app| 欧美日韩色一区| 美女视频黄久久| 久久综合九色综合久久久精品综合| 国产精品一区在线| 国产精品色在线| 高清不卡在线观看av| 综合久久给合久久狠狠狠97色| 91小视频在线免费看| 亚洲一本大道在线| 制服丝袜亚洲播放| 精品一区二区三区av| 欧美国产精品一区| 91在线你懂得| 五月天中文字幕一区二区| 日韩欧美专区在线| 国产精品一区二区在线观看不卡| 国产精品理伦片| 欧美日韩国产影片| 国产在线精品一区二区夜色 | 国产精品一区二区免费不卡| 中文字幕中文字幕一区| 欧美日韩精品二区第二页| 免费观看在线色综合| 国产人久久人人人人爽| 色哟哟一区二区三区| 麻豆国产精品官网| 国产目拍亚洲精品99久久精品| 欧美伊人精品成人久久综合97| 国产日韩精品一区二区三区在线| 精品国产一二三区| 国产欧美日韩三级| 国产女同互慰高潮91漫画| 色综合久久88色综合天天6| 婷婷久久综合九色综合伊人色| 久久综合狠狠综合久久激情| 91在线观看一区二区| 亚洲成人福利片| 国产色91在线| 欧美日韩国产大片| 国产suv一区二区三区88区| 亚洲国产aⅴ成人精品无吗| 精品国产91乱码一区二区三区| 91污在线观看| 精品一区二区影视| 亚洲综合一区二区精品导航| 精品粉嫩超白一线天av| 日本精品一级二级| 国产露脸91国语对白| 亚洲高清一区二区三区| 国产日韩精品一区二区三区在线| 欧美精品国产精品| 不卡欧美aaaaa| 另类的小说在线视频另类成人小视频在线| 亚洲国产精品99久久久久久久久| 欧美一区二区三区视频免费播放| 91尤物视频在线观看| 国产精品一二二区| 蜜臀99久久精品久久久久久软件| 亚洲欧美区自拍先锋| 久久久不卡影院| 欧美一区二区三区精品| 久久久久久久久久看片| 欧美变态口味重另类| 色综合欧美在线视频区| 国产盗摄精品一区二区三区在线| 午夜视频一区二区| 亚洲欧洲性图库| 国产女人aaa级久久久级| 欧美mv日韩mv国产网站| 欧美另类一区二区三区| 色婷婷综合久久| 99久久伊人精品| 高潮精品一区videoshd| 激情成人午夜视频| 久久狠狠亚洲综合| 日韩专区一卡二卡| 亚洲国产中文字幕在线视频综合| 亚洲三级在线免费| 中文字幕成人av| 中文一区在线播放| 中文字幕国产精品一区二区| 久久久精品天堂| 久久久久久久久久久黄色| 日韩一区二区高清| 欧美一区二区三区免费视频| 欧美日本精品一区二区三区| 精品视频在线视频|