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

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

?? mydipview.cpp

?? 關(guān)于圖像變換操作的程序
?? CPP
字號(hào):
// MyDIPView.cpp : implementation of the CMyDIPView class
//

#include "stdafx.h"
#include "MyDIP.h"

#include "MyDIPDoc.h"
#include "MyDIPView.h"
#include "math.h"
#include<complex>
using namespace std;
#define PI 3.14159
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/*************************************************************************
 *
 * 函數(shù)名稱(chēng):
 *   FFT()
 *
 * 參數(shù):
 *   complex<double> * TD	- 指向時(shí)域數(shù)組的指針
 *   complex<double> * FD	- 指向頻域數(shù)組的指針
 *   r						-2的冪數(shù),即迭代次數(shù)
 *
 * 返回值:
 *   無(wú)。
 *
 * 說(shuō)明:
 *   該函數(shù)用來(lái)實(shí)現(xiàn)快速付立葉變換。
 *
 ************************************************************************/
VOID WINAPI FFT(complex<double> * TD, complex<double> * FD, int r)
{
	// 付立葉變換點(diǎn)數(shù)
	LONG	count;
	
	// 循環(huán)變量
	int		i,j,k;
	
	// 中間變量
	int		bfsize,p;
	
	// 角度
	double	angle;
	
	complex<double> *W,*X1,*X2,*X;
	
	// 計(jì)算付立葉變換點(diǎn)數(shù)
	count = 1 << r;
	
	// 分配運(yùn)算所需存儲(chǔ)器
	W  = new complex<double>[count / 2];
	X1 = new complex<double>[count];
	X2 = new complex<double>[count];
	
	// 計(jì)算加權(quán)系數(shù)
	for(i = 0; i < count / 2; i++)
	{
		angle = -i * PI * 2 / count;
		W[i] = complex<double> (cos(angle), sin(angle));
	}
	
	// 將時(shí)域點(diǎn)寫(xiě)入X1
	memcpy(X1, TD, sizeof(complex<double>) * count);
	
	// 采用蝶形算法進(jìn)行快速付立葉變換
	for(k = 0; k < r; k++)
	{
		for(j = 0; j < 1 << k; j++)
		{
			bfsize = 1 << (r-k);
			for(i = 0; i < bfsize / 2; i++)
			{
				p = j * bfsize;
				X2[i + p] = X1[i + p] + X1[i + p + bfsize / 2];
				X2[i + p + bfsize / 2] = (X1[i + p] - X1[i + p + bfsize / 2]) * W[i * (1<<k)];
			}
		}
		X  = X1;
		X1 = X2;
		X2 = X;
	}
	
	// 重新排序
	for(j = 0; j < count; j++)
	{
		p = 0;
		for(i = 0; i < r; i++)
		{
			if (j&(1<<i))
			{
				p+=1<<(r-i-1);
			}
		}
		FD[j]=X1[p];
	}
	
	// 釋放內(nèi)存
	delete W;
	delete X1;
	delete X2;
}


/*************************************************************************
 *
 * 函數(shù)名稱(chēng):
 *   Fourier()
 *
 * 參數(shù):
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素?cái)?shù))
 *   LONG  lHeight      - 源圖像高度(象素?cái)?shù))
 *
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 *
 * 說(shuō)明:
 *   該函數(shù)用來(lái)對(duì)圖像進(jìn)行付立葉變換。
 *
 ************************************************************************/
