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

📄 dlghistogram.cpp

📁 一般的论文 毕业用的 有很大的用处
💻 CPP
字号:
// DlgHistogram.cpp : implementation file
//

#include "stdafx.h"
#include "TAO.h"
#include "DlgHistogram.h"

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

/////////////////////////////////////////////////////////////////////////////
// CDlgHistogram dialog


CDlgHistogram::CDlgHistogram(CWnd* pParent /*=NULL*/)
	: CDialog(CDlgHistogram::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDlgHistogram)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
}


void CDlgHistogram::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDlgHistogram)
		// NOTE: the ClassWizard will add DDX and DDV calls here
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CDlgHistogram, CDialog)
	//{{AFX_MSG_MAP(CDlgHistogram)
	ON_BN_CLICKED(IDC_HISTOGRAM, OnHistogram)
	ON_WM_PAINT()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDlgHistogram message handlers
void CDlgHistogram::OnHistogram()
{

}

 

void CDlgHistogram::OnPaint()
{
	CPaintDC dc(this); // device context for painting
	
	CWnd* pWnd = GetDlgItem(IDC_HISTOGRAM);// 获取绘制坐标的文本框
	
	CString str;// 字符串		
	long i;// 循环变量		
	long lMaxCount = 0;// 最大计数				
	CDC* pDC = pWnd->GetDC();// 指针

	pWnd->Invalidate();
	pWnd->UpdateWindow();	
	pDC->Rectangle(0,0,310,300);


	CPen* pPenGreen = new CPen;// 创建画笔对象		
	pPenGreen->CreatePen(PS_SOLID,2,RGB(0,160,0));// 绿色画笔
	
	CPen* pPenBlue = new CPen;// 创建画笔对象		
	pPenBlue->CreatePen(PS_SOLID,2,RGB(0,0, 255));// 蓝色画笔
	
	CGdiObject* pOldPen = pDC->SelectObject(pPenBlue);// 选中当前绿色画笔,并保存以前的画笔
	
	pDC->MoveTo(10,10);// 绘制坐标轴	
	pDC->LineTo(10,280);// 垂直轴		
	pDC->LineTo(300,280);// 水平轴	
	
	str.Format("0");// 写X轴刻度值
	pDC->TextOut(10, 283, str);
	str.Format("50");
	pDC->TextOut(60, 283, str);
	str.Format("100");
	pDC->TextOut(110, 283, str);
	str.Format("150");
	pDC->TextOut(160, 283, str);
	str.Format("200");
	pDC->TextOut(210, 283, str);
	str.Format("255");
	pDC->TextOut(265, 283, str);
	
	for (i = 0; i < 256; i += 5)// 绘制X轴刻度
	{
		if ((i & 1) == 0)
		{
			pDC->MoveTo(i + 10, 280);// 10的倍数
			pDC->LineTo(i + 10, 284);
		}
		else
		{		
			pDC->MoveTo(i + 10, 280);
			pDC->LineTo(i + 10, 282);
		}
	}		
	pDC->MoveTo(295,275);// 绘制X轴箭头
	pDC->LineTo(300,280);
	pDC->LineTo(295,285);	
	
	pDC->MoveTo(10,10);// 绘制Y轴箭头
	pDC->LineTo(5,15);
	pDC->MoveTo(10,10);
	pDC->LineTo(15,15);
	
	for (i =0; i <=255; i ++)// 计算最大计数值
	{		
		if (m_DibCount[i] > lMaxCount)//是否大于当前最大值
		{			
			lMaxCount = m_DibCount[i];// 更新最大值
		}
	}	
	pDC->MoveTo(10, 25);// 输出最大计数值
	pDC->LineTo(14, 25);
	str.Format("%d", lMaxCount);
	pDC->TextOut(11, 26, str);	
	
	
	str.Format("图象的灰度直方图");//输出标题
	pDC->TextOut(185, 5, str);	
	
	pDC->SelectObject(pPenGreen);// 更改成蓝色画笔	
	
	if (lMaxCount > 0)// 判断是否有计数
	{		
		for (i = 0; i <= 255; i ++)// 绘制直方图
		{
			pDC->MoveTo(i + 10, 280);
			pDC->LineTo(i + 10, 281 - (int) (m_DibCount[i] * 256 / lMaxCount));
		}
	}		
	pDC->SelectObject(pOldPen);	// 恢复旧画笔		
	delete pPenGreen;// 删除新建的画笔对象
	delete pPenBlue;
	// TODO: Add your message handler code here
	
	// Do not call CDialog::OnPaint() for painting messages
}

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


	unsigned char * lpDibSrc;
	int i;
	int j;
	CWnd* pWnd = GetDlgItem(IDC_HISTOGRAM);

	for ( i=0;i<256;i++)
	{
		m_DibCount[i]=0;
	}

	for (i = 0; i < m_Hight; i ++)// 各灰度值的计数
	{
		for (j = 0; j < m_Width; j ++)
		{
			lpDibSrc = (unsigned char *)m_StartBits + m_Width * i + j;						
			m_DibCount[*(lpDibSrc)]++;// 加1
		}
	}	
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}


⌨️ 快捷键说明

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