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

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

?? templatetrans.cpp

?? CEComm: Windows CE 4.0下的串口調(diào)試程序 串口精靈源代碼 TTY:Windows 下的類似超級(jí)終端的原代碼. TAPICase: Windows 下用TAPI撥號(hào)的例子 image
?? CPP
字號(hào):

/**************************************************************************
 *  文件名:TemplateTrans.cpp
 *
 *  圖像模板變換API函數(shù)庫(kù):
 *
 *  Template()			- 圖像模板變換,通過(guò)改變模板,可以用它實(shí)現(xiàn)
 *						  圖像的平滑、銳化、邊緣識(shí)別等操作。
 *  MedianFilter()		- 圖像中值濾波。
 *  GetMedianNum()		- 獲取中值。被函數(shù)MedianFilter()調(diào)用來(lái)求中值。
 *  ReplaceColorPal()	- 更換偽彩色編碼表。
 *
 *************************************************************************/

#include "stdafx.h"
#include "TemplateTrans.h"
#include "DIBAPI.h"

#include <math.h>
#include <direct.h>

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   Template()
 *
 * 參數(shù):
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素?cái)?shù))
 *   LONG  lHeight      - 源圖像高度(象素?cái)?shù))
 *   int   iTempH		- 模板的高度
 *   int   iTempW		- 模板的寬度
 *   int   iTempMX		- 模板的中心元素X坐標(biāo) ( < iTempW - 1)
 *   int   iTempMY		- 模板的中心元素Y坐標(biāo) ( < iTempH - 1)
 *	 FLOAT * fpArray	- 指向模板數(shù)組的指針
 *	 FLOAT fCoef		- 模板系數(shù)
 *
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 *
 * 說(shuō)明:
 *   該函數(shù)用指定的模板(任意大小)來(lái)對(duì)圖像進(jìn)行操作,參數(shù)iTempH指定模板
 * 的高度,參數(shù)iTempW指定模板的寬度,參數(shù)iTempMX和iTempMY指定模板的中心
 * 元素坐標(biāo),參數(shù)fpArray指定模板元素,fCoef指定系數(shù)。
 *
 ************************************************************************/

