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

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

?? wavelet2ddlg.cpp

?? Good idea, realization wavelet algorithm
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Wavelet2DDlg.cpp : implementation file
//

#include "stdafx.h"
#include "Wavelet2D.h"
#include "Wavelet2DDlg.h"
#include "ColorTable.h"
#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()

/////////////////////////////////////////////////////////////////////////////
// CWavelet2DDlg dialog

CWavelet2DDlg::CWavelet2DDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CWavelet2DDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CWavelet2DDlg)
		// NOTE: the ClassWizard will add member initialization here
	m_bWavelet = FALSE;
	m_strBmpFile=_T("Sample.bmp");
	m_nDecomposeStage = 1;
	m_nFilterLen      = 6;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_strFilterFile[0]="h1.dat";
	m_strFilterFile[1]="h2.dat";	
	m_strFilterFile[2]="h3.dat";
	m_strFilterFile[3]="h4.dat";
	m_strFilterFile[4]="h5.dat";
	m_strFilterFile[5]="h6.dat";
	m_strFilterFile[6]="h7.dat";
	m_strFilterFile[7]="h8.dat";
	m_strFilterFile[8]="h9.dat";
	m_strFilterFile[9]="h10.dat";

	m_pBmpInfo = (BITMAPINFO *)malloc(2048);
	if(m_pBmpInfo)
	{
		m_pBmpInfo->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
		m_pBmpInfo->bmiHeader.biWidth = m_nImageWidth;
		m_pBmpInfo->bmiHeader.biHeight = m_nImageHeight;
		m_pBmpInfo->bmiHeader.biPlanes = 1;
		m_pBmpInfo->bmiHeader.biBitCount = 8;
		m_pBmpInfo->bmiHeader.biCompression = BI_RGB;
		m_pBmpInfo->bmiHeader.biSizeImage = 0;
		m_pBmpInfo->bmiHeader.biXPelsPerMeter = 0;
		m_pBmpInfo->bmiHeader.biYPelsPerMeter = 0;
		m_pBmpInfo->bmiHeader.biClrUsed = 0;
		m_pBmpInfo->bmiHeader.biClrImportant = 0;
		for( int k = 0; k < 256; ++k){
			m_pBmpInfo->bmiColors[k].rgbBlue = (BYTE)k;
			m_pBmpInfo->bmiColors[k].rgbGreen = (BYTE)k;
			m_pBmpInfo->bmiColors[k].rgbRed = (BYTE)k;
			m_pBmpInfo->bmiColors[k].rgbReserved	= 0;
		}
	}

	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CWavelet2DDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CWavelet2DDlg)
	DDX_Control(pDX, IDC_EDIT_BMPFILE, m_editBmpFile);
	DDX_Control(pDX, IDC_COMBO_FILTERLEN, m_combFilterLen);
	DDX_Control(pDX, IDC_COMBO_DECOMPOSESTAGE, m_combDecomposeStage);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CWavelet2DDlg, CDialog)
	//{{AFX_MSG_MAP(CWavelet2DDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_WAVELET2D, OnBtnWavelet2D)
	ON_BN_CLICKED(IDC_BUTTON_BMPFILE, OnBtnBmpFile)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWavelet2DDlg message handlers

BOOL CWavelet2DDlg::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
	
	// 初始化控件
	m_editBmpFile.SetWindowText(m_strBmpFile);
	CString strComb;
	int k=0;
	for(k=0;k<6;k++)
	{ 
	    strComb.Format("%d",k+1);
	    m_combDecomposeStage.InsertString(k,strComb);
        m_combDecomposeStage.SetItemData(k,k+1);
        m_combDecomposeStage.SetCurSel(0);
	}
	for(k=0;k<10;k++)
	{ 
	    strComb.Format("%d",2*(k+1));
	    m_combFilterLen.InsertString(k,strComb);
        m_combFilterLen.SetItemData(k,2*(k+1));
        m_combFilterLen.SetCurSel(2);
	}
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CWavelet2DDlg::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 CWavelet2DDlg::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
	{
		if(m_bWavelet)
		   OnBtnWavelet2D();
		CDialog::OnPaint();
	}
}

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