BOOL WINAPI Fourier(LPSTR lpDIBBits, LONG lWidth, LONG lHeight)
{
	
	// 指向源圖像的指針
	unsigned char*	lpSrc;
	
	// 中間變量
	double	dTemp;
	
	// 循環(huán)變量
	LONG	i;
	LONG	j;
	
	// 進(jìn)行付立葉變換的寬度和高度(2的整數(shù)次方)
	LONG	w;
	LONG	h;
	
	int		wp;
	int		hp;
	
	// 圖像每行的字節(jié)數(shù)
	LONG	lLineBytes;
	
	// 計(jì)算圖像每行的字節(jié)數(shù)
	lLineBytes = WIDTHBYTES(lWidth * 8);
	
	// 賦初值
	w = 1;
	h = 1;
	wp = 0;
	hp = 0;
	
	// 計(jì)算進(jìn)行付立葉變換的寬度和高度(2的整數(shù)次方)
	while(w * 2 <= lWidth)
	{
		w *= 2;
		wp++;
	}
	
	while(h * 2 <= lHeight)
	{
		h *= 2;
		hp++;
	}
	
	// 分配內(nèi)存
	complex<double> *TD = new complex<double>[w * h];
	complex<double> *FD = new complex<double>[w * h];
	
	// 行
	for(i = 0; i < h; i++)
	{
		// 列
		for(j = 0; j < w; j++)
		{
			// 指向DIB第i行,第j個(gè)象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			
			// 給時(shí)域賦值
			TD[j + w * i] = complex<double>(*(lpSrc), 0);
		}
	}
	
	for(i = 0; i < h; i++)
	{
		// 對(duì)y方向進(jìn)行快速付立葉變換
		FFT(&TD[w * i], &FD[w * i], wp);
	}
	
	// 保存變換結(jié)果
	for(i = 0; i < h; i++)
	{
		for(j = 0; j < w; j++)
		{
			TD[i + h * j] = FD[j + w * i];
		}
	}
	
	for(i = 0; i < w; i++)
	{
		// 對(duì)x方向進(jìn)行快速付立葉變換
		FFT(&TD[i * h], &FD[i * h], hp);
	}
	
	// 行
	for(i = 0; i < h; i++)
	{
		// 列
		for(j = 0; j < w; j++)
		{
			// 計(jì)算頻譜
			dTemp = sqrt(FD[j * h + i].real() * FD[j * h + i].real() + 
				         FD[j * h + i].imag() * FD[j * h + i].imag()) / 100;
			
			// 判斷是否超過(guò)255
			if (dTemp > 255)
			{
				// 對(duì)于超過(guò)的,直接設(shè)置為255
				dTemp = 255;
			}
			
			// 指向DIB第(i<h/2 ? i+h/2 : i-h/2)行,第(j<w/2 ? j+w/2 : j-w/2)個(gè)象素的指針
			// 此處不直接取i和j,是為了將變換后的原點(diǎn)移到中心
			//lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * 
				(lHeight - 1 - (i<h/2 ? i+h/2 : i-h/2)) + (j<w/2 ? j+w/2 : j-w/2);
			
			// 更新源圖像
			* (lpSrc) = (BYTE)(dTemp);
		}
	}
	
	// 刪除臨時(shí)變量
	delete TD;
	delete FD;
	
	// 返回
	return TRUE;
}

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView

IMPLEMENT_DYNCREATE(CMyDIPView, CScrollView)

BEGIN_MESSAGE_MAP(CMyDIPView, CScrollView)
	//{{AFX_MSG_MAP(CMyDIPView)
	ON_COMMAND(ID_MENUITEM32778, OnMenuitem32778)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CScrollView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView construction/destruction

CMyDIPView::CMyDIPView()
{
	// TODO: add construction code here

}

CMyDIPView::~CMyDIPView()
{
}

BOOL CMyDIPView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView drawing