BOOL WINAPI Template(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
					 int iTempH, int iTempW, 
					 int iTempMX, int iTempMY,
					 FLOAT * fpArray, FLOAT fCoef)
{
	// 指向復(fù)制圖像的指針
	LPSTR	lpNewDIBBits;
	HLOCAL	hNewDIBBits;
	
	// 指向源圖像的指針
	unsigned char*	lpSrc;
	
	// 指向要復(fù)制區(qū)域的指針
	unsigned char*	lpDst;
	
	// 循環(huán)變量
	LONG	i;
	LONG	j;
	LONG	k;
	LONG	l;
	
	// 計(jì)算結(jié)果
	FLOAT	fResult;
	
	// 圖像每行的字節(jié)數(shù)
	LONG lLineBytes;
	
	// 計(jì)算圖像每行的字節(jié)數(shù)
	lLineBytes = WIDTHBYTES(lWidth * 8);
	
	// 暫時(shí)分配內(nèi)存,以保存新圖像
	hNewDIBBits = LocalAlloc(LHND, lLineBytes * lHeight);
	
	// 判斷是否內(nèi)存分配失敗
	if (hNewDIBBits == NULL)
	{
		// 分配內(nèi)存失敗
		return FALSE;
	}
	
	// 鎖定內(nèi)存
	lpNewDIBBits = (char * )LocalLock(hNewDIBBits);
	
	// 初始化圖像為原始圖像
	memcpy(lpNewDIBBits, lpDIBBits, lLineBytes * lHeight);
	
	// 行(除去邊緣幾行)
	for(i = iTempMY; i < lHeight - iTempH + iTempMY + 1; i++)
	{
		// 列(除去邊緣幾列)
		for(j = iTempMX; j < lWidth - iTempW + iTempMX + 1; j++)
		{
			// 指向新DIB第i行,第j個(gè)象素的指針
			lpDst = (unsigned char*)lpNewDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			
			fResult = 0;
			
			// 計(jì)算
			for (k = 0; k < iTempH; k++)
			{
				for (l = 0; l < iTempW; l++)
				{
					// 指向DIB第i - iTempMY + k行,第j - iTempMX + l個(gè)象素的指針
					lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i + iTempMY - k)
						+ j - iTempMX + l;
					
					// 保存象素值
					fResult += (* lpSrc) * fpArray[k * iTempW + l];
				}
			}
			
			// 乘上系數(shù)
			fResult *= fCoef;
			
			// 取絕對(duì)值
			fResult = (FLOAT ) fabs(fResult);
			
			// 判斷是否超過(guò)255
			if(fResult > 255)
			{
				// 直接賦值為255
				* lpDst = 255;
			}
			else
			{
				// 賦值
				* lpDst = (unsigned char) (fResult + 0.5);
			}
			
		}
	}
	
	// 復(fù)制變換后的圖像
	memcpy(lpDIBBits, lpNewDIBBits, lLineBytes * lHeight);
	
	// 釋放內(nèi)存
	LocalUnlock(hNewDIBBits);
	LocalFree(hNewDIBBits);
	
	// 返回
	return TRUE;

}

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   MedianFilter()
 *
 * 參數(shù):
 *   LPSTR lpDIBBits		- 指向源DIB圖像指針
 *   LONG  lWidth			- 源圖像寬度(象素?cái)?shù))
 *   LONG  lHeight			- 源圖像高度(象素?cái)?shù))
 *   int   iFilterH			- 濾波器的高度
 *   int   iFilterW			- 濾波器的寬度
 *   int   iFilterMX		- 濾波器的中心元素X坐標(biāo)
 *   int   iFilterMY		- 濾波器的中心元素Y坐標(biāo)
 *
 * 返回值:
 *   BOOL					- 成功返回TRUE,否則返回FALSE。
 *
 * 說(shuō)明:
 *   該函數(shù)對(duì)DIB圖像進(jìn)行中值濾波。
 *
 ************************************************************************/

