?? dlghistshow1.cpp
字號(hào):
// DlgHistShow1.cpp : implementation file
//
#include "stdafx.h"
#include "ImageProcessing.h"
#include "DlgHistShow1.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDlgHistShow dialog
CDlgHistShow::CDlgHistShow(CWnd* pParent /*=NULL*/)
: CDialog(CDlgHistShow::IDD, pParent)
{
//{{AFX_DATA_INIT(CDlgHistShow)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
}
void CDlgHistShow::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDlgHistShow)
// NOTE: the ClassWizard will add DDX and DDV calls here
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDlgHistShow, CDialog)
//{{AFX_MSG_MAP(CDlgHistShow)
ON_WM_PAINT()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDlgHistShow message handlers
BOOL CDlgHistShow::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
// 設(shè)置直線原圖象象素的指針
unsigned char * lpSrc;
// 循環(huán)變量
int i,j;
// 獲取繪制直方圖的標(biāo)簽
CWnd* pWnd = GetDlgItem(IDC_DLG_HIST_SHOW);
// 計(jì)算得到直方圖
// 圖象的高度和寬度
CSize sizeImage;
sizeImage = m_pDib->GetDimensions();
// 獲得圖象數(shù)據(jù)存儲(chǔ)的高度和寬度
CSize sizeSaveImage;
sizeSaveImage = m_pDib->GetDibSaveDim();
// 重置計(jì)數(shù)為0
for (i = 0; i < 256; i ++)
{
// 清零
m_nHist[i] = 0;
}
// 計(jì)算各個(gè)灰度值的計(jì)數(shù),即得到直方圖
for (i = 0; i < sizeImage.cy; i ++)
{
for (j = 0; j < sizeImage.cx; j ++)
{
lpSrc = (unsigned char *)m_pDib->m_lpImage + sizeSaveImage.cx * i + j;
// 計(jì)數(shù)加1
m_nHist[*(lpSrc)]++;
}
}
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CDlgHistShow::OnPaint()
{
CPaintDC dc(this); // device context for painting
// TODO: Add your message handler code here
// 循環(huán)變量
int i;
// 獲取繪制直方圖文本框的標(biāo)簽
CWnd* pWnd = GetDlgItem(IDC_DLG_HIST_SHOW);
// 獲取設(shè)備上下文
CDC* pDC = pWnd->GetDC();
pWnd->Invalidate();
pWnd->UpdateWindow();
pDC->Rectangle(0, 0, 330, 300);
// 創(chuàng)建畫筆對(duì)象
CPen* pPenRed = new CPen;
// 創(chuàng)建紅色畫筆(用于繪制坐標(biāo)軸)
pPenRed->CreatePen(PS_SOLID, 1, RGB(255,0,0));
// 選入紅色畫筆,并保存以前的畫筆
CPen* pOldPen = pDC->SelectObject(pPenRed);
// 繪制坐標(biāo)軸
pDC->MoveTo(10,10);
// 繪制垂直軸
pDC->LineTo(10, 280);
// 繪制水平軸
pDC->LineTo(320, 280);
// 繪制X軸刻度值
CString strTemp;
strTemp.Format("0");
pDC->TextOut(10, 283, strTemp);
strTemp.Format("50");
pDC->TextOut(60, 283, strTemp);
strTemp.Format("100");
pDC->TextOut(110, 283, strTemp);
strTemp.Format("150");
pDC->TextOut(160, 283, strTemp);
strTemp.Format("200");
pDC->TextOut(210, 283, strTemp);
strTemp.Format("255");
pDC->TextOut(265, 283, strTemp);
// 繪制X軸刻度
for (i = 0; i < 256; i += 5)
{
if ((i & 1) == 0)
{
// 10的倍數(shù)
pDC->MoveTo(i + 10, 280);
pDC->LineTo(i + 10, 284);
}
else
{
// 5的奇數(shù)倍數(shù)
pDC->MoveTo(i + 10, 280);
pDC->LineTo(i + 10, 282);
}
}
// 繪制X軸箭頭
pDC->MoveTo(315,275);
pDC->LineTo(320,280);
pDC->LineTo(315,285);
// 繪制Y軸箭頭
pDC->MoveTo(10,10);
pDC->LineTo(5,15);
pDC->MoveTo(10,10);
pDC->LineTo(15,15);
// 直方圖中最大計(jì)數(shù)值
LONG lMaxCount = 0;
// 計(jì)算最大計(jì)數(shù)值
for (i = 0; i <= 255; i ++)
{
// 判斷是否大于當(dāng)前最大值
if (m_nHist[i] > lMaxCount)
{
// 更新最大值
lMaxCount = m_nHist[i];
}
}
// 輸出最大計(jì)數(shù)值
pDC->MoveTo(10, 25);
pDC->LineTo(14, 25);
strTemp.Format("%d", lMaxCount);
pDC->TextOut(11, 26, strTemp);
// 聲名畫筆對(duì)象
CPen* pPenBlue = new CPen;
// 創(chuàng)建藍(lán)色畫筆(用于繪制直方圖)
pPenBlue->CreatePen(PS_SOLID, 1, RGB(0,0,255));
// 選入藍(lán)色畫筆
pDC->SelectObject(pPenBlue);
// 判斷是否存在計(jì)數(shù)值
if(lMaxCount > 0){
// 繪制直方圖
for (i = 0; i <= 255; i ++)
{
pDC->MoveTo(i + 10, 280);
pDC->LineTo(i + 10, 281 - (int) (m_nHist[i] * 256 / lMaxCount));
}
}
// 恢復(fù)以前的畫筆
pDC->SelectObject(pOldPen);
// 刪除新的畫筆
delete pPenRed;
delete pPenBlue;
}
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -