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

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

?? wavelet1ddlg.cpp

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

#include "stdafx.h"
#include "Wavelet1D.h"
#include "Wavelet1DDlg.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)
	virtual void OnOK();
	//}}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)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWavelet1DDlg dialog

// 參數初始化
CWavelet1DDlg::CWavelet1DDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CWavelet1DDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CWavelet1DDlg)
		// NOTE: the ClassWizard will add member initialization here
	m_bWavelet = FALSE;
	m_strBmpFile=_T("Sample.bmp");
	m_nDecomposeStage = 1;
	m_nDisplayStage   = 1;
    m_nFilterLen      = 6;
	m_nBinGate        =100;
	Data = NULL;
	DotData = NULL;
	//}}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_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CWavelet1DDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CWavelet1DDlg)
	DDX_Control(pDX, IDC_COMBO_DISPLAYSTAGE, m_combDisplayStage);
	DDX_Control(pDX, IDC_COMBO_FILTERLEN, m_combFilterLen);
	DDX_Control(pDX, IDC_COMBO_STAGE, m_combDecomposeStage);
	DDX_Control(pDX, IDC_EDIT_BMPFILE, m_editBmpFile);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CWavelet1DDlg, CDialog)
	//{{AFX_MSG_MAP(CWavelet1DDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_BMPFILE, OnBtnBmpFile)
	ON_BN_CLICKED(IDC_BUTTON_WAVELET1D, OnBtnWavelet1D)
	ON_CBN_SELCHANGE(IDC_COMBO_DISPLAYSTAGE, OnSelchangeCombDisplayStage)
	ON_CBN_EDITCHANGE(IDC_COMBO_DISPLAYSTAGE, OnEditchangeCombDisplayStage)
	ON_CBN_EDITCHANGE(IDC_COMBO_DECOMPOSESTAGE, OnEditchangeCombDecomposeStage)
	ON_CBN_EDITCHANGE(IDC_COMBO_FILTERLEN, OnEditchangeCombFilterLen)
	ON_CBN_EDITCHANGE(IDM_ABOUTBOX, OnEditchangeAboutbox)
	ON_EN_CHANGE(IDC_EDIT_BMPFILE, OnChangeEditBmpfile)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CWavelet1DDlg message handlers

BOOL CWavelet1DDlg::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

	// 初始化控件
	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);
	}
	strComb.Format("%d",1);
	m_combFilterLen.InsertString(0,strComb);
    m_combFilterLen.SetItemData(0,2);
	for(k=1;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);
	}

	m_combDisplayStage.EnableWindow(FALSE);

	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CWavelet1DDlg::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 CWavelet1DDlg::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();
    	if(m_bWavelet)
		   DrawWavelet1D();
	}
}

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

void CWavelet1DDlg::OnSelchangeCombDisplayStage() 
{
	m_nDisplayStage=m_combDisplayStage.GetItemData(m_combDisplayStage.GetCurSel());
	DrawWavelet1D();
}

void CWavelet1DDlg::OnEditchangeCombDisplayStage() 
{
	m_combDisplayStage.SetCurSel(1);	
}

void CWavelet1DDlg::OnEditchangeCombDecomposeStage() 
{
	m_combDecomposeStage.SetCurSel(0);
}

void CWavelet1DDlg::OnEditchangeCombFilterLen() 
{
    m_combFilterLen.SetCurSel(2);
}

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

// 確定退出
void CWavelet1DDlg::OnOK() 
{
	// 若已進行過小波變換,則所用資源
	if(m_bWavelet)
	{
	   ReleaseMemory();
	}	
	CDialog::OnOK();
}