BOOL WINAPI MedianFilter(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
						 int iFilterH, int iFilterW, 
						 int iFilterMX, int iFilterMY)
{
	
	// 指向源圖像的指針
	unsigned char*	lpSrc;
	
	// 指向要復(fù)制區(qū)域的指針
	unsigned char*	lpDst;
	
	// 指向復(fù)制圖像的指針
	LPSTR			lpNewDIBBits;
	HLOCAL			hNewDIBBits;
	
	// 指向?yàn)V波器數(shù)組的指針
	unsigned char	* aValue;
	HLOCAL			hArray;
	
	// 循環(huán)變量
	LONG			i;
	LONG			j;
	LONG			k;
	LONG			l;
	
	// 圖像每行的字節(jié)數(shù)
	LONG			lLineBytes;
	
	// 計(jì)算圖像每行的字節(jié)數(shù)
	lLineBytes = WIDTHBYTES(lWidth * 8);
	
	// 暫時(shí)分配內(nèi)存,以保存新圖像
	hNewDIBBits = LocalAlloc(LHND, lLineBytes * lHeight);
	
	// 判斷是否內(nèi)存分配失敗
	if (hNewDIBBits == NULL)
	{
		// 分配內(nèi)存失敗
		return FALSE;
	}
	
	// 鎖定內(nèi)存
	lpNewDIBBits = (char * )LocalLock(hNewDIBBits);
	
	// 初始化圖像為原始圖像
	memcpy(lpNewDIBBits, lpDIBBits, lLineBytes * lHeight);
	
	// 暫時(shí)分配內(nèi)存,以保存濾波器數(shù)組
	hArray = LocalAlloc(LHND, iFilterH * iFilterW);
	
	// 判斷是否內(nèi)存分配失敗
	if (hArray == NULL)
	{
		// 釋放內(nèi)存
		LocalUnlock(hNewDIBBits);
		LocalFree(hNewDIBBits);
		
		// 分配內(nèi)存失敗
		return FALSE;
	}
	
	// 鎖定內(nèi)存
	aValue = (unsigned char * )LocalLock(hArray);
	
	// 開(kāi)始中值濾波
	// 行(除去邊緣幾行)
	for(i = iFilterMY; i < lHeight - iFilterH + iFilterMY + 1; i++)
	{
		// 列(除去邊緣幾列)
		for(j = iFilterMX; j < lWidth - iFilterW + iFilterMX + 1; j++)
		{
			// 指向新DIB第i行,第j個(gè)象素的指針
			lpDst = (unsigned char*)lpNewDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			
			// 讀取濾波器數(shù)組
			for (k = 0; k < iFilterH; k++)
			{
				for (l = 0; l < iFilterW; l++)
				{
					// 指向DIB第i - iFilterMY + k行,第j - iFilterMX + l個(gè)象素的指針
					lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i + iFilterMY - k) + j - iFilterMX + l;
					
					// 保存象素值
					aValue[k * iFilterW + l] = *lpSrc;
				}
			}
			
			// 獲取中值
			* lpDst = GetMedianNum(aValue, iFilterH * iFilterW);
		}
	}
	
	// 復(fù)制變換后的圖像
	memcpy(lpDIBBits, lpNewDIBBits, lLineBytes * lHeight);
	
	// 釋放內(nèi)存
	LocalUnlock(hNewDIBBits);
	LocalFree(hNewDIBBits);
	LocalUnlock(hArray);
	LocalFree(hArray);
	
	// 返回
	return TRUE;
}

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   GetMedianNum()
 *
 * 參數(shù):
 *   unsigned char * bpArray	- 指向要獲取中值的數(shù)組指針
 *   int   iFilterLen			- 數(shù)組長(zhǎng)度
 *
 * 返回值:
 *   unsigned char      - 返回指定數(shù)組的中值。
 *
 * 說(shuō)明:
 *   該函數(shù)用冒泡法對(duì)一維數(shù)組進(jìn)行排序,并返回?cái)?shù)組元素的中值。
 *
 ************************************************************************/

unsigned char WINAPI GetMedianNum(unsigned char * bArray, int iFilterLen)
{
	// 循環(huán)變量
	int		i;
	int		j;
	
	// 中間變量
	unsigned char bTemp;
	
	// 用冒泡法對(duì)數(shù)組進(jìn)行排序
	for (j = 0; j < iFilterLen - 1; j ++)
	{
		for (i = 0; i < iFilterLen - j - 1; i ++)
		{
			if (bArray[i] > bArray[i + 1])
			{
				// 互換
				bTemp = bArray[i];
				bArray[i] = bArray[i + 1];
				bArray[i + 1] = bTemp;
			}
		}
	}
	
	// 計(jì)算中值
	if ((iFilterLen & 1) > 0)
	{
		// 數(shù)組有奇數(shù)個(gè)元素,返回中間一個(gè)元素
		bTemp = bArray[(iFilterLen + 1) / 2];
	}
	else
	{
		// 數(shù)組有偶數(shù)個(gè)元素,返回中間兩個(gè)元素平均值
		bTemp = (bArray[iFilterLen / 2] + bArray[iFilterLen / 2 + 1]) / 2;
	}
	
	// 返回中值
	return bTemp;
}

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   GradSharp()
 *
 * 參數(shù):
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素?cái)?shù))
 *   LONG  lHeight      - 源圖像高度(象素?cái)?shù))
 *   BYTE  bThre		- 閾值
 *
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 *
 * 說(shuō)明:
 *   該函數(shù)用來(lái)對(duì)圖像進(jìn)行梯度銳化。
 *
 ************************************************************************/
