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

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

?? mydipview.cpp

?? 采用Matlab自己編寫的傅里葉變換
?? CPP
字號:
// 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
/*************************************************************************
 *
 * 函數名稱:
 *   FFT()
 *
 * 參數:
 *   complex<double> * TD	- 指向時域數組的指針
 *   complex<double> * FD	- 指向頻域數組的指針
 *   r						-2的冪數,即迭代次數
 *
 * 返回值:
 *   無。
 *
 * 說明:
 *   該函數用來實現快速付立葉變換。
 *
 ************************************************************************/
VOID WINAPI FFT(complex<double> * TD, complex<double> * FD, int r)
{
	// 付立葉變換點數
	LONG	count;
	
	// 循環變量
	int		i,j,k;
	
	// 中間變量
	int		bfsize,p;
	
	// 角度
	double	angle;
	
	complex<double> *W,*X1,*X2,*X;
	
	// 計算付立葉變換點數
	count = 1 << r;
	
	// 分配運算所需存儲器
	W  = new complex<double>[count / 2];
	X1 = new complex<double>[count];
	X2 = new complex<double>[count];
	
	// 計算加權系數
	for(i = 0; i < count / 2; i++)
	{
		angle = -i * PI * 2 / count;
		W[i] = complex<double> (cos(angle), sin(angle));
	}
	
	// 將時域點寫入X1
	memcpy(X1, TD, sizeof(complex<double>) * count);
	
	// 采用蝶形算法進行快速付立葉變換
	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];
	}
	
	// 釋放內存
	delete W;
	delete X1;
	delete X2;
}


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