// “一維小波變換”按鈕消息處理函數
// 功能:打開文件,分配內存,進行變換,繪制結果
void CWavelet1DDlg::OnBtnWavelet1D() 
{
	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;
	}
	// 若已進行過小波變換,則釋放上次變換所用資源
	if(m_bWavelet)
	{
	   ReleaseMemory();
	}
	// 讀取原始數據圖像文件
	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());

	//打開待處理圖像
	// 判斷是否是8-bpp位圖
	if (::DIBNumColors(lpDIB) > 256||m_nImageWidth>=400||m_nImageHeight>=300)
	{
		// 提示用戶
		AfxMessageBox(_T("不是256色位圖或者圖像過大!") , MB_ICONINFORMATION | MB_OK,NULL);
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) GetHDIB());
		return ;
	}
	// 得到原始數據圖像的寬度和高度
	m_nImageWidth=::DIBWidth(lpDIB);
	m_nImageHeight=::DIBHeight(lpDIB);	

	// 更改光標形狀
	BeginWaitCursor();
	// 找到DIB圖像象素起始位置
	lpDIBBits = ::FindDIBBits(lpDIB);
	// 得到小波變換所需的層次、濾波器長度等參數
	GetParam();
	// 獲取濾波器參數
	if(!GetHn())
		return;
	// 給Data數組分配內存
	if(!GetMemory())	
		return;
	// 將原始數據圖像二值化并投影,將其存儲到Data[0]中
	PrepareData();
	// 對Data[0]中數據進行小波變換
	Wavelet1D();
	// 繪制小波變換結果
	DrawWavelet1D();
 	// 解除鎖定
	::GlobalUnlock((HGLOBAL)GetHDIB());
	// 恢復光標
	EndWaitCursor();

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

// 得到小波變換所需的層次、濾波器長度等參數
void CWavelet1DDlg::GetParam()
{
	// 得到要進行小波變換的層次
	if(m_combDecomposeStage.GetCurSel()==CB_ERR)
	   m_nDecomposeStage=1;
	else
   	   m_nDecomposeStage=m_combDecomposeStage.GetItemData(m_combDecomposeStage.GetCurSel());
	// 得到濾波器長度	
	if(m_combFilterLen.GetCurSel()==CB_ERR)
	   m_nFilterLen=6;
	else
	   m_nFilterLen=m_combFilterLen.GetItemData(m_combFilterLen.GetCurSel());
    // 顯示第一層小波變換后的結果
    m_nDisplayStage=1;
    // 只有在進行小波變換后才能初始化顯示變換結果層次的Comb控件
	CString strComb;
	m_combDisplayStage.EnableWindow(TRUE);
    m_combDisplayStage.ResetContent();
	for(int k=0;k<=m_nDecomposeStage;k++)
	{
	    strComb.Format("%d",k);	    
		m_combDisplayStage.InsertString(k,strComb);
        m_combDisplayStage.SetItemData(k,k);
        m_combDisplayStage.SetCurSel(1);
	}
}

// 將原始數據圖像二值化并投影,將其存儲到Data[0]中
void CWavelet1DDlg::PrepareData()
{
    // 原始數據圖像二值化及垂直、水平方向投影
	// DotData[i]存放投影后一維待變換數據
	// Data[0][i]同DotData[i],存放投影后一維待變換數據
	// Data[1][i]存放一層小波變換后數據,依此類推
	int temp;
    int i,j;
    for(i=0;i<m_nImageHeight+m_nImageWidth;i++)
	    *(DotData+i)=0;
    for(i=0;i<m_nImageHeight;i++)
	   for(j=0;j<m_nImageWidth;j++)
	   {  
           temp=*((unsigned char *)lpDIBBits+m_nImageWidth*i+j);
		   if(temp<=m_nBinGate)
		   {
			  (*(DotData+i))++;
			  (*(DotData+m_nImageHeight+j))++;
			  *((unsigned char *)lpDIBBits+m_nImageWidth*i+j)=0;
		   }
		   else
		   {
			   *((unsigned char *)lpDIBBits+m_nImageWidth*i+j)=255;
		   }
	   }

	// 將二值化后圖像點陣投影數據讀入Data數組
	for(i=0;i<m_nImageHeight+m_nImageWidth;i++)
		Data[0][i]=DotData[i];	
}