void CMyDIPView::OnDraw(CDC* pDC)
{   
	CMyDIPDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	if(pDoc->m_hDIB == NULL)
		return ;
	// TODO: add draw code for native data here
	int i,j;
    unsigned char *lpSrc;
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->m_hDIB);
	int cxDIB = (int) ::DIBWidth(lpDIB);         // Size of DIB - x
	int cyDIB = (int) ::DIBHeight(lpDIB);        // Size of DIB - y
	LPSTR lpDIBBits=::FindDIBBits (lpDIB);
	// 計(jì)算圖像每行的字節(jié)數(shù)
	long lLineBytes = WIDTHBYTES(cxDIB * 8);
	// 每行
	for(i = 0; i < cyDIB; i++)
	{
		// 每列
		for(j = 0; j < cxDIB; j++)
		{
			// 指向DIB第i行,第j個(gè)象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (cyDIB - 1 - i) + j;
			// 計(jì)算新的灰度值
			//*(lpSrc) = BYTE(255-*lpSrc);
		}
	}
	::GlobalUnlock((HGLOBAL) pDoc->m_hDIB);
	CRect rect(0,0,cxDIB,cyDIB), rcDIB(0,0,cxDIB,cyDIB);
	::PaintDIB(pDC->m_hDC, &rect, pDoc->m_hDIB, &rcDIB, pDoc->m_palDIB);
}

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView printing

BOOL CMyDIPView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

void CMyDIPView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CMyDIPView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView diagnostics

#ifdef _DEBUG
void CMyDIPView::AssertValid() const
{
	CScrollView::AssertValid();
}

void CMyDIPView::Dump(CDumpContext& dc) const
{
	CScrollView::Dump(dc);
}

CMyDIPDoc* CMyDIPView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMyDIPDoc)));
	return (CMyDIPDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMyDIPView message handlers

void CMyDIPView::OnSize(UINT nType, int cx, int cy)
{
	CScrollView::OnSize(nType, cx, cy);
}

void CMyDIPView::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();

	SetScrollSizes(MM_TEXT, GetDocument()->m_sizeDoc);
}


//對(duì)比度拉伸
//DEL void CMyDIPView::OnMenuitem32777() 
//DEL {
//DEL 	
//DEL 	// 獲取文檔
//DEL 	CMyDIPDoc* pDoc = GetDocument();
//DEL 	int i,j;
//DEL 	int r1=60,r2=200;
//DEL 	double k=1.5;
//DEL     unsigned char *lpSrc;	
//DEL 	ASSERT_VALID(pDoc);
//DEL 	if(pDoc->m_hDIB == NULL)
//DEL 		return ;
//DEL 	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->m_hDIB);
//DEL 	LPSTR lpDIBBits=::FindDIBBits (lpDIB);
//DEL 	int cxDIB = (int) ::DIBWidth(lpDIB);         // Size of DIB - x
//DEL 	int cyDIB = (int) ::DIBHeight(lpDIB);        // Size of DIB - y
//DEL 	long lLineBytes = WIDTHBYTES(cxDIB * 8);     // 計(jì)算圖像每行的字節(jié)數(shù)
//DEL 	// 每行
//DEL 	for(i = 0; i < cyDIB; i++)
//DEL 	{
//DEL 		// 每列
//DEL 		for(j = 0; j < cxDIB; j++)
//DEL 		{
//DEL 			// 指向DIB第i行,第j個(gè)象素的指針
//DEL 			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (cyDIB - 1 - i) + j;
//DEL 			// 計(jì)算新的灰度值
//DEL 			if(*lpSrc<r1) *lpSrc=BYTE(*lpSrc/k);
//DEL 			else if(*lpSrc<r2) *lpSrc= BYTE((*lpSrc-r1)*k+r1/k);
//DEL 			else *lpSrc=BYTE((*lpSrc-r2)/k+255-(255-r2)/k);
//DEL 		}
//DEL 	}
//DEL 	::GlobalUnlock((HGLOBAL) pDoc->m_hDIB);
//DEL     Invalidate(TRUE);
//DEL }

