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

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

?? geotrans.cpp

?? VC++數(shù)字圖像處理 配套光盤
?? CPP
字號:
// GeoTrans.cpp : Defines the initialization routines for the DLL.
//

#include "stdafx.h"
#include "GeoTrans.h"
#include "DIBAPI.h"
#include "TransDIB.h"
#include "math.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

//
//	Note!
//
//		If this DLL is dynamically linked against the MFC
//		DLLs, any functions exported from this DLL which
//		call into MFC must have the AFX_MANAGE_STATE macro
//		added at the very beginning of the function.
//
//		For example:
//
//		extern "C" BOOL PASCAL EXPORT ExportedFunction()
//		{
//			AFX_MANAGE_STATE(AfxGetStaticModuleState());
//			// normal function body here
//		}
//
//		It is very important that this macro appear in each
//		function, prior to any calls into MFC.  This means that
//		it must appear as the first statement within the 
//		function, even before any object variable declarations
//		as their constructors may generate calls into the MFC
//		DLL.
//
//		Please see MFC Technical Notes 33 and 58 for additional
//		details.
//

/////////////////////////////////////////////////////////////////////////////
// CGeoTransApp

BEGIN_MESSAGE_MAP(CGeoTransApp, CWinApp)
	//{{AFX_MSG_MAP(CGeoTransApp)
		// NOTE - the ClassWizard will add and remove mapping macros here.
		//    DO NOT EDIT what you see in these blocks of generated code!
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CGeoTransApp construction

CGeoTransApp::CGeoTransApp()
{
	// TODO: add construction code here,
	// Place all significant initialization in InitInstance
}

/////////////////////////////////////////////////////////////////////////////
// The one and only CGeoTransApp object

CGeoTransApp theApp;

// 圖像鏡像導出函數(shù)
int _stdcall MirrorBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest,BOOL bDirection)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息
	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
    LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);

	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!MirrorDIB((LPSTR)lpDIBits, cx, cy, bDirection))
		return -2;
/**/

	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	

	return 1;

}

//圖像轉(zhuǎn)置導出函數(shù)
int _stdcall TransposeBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest)
{
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return 0;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;
	

	//對DIB進行轉(zhuǎn)換
	TransposeDIB((LPSTR)lpDIB);

	//將變化后的信息放到目的句柄
	lpBmpih=(BITMAPINFOHEADER *)lpDIB;
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;
	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -1;
	return 1;

}

//圖像縮放導出函數(shù)  
int _stdcall RotateBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest, int iRotateAngle)
{
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return 0;	
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;
	

	//對DIB進行轉(zhuǎn)換
	LPBYTE lpNewDIB=RotateDIB((LPSTR)lpDIB,iRotateAngle);

	LPBYTE lpDIBits =(LPBYTE)::FindDIBBits((LPSTR)lpNewDIB);

	//將變化后的信息放到目的句柄
	lpBmpih=(BITMAPINFOHEADER *)lpNewDIB;
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	GlobalFree(lpDIB);
	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpNewDIB,DIB_RGB_COLORS)==0)
		return -1;
	return 1;

}

//圖像旋轉(zhuǎn)導出函數(shù)
int _stdcall ZoomBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest, double fXZoomRatio, double fYZoomRatio)
{
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return 0;	
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;
	

	//對DIB進行轉(zhuǎn)換
	LPBYTE lpNewDIB=ZoomDIB((LPSTR)lpDIB,(float)fXZoomRatio,(float)fYZoomRatio);

	LPBYTE lpDIBits =(LPBYTE)::FindDIBBits((LPSTR)lpNewDIB);

	//將變化后的信息放到目的句柄
	lpBmpih=(BITMAPINFOHEADER *)lpNewDIB;
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	GlobalFree(lpDIB);
	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpNewDIB,DIB_RGB_COLORS)==0)
		return 0;
	return 1;

}

//圖像反色導出函數(shù)
int _stdcall LinerTransBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!LinerTrans((LPSTR)lpDIBits,cx,cy,-1.0,255.0))
		return -2;


	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	
//	GlobalFree(lpDIB);
	return 1;

}

//中值濾波導出函數(shù)
int _stdcall MedianFilterBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest, int iFilterH, int iFilterW, int iFilterMX, int iFilterMY)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!MedianFilter((LPSTR)lpDIBits,cx,cy, iFilterH, iFilterW,iFilterMX,iFilterMY))
		return -2;


	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	