// 選擇原始數據圖像文件
void CWavelet2DDlg::OnBtnBmpFile() 
{
	CFileDialog BmpFileDlg(TRUE,"bmp","*.bmp");
	if(BmpFileDlg.DoModal()==IDOK)
	{
	   m_bWavelet=FALSE;
		m_strBmpFile=BmpFileDlg.GetPathName();
	   m_editBmpFile.SetWindowText(m_strBmpFile);
	}	
}

// “二維小波變換”按鈕消息處理函數
// 功能:打開文件,分配內存,進行變換,繪制結果
void CWavelet2DDlg::OnBtnWavelet2D() 
{
	CFile BmpFile;
	CFileException fe;
	// 打開原始圖像數據
	if(m_strBmpFile.IsEmpty())
	{	
		AfxMessageBox (_T("請選擇一個位圖(*.bmp)文件!"),MB_ICONINFORMATION|MB_OK,NULL);
	    return;
	}
	if(!BmpFile.Open(m_strBmpFile,CFile::modeRead,&fe))
	{	
		AfxMessageBox (_T("打開文件失敗!"),MB_ICONINFORMATION|MB_OK,NULL);
	    return;
	}
	// 讀取原始數據圖像文件
	TRY
	{
		DIB = ::ReadDIBFile(BmpFile);
	}
	CATCH (CFileException, eLoad)
	{		
		BmpFile.Abort();	// 讀取失敗			
		AfxMessageBox (_T("讀取數據失敗!"),MB_ICONINFORMATION|MB_OK,NULL);		
		DIB = NULL;         // 設置DIB為空
		return ;
	}
	END_CATCH	
    
	// 鎖定DIB
	lpDIB = (LPSTR)::GlobalLock((HGLOBAL)GetHDIB());
	// 得到圖像寬度和高度
	m_nImageWidth=::DIBWidth(lpDIB);
	m_nImageHeight=::DIBHeight(lpDIB);

	// 打開待處理圖像
	// 判斷是否是8-bpp位圖
	if (::DIBNumColors(lpDIB) > 256||m_nImageWidth>400||m_nImageHeight>400)
	{
		// 提示用戶
		AfxMessageBox(_T("不是256色位圖或者圖像過大!") , MB_ICONINFORMATION | MB_OK,NULL);
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) GetHDIB());
		return;
	}

	// 更改光標形狀
	BeginWaitCursor();
	// 找到DIB圖像象素起始位置
	lpDIBBits = ::FindDIBBits(lpDIB);
	// 得到小波變換所需的層次、濾波器長度等參數
	GetParam();	
	// 獲取濾波器參數
	if(!GetHn())
		return;
    // 繪制原始圖像
    DrawOriginalBmp();
    // 給image數組分配內存
	if(!GetMemory())	
		return;
	// 將圖像數據讀入image數組
	for(int i=0;i<m_nImageHeight;i++)
		for(int j=0;j<m_nImageWidth;j++)
		    image[i][j]=(unsigned char)(*((unsigned char *)lpDIBBits+m_nImageWidth*i+j));
     
	// 對圖像進行二維小波變換
	Wavelet2D();
	// 繪制二維小波變換后的圖像
	DrawWavelet2D();
	// 釋放資源	
	ReleaseMemory();
 	// 解除鎖定
	::GlobalUnlock((HGLOBAL) GetHDIB());
	// 恢復光標
	EndWaitCursor();

    // 設置已進行過小波變換標志
	m_bWavelet=TRUE;
}

// 確定退出函數
void CWavelet2DDlg::OnOK() 
{
	if(m_pBmpInfo)
		free(m_pBmpInfo);	

	CDialog::OnOK();
}

// 分配小波變換所需內存
BOOL CWavelet2DDlg::GetMemory()
{
    BOOL flag=TRUE;
	
    image=new double *[m_nImageHeight];
	for(int n=0;n<m_nImageHeight;n++)
	{
		*(image+n)=new double[sizeof(double)*m_nImageWidth];
	    if(*(image+n)==NULL)
		   flag=FALSE;
	}
	tempRow=new double[sizeof(double)*m_nImageWidth];
	tempCol=new double[sizeof(double)*m_nImageHeight];
	if(tempRow==NULL||tempCol==NULL)
		flag=FALSE;
    return flag;
}

