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

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

?? templatetrans.cpp

?? 《Visual C++數字圖像處理》配套源代碼
?? CPP
字號:

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

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

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

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

BOOL WINAPI Template(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
					 int iTempH, int iTempW, 
					 int iTempMX, int iTempMY,
					 FLOAT * fpArray, FLOAT fCoef)
{
	// 指向復制圖像的指針
	LPSTR	lpNewDIBBits;
	HLOCAL	hNewDIBBits;
	
	// 指向源圖像的指針
	unsigned char*	lpSrc;
	
	// 指向要復制區域的指針
	unsigned char*	lpDst;
	
	// 循環變量
	LONG	i;
	LONG	j;
	LONG	k;
	LONG	l;
	
	// 計算結果
	FLOAT	fResult;
	
	// 圖像每行的字節數
	LONG lLineBytes;
	
	// 計算圖像每行的字節數
	lLineBytes = WIDTHBYTES(lWidth * 8);
	
	// 暫時分配內存,以保存新圖像
	hNewDIBBits = LocalAlloc(LHND, lLineBytes * lHeight);
	
	// 判斷是否內存分配失敗
	if (hNewDIBBits == NULL)
	{
		// 分配內存失敗
		return FALSE;
	}
	
	// 鎖定內存
	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個象素的指針
			lpDst = (unsigned char*)lpNewDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			
			fResult = 0;
			
			// 計算
			for (k = 0; k < iTempH; k++)
			{
				for (l = 0; l < iTempW; l++)
				{
					// 指向DIB第i - iTempMY + k行,第j - iTempMX + l個象素的指針
					lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i + iTempMY - k)
						+ j - iTempMX + l;
					
					// 保存象素值
					fResult += (* lpSrc) * fpArray[k * iTempW + l];
				}
			}
			
			// 乘上系數
			fResult *= fCoef;
			
			// 取絕對值
			fResult = (FLOAT ) fabs(fResult);
			
			// 判斷是否超過255
			if(fResult > 255)
			{
				// 直接賦值為255
				* lpDst = 255;
			}
			else
			{
				// 賦值
				* lpDst = (unsigned char) (fResult + 0.5);
			}
			
		}
	}
	
	// 復制變換后的圖像
	memcpy(lpDIBBits, lpNewDIBBits, lLineBytes * lHeight);
	
	// 釋放內存
	LocalUnlock(hNewDIBBits);
	LocalFree(hNewDIBBits);
	
	// 返回
	return TRUE;

}

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

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

/*************************************************************************
 *
 * 函數名稱:
 *   GetMedianNum()
 *
 * 參數:
 *   unsigned char * bpArray	- 指向要獲取中值的數組指針
 *   int   iFilterLen			- 數組長度
 *
 * 返回值:
 *   unsigned char      - 返回指定數組的中值。
 *
 * 說明:
 *   該函數用冒泡法對一維數組進行排序,并返回數組元素的中值。
 *
 ************************************************************************/

