⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 神经网络作业view.cpp

📁 运用BP网络实现三个二进制位的异或运算,带有样本库可编译运行
💻 CPP
字号:
// 神经网络作业View.cpp : implementation of the CMyView class
//

#include "stdafx.h"
#include "神经网络作业.h"

#include "神经网络作业Doc.h"
#include "神经网络作业View.h"
#include "BmpProc.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMyView

IMPLEMENT_DYNCREATE(CMyView, CScrollView)

BEGIN_MESSAGE_MAP(CMyView, CScrollView)
	//{{AFX_MSG_MAP(CMyView)
	ON_COMMAND(ID_IMG_ADJUST, OnImgAdjust)
	ON_COMMAND(ID_IMG_CONPAI, OnImgConpai)
	ON_COMMAND(ID_IMG_DENOISE, OnImgDenoise)
	ON_COMMAND(ID_IMG_DIVIDE, OnImgDivide)
	ON_COMMAND(ID_IMG_SHARP, OnImgSharp)
	ON_COMMAND(ID_IMG_STANDARIZE, OnImgStandarize)
	ON_COMMAND(ID_IMG_TOGRAY, OnImgTogray)
	ON_COMMAND(ID_IMG_WBLAC, OnImgWblac)
	ON_COMMAND(ID_NEUNET_RECOGNIZE, OnNeunetRecognize)
	ON_COMMAND(ID_NEUNET_TRAIN, OnNeunetTrain)
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CMyView construction/destruction

CMyView::CMyView()
{
	// TODO: add construction code here

}

CMyView::~CMyView()
{
}

BOOL CMyView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CMyView drawing

void CMyView::OnDraw(CDC* pDC)
{
	// 显示等待光标
	BeginWaitCursor();
	
	// 获取文档
	CMyDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	
	// 获取DIB
	HDIB hDIB = pDoc->GetHDIB();
	
	// 判断DIB是否为空
	if (hDIB != NULL)
	{
		LPBYTE lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);
		
		// 获取DIB宽度
		int cxDIB = (int) pDoc->m_clsDIB.DIBWidth(lpDIB);
		
		// 获取DIB高度
		int cyDIB = (int) pDoc->m_clsDIB.DIBHeight(lpDIB);

		::GlobalUnlock((HGLOBAL) hDIB);
		
		CRect rcDIB;
		rcDIB.top = rcDIB.left = 0;
		rcDIB.right = cxDIB;
		rcDIB.bottom = cyDIB;
		
		CRect rcDest;
		
		// 判断是否是打印
		if (pDC->IsPrinting())
		{
			// 是打印,计算输出图像的位置和大小,以便符合页面
			
			// 获取打印页面的水平宽度(象素)
			int cxPage = pDC->GetDeviceCaps(HORZRES);
			
			// 获取打印页面的垂直高度(象素)
			int cyPage = pDC->GetDeviceCaps(VERTRES);
			
			// 获取打印机每英寸象素数
			int cxInch = pDC->GetDeviceCaps(LOGPIXELSX);
			int cyInch = pDC->GetDeviceCaps(LOGPIXELSY);
			
			// 计算打印图像大小(缩放,根据页面宽度调整图像大小)
			rcDest.top = rcDest.left = 0;
			rcDest.bottom = (int)(((double)cyDIB * cxPage * cyInch) / ((double)cxDIB * cxInch));
			rcDest.right = cxPage;
			
			// 计算打印图像位置(垂直居中)
			int temp = cyPage - (rcDest.bottom - rcDest.top);
			rcDest.bottom += temp/2;
			rcDest.top += temp/2;
		}
		else // 非打印
		{
			// 不必缩放图像
			rcDest = rcDIB;
		}
		// 输出DIB
		pDoc->m_clsDIB.PaintDIB(pDC->m_hDC, &rcDest, pDoc->GetHDIB(),
			&rcDIB, pDoc->GetDocPalette());
	}
	// 恢复正常光标
	EndWaitCursor();
}

void CMyView::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();

	CSize sizeTotal;
	// TODO: calculate the total size of this view
	sizeTotal.cx = sizeTotal.cy = 100;
	SetScrollSizes(MM_TEXT, sizeTotal);
}

/////////////////////////////////////////////////////////////////////////////
// CMyView printing

BOOL CMyView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

void CMyView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CMyView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CMyView diagnostics

#ifdef _DEBUG
void CMyView::AssertValid() const
{
	CScrollView::AssertValid();
}

void CMyView::Dump(CDumpContext& dc) const
{
	CScrollView::Dump(dc);
}

CMyDoc* CMyView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMyDoc)));
	return (CMyDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMyView message handlers

void CMyView::OnImgAdjust() 
{
	// 获取文档
	CMyDoc* pDoc = GetDocument();

	// 进行灰度转化
	CBmpProc clsGrayProc;
	clsGrayProc.Adjust(pDoc->GetHDIB());
	
	// 重画视图
	Invalidate();

	// 设置脏标记
	pDoc->SetModifiedFlag(TRUE);
	
	
}

void CMyView::OnImgConpai() 
{
	// TODO: Add your command handler code here
	
}

void CMyView::OnImgDenoise() 
{
	// 获取文档
	CMyDoc* pDoc = GetDocument();

	// 进行灰度转化
	CBmpProc clsGrayProc;
	clsGrayProc.Denoise(pDoc->GetHDIB());
	
	// 重画视图
	Invalidate();

	// 设置脏标记
	pDoc->SetModifiedFlag(TRUE);
	
}

void CMyView::OnImgDivide() 
{
	// TODO: Add your command handler code here
	
}

void CMyView::OnImgSharp() 
{
	// 获取文档
	CMyDoc* pDoc = GetDocument();

	// 进行灰度转化
	CBmpProc clsGrayProc;
	clsGrayProc.Sharp(pDoc->GetHDIB());
	
	// 重画视图
	Invalidate();

	// 设置脏标记
	pDoc->SetModifiedFlag(TRUE);
	
}

void CMyView::OnImgStandarize() 
{
	// TODO: Add your command handler code here
	
}

void CMyView::OnImgTogray() 
{
	// 获取文档
	CMyDoc* pDoc = GetDocument();

	// 进行灰度转化
	CBmpProc clsGrayProc;
	clsGrayProc.ToGray(pDoc->GetHDIB());
	
	// 重画视图
	Invalidate();

	// 设置脏标记
	pDoc->SetModifiedFlag(TRUE);
	
}

void CMyView::OnImgWblac() 
{
	// 获取文档
	CMyDoc* pDoc = GetDocument();

	// 进行灰度转化
	CBmpProc clsGrayProc;
	clsGrayProc.ConvertToWBlk(pDoc->GetHDIB());
	
	// 重画视图
	Invalidate();

	// 设置脏标记
	pDoc->SetModifiedFlag(TRUE);
	
}

void CMyView::OnNeunetRecognize() 
{
	// TODO: Add your command handler code here
	
}

void CMyView::OnNeunetTrain() 
{
	// TODO: Add your command handler code here
	
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -