亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
成人av在线网| 日韩精品一区二区三区视频在线观看 | 国产精品嫩草影院com| 丝袜美腿亚洲一区| 91丨porny丨首页| 亚洲三级电影网站| 欧美韩日一区二区三区| 国产麻豆欧美日韩一区| 国产精品久久久久三级| av中文字幕不卡| 亚洲图片欧美色图| 日韩亚洲欧美在线| 高清av一区二区| 洋洋成人永久网站入口| 欧美精品自拍偷拍| 国产精品1024| 午夜精品一区在线观看| 欧美mv和日韩mv的网站| 成人av在线播放网站| 免费视频一区二区| 国产欧美日韩在线看| 色婷婷久久99综合精品jk白丝| 亚洲影院理伦片| 精品对白一区国产伦| 色综合天天在线| 国产精品123区| 看片的网站亚洲| 国产一区二区三区观看| 在线观看日韩av先锋影音电影院| 成人综合在线观看| av电影在线观看一区| 在线视频综合导航| 欧美一级理论片| 久久久久免费观看| 日韩欧美一区二区久久婷婷| 欧美亚洲自拍偷拍| 色系网站成人免费| 色综合久久综合网97色综合 | 欧美人妇做爰xxxⅹ性高电影| 成人免费高清视频| 成人毛片视频在线观看| 免费观看30秒视频久久| 免费成人在线视频观看| 日韩电影网1区2区| 日韩国产在线观看一区| 午夜伦理一区二区| 麻豆国产91在线播放| 久久99国产精品免费网站| 午夜精品一区二区三区免费视频| 一区二区三区高清| 伊人夜夜躁av伊人久久| 亚洲欧美国产高清| 亚洲一区二区在线观看视频| 亚洲一区二区av在线| 日韩高清不卡一区二区| 蜜臀av国产精品久久久久| 国产不卡视频一区二区三区| 国产乱子轮精品视频| av中文字幕在线不卡| 欧美日韩一级二级| 久久久久久综合| 亚洲乱码一区二区三区在线观看| 亚洲一级二级三级| 久久国内精品自在自线400部| 国产九色sp调教91| 欧美无砖专区一中文字| 国产成人精品1024| 在线观看亚洲成人| 久久久久久久久久久黄色| 亚洲日本韩国一区| 美腿丝袜一区二区三区| 色8久久人人97超碰香蕉987| 国产日韩精品一区二区三区在线| 一区二区三区加勒比av| 国产一区二区三区免费在线观看| 欧美日韩一区二区三区四区五区 | 亚洲欧洲一区二区三区| 裸体一区二区三区| 日韩欧美色电影| 蜜臀久久99精品久久久画质超高清 | 在线观看成人免费视频| 国产日韩欧美制服另类| 久久99在线观看| 日韩一区和二区| 午夜亚洲福利老司机| 一本大道av一区二区在线播放| 久久久国产精华| 国产成人免费av在线| 久久欧美中文字幕| 成人一区二区三区中文字幕| 国产午夜精品久久| 成人一级黄色片| 国产精品天干天干在观线| 国产成人在线网站| 欧美国产一区视频在线观看| 成人成人成人在线视频| 亚洲另类在线一区| 欧美精品在线观看播放| 青青草原综合久久大伊人精品优势| 欧美日韩国产区一| 麻豆精品视频在线观看视频| 国产丝袜在线精品| 国产福利91精品一区| 中文字幕av一区 二区| 97成人超碰视| 奇米综合一区二区三区精品视频 | 成人精品免费视频| 亚洲成人一区二区| 久久久亚洲精华液精华液精华液| 国产**成人网毛片九色| 亚洲国产精品久久久久婷婷884| 欧美午夜精品久久久久久孕妇| 亚瑟在线精品视频| 国产清纯白嫩初高生在线观看91| 色噜噜狠狠色综合中国| 日韩成人精品视频| 国产精品久久久久久久久免费桃花| 色偷偷88欧美精品久久久| 黑人巨大精品欧美黑白配亚洲| 亚洲桃色在线一区| 久久美女高清视频| 91精品国产综合久久精品麻豆| 成人免费毛片aaaaa**| 强制捆绑调教一区二区| 亚洲视频 欧洲视频| 精品美女被调教视频大全网站| 欧美日韩中文字幕一区| av成人老司机| 国产不卡在线一区| 国产又黄又大久久| 久久国产夜色精品鲁鲁99| 亚洲一区二区av电影| 一区二区欧美在线观看| 中文字幕电影一区| 国产精品久久久久影院老司| 精品日产卡一卡二卡麻豆| 欧美美女网站色| 欧美精品一二三区| 欧美日韩情趣电影| 欧美日韩一区二区三区高清| 91在线丨porny丨国产| 99久久精品国产观看| 成人va在线观看| 色又黄又爽网站www久久| 色视频成人在线观看免| 日本韩国欧美在线| 欧美网站大全在线观看| 日韩欧美国产一区二区三区| 久久综合久久久久88| 中文av一区特黄| 亚洲国产乱码最新视频| 美女网站视频久久| 成人av网站大全| 欧美午夜片在线观看| 欧美哺乳videos| 国产精品成人免费在线| 午夜婷婷国产麻豆精品| 国产乱码字幕精品高清av| 97se亚洲国产综合自在线| 欧美日韩你懂得| 日本一区二区三区国色天香| 欧美激情在线观看视频免费| 五月综合激情网| eeuss鲁片一区二区三区在线观看| 欧美亚洲日本一区| 日本一区二区三区在线不卡| 亚洲观看高清完整版在线观看| 国产风韵犹存在线视精品| 欧美色视频一区| 国产精品天天看| 国产一区二区福利| 日韩一级免费观看| 亚洲午夜久久久久中文字幕久| 国产成人在线看| 日韩西西人体444www| 午夜视频在线观看一区二区三区| 91色九色蝌蚪| 国产精品久久久久婷婷| 国产精品一区在线| 久久亚洲精精品中文字幕早川悠里| 亚洲成人av一区二区三区| 在线欧美一区二区| 亚洲图片你懂的| 一本久久精品一区二区| 欧美mv日韩mv国产网站app| 五月天视频一区| 欧美疯狂性受xxxxx喷水图片| 亚洲精品免费一二三区| 色综合一区二区| 一区二区三区欧美在线观看| 在线一区二区三区| 亚洲成人午夜影院| 欧美日韩亚洲综合一区二区三区| 亚洲mv在线观看| 精品久久久久一区| 国产成人免费视频网站高清观看视频 | 精品国产露脸精彩对白| 国产成人一区二区精品非洲| 国产精品青草综合久久久久99| 成人av电影在线观看|