//	GlobalFree(lpDIB);
	return 1;

}

//梯度銳化導出函數(shù)
int _stdcall GradSharpBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest,BYTE bThre)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!GradSharp((LPSTR)lpDIBits,cx,cy,bThre))
		return -2;


	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	
//	GlobalFree(lpDIB);
	return 1;

}

//圖像中加入隨機噪聲導出函數(shù)
int _stdcall RandomNoiseBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!RandomNoiseDIB((LPSTR)lpDIBits,cx,cy))
		return -2;


	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	
//	GlobalFree(lpDIB);
	return 1;

}


//圖像中加入椒鹽噪聲導出函數(shù)
int _stdcall SaltNoiseBmp(HDC hdcSrc,HBITMAP hbmpSrc,HDC hdcDest)
{	
	//得到圖象大小信息
	int cx,cy;

	//讀取DIB信息

	LPBYTE lpDIB=DIBfromBitmap(hdcSrc,hbmpSrc);
	if(lpDIB==NULL)
		return -1;	
	LPBYTE lpDIBits =(LPBYTE)lpDIB+sizeof(BITMAPINFOHEADER) + ::PaletteSize((LPSTR)lpDIB);
	
	BITMAPINFOHEADER * lpBmpih=(BITMAPINFOHEADER *)lpDIB; 
	cx=lpBmpih->biWidth;
	cy=lpBmpih->biHeight;

	//對DIB進行轉(zhuǎn)換
	if(!SaltNoiseDIB((LPSTR)lpDIBits,cx,cy))
		return -2;


	//將變化后的信息放到目的句柄

	if(SetDIBitsToDevice(hdcDest,0,0,cx,cy,0,0,0,cy,lpDIBits,(BITMAPINFO*)lpDIB,DIB_RGB_COLORS)==0)
		return -3;
	
	return 1;

}