// 釋放資源
void CWavelet2DDlg::ReleaseMemory()
{
	for(int k=0;k<m_nImageHeight;k++)
	  delete *(image+k);
    delete []image; 
	delete tempCol;
	delete tempRow;
	image=NULL;
	tempCol=NULL;
	tempRow=NULL;
	if(DIB)
	{ 
	   ::GlobalFree((HGLOBAL) DIB);
	   DIB=NULL;
	}
}

// 得到濾波器參數
BOOL CWavelet2DDlg::GetHn()
{

     int i;
	 double temp1;
	 FILE *fp1;
	 if((fp1=fopen(m_strFilterFile[m_nFilterLen/2-1],"rb+"))==NULL)
	 {
	    AfxMessageBox("打開Hn數據文件失敗!",MB_OK|MB_ICONINFORMATION);
		return FALSE;
	 }
	 for(i=0;i<30;i++)
		 h[i]=0;
	 for(i=0;i<m_nFilterLen;i++)
	 {
	    fread(&temp1,sizeof(double),1,fp1);
		h[i]=temp1;
	 }
	 fclose(fp1);
     return TRUE;
}

//返回H算子周期化后得值
double CWavelet2DDlg::HH(int i,int m)
{
     return h[i+m];

}

//返回G算子周期化后的值
double CWavelet2DDlg::GG(int i, int m)
{
     char flag;
	 if(i%2)
		 flag=-1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂在线一区二区| 日日噜噜夜夜狠狠视频欧美人| 日韩精品一区二区三区中文不卡| 欧美三级乱人伦电影| 色老综合老女人久久久| 99re视频精品| 91麻豆免费视频| 一本色道久久综合精品竹菊| 91视频精品在这里| 日本精品免费观看高清观看| 一本到不卡精品视频在线观看| 91麻豆蜜桃一区二区三区| 欧美在线观看18| 精品视频一区二区三区免费| 91精品免费观看| 88在线观看91蜜桃国自产| 91啪亚洲精品| 精品视频在线看| 日韩免费看的电影| 午夜电影一区二区| 99精品久久久久久| 99热国产精品| 色嗨嗨av一区二区三区| 欧美曰成人黄网| 欧美二区在线观看| 精品成人一区二区三区四区| 国产清纯美女被跳蛋高潮一区二区久久w| 国产视频视频一区| 亚洲日本青草视频在线怡红院| 日韩码欧中文字| 亚洲制服欧美中文字幕中文字幕| 日产国产欧美视频一区精品| 精品一区二区三区在线视频| 高清国产一区二区三区| 欧美在线影院一区二区| 欧美成人bangbros| 中文字幕一区二区三区在线播放 | 亚洲欧美日韩久久| 午夜精品影院在线观看| 激情伊人五月天久久综合| 成人国产精品视频| 欧美中文字幕不卡| 久久天天做天天爱综合色| 久久综合九色综合欧美98| 不卡一区二区在线| 欧美理论在线播放| 久久一区二区视频| 亚洲一区二区三区中文字幕在线| 亚洲成av人**亚洲成av**| 国产一区二区电影| 欧洲一区二区三区在线| wwww国产精品欧美| 一区二区三区欧美激情| 国内精品在线播放| 欧美三级视频在线| 中文字幕欧美国产| 天天色天天操综合| 不卡av电影在线播放| 欧美一区二区视频免费观看| 亚洲视频图片小说| 久久av中文字幕片| 欧美日韩免费不卡视频一区二区三区| 精品捆绑美女sm三区| 一区二区三区蜜桃网| 国产成人免费9x9x人网站视频| 欧美日韩一区二区三区四区| 国产精品美女久久久久aⅴ| 捆绑紧缚一区二区三区视频 | 欧美成人一区二区三区在线观看 | 日韩欧美成人一区二区| 国产精品国产自产拍在线| 石原莉奈在线亚洲二区| 色综合天天性综合| 久久久久国产精品麻豆ai换脸| 亚洲成av人片在线观看| 成人动漫一区二区在线| 欧美精品一区二区精品网| 婷婷成人综合网| 日本黄色一区二区| 国产精品久久久久久久久图文区 | 欧美精品久久久久久久多人混战| 国产精品久久久久久久久动漫| 精品一区二区日韩| 日韩三级视频在线看| 午夜一区二区三区视频| 日本高清视频一区二区| 亚洲免费观看高清完整版在线观看 | www欧美成人18+| 日本系列欧美系列| 欧美一级欧美三级在线观看| 亚洲欧洲日韩av| 高清国产午夜精品久久久久久| 久久这里都是精品| 精品无人区卡一卡二卡三乱码免费卡| 欧美疯狂做受xxxx富婆| 亚洲五码中文字幕| 欧美丝袜丝nylons| 亚洲国产va精品久久久不卡综合| 色婷婷国产精品| 一区二区三区欧美亚洲| 在线观看av不卡| 亚洲成人免费在线观看| 欧美三级蜜桃2在线观看| 亚洲成人动漫在线免费观看| 91丨九色丨蝌蚪丨老版| 亚洲色图都市小说| 91久久精品一区二区二区| 日韩美女视频19| 色婷婷久久一区二区三区麻豆| 亚洲精品欧美激情| 91黄色免费看| 一区二区三区久久| 色呦呦日韩精品| 亚洲国产精品影院| 91精品国产综合久久久久久漫画| 日本网站在线观看一区二区三区| 欧美一区二区三区免费大片 | 久久精品亚洲一区二区三区浴池 | 日本一区二区三级电影在线观看 | 日韩欧美激情在线| 国产伦精品一区二区三区免费迷| 亚洲精品在线一区二区| 国产精品自拍一区| 亚洲人成网站影音先锋播放| 精品污污网站免费看| 美国精品在线观看| 久久女同性恋中文字幕| a美女胸又www黄视频久久| 伊人夜夜躁av伊人久久| 制服丝袜亚洲色图| 国产一区二区剧情av在线| 国产精品久久久久久久第一福利 | 欧美激情一区不卡| 色综合色综合色综合色综合色综合| 亚洲午夜精品一区二区三区他趣| 在线精品视频免费播放| 青青草原综合久久大伊人精品优势| 精品久久人人做人人爰| 成人高清免费观看| 亚洲成人av免费| 26uuu成人网一区二区三区| 99久久精品国产精品久久| 亚洲成a天堂v人片| 欧美国产日本视频| 欧美四级电影在线观看| 国产一区免费电影| 亚洲精品国产第一综合99久久 | 日韩一区二区三区四区| 成人永久看片免费视频天堂| 一区二区在线电影| 欧美变态tickle挠乳网站| 色综合久久88色综合天天6| 美女一区二区三区| 亚洲色图在线播放| 精品国产一区二区三区四区四| 色婷婷激情久久| 国产精品一卡二卡在线观看| 亚洲一区二区三区四区五区黄 | 午夜日韩在线观看| 亚洲国产精品成人综合| 日韩一区二区高清| 色狠狠综合天天综合综合| 国产一区二区三区免费看| 一区二区三区欧美| 国产人妖乱国产精品人妖| 91精品国产入口在线| 97超碰欧美中文字幕| 精品系列免费在线观看| 婷婷丁香久久五月婷婷| 亚洲裸体xxx| 欧美国产成人精品| 欧美成人女星排名| 欧美群妇大交群的观看方式| www.久久精品| 日韩欧美二区三区| 91精彩视频在线| 福利91精品一区二区三区| 日韩精品电影一区亚洲| 亚洲青青青在线视频| 日本一区二区不卡视频| 精品国产乱码久久久久久蜜臀| 欧美日韩免费观看一区三区| 99久久夜色精品国产网站| 国产精品一二三| 九九久久精品视频| 免费在线观看成人| 日本亚洲欧美天堂免费| 午夜精品一区在线观看| 亚洲自拍与偷拍| 亚洲免费av高清| 亚洲视频狠狠干| 中文字幕在线一区免费| 亚洲国产成人自拍| 欧美国产日韩精品免费观看| 国产亚洲精品7777| 国产欧美一区二区三区沐欲| 337p日本欧洲亚洲大胆精品| 欧美不卡一区二区| wwwwww.欧美系列| 久久精品综合网|