void CMyDIPView::OnMenuitem32778() 
{
	// 圖像付立葉變換
	
	// 獲取文檔
	CMyDIPDoc* pDoc = GetDocument();
	
	// 指向DIB的指針
	LPSTR	lpDIB;
	
	// 指向DIB象素指針
	LPSTR    lpDIBBits;
	
	// 鎖定DIB
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());
	
	// 找到DIB圖像象素起始位置
	lpDIBBits = ::FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖的付立葉變換,其它的可以類(lèi)推)
	if (::DIBNumColors(lpDIB) != 256)
	{
		// 提示用戶(hù)
		MessageBox("目前只支持256色位圖的付立葉變換!", "系統(tǒng)提示" ,
			MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
		
		// 返回
		return;
	}
	
	// 更改光標(biāo)形狀
	BeginWaitCursor();
	
	// 調(diào)用Fourier()函數(shù)進(jìn)行付立葉變換
	if (::Fourier(lpDIBBits, ::DIBWidth(lpDIB), ::DIBHeight(lpDIB)))
	{
		
		// 設(shè)置臟標(biāo)記
		pDoc->SetModifiedFlag(TRUE);
		
		// 更新視圖
		pDoc->UpdateAllViews(NULL);
	}
	else
	{
		// 提示用戶(hù)
		MessageBox("分配內(nèi)存失敗!", "系統(tǒng)提示" , MB_ICONINFORMATION | MB_OK);
	}
	
	// 解除鎖定
	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	
	// 恢復(fù)光標(biāo)
	EndWaitCursor();
	
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av不卡在线播放| 欧美日韩在线一区二区| 亚洲精品美国一| 欧美一区二区三区四区视频| 丁香天五香天堂综合| 日韩电影在线免费| 亚洲三级在线观看| 国产性做久久久久久| 91麻豆精品国产91久久久更新时间| 国产精品亚洲一区二区三区妖精| 亚洲成人精品影院| 中文字幕av资源一区| 欧美一级二级三级蜜桃| 在线看不卡av| 成人av网址在线| 国产精品1024| 蜜臀久久99精品久久久久久9| 日韩美女视频一区二区| 日本一区二区视频在线| 日韩欧美不卡在线观看视频| 欧美网站一区二区| 91蝌蚪porny九色| 成人性生交大片免费看视频在线 | 成人免费小视频| 久久久五月婷婷| 欧美不卡一区二区三区四区| 欧美日韩大陆一区二区| 一本久久a久久精品亚洲| 国产91清纯白嫩初高中在线观看 | 欧美激情综合五月色丁香小说| 欧美日韩国产成人在线免费| 91蜜桃免费观看视频| 成人精品电影在线观看| 国产成人免费视频网站高清观看视频| 蜜桃精品在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲成年人网站在线观看| 一区二区三区四区激情| 成人免费在线播放视频| 一区在线播放视频| 亚洲欧美自拍偷拍色图| 亚洲视频小说图片| 亚洲欧美电影院| 亚洲免费在线看| 亚洲国产精品久久一线不卡| 亚洲一区二区三区四区五区中文| 亚洲精品免费在线| 一卡二卡欧美日韩| 亚洲v日本v欧美v久久精品| 亚洲一卡二卡三卡四卡 | 亚洲激情图片qvod| 伊人开心综合网| 亚洲一区二区三区影院| 亚洲成人av资源| 蜜桃精品视频在线| 韩国女主播一区二区三区| 国产一区二区三区高清播放| 国产乱一区二区| 99久久综合色| 欧美在线视频不卡| 欧美一区二区三区四区在线观看| 日韩免费视频一区二区| 精品1区2区在线观看| 久久久99久久| 亚洲精品综合在线| 午夜成人在线视频| 国内精品久久久久影院一蜜桃| 国产精品自拍三区| 色又黄又爽网站www久久| 欧美日韩高清不卡| 久久久精品国产免大香伊| 国产精品蜜臀在线观看| 亚洲综合成人网| 日韩av中文字幕一区二区| 国产在线精品一区二区三区不卡| 成人小视频免费在线观看| 色婷婷精品久久二区二区蜜臂av| 欧美在线观看一二区| 欧美电视剧免费全集观看| 中文字幕中文字幕在线一区| 婷婷夜色潮精品综合在线| 国产精品自拍在线| 在线亚洲一区二区| 亚洲精品一区二区三区在线观看| 国产精品美日韩| 三级精品在线观看| 粉嫩13p一区二区三区| 在线观看一区二区精品视频| 日韩欧美久久一区| 亚洲欧美日本韩国| 韩国三级在线一区| 欧美亚洲愉拍一区二区| 国产色婷婷亚洲99精品小说| 亚洲www啪成人一区二区麻豆| 国产一区二区网址| 欧美少妇bbb| 国产精品成人网| 久久99最新地址| 欧美在线制服丝袜| 国产精品伦理在线| 狠狠色狠狠色综合日日91app| 一本久久a久久精品亚洲| 久久亚区不卡日本| 午夜视频一区二区三区| av网站免费线看精品| 日韩欧美的一区二区| 亚洲综合激情小说| 99久久国产免费看| 久久五月婷婷丁香社区| 丝袜美腿亚洲综合| 日本韩国精品一区二区在线观看| 综合久久国产九一剧情麻豆| 紧缚捆绑精品一区二区| 欧美日韩一级黄| 亚洲欧洲中文日韩久久av乱码| 国产一区二区三区国产| 欧美一级一级性生活免费录像| 日韩美女啊v在线免费观看| 国产精品一区二区久久精品爱涩| 91精品国产综合久久精品| 亚洲人成网站影音先锋播放| 国产精品一区二区黑丝| 欧美大白屁股肥臀xxxxxx| 亚洲成人动漫在线观看| 91成人在线精品| 亚洲猫色日本管| av一区二区久久| 国产精品亲子乱子伦xxxx裸| 国产精品888| 国产亚洲人成网站| 国产一区二区电影| www精品美女久久久tv| 狠狠色丁香婷综合久久| 精品久久久久久久一区二区蜜臀| 天天色综合天天| 777欧美精品| 免费看黄色91| 欧美tk丨vk视频| 免费欧美在线视频| 日韩精品一区二区三区老鸭窝| 日本不卡在线视频| 精品美女在线观看| 久久99精品国产麻豆婷婷 | 亚洲欧美中日韩| 99精品久久久久久| 一区二区三区在线看| 欧美亚洲高清一区二区三区不卡| 亚洲精品国产无天堂网2021| 欧美日韩亚洲综合在线| 日韩电影一区二区三区四区| 日韩午夜中文字幕| 国产乱码精品一品二品| 中文字幕一区不卡| 在线欧美日韩精品| 日韩电影在线观看网站| 久久先锋影音av| 99久久er热在这里只有精品15 | 成人一区二区视频| 亚洲乱码国产乱码精品精的特点| 日本福利一区二区| 首页欧美精品中文字幕| 精品国产乱码久久久久久夜甘婷婷| 国产剧情一区二区三区| 1区2区3区欧美| 欧美年轻男男videosbes| 韩国欧美一区二区| 亚洲视频中文字幕| 制服丝袜在线91| 国产精品夜夜爽| 一区二区三区免费在线观看| 91精品国产91热久久久做人人 | 欧美日韩免费观看一区二区三区| 五月婷婷激情综合网| 337p日本欧洲亚洲大胆色噜噜| 国产成人av电影免费在线观看| 亚洲欧美一区二区三区孕妇| 欧美精品123区| 国产九色sp调教91| 夜夜精品浪潮av一区二区三区| 91精品国产乱码久久蜜臀| 国产91丝袜在线18| 亚洲第一二三四区| 久久精品人人做人人综合 | 久久影院视频免费| 欧美羞羞免费网站| 国产精一品亚洲二区在线视频| 一区二区国产视频| 久久久国产精华| 欧美日韩久久一区二区| 豆国产96在线|亚洲| 日韩精品国产精品| 中文字幕在线播放不卡一区| 欧美二区三区91| 99视频国产精品| 久久机这里只有精品| 亚洲乱码国产乱码精品精可以看 | 亚洲大片免费看| 中文字幕亚洲精品在线观看| 久久综合一区二区| 777a∨成人精品桃花网|