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

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

?? example1dlg.cpp

?? 一個Fourier變換的小程序;算法簡單實用。
?? CPP
字號:
// example1Dlg.cpp : implementation file
//

#include "stdafx.h"
#include "example1.h"
#include "example1Dlg.h"
#include "Fourier.h"

#include <COMPLEX>
using namespace std;

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

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CExample1Dlg dialog

CExample1Dlg::CExample1Dlg(CWnd* pParent /*=NULL*/)
	: CDialog(CExample1Dlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CExample1Dlg)
	m_FileIn = _T("");
	m_FileOut = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);

	m_Width=0;
	m_Height=0;
	m_Type = -1;
}

void CExample1Dlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CExample1Dlg)
	DDX_Text(pDX, IDC_EDIT1, m_FileIn);
	DDX_Text(pDX, IDC_EDIT2, m_FileOut);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CExample1Dlg, CDialog)
	//{{AFX_MSG_MAP(CExample1Dlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	ON_BN_CLICKED(IDC_BUTTON2, OnButton2)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CExample1Dlg message handlers

BOOL CExample1Dlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CExample1Dlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CExample1Dlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CExample1Dlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CExample1Dlg::OnButton1() 
{
	// TODO: Add your control notification handler code here
	UpdateData(true);

	CFileDialog dlg(TRUE,NULL,NULL,OFN_HIDEREADONLY,"rmg文件(*.rmg)|*.rmg|所有文件(*.*)|*.*||");
	if(dlg.DoModal()!=IDOK)
		return;
	m_FileIn =dlg.GetPathName();

	int dot =m_FileIn.ReverseFind('.');

	CString m_FileInH;
	if(dot==-1)
		m_FileInH =m_FileIn+".ldr";
	else
		m_FileInH =m_FileIn.Left(dot)+".ldr";
	FILE *fp;
	fp=fopen(m_FileInH,"r");
	if(fp==NULL)
	{
		MessageBox("無法打開圖像屬性文件!","錯誤",MB_ICONERROR|MB_OK);
		m_FileIn="";
		m_FileInH="";
		return;
	}
	char buf[1000];
	while(!feof(fp))
	{
		fscanf(fp,"%s",buf);
		if(!strcmp(buf,"[像元數]"))
		{
			fscanf(fp,"%s",buf);
			m_Width=atoi(buf);
		}
		if(!strcmp(buf,"[行數]"))
		{
			fscanf(fp,"%s",buf);
			m_Height=atoi(buf);
		}
		if(!strcmp(buf,"[數據類型]"))
		{
			fscanf(fp,"%s",buf);
			m_Type=atoi(buf);
		}
	}
	fclose(fp);
	UpdateData(false);		
}

void CExample1Dlg::OnButton2() 
{
	// TODO: Add your control notification handler code here
	UpdateData(true);

	CFileDialog dlgfile(false,"rmg",NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,
		"rmg文件(*.rmg)|*.rmg|所有文件(*.*)|*.*||",NULL);
	if((dlgfile.DoModal())==IDOK)
	{
		m_FileOut=dlgfile.GetPathName();
		UpdateData(false);
	}			
}