?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人av一区二区三区| 亚洲同性gay激情无套| 99久久婷婷国产| 韩国午夜理伦三级不卡影院| 亚洲大片免费看| 亚洲一线二线三线视频| 国产农村妇女毛片精品久久麻豆| 日韩欧美一级片| 在线成人高清不卡| 欧美日本一道本| 欧美在线观看一区二区| 欧美亚男人的天堂| 91福利资源站| 91麻豆精品国产无毒不卡在线观看| 欧美丝袜第三区| 欧美日韩精品欧美日韩精品一综合| 91国在线观看| 欧美日韩黄色影视| 91精品国产一区二区三区| 欧美日韩国产电影| 日韩美女主播在线视频一区二区三区| 欧美精品久久99久久在免费线| 欧美日韩精品高清| 日韩欧美123| 欧美一区二区三区视频免费| 亚洲靠逼com| 亚洲高清三级视频| 五月天欧美精品| 麻豆精品一区二区三区| 国产一区二区影院| 不卡av在线免费观看| 一本一本大道香蕉久在线精品| 91极品视觉盛宴| 欧美变态tickling挠脚心| 久久夜色精品国产欧美乱极品| 国产精品丝袜一区| 亚洲线精品一区二区三区 | 国产乱淫av一区二区三区| 精品一区二区在线看| 大尺度一区二区| 一本大道久久a久久精品综合| 91精品国产一区二区| 国产人久久人人人人爽| 亚洲一区二区不卡免费| 美腿丝袜在线亚洲一区| av在线一区二区三区| 欧美高清精品3d| 国产日产欧美精品一区二区三区| 亚洲欧美在线另类| 日本网站在线观看一区二区三区| 成人免费看视频| 欧美一区二区三区在线观看视频| 中文在线一区二区| 日韩不卡在线观看日韩不卡视频| 国产91精品一区二区| 制服丝袜一区二区三区| 国产精品久久久久影院| 麻豆久久久久久| 色欧美日韩亚洲| 中文字幕电影一区| 精品在线你懂的| 欧美性大战久久久久久久蜜臀| 久久久久久99久久久精品网站| 亚洲午夜一区二区| 99久久久无码国产精品| 久久久精品免费网站| 日本不卡在线视频| 欧美日韩一区二区三区在线 | 精品美女一区二区| 亚洲免费观看视频| 成人动漫视频在线| 欧美韩日一区二区三区| 久久99国产精品尤物| 91麻豆精品久久久久蜜臀| 一个色综合av| 在线观看亚洲专区| 亚洲精品免费在线播放| 波多野结衣在线aⅴ中文字幕不卡| 欧美成人精品福利| 精品在线播放午夜| 欧美大胆一级视频| 久久精品99国产精品日本| 日韩欧美中文字幕制服| 青青青伊人色综合久久| 欧美二区在线观看| 日韩va欧美va亚洲va久久| 欧美日韩情趣电影| 手机精品视频在线观看| 91精品一区二区三区久久久久久| 图片区小说区区亚洲影院| 在线播放欧美女士性生活| 亚洲h精品动漫在线观看| 欧美日韩黄色一区二区| 视频一区二区欧美| 日韩精品一区二| 国产成人亚洲精品青草天美| 亚洲国产成人自拍| 91麻豆精品在线观看| 亚洲国产精品久久艾草纯爱| 欧美精品亚洲二区| 国产一区二区三区免费播放 | 亚洲精品ww久久久久久p站| 欧洲av一区二区嗯嗯嗯啊| 五月激情综合色| 精品日韩欧美在线| 成人精品视频网站| 亚洲动漫第一页| 欧美成人a在线| 暴力调教一区二区三区| 亚洲精品写真福利| 日韩欧美中文一区二区| 成人蜜臀av电影| 午夜影视日本亚洲欧洲精品| 精品国免费一区二区三区| 波多野结衣欧美| 日韩vs国产vs欧美| 亚洲人成网站色在线观看| 91麻豆精品国产无毒不卡在线观看| 国产在线视视频有精品| 亚洲一区av在线| 国产欧美精品一区二区三区四区 | 视频一区视频二区中文| 久久久激情视频| 色一情一乱一乱一91av| 九九久久精品视频| 亚洲精品v日韩精品| 久久―日本道色综合久久| 色哦色哦哦色天天综合| 国产剧情在线观看一区二区| 亚洲午夜私人影院| 国产精品激情偷乱一区二区∴| 欧美日韩黄色影视| av中文字幕在线不卡| 精品一区二区三区欧美| 午夜激情一区二区三区| 亚洲精品久久久久久国产精华液| 精品裸体舞一区二区三区| 欧美日韩专区在线| 99精品国产视频| 国产高清视频一区| 免费观看成人av| 午夜视频在线观看一区二区三区| 中文字幕一区二区三区视频| 久久免费偷拍视频| 欧美成人在线直播| 欧美日韩三级一区二区| 在线观看av一区二区| 99麻豆久久久国产精品免费| 国产精品一区二区黑丝| 国产精品亚洲成人| 国产一区二区女| 黄色成人免费在线| 六月丁香综合在线视频| 美女www一区二区| 日韩成人一区二区| 日av在线不卡| 丝袜美腿亚洲一区| 天堂成人国产精品一区| 首页欧美精品中文字幕| 日韩成人免费在线| 久久国产麻豆精品| 久久99久久久久久久久久久| 毛片一区二区三区| 国产综合色精品一区二区三区| 麻豆国产精品官网| 狠狠色丁香九九婷婷综合五月| 麻豆成人久久精品二区三区小说| 天天亚洲美女在线视频| 日本女优在线视频一区二区| 久久电影网站中文字幕| 国产成人综合亚洲网站| 99国产精品国产精品毛片| 欧美亚洲高清一区| 欧美一卡在线观看| 7777精品伊人久久久大香线蕉超级流畅| 色播五月激情综合网| 欧美日韩成人综合天天影院| 欧美一卡二卡三卡| 久久精品人人做人人爽97| 中文字幕第一区综合| 亚洲成av人片在www色猫咪| 日韩av电影免费观看高清完整版| 久草热8精品视频在线观看| 成人高清视频免费观看| 欧美无人高清视频在线观看| 欧美不卡视频一区| 亚洲视频一区二区在线| 视频在线观看国产精品| 成人永久看片免费视频天堂| 欧美中文字幕一区二区三区 | 国产又粗又猛又爽又黄91精品| 成人午夜av影视| 欧美一区二区三区视频在线| 中文字幕二三区不卡| 日日摸夜夜添夜夜添国产精品 | 亚洲精品成a人| 国产精一品亚洲二区在线视频| 色综合夜色一区| 久久久久久99久久久精品网站| 一区二区视频免费在线观看|