//對比度拉伸
//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);     // 計算圖像每行的字節數
//DEL 	// 每行
//DEL 	for(i = 0; i < cyDIB; i++)
//DEL 	{
//DEL 		// 每列
//DEL 		for(j = 0; j < cxDIB; j++)
//DEL 		{
//DEL 			// 指向DIB第i行,第j個象素的指針
//DEL 			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (cyDIB - 1 - i) + j;
//DEL 			// 計算新的灰度值
//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位圖的付立葉變換,其它的可以類推)
	if (::DIBNumColors(lpDIB) != 256)
	{
		// 提示用戶
		MessageBox("目前只支持256色位圖的付立葉變換!", "系統提示" ,
			MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
		
		// 返回
		return;
	}
	
	// 更改光標形狀
	BeginWaitCursor();
	
	// 調用Fourier()函數進行付立葉變換
	if (::Fourier(lpDIBBits, ::DIBWidth(lpDIB), ::DIBHeight(lpDIB)))
	{
		
		// 設置臟標記
		pDoc->SetModifiedFlag(TRUE);
		
		// 更新視圖
		pDoc->UpdateAllViews(NULL);
	}
	else
	{
		// 提示用戶
		MessageBox("分配內存失敗!", "系統提示" , MB_ICONINFORMATION | MB_OK);
	}
	
	// 解除鎖定
	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	
	// 恢復光標
	EndWaitCursor();
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米综合一区二区三区精品视频| 久久久噜噜噜久久人人看| 久久久久久一级片| 亚洲一区二区四区蜜桃| 国精产品一区一区三区mba视频| 在线观看免费成人| 亚洲国产成人自拍| 国产亚洲成av人在线观看导航| 亚洲免费av网站| 国产精品一品视频| 欧美一区三区二区| 亚洲一区二区三区四区在线免费观看 | 中文字幕一区二区三区在线观看 | 国产精品盗摄一区二区三区| 蜜桃视频一区二区三区| 欧美三级乱人伦电影| 中文字幕欧美一区| 国产成人av影院| 精品少妇一区二区三区 | 亚洲人成精品久久久久久| 国产成人在线视频网址| 精品国产三级电影在线观看| 偷拍与自拍一区| 欧美亚洲一区三区| 亚洲精品美国一| 99久久精品免费看国产| 中文字幕第一页久久| 国产成人无遮挡在线视频| 精品国产三级电影在线观看| 麻豆91免费观看| 日韩一区二区在线播放| 五月婷婷综合激情| 欧美日韩成人激情| 亚洲国产精品一区二区久久恐怖片| 91视频国产资源| 亚洲视频精选在线| 91视视频在线观看入口直接观看www | 91色.com| 亚洲蜜桃精久久久久久久| 99国产欧美久久久精品| 亚洲日本va在线观看| 一本久久a久久免费精品不卡| 成人欧美一区二区三区视频网页 | 蜜臀va亚洲va欧美va天堂| 欧美一区三区四区| 精品一区二区三区久久久| 精品999久久久| 狠狠色狠狠色综合系列| 久久夜色精品国产噜噜av| 国产原创一区二区| 中文字幕免费不卡| 99热精品一区二区| 一区二区三区小说| 欧美猛男男办公室激情| 日本女优在线视频一区二区| 日韩午夜三级在线| 韩国女主播一区| 欧美激情中文不卡| 99久久免费精品高清特色大片| 亚洲精品欧美激情| 欧美日韩成人综合在线一区二区| 美女一区二区久久| 久久蜜桃香蕉精品一区二区三区| 丁香婷婷综合五月| 亚洲欧美区自拍先锋| 欧美日韩一区在线观看| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲精品一区二区三区香蕉| 大美女一区二区三区| 亚洲精品免费一二三区| 欧美一区二区大片| 国产成人激情av| 亚洲精品国产无套在线观| 欧美剧情片在线观看| 激情综合色综合久久综合| 中文字幕欧美激情一区| 日本高清不卡在线观看| 美脚の诱脚舐め脚责91 | 精品欧美一区二区在线观看| 春色校园综合激情亚洲| 一区二区理论电影在线观看| 日韩三级av在线播放| 成人精品高清在线| 亚洲一区二区视频在线观看| 久久日一线二线三线suv| 99久久综合精品| 日韩电影在线一区| 欧美激情资源网| 7777精品伊人久久久大香线蕉完整版| 激情六月婷婷久久| 一区二区三区精密机械公司| 欧美一区二区三区系列电影| 成人激情av网| 奇米精品一区二区三区在线观看 | 日韩在线观看一区二区| 久久精品一区四区| 欧美性xxxxxx少妇| 国产综合色视频| 夜色激情一区二区| 国产亚洲一本大道中文在线| 欧美在线视频日韩| 国产电影一区二区三区| 亚洲成人激情综合网| 国产欧美一区二区三区网站| 欧美日韩激情一区二区三区| 懂色av噜噜一区二区三区av| 日本成人在线看| 亚洲精品欧美专区| 国产日韩v精品一区二区| 欧美日韩不卡一区| 成人一区二区三区| 免费人成网站在线观看欧美高清| 亚洲色图视频网| 欧美精品一区二区久久久| 欧美性猛交xxxx乱大交退制版 | 久久国产精品区| 亚洲国产毛片aaaaa无费看| 国产精品乱码人人做人人爱| 欧美一卡二卡在线观看| 色激情天天射综合网| 成人av网站在线观看| 久久精品二区亚洲w码| 亚洲成人黄色小说| 日韩伦理电影网| 国产欧美一区二区在线观看| 精品国产亚洲一区二区三区在线观看| 欧美色爱综合网| 色综合色综合色综合 | 免费av网站大全久久| 亚洲在线视频免费观看| 中文字幕在线不卡一区| 2023国产一二三区日本精品2022| 欧美福利电影网| 欧美综合亚洲图片综合区| 不卡的av网站| 春色校园综合激情亚洲| 美女脱光内衣内裤视频久久网站| 亚洲成人7777| 一区二区视频在线| 亚洲欧美在线另类| 国产精品免费av| 国产日本欧洲亚洲| 国产亚洲污的网站| 久久嫩草精品久久久久| 欧美精品一区二区三区蜜桃| 精品国产麻豆免费人成网站| 日韩一级免费一区| 欧美一区二区高清| 欧美一区二区三区公司| 91精品在线麻豆| 在线成人av网站| 欧美特级限制片免费在线观看| 色综合中文字幕| 在线中文字幕不卡| 欧洲另类一二三四区| 欧美亚洲尤物久久| 欧美日韩一区二区电影| 欧美男生操女生| 欧美一级淫片007| 欧美成人精品1314www| 日韩欧美国产综合在线一区二区三区| 666欧美在线视频| 欧美一级淫片007| 日韩欧美国产不卡| 欧美不卡视频一区| 久久综合av免费| 国产日韩影视精品| 中文字幕不卡在线| 亚洲色图在线视频| 亚洲电影视频在线| 日本最新不卡在线| 经典三级视频一区| 国产成人在线色| 91捆绑美女网站| 欧美三级蜜桃2在线观看| 91精品国产色综合久久不卡电影| 日韩限制级电影在线观看| 久久久久97国产精华液好用吗| 国产日韩欧美精品电影三级在线| 国产精品传媒视频| 一区二区三区四区视频精品免费| 亚洲国产精品久久艾草纯爱| 偷窥国产亚洲免费视频| 九九在线精品视频| 丰满白嫩尤物一区二区| 91在线精品一区二区| 欧美色综合网站| 欧美电影免费观看高清完整版在线观看 | 色综合久久88色综合天天免费| 在线观看中文字幕不卡| 欧美一区二区三区男人的天堂| 精品久久一二三区| 中文字幕日韩一区| 亚洲高清免费一级二级三级| 蜜桃av噜噜一区二区三区小说| 国产91丝袜在线观看| 在线一区二区三区四区五区| 欧美一级xxx| 亚洲国产成人在线| 婷婷一区二区三区|