unsigned char WINAPI GetMedianNum(unsigned char * bArray, int iFilterLen)
{
	// 循環變量
	int		i;
	int		j;
	
	// 中間變量
	unsigned char bTemp;
	
	// 用冒泡法對數組進行排序
	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;
			}
		}
	}
	
	// 計算中值
	if ((iFilterLen & 1) > 0)
	{
		// 數組有奇數個元素,返回中間一個元素
		bTemp = bArray[(iFilterLen + 1) / 2];
	}
	else
	{
		// 數組有偶數個元素,返回中間兩個元素平均值
		bTemp = (bArray[iFilterLen / 2] + bArray[iFilterLen / 2 + 1]) / 2;
	}
	
	// 返回中值
	return bTemp;
}

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

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

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日噜噜夜夜狠狠视频欧美人| 亚洲视频在线观看三级| 日本韩国欧美三级| 91丨九色丨黑人外教| 99riav久久精品riav| 99久久综合99久久综合网站| 成人黄色a**站在线观看| aaa亚洲精品| 欧美丝袜丝交足nylons| 欧美二区在线观看| 欧美一区二区三区色| 日韩免费在线观看| 国产日韩精品一区二区浪潮av| 国产日产精品1区| 亚洲欧洲无码一区二区三区| 亚洲欧洲精品一区二区精品久久久 | 欧美在线观看视频一区二区| 91啪亚洲精品| 欧美日韩视频第一区| 欧美一级一区二区| 久久久久久免费网| 中文字幕精品一区二区三区精品| 18成人在线视频| 亚洲一区二区在线观看视频| 日本中文字幕不卡| 国产精品一级片| av在线一区二区三区| 欧美日韩视频专区在线播放| 日韩欧美成人一区| 国产精品久久久久影院老司| 亚洲精品国产无天堂网2021| 午夜精品一区二区三区电影天堂| 久久精品国产第一区二区三区| 国产91丝袜在线播放0| 在线观看亚洲一区| 欧美日韩精品一区二区在线播放| 精品对白一区国产伦| 亚洲三级在线看| 久久不见久久见中文字幕免费| 99re视频精品| 久久一区二区视频| 樱桃视频在线观看一区| 国产揄拍国内精品对白| 欧美色图免费看| 中文字幕中文在线不卡住| 同产精品九九九| 99久久精品国产网站| 日韩女优av电影| 亚洲成av人影院| jlzzjlzz亚洲女人18| 精品区一区二区| 亚洲777理论| 91在线免费看| 久久夜色精品一区| 亚洲午夜羞羞片| 一本色道久久综合亚洲91| 欧美白人最猛性xxxxx69交| 一区二区三区四区激情 | 久久久精品日韩欧美| 亚洲丰满少妇videoshd| 成人视屏免费看| 精品国产欧美一区二区| 天堂资源在线中文精品| 欧洲一区二区三区在线| 国产精品美女一区二区三区| 国产真实乱子伦精品视频| 欧美系列在线观看| 亚洲欧洲一区二区在线播放| 国产黄人亚洲片| 久久蜜桃一区二区| 蜜臀a∨国产成人精品| 7777精品伊人久久久大香线蕉| 亚洲色图制服丝袜| 一本色道亚洲精品aⅴ| 国产三级三级三级精品8ⅰ区| 久久精品免费观看| 欧美第一区第二区| 久久精品国产第一区二区三区| 欧美一二三区在线观看| 蜜臀精品久久久久久蜜臀| 在线不卡中文字幕播放| 亚洲成av人综合在线观看| 欧美日韩国产天堂| 日韩电影在线免费观看| 欧美一区二区精美| 激情丁香综合五月| 精品福利av导航| 国产精品一二一区| 国产精品传媒视频| 91在线观看成人| 亚洲大片免费看| 日韩精品专区在线影院重磅| 极品美女销魂一区二区三区免费| 久久久国产午夜精品| 成人小视频免费在线观看| 中文字幕一区二区三区四区| 99re6这里只有精品视频在线观看| 亚洲乱码中文字幕综合| 欧美日韩国产一级二级| 精品一区二区三区蜜桃| 中文幕一区二区三区久久蜜桃| 色婷婷综合久久久中文字幕| 天天综合天天综合色| 精品人在线二区三区| 成人激情开心网| 亚洲不卡av一区二区三区| 26uuu亚洲| 99re免费视频精品全部| 日本aⅴ免费视频一区二区三区| 久久久久久久久久看片| 91成人在线免费观看| 美国欧美日韩国产在线播放| 国产精品欧美一级免费| 欧美日韩日日夜夜| 国产成人精品影视| 五月综合激情婷婷六月色窝| 久久九九久久九九| 欧美天堂一区二区三区| 国产精品小仙女| 亚洲国产成人tv| 中文字幕日韩一区| 日韩一区二区视频| 91香蕉视频污在线| 国产精品伊人色| 午夜激情一区二区三区| 中文字幕欧美国产| 日韩欧美亚洲国产精品字幕久久久| 盗摄精品av一区二区三区| 日韩国产在线观看一区| 亚洲女同ⅹxx女同tv| 国产色91在线| 欧美一区二视频| 欧美亚洲图片小说| 99国产精品久| 成人性色生活片免费看爆迷你毛片| 视频一区二区不卡| 亚洲国产色一区| 国产精品国产三级国产aⅴ入口 | 亚洲精品视频在线观看网站| 精品对白一区国产伦| 欧美日韩www| 色噜噜狠狠成人网p站| 国产夫妻精品视频| 韩国欧美一区二区| 国内欧美视频一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅| 午夜精品久久久久久久蜜桃app| 亚洲人成网站色在线观看| 国产精品免费视频观看| 国产亚洲一二三区| 国产午夜一区二区三区| 久久这里只精品最新地址| 日韩亚洲国产中文字幕欧美| 日韩欧美在线综合网| 欧美一区二区三区免费观看视频| 欧美电影在线免费观看| 欧美日韩一级视频| 91久久线看在观草草青青| 一本色道亚洲精品aⅴ| 欧美在线不卡一区| 欧美在线影院一区二区| 欧美日韩午夜影院| 欧美高清dvd| 日韩一区二区影院| 精品日韩成人av| 国产亚洲欧美一级| 欧美国产日韩a欧美在线观看 | 欧美日韩综合不卡| 538prom精品视频线放| 欧美男人的天堂一二区| 欧美电影精品一区二区 | 国产精一区二区三区| 韩国午夜理伦三级不卡影院| 高清日韩电视剧大全免费| 成人av影院在线| 在线精品视频免费观看| 制服视频三区第一页精品| 26uuu欧美| 亚洲男人都懂的| 青草av.久久免费一区| 国产福利一区二区三区视频在线| caoporen国产精品视频| 欧美日韩免费一区二区三区| 精品日韩99亚洲| 一区二区三区高清在线| 蜜臀va亚洲va欧美va天堂| 成人听书哪个软件好| 88在线观看91蜜桃国自产| 国产日韩av一区| 午夜精品在线看| 国产成人精品亚洲777人妖| 欧美视频日韩视频| 久久蜜桃av一区二区天堂| 一区二区三区在线免费观看| 麻豆免费精品视频| 91蝌蚪porny九色| 日韩一级高清毛片| 亚洲欧洲日韩在线| 国内偷窥港台综合视频在线播放| 色综合天天综合狠狠|