// 一維小波變換
void CWavelet1DDlg::Wavelet1D()
{
     int i,j;
	 for(i=1;i<=m_nDecomposeStage;i++)
	 {
	     // 復制數據
		 for(j=0;j<(m_nImageWidth+m_nImageHeight);j++)
		     Data[i][j]=Data[i-1][j];
		 // 第i層小波變換
         if(!DecompStage(i,m_nFilterLen))
		 {
			 AfxMessageBox("變換失敗!",MB_OK|MB_ICONINFORMATION);
		     break;
		 }
	 }
}

// 得到濾波器參數
BOOL CWavelet1DDlg::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;
}

// 分配小波變換所需內存
BOOL CWavelet1DDlg::GetMemory()
{
    BOOL flag=TRUE;	
    Data=new double *[m_nImageHeight];
	for(int n=0;n<=m_nDecomposeStage;n++)
	{
		*(Data+n)=new double[sizeof(double)*m_nImageWidth];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美中文字幕一区二区三区亚洲| 在线观看免费成人| 91丨porny丨在线| 欧美一区二区三区思思人| 久久毛片高清国产| 亚洲va国产va欧美va观看| 国产一区二区不卡在线| 在线中文字幕不卡| 国产午夜精品久久久久久久| 午夜精品视频在线观看| av不卡免费在线观看| 日韩欧美一级片| 亚洲大尺度视频在线观看| 高清不卡在线观看| 日韩欧美国产综合一区| 亚洲资源在线观看| av资源网一区| 中文在线一区二区| 狠狠色综合日日| 91精品国产综合久久久久久久久久 | 一区二区三区不卡在线观看 | 国产成人免费网站| 欧美一二三区在线观看| 午夜日韩在线观看| 91黄色免费版| 亚洲一区二区三区在线播放| 99视频在线精品| 中文在线免费一区三区高中清不卡| 精品一区二区三区久久| 欧美一区二区三区四区在线观看 | 久久久久久久久久久久久女国产乱 | 欧美国产成人精品| 精东粉嫩av免费一区二区三区| 欧美日韩亚洲综合一区 | 奇米综合一区二区三区精品视频| 欧美丝袜丝交足nylons图片| 亚洲日本乱码在线观看| 99视频热这里只有精品免费| 中文幕一区二区三区久久蜜桃| 国产一区二区在线观看免费| 欧美成人一区二区| 精品一区二区成人精品| 欧美精品一区二区三区四区| 激情六月婷婷综合| 久久久亚洲精品石原莉奈| 国产毛片一区二区| 国产精品美女久久福利网站| 色婷婷综合久久久久中文| 亚洲一区二区不卡免费| 欧美日韩免费观看一区二区三区| 亚洲成人综合视频| 日韩一区二区影院| 国产一区二区三区四区五区入口| 国产日韩综合av| 99久久综合狠狠综合久久| 国产精品国产三级国产aⅴ入口 | 国内欧美视频一区二区| 久久久久久久久久看片| 99久久99久久精品免费观看| 亚洲一区二区中文在线| 日韩一级欧美一级| 福利电影一区二区三区| 亚洲激情自拍视频| 日韩欧美国产电影| 成人app软件下载大全免费| 一区二区在线免费| 91麻豆精品国产91久久久更新时间| 久久99蜜桃精品| 国产精品久久久久久久久晋中| 欧美中文字幕一区二区三区| 激情六月婷婷久久| 亚洲欧洲性图库| 欧美精品第1页| 国产精品一区在线| 亚洲人成网站色在线观看| 91精品欧美一区二区三区综合在| 国产精品亚洲а∨天堂免在线| 亚洲黄色性网站| 欧美一区二区女人| 97久久精品人人做人人爽50路| 丝袜亚洲精品中文字幕一区| 久久午夜免费电影| 欧美日韩综合在线免费观看| 成人免费的视频| 麻豆成人久久精品二区三区小说| 亚洲视频一二三区| 久久这里只有精品视频网| 在线观看亚洲专区| 国产精品影音先锋| 麻豆一区二区在线| 亚洲一区二区在线观看视频| 国产精品三级视频| 精品久久久久久久人人人人传媒 | 日韩视频在线一区二区| 色综合色狠狠综合色| 国产一区二区精品久久99| 天天爽夜夜爽夜夜爽精品视频| 国产精品免费aⅴ片在线观看| 欧美一区午夜视频在线观看| 色婷婷亚洲一区二区三区| 岛国精品在线播放| 国模少妇一区二区三区| 青椒成人免费视频| 午夜精品久久一牛影视| 亚洲一区二区在线观看视频| 亚洲品质自拍视频| 国产精品理伦片| 国产欧美一区二区精品性色 | 国产自产2019最新不卡| 日产国产高清一区二区三区| 亚洲福利视频一区二区| 亚洲一区视频在线| 亚洲精品乱码久久久久久 | 偷偷要91色婷婷| 一个色在线综合| 一区二区三区四区精品在线视频| 欧美激情中文字幕| 国产欧美日韩不卡免费| 国产日韩精品久久久| 国产蜜臀97一区二区三区| 中文字幕国产一区二区| 国产精品久久久久9999吃药| 国产精品女主播av| 亚洲婷婷综合色高清在线| 亚洲久本草在线中文字幕| 日韩一区中文字幕| 一区二区三区在线视频免费| 一区二区三区精密机械公司| 亚洲一区二区在线免费观看视频 | 欧美精品视频www在线观看| 欧美日韩小视频| 91麻豆精品国产91久久久久| 日韩美女主播在线视频一区二区三区| 欧美一区二区三区在线电影| 91精品国产免费| 精品成人一区二区三区| 国产亚洲视频系列| 国产精品盗摄一区二区三区| 亚洲综合网站在线观看| 免费成人你懂的| 高清不卡一区二区在线| 色婷婷亚洲综合| 日韩欧美在线一区二区三区| 久久网这里都是精品| 国产精品国产a| 五月天中文字幕一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产一区不卡精品| 91亚洲国产成人精品一区二三| 欧美系列一区二区| 欧美xxx久久| 亚洲欧洲精品一区二区三区| 亚洲不卡在线观看| 国产精品综合一区二区三区| 91网站在线观看视频| 欧美精品在线观看一区二区| 欧美国产欧美综合| 亚洲国产综合色| 国产成人av电影在线观看| 欧美中文字幕久久| 国产婷婷一区二区| 视频一区二区三区在线| 成人开心网精品视频| 91精品国产入口| 亚洲免费观看高清完整| 国内精品在线播放| 在线欧美一区二区| 欧美高清在线一区二区| 日本在线观看不卡视频| 91丨九色丨国产丨porny| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 欧美激情一区不卡| 日韩在线一二三区| 一本色道久久综合亚洲91| 日韩精品一区二区在线| 午夜婷婷国产麻豆精品| 不卡视频一二三四| 精品日本一线二线三线不卡| 亚洲一级电影视频| 99精品视频在线播放观看| 久久精品夜夜夜夜久久| 免费成人在线网站| 欧美日韩一级二级三级| 亚洲卡通欧美制服中文| 不卡一卡二卡三乱码免费网站| 欧美精品一区二区三区视频| 日韩av一区二区在线影视| 欧美色涩在线第一页| 亚洲人妖av一区二区| 国产aⅴ精品一区二区三区色成熟| 91麻豆精品国产91| 亚洲成人av中文| 欧美日韩日日摸| 亚洲国产精品精华液网站| 色综合久久久久综合99| 国产精品久久久久影院色老大 | 久久精品视频一区二区| 激情图片小说一区| 精品国产网站在线观看| 精品在线你懂的|