void CExample1Dlg::OnOK() 
{
	// TODO: Add extra validation here
	UpdateData(true);
	BeginWaitCursor();
	//
	int i,j;
	CFile file1;
	CFileException ex1;
	int w,h;
	int wp,hp;
	w=1;h=1;
	wp=0;hp=0;
	while(w<m_Width)
	{
		w=w*2;
		wp=wp+1;
	}
	while(h<m_Height)
	{
		h=h*2;
		hp=hp+1;
	}
	//
	if(m_Type==1)	//short
	{
		short* data=new short[m_Width*m_Height];
		//
		if(!file1.Open(m_FileIn,CFile::modeRead | CFile::shareDenyWrite,&ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError, 1024);
			AfxMessageBox(szError);
			return ;
		}
		file1.Read(data,sizeof(short)*m_Width*m_Height);
		file1.Close();
		//
		//
		complex<float>* outdata=new complex<float>[w*h];
		memset(outdata,0,sizeof(complex<float>));	//設置為0,最好設置
		//
		CFourier fre;
		fre.Fourier2(data,m_Width,m_Height,outdata);
		fre.fftshift(outdata,w,h,1);
		fre.fftshift(outdata,w,h,2);
		//
		if(!file1.Open(m_FileOut,CFile::modeWrite |
					CFile::shareExclusive | CFile::modeCreate, &ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError,1024);
			AfxMessageBox(szError);
			return;
		}
		file1.Write(outdata,sizeof(complex<float>)*w*h);
		file1.Close();
		//
		delete[] data;
		delete[] outdata;
	}
	else if(m_Type==2)	//int 
	{
		int* data=new int[m_Width*m_Height];
		//
		if(!file1.Open(m_FileIn,CFile::modeRead | CFile::shareDenyWrite,&ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError, 1024);
			AfxMessageBox(szError);
			return ;
		}
		file1.Read(data,sizeof(int)*m_Width*m_Height);
		file1.Close();
		//
		//
		complex<float>* outdata=new complex<float>[w*h];
		//
		CFourier fre;
		fre.Fourier2(data,m_Width,m_Height,outdata);
		fre.fftshift(outdata,w,h,1);
		fre.fftshift(outdata,w,h,2);
		//
		if(!file1.Open(m_FileOut,CFile::modeWrite |
					CFile::shareExclusive | CFile::modeCreate, &ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError,1024);
			AfxMessageBox(szError);
			return;
		}
		file1.Write(outdata,sizeof(complex<float>)*w*h);
		file1.Close();
		//
		delete[] data;
		delete[] outdata;		
	}
	else if(m_Type==3)	//float
	{
		//先讀數據
		float * data_1=new float[m_Width*m_Height];	//原始數據
		float * data_2=new float[m_Height*m_Width];	//轉置數據
		if(!file1.Open(m_FileIn,CFile::modeRead | CFile::shareDenyWrite,&ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError, 1024);
			AfxMessageBox(szError);
			return ;
		}
		file1.Read(data_1,sizeof(float)*m_Width*m_Height);
		file1.Close();
		//轉置
		for(i=0;i<m_Height;i++)
		{
			for(j=0;j<m_Width;j++)
			{
				data_2[j*m_Height+i]=data_1[i*m_Width+j];
			}
		}
		delete[] data_1;	//釋放臨時內存空間
		//
		data_1 = new* 
		//-------------------------------------
		//先對行處理FFT
		int New_H1 = 25*1024*1024/(sizeof(float)*m_Width);		//25M作為一個分塊的高度
		int block_1 = m_Height/New_H1 + 1 ;	//分的塊數

		complex<float>* outdata=new complex<float>[w*m_Height];	//中間分配的內存

		float* data=new float[m_Width*New_H1];					//每一塊分配的內存		
		//打開讀的文件
		if(!file1.Open(m_FileIn,CFile::modeRead | CFile::shareDenyWrite,&ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError, 1024);
			AfxMessageBox(szError);
			return ;
		}
		//
		CFourier fre;
		for(int i=0;i<block_1;i++)
		{
			if(i<block_1-1)		//前面的小塊
			{
				file1.Read(data,sizeof(float)*m_Width*New_H1);
				//
				fre.Fourier2(data,m_Width,New_H1,Outdata+i*New_H1*w,2);			//2--->對行
			}
			else				//最后的一塊
			{
				file1.Read(data,sizeof(float)*m_Width*(m_Height-(block_1-1)*New_H1));
				//
				fre.Fourier2(data,m_Width,(m_Height-(block_1-1)*New_H1),outdata+i*New_H1*w,2);
			}
		}
		//
		fre.fftshift(outdata,w,m_Height,2);		//對行
		//
		file1.Close();		//關閉文件
		delete[] data;		//釋放內存
		//---------------------------------------------------------------
		//再對列處理FFT
		if(!file1.Open(m_FileOut,CFile::modeWrite |
					CFile::shareExclusive | CFile::modeCreate, &ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError,1024);
			AfxMessageBox(szError);
			return;
		}
		//
		complex<float>*TD=new complex<float>[h];	//分配內存存儲時域數據
		//
		for(i=0;i<w;i++)
		{
			memset(TD,0,sizeof(complex<float>)*h);	//賦值0
			//將一列數據存到TD中
			for(int j=0;j<lHeight;j++)
			{
				TD[j]=complex<float>(outdata[j*w+i],0);
			}
			//對TD做FFT
			fre.FFT(TD,hp);
			//將數據保存到FDresult
			for(j=0;j<h;j++)
			{
				FDresult[j*+i]=TD[j];
			}		
		}
		//
		delete[] TD;
		delete[] FDresult;

		//
		if(!file1.Open(m_FileOut,CFile::modeWrite |
					CFile::shareExclusive | CFile::modeCreate, &ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError,1024);
			AfxMessageBox(szError);
			return;
		}
		file1.Write(outdata,sizeof(complex<float>)*w*h);
		file1.Close();
		//
		delete[] data;
		delete[] outdata;
	}
	else if(m_Type==6)	//complex<float>
	{
		complex<float>* data=new complex<float>[m_Width*m_Height];
		//
		if(!file1.Open(m_FileIn,CFile::modeRead | CFile::shareDenyWrite,&ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError, 1024);
			AfxMessageBox(szError);
			return ;
		}
		file1.Read(data,sizeof(complex<float>)*m_Width*m_Height);
		file1.Close();
		//
		//
		complex<float>* outdata=new complex<float>[w*h];
		//
		CFourier fre;
		//正變換
		fre.Fourier2(data,m_Width,m_Height,outdata);
		fre.fftshift(outdata,w,h,1);	//對行
		fre.fftshift(outdata,w,h,2);	//對列
//		//反變換
//		fre.fftshift(data,m_Width,m_Height,1);
//		fre.fftshift(data,m_Width,m_Height,2);
//		fre.InFourier2(data,m_Width,m_Height,outdata);
		//
		if(!file1.Open(m_FileOut,CFile::modeWrite |
					CFile::shareExclusive | CFile::modeCreate, &ex1))
		{
			TCHAR szError[1024];
			ex1.GetErrorMessage(szError,1024);
			AfxMessageBox(szError);
			return;
		}
		file1.Write(outdata,sizeof(complex<float>)*w*h);
		file1.Close();
		//
		delete[] data;
		delete[] outdata;
	}

	//
	EndWaitCursor();
	CDialog::OnOK();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧洲在线/亚洲| 久久这里只有精品6| 欧美一区二区三区性视频| 国产日韩影视精品| 日韩中文字幕av电影| 成人综合婷婷国产精品久久蜜臀| 欧美午夜在线一二页| 久久久久国产成人精品亚洲午夜| 亚洲一区二区三区四区在线| 国产电影精品久久禁18| 欧美日韩国产精选| ●精品国产综合乱码久久久久| 精品一区二区在线看| 欧美亚洲尤物久久| 国产精品国产自产拍高清av王其| 精品一区二区三区在线播放视频| 欧美日韩日本视频| 国产精品第一页第二页第三页| 激情五月婷婷综合网| 欧美日韩免费不卡视频一区二区三区| 国产精品妹子av| 国产精品一二一区| 精品国产乱码久久久久久老虎| 无码av中文一区二区三区桃花岛| 一本色道久久综合精品竹菊| 国产精品久久免费看| 精品一区二区三区在线播放 | 盗摄精品av一区二区三区| 精品视频一区二区三区免费| 亚洲精选视频在线| www.日韩大片| 国产精品久久福利| 成人免费不卡视频| 国产精品色婷婷| 成人18精品视频| 一区视频在线播放| 99久久国产综合精品麻豆| 国产精品成人免费在线| 成人免费视频app| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 青青草国产精品97视觉盛宴| 91精品国产一区二区三区香蕉| 日韩高清在线观看| 日韩精品自拍偷拍| 麻豆精品精品国产自在97香蕉| 欧美成人精品高清在线播放| 久久精品国产亚洲高清剧情介绍| 欧美成人国产一区二区| 极品少妇xxxx偷拍精品少妇| 久久久五月婷婷| www.爱久久.com| 一区二区三区四区视频精品免费 | 日韩精品在线看片z| 激情欧美日韩一区二区| 久久久一区二区三区| 国产91色综合久久免费分享| 亚洲欧美一区二区三区久本道91| 欧美在线视频全部完| 三级欧美在线一区| 久久午夜国产精品| 99视频在线精品| 午夜久久久久久电影| 久久综合精品国产一区二区三区| 成人黄页在线观看| 亚洲国产精品一区二区久久| 日韩精品专区在线影院重磅| 成人综合激情网| 亚洲va欧美va人人爽| 精品国产免费视频| 91在线国产福利| 麻豆精品在线视频| 国产精品日韩精品欧美在线| 欧美日韩国产首页在线观看| 国产麻豆视频精品| 一区二区三区四区视频精品免费| 精品粉嫩超白一线天av| 91香蕉视频mp4| 精品一区二区免费| 亚洲色图欧洲色图| 日韩欧美一级在线播放| 99re成人在线| 国内成人精品2018免费看| 最新高清无码专区| 精品入口麻豆88视频| aaa欧美大片| 激情成人综合网| 亚洲成人久久影院| 国产精品网站在线| 日韩一区二区在线播放| 99久久久久久99| 韩国三级中文字幕hd久久精品| 亚洲精品中文字幕乱码三区| 国产亚洲精品7777| 69堂亚洲精品首页| 色噜噜狠狠成人中文综合| 国产一区二区三区观看| 亚洲高清免费视频| 亚洲欧洲精品天堂一级| 精品国产区一区| 欧美一区二区三区视频免费播放| 色婷婷av一区二区三区软件| 国产精品一级在线| 久久精品久久99精品久久| 亚洲一二三区在线观看| 亚洲色欲色欲www| 国产精品入口麻豆原神| 久久久99精品久久| 欧美mv日韩mv国产网站| 欧美一区二区三区精品| 欧美日韩在线不卡| 色94色欧美sute亚洲13| 99久久精品免费看国产免费软件| 国产成人小视频| 国产一本一道久久香蕉| 激情五月激情综合网| 另类人妖一区二区av| 视频一区视频二区中文字幕| 亚洲成人综合在线| 亚洲一区在线视频观看| 夜夜精品视频一区二区| 亚洲自拍偷拍图区| 亚洲小说欧美激情另类| 亚洲成人免费av| 秋霞电影一区二区| 经典三级在线一区| 国产一区二区毛片| 国产成人在线视频免费播放| 成人听书哪个软件好| www.亚洲在线| 欧美色精品天天在线观看视频| 欧美日本一道本在线视频| 欧美剧情电影在线观看完整版免费励志电影 | 中日韩av电影| 国产精品久久久久9999吃药| 亚洲日本va午夜在线电影| 一区二区三区在线免费观看| 性久久久久久久久久久久| 青草国产精品久久久久久| 精品亚洲成a人在线观看 | 久久久国产精品麻豆| 国产精品私人影院| 亚洲乱码日产精品bd| 性做久久久久久免费观看| 另类专区欧美蜜桃臀第一页| 成人一区在线观看| 91极品视觉盛宴| 欧美成人a视频| 亚洲欧洲av色图| 秋霞午夜鲁丝一区二区老狼| 高清shemale亚洲人妖| 欧美最新大片在线看| 欧美mv和日韩mv国产网站| 国产精品美女视频| 日韩影院精彩在线| 粉嫩av一区二区三区粉嫩 | 亚洲va国产天堂va久久en| 久久99热狠狠色一区二区| 风间由美一区二区三区在线观看| 91久久精品一区二区| 欧美精三区欧美精三区| 国产日韩精品一区二区三区| 亚洲综合男人的天堂| 精品一区二区免费看| 91在线视频播放地址| 69精品人人人人| 日韩理论电影院| 国产一区视频网站| 欧美性猛片xxxx免费看久爱| 久久久久久日产精品| 亚洲国产精品一区二区久久恐怖片| 韩国v欧美v亚洲v日本v| 在线观看日韩av先锋影音电影院| 2020日本不卡一区二区视频| 亚洲一区二区三区四区在线免费观看| 国产精品18久久久| 欧美一区二区精品| 一区二区三区四区激情| 国产激情91久久精品导航| 欧美电影影音先锋| 自拍av一区二区三区| 国产麻豆91精品| 日韩欧美一区二区久久婷婷| 亚洲成人先锋电影| 91视频一区二区三区| 国产欧美日韩在线观看| 经典三级视频一区| 日韩视频在线永久播放| 亚洲bt欧美bt精品| 在线免费观看成人短视频| 国产精品乱码人人做人人爱| 国产精品资源在线| 精品国产免费一区二区三区香蕉| 日本欧美韩国一区三区| 欧美日韩小视频| 午夜电影网一区| 欧美日韩免费观看一区三区| 亚洲欧美国产毛片在线| 成人黄色综合网站| 国产精品三级久久久久三级| 成人午夜激情在线|