BOOL WINAPI GradSharp(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BYTE bThre)
{
	
	// 指向源圖像的指針
	unsigned char*	lpSrc;
	unsigned char*	lpSrc1;
	unsigned char*	lpSrc2;
	
	// 循環(huán)變量
	LONG	i;
	LONG	j;
	
	// 圖像每行的字節(jié)數(shù)
	LONG	lLineBytes;
	
	// 中間變量
	BYTE	bTemp;
	
	// 計(jì)算圖像每行的字節(jié)數(shù)
	lLineBytes = WIDTHBYTES(lWidth * 8);
	
	// 每行
	for(i = 0; i < lHeight; i++)
	{
		// 每列
		for(j = 0; j < lWidth; j++)
		{
			// 指向DIB第i行,第j個(gè)象素的指針
			lpSrc  = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			
			// 指向DIB第i+1行,第j個(gè)象素的指針
			lpSrc1 = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 2 - i) + j;
			
			// 指向DIB第i行,第j+1個(gè)象素的指針
			lpSrc2 = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j + 1;
			
			bTemp = abs((*lpSrc)-(*lpSrc1)) + abs((*lpSrc)-(*lpSrc2));
			
			// 判斷是否小于閾值
			if (bTemp < 255)
			{
				// 判斷是否大于閾值,對(duì)于小于情況,灰度值不變。
				if (bTemp >= bThre)
				{
					// 直接賦值為bTemp
					*lpSrc = bTemp;
				}
			}
			else
			{
				// 直接賦值為255
				*lpSrc = 255;
			}
		}
	}
	
	// 返回
	return TRUE;
}

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   ReplaceColorPal()
 *
 * 參數(shù):
 *   LPSTR lpDIB			- 指向源DIB圖像指針
 *   BYTE * bpColorsTable	- 偽彩色編碼表
 *
 * 返回值:
 *   BOOL					- 成功返回TRUE,否則返回FALSE。
 *
 * 說(shuō)明:
 *   該函數(shù)用指定的偽彩色編碼表來(lái)替換圖像的調(diào)試板,參數(shù)bpColorsTable
 * 指向要替換的偽彩色編碼表。
 *
 ************************************************************************/
BOOL WINAPI ReplaceColorPal(LPSTR lpDIB, BYTE * bpColorsTable)
{
	
	// 循環(huán)變量
	int i;
	
	// 顏色表中的顏色數(shù)目
	WORD wNumColors;
	
	// 指向BITMAPINFO結(jié)構(gòu)的指針(Win3.0)
	LPBITMAPINFO lpbmi;
	
	// 指向BITMAPCOREINFO結(jié)構(gòu)的指針
	LPBITMAPCOREINFO lpbmc;
	
	// 表明是否是Win3.0 DIB的標(biāo)記
	BOOL bWinStyleDIB;
	
	// 創(chuàng)建結(jié)果
	BOOL bResult = FALSE;
	
	// 獲取指向BITMAPINFO結(jié)構(gòu)的指針(Win3.0)
	lpbmi = (LPBITMAPINFO)lpDIB;
	
	// 獲取指向BITMAPCOREINFO結(jié)構(gòu)的指針
	lpbmc = (LPBITMAPCOREINFO)lpDIB;
	
	// 獲取DIB中顏色表中的顏色數(shù)目
	wNumColors = ::DIBNumColors(lpDIB);
		
	// 判斷顏色數(shù)目是否是256色
	if (wNumColors == 256)
	{
		
		// 判斷是否是WIN3.0的DIB
		bWinStyleDIB = IS_WIN30_DIB(lpDIB);
		
		// 讀取偽彩色編碼,更新DIB調(diào)色板
		for (i = 0; i < (int)wNumColors; i++)
		{
			if (bWinStyleDIB)
			{
				// 更新DIB調(diào)色板紅色分量
				lpbmi->bmiColors[i].rgbRed = bpColorsTable[i * 4];
				
				// 更新DIB調(diào)色板綠色分量
				lpbmi->bmiColors[i].rgbGreen = bpColorsTable[i * 4 + 1];
				
				// 更新DIB調(diào)色板藍(lán)色分量
				lpbmi->bmiColors[i].rgbBlue = bpColorsTable[i * 4 + 2];
				
				// 更新DIB調(diào)色板保留位
				lpbmi->bmiColors[i].rgbReserved = 0;
			}
			else
			{
				// 更新DIB調(diào)色板紅色分量
				lpbmc->bmciColors[i].rgbtRed = bpColorsTable[i * 4];
				
				// 更新DIB調(diào)色板綠色分量
				lpbmc->bmciColors[i].rgbtGreen = bpColorsTable[i * 4 + 1];
				
				// 更新DIB調(diào)色板藍(lán)色分量
				lpbmc->bmciColors[i].rgbtBlue = bpColorsTable[i * 4 + 2];
			}
		}
	}
	
	// 返回
	return bResult;	

}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品中文字幕一区二区三区| 奇米精品一区二区三区在线观看| 国产视频一区二区三区在线观看| 日韩欧美在线网站| 欧美一区二区国产| 日韩精品最新网址| 久久嫩草精品久久久精品| 欧美一级高清片在线观看| 日韩限制级电影在线观看| 欧美一区二区久久久| 精品乱人伦小说| 久久久噜噜噜久噜久久综合| 久久嫩草精品久久久精品一| 中文字幕的久久| |精品福利一区二区三区| 亚洲色图制服丝袜| 亚洲一区二区三区激情| 日韩av在线发布| 国产一区二区三区在线观看免费 | 色婷婷久久一区二区三区麻豆| 99精品视频免费在线观看| 91蜜桃在线免费视频| 色综合久久中文字幕综合网| 欧美自拍偷拍午夜视频| 欧美伦理视频网站| 欧美成人性福生活免费看| 激情六月婷婷综合| 激情都市一区二区| 成人美女在线观看| 91福利社在线观看| 日韩女优毛片在线| 中文字幕欧美一区| 天天影视色香欲综合网老头| 精品一区二区三区欧美| 成人成人成人在线视频| 欧美日韩国产片| 久久综合狠狠综合| 亚洲欧美日本韩国| 美女一区二区三区在线观看| 国产精品77777竹菊影视小说| 99九九99九九九视频精品| 91精品国模一区二区三区| 国产人成亚洲第一网站在线播放| 亚洲人一二三区| 美国十次综合导航| 波多野洁衣一区| 日韩一卡二卡三卡国产欧美| 国产欧美日韩在线看| 亚洲一级二级在线| 国产精品中文有码| 538在线一区二区精品国产| 国产欧美一区二区三区鸳鸯浴| 亚洲综合视频在线| 国产91精品一区二区| 欧美男女性生活在线直播观看| 国产亚洲精品aa| 亚洲大尺度视频在线观看| 国产精品一线二线三线精华| 欧美性生活久久| 欧美激情一区二区三区全黄| 性感美女久久精品| 91亚洲资源网| 久久久久久久av麻豆果冻| 日韩精品成人一区二区三区| 99久久精品国产网站| 久久麻豆一区二区| 亚洲成av人片在线| aa级大片欧美| 国产清纯在线一区二区www| 日韩在线一区二区三区| 色综合天天综合网天天看片| 亚洲精品一区二区三区香蕉 | jlzzjlzz亚洲女人18| 精品日韩欧美在线| 五月天亚洲精品| 91视频精品在这里| 国产精品久久久久久久久免费桃花| 久久精品国产亚洲aⅴ| 欧美日本在线一区| 亚洲精品va在线观看| 成人免费高清在线| 国产无人区一区二区三区| 青青草97国产精品免费观看 | 欧美精品一区二区三区蜜桃视频| 亚洲电影一级片| 色香色香欲天天天影视综合网| 国产日韩欧美综合在线| 久草热8精品视频在线观看| 欧美老女人第四色| 亚洲超碰97人人做人人爱| 91麻豆产精品久久久久久 | 激情成人综合网| 日韩欧美中文字幕制服| 婷婷一区二区三区| 欧美三级中文字幕在线观看| 亚洲伊人伊色伊影伊综合网| 色欧美日韩亚洲| 亚洲另类在线制服丝袜| 色综合天天综合网国产成人综合天 | 亚洲第一二三四区| 欧美中文字幕一区二区三区| 亚洲青青青在线视频| 色域天天综合网| 亚洲激情在线播放| 色综合久久九月婷婷色综合| 日韩毛片一二三区| 91香蕉视频mp4| 亚洲精品va在线观看| 欧美在线免费视屏| 日韩在线a电影| 欧美一级免费观看| 另类小说欧美激情| 国产亚洲欧美色| av在线不卡观看免费观看| 亚洲欧美日韩久久精品| 在线中文字幕一区| 亚洲成人综合视频| 日韩视频中午一区| 国产精品一品视频| 亚洲欧洲精品一区二区精品久久久| 91尤物视频在线观看| 亚洲国产综合91精品麻豆| 欧美精品v日韩精品v韩国精品v| 午夜不卡在线视频| 久久综合成人精品亚洲另类欧美 | 午夜精品123| 日韩精品一区二区三区四区视频| 国产精品一区二区视频| 中文字幕日韩精品一区| 欧美视频你懂的| 久久成人av少妇免费| 国产亚洲欧美在线| 在线亚洲免费视频| 麻豆久久一区二区| 国产精品美女久久久久久久| 在线中文字幕一区二区| 毛片av一区二区| 国产精品乱人伦一区二区| 欧美在线不卡一区| 精品在线一区二区| 成人av网站免费观看| 亚洲精品高清在线| 欧美大度的电影原声| 成人激情黄色小说| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲精选视频免费看| 91精品国产色综合久久不卡电影 | 成人a级免费电影| 亚洲大型综合色站| 国产亚洲人成网站| 欧美日韩和欧美的一区二区| 国产精品综合一区二区| 亚洲一区二区四区蜜桃| 久久亚洲综合色| 欧美性大战久久久久久久蜜臀| 国产一区二区中文字幕| 亚洲一区免费观看| 中文字幕欧美国产| 欧美精品 日韩| 成人黄色网址在线观看| 日本va欧美va精品发布| 亚洲欧洲日韩在线| 久久综合色鬼综合色| 欧美最新大片在线看| 国产寡妇亲子伦一区二区| 亚洲国产精品人人做人人爽| 国产亚洲欧美一级| 9191久久久久久久久久久| 成人性视频免费网站| 免费久久精品视频| 一区二区三区在线免费| 久久久www免费人成精品| 欧美日韩日本视频| 97精品电影院| 国产不卡免费视频| 乱中年女人伦av一区二区| 亚洲一区二三区| 最新久久zyz资源站| ww亚洲ww在线观看国产| 欧美男女性生活在线直播观看| 91一区二区三区在线播放| 国产露脸91国语对白| 日韩电影在线看| 亚洲一级不卡视频| 日韩理论片一区二区| 中文av一区二区| 久久精品日产第一区二区三区高清版 | 国产精品亚洲第一区在线暖暖韩国| 免费成人在线影院| 午夜欧美在线一二页| 一区二区三区四区激情 | 国产99久久久国产精品免费看| 日本不卡视频在线| 性做久久久久久免费观看| 亚洲视频 欧洲视频| 综合网在线视频| 亚洲免费观看高清完整版在线观看熊 | 久久久不卡网国产精品一区| 精品国产一区二区精华| 久久er精品视频|