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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? intensitydlg.cpp

?? 經(jīng)典編著《Visual C++數(shù)字圖像處理典型算法及實(shí)現(xiàn)》光盤源程序。
?? CPP
字號(hào):
// IntensityDlg.cpp : implementation file
//

#include "stdafx.h"
#include "LineTrans.h"
#include "IntensityDlg.h"

#include "DibImage.h"

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

/////////////////////////////////////////////////////////////////////////////
// CIntensityDlg dialog


CIntensityDlg::CIntensityDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CIntensityDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CIntensityDlg)
	m_iLowGray = 0;
	m_iUpGray = 0;
	//}}AFX_DATA_INIT
}


void CIntensityDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CIntensityDlg)
	DDX_Text(pDX, IDC_EDIT_LOWGRAY, m_iLowGray);
	DDV_MinMaxInt(pDX, m_iLowGray, 0, 255);
	DDX_Text(pDX, IDC_EDIT_UPGRAY, m_iUpGray);
	DDV_MinMaxInt(pDX, m_iUpGray, 0, 255);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CIntensityDlg, CDialog)
	//{{AFX_MSG_MAP(CIntensityDlg)
	ON_WM_PAINT()
	ON_EN_KILLFOCUS(IDC_EDIT_LOWGRAY, OnKillfocusEDITLowGray)
	ON_EN_KILLFOCUS(IDC_EDIT_UPGRAY, OnKillfocusEDITUpGray)
	ON_WM_MOUSEMOVE()
	ON_WM_LBUTTONDOWN()
	ON_WM_LBUTTONUP()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CIntensityDlg message handlers

BOOL CIntensityDlg::OnInitDialog() 
{
	unsigned char * lpSrc;		// 指向源圖像象素的指針
	LONG i,j;

	CDialog::OnInitDialog();

	CWnd* pWnd = GetDlgItem(IDC_COORD);
	pWnd->GetClientRect(m_MouseRect);
	pWnd->ClientToScreen(&m_MouseRect);
	
	CRect rect;
	GetClientRect(rect);
	ClientToScreen(&rect);	
	m_MouseRect.top -= rect.top;
	m_MouseRect.left -= rect.left;
	
	// 設(shè)置接受鼠標(biāo)事件的有效區(qū)域
	m_MouseRect.top += 25;
	m_MouseRect.left += 10;
	m_MouseRect.bottom = m_MouseRect.top + 255;
	m_MouseRect.right = m_MouseRect.left + 256;
	
	for (i = 0; i < 256; i ++)
	{
		m_lCount[i] = 0;
	}
		
	LONG lLineBytes;			// 圖像每行的字節(jié)數(shù)
	lLineBytes = WIDTHBYTES(m_lWidth * 8);
	
	// 計(jì)算各個(gè)灰度值的計(jì)數(shù)
	for (i = 0; i < m_lHeight; i ++)
	{
		for (j = 0; j < m_lWidth; j ++)
		{
			lpSrc = (unsigned char *)m_lpDIBBits + lLineBytes * i + j;
			m_lCount[*(lpSrc)]++;
		}
	}
	
	m_iIsDraging = 0;

	return TRUE;
}

void CIntensityDlg::OnKillfocusEDITLowGray() 
{
	UpdateData(TRUE);
	
	// 判斷是否下限超過上限
	if (m_iLowGray > m_iUpGray)
	{
		int iTemp = m_iLowGray;
		m_iLowGray = m_iUpGray;
		m_iUpGray = iTemp;
		UpdateData(FALSE);
	}

	InvalidateRect(m_MouseRect, TRUE);
}

void CIntensityDlg::OnKillfocusEDITUpGray() 
{
	UpdateData(TRUE);
	
	// 判斷是否下限超過上限
	if (m_iLowGray > m_iUpGray)
	{
		int iTemp = m_iLowGray;
		m_iLowGray = m_iUpGray;
		m_iUpGray = iTemp;
		UpdateData(FALSE);
	}
	
	InvalidateRect(m_MouseRect, TRUE);	
}

void CIntensityDlg::OnLButtonDown(UINT nFlags, CPoint point) 
{
	// 判斷是否在接受鼠標(biāo)事件的有效區(qū)域中
	if(m_MouseRect.PtInRect(point))
	{
		if (point.x == (m_MouseRect.left + m_iLowGray))
		{			
			m_iIsDraging = 1;		// 設(shè)置拖動(dòng)狀態(tài)1,拖動(dòng)下限
			::SetCursor(::LoadCursor(NULL, IDC_SIZEWE));
		}
		else if (point.x == (m_MouseRect.left + m_iUpGray))
		{			
			m_iIsDraging = 2;		// 設(shè)置拖動(dòng)狀態(tài)為2,拖動(dòng)上限
			::SetCursor(::LoadCursor(NULL, IDC_SIZEWE));
		}
	}

	CDialog::OnLButtonDown(nFlags, point);
}

void CIntensityDlg::OnMouseMove(UINT nFlags, CPoint point) 
{	
	// 判斷是否在接受鼠標(biāo)事件的有效區(qū)域中
	if(m_MouseRect.PtInRect(point))
	{
		// 判斷是否正在拖動(dòng)
		if (m_iIsDraging != 0)
		{
			// 判斷正在拖動(dòng)上限還是下限
			if (m_iIsDraging == 1)
			{
				// 判斷是否下限<上限
				if (point.x - m_MouseRect.left < m_iUpGray)
				{					
					m_iLowGray = point.x - m_MouseRect.left;	// 更改下限
				}
				else
				{					
					m_iLowGray = m_iUpGray - 1;		// 下限拖過上限,設(shè)置為上限-1					
					point.x = m_MouseRect.left + m_iUpGray - 1; // 重設(shè)鼠標(biāo)位置
				}
			}
			else
			{
				// 正在拖動(dòng)上限		
				// 判斷是否上限>下限
				if (point.x - m_MouseRect.left > m_iLowGray)	
				{					
					m_iUpGray = point.x - m_MouseRect.left;		// 更改下限
				}
				else
				{
					m_iUpGray = m_iLowGray + 1;	// 下限拖過上限,設(shè)置為下限+1				
					point.x = m_MouseRect.left + m_iLowGray + 1;// 重設(shè)鼠標(biāo)位置
				}
			}
			
			::SetCursor(::LoadCursor(NULL, IDC_SIZEWE));

			UpdateData(FALSE);		
			InvalidateRect(m_MouseRect, TRUE);
		}
		else if (point.x == (m_MouseRect.left + m_iLowGray) || point.x == 
			(m_MouseRect.left + m_iUpGray))
		{
			::SetCursor(::LoadCursor(NULL, IDC_SIZEWE));
		}
	}
	
	CDialog::OnMouseMove(nFlags, point);
}

void CIntensityDlg::OnLButtonUp(UINT nFlags, CPoint point) 
{
	// 當(dāng)用戶釋放鼠標(biāo)左鍵停止拖動(dòng)
	if (m_iIsDraging != 0)
	{
		m_iIsDraging = 0;
	}

	CDialog::OnLButtonUp(nFlags, point);
}

void CIntensityDlg::OnPaint() 
{
	CString str;
	LONG i;
	LONG lMaxCount = 0;			// 最大計(jì)數(shù)

	CPaintDC dc(this);
	
	CWnd* pWnd = GetDlgItem(IDC_COORD);
	CDC* pDC = pWnd->GetDC();
	pWnd->Invalidate();
	pWnd->UpdateWindow();	
	pDC->Rectangle(0,0,330,300);
	
	CPen* pPenRed = new CPen;						// 創(chuàng)建畫筆對(duì)象	
	pPenRed->CreatePen(PS_SOLID,1,RGB(255,0,0));	// 紅色畫筆	
	CPen* pPenBlue = new CPen;						// 創(chuàng)建畫筆對(duì)象	
	pPenBlue->CreatePen(PS_SOLID,1,RGB(0,0, 255));	// 藍(lán)色畫筆	
	CPen* pPenGreen = new CPen;						// 創(chuàng)建畫筆對(duì)象	
	pPenGreen->CreatePen(PS_DOT,1,RGB(0,255,0));	// 綠色畫筆
	
	// 選中當(dāng)前紅色畫筆,并保存以前的畫筆
	CGdiObject* pOldPen = pDC->SelectObject(pPenRed);	
	pDC->MoveTo(10,10);								// 繪制坐標(biāo)軸	
	pDC->LineTo(10,280);							// 垂直軸	
	pDC->LineTo(320,280);							// 水平軸
	
	// 寫X軸刻度值
	str.Format("0");
	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);
	
	// 繪制X軸刻度
	for (i = 0; i < 256; i += 5)
	{
		if ((i & 1) == 0)
		{
			pDC->MoveTo(i + 10, 280);
			pDC->LineTo(i + 10, 284);
		}
		else
		{
			pDC->MoveTo(i + 10, 280);
			pDC->LineTo(i + 10, 282);
		}
	}
	
	// 繪制X軸箭頭
	pDC->MoveTo(315,275);
	pDC->LineTo(320,280);
	pDC->LineTo(315,285);
	
	// 繪制X軸箭頭
	pDC->MoveTo(10,10);
	pDC->LineTo(5,15);
	pDC->MoveTo(10,10);
	pDC->LineTo(15,15);
	
	// 計(jì)算最大計(jì)數(shù)值
	for (i = m_iLowGray; i <= m_iUpGray; i ++)
	{
		// 判斷是否大于當(dāng)前最大值
		if (m_lCount[i] > lMaxCount)
		{
			lMaxCount = m_lCount[i];
		}
	}
	
	// 輸出最大計(jì)數(shù)值
	pDC->MoveTo(10, 25);
	pDC->LineTo(14, 25);
	str.Format("%d", lMaxCount);
	pDC->TextOut(11, 26, str);
	
	// 更改成綠色畫筆
	pDC->SelectObject(pPenGreen);	
	
	// 繪制窗口上下限
	pDC->MoveTo(m_iLowGray + 10, 25);
	pDC->LineTo(m_iLowGray + 10, 280);	
	pDC->MoveTo(m_iUpGray + 10, 25);
	pDC->LineTo(m_iUpGray + 10, 280);
	
	// 更改成藍(lán)色畫筆
	pDC->SelectObject(pPenBlue);	
	
	// 判斷是否有計(jì)數(shù)
	if (lMaxCount > 0)
	{
		// 繪制直方圖
		for (i = m_iLowGray; i <= m_iUpGray; i ++)
		{
			pDC->MoveTo(i + 10, 280);
			pDC->LineTo(i + 10, 281 - (int) (m_lCount[i] * 256 / lMaxCount));
		}
	}
	
	// 恢復(fù)以前的畫筆
	pDC->SelectObject(pOldPen);	
	
	delete pPenRed;
	delete pPenBlue;
	delete pPenGreen;	
}

void CIntensityDlg::OnOK() 
{
	// 判斷是否下限超過上限
	if (m_iLowGray > m_iUpGray)
	{
		int iTemp = m_iLowGray;
		m_iLowGray = m_iUpGray;
		m_iUpGray = iTemp;
	}
	
	CDialog::OnOK();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久久久久久久久久久久久久 | 另类小说图片综合网| 亚洲人成在线观看一区二区| 国产日韩欧美不卡在线| 欧美成人一区二区三区片免费| 777久久久精品| 欧美一级日韩不卡播放免费| 欧美精品日日鲁夜夜添| 欧美一区二区三区免费在线看| 欧美精品在线视频| 日韩欧美aaaaaa| 久久精品人人做人人爽97| 欧美激情一区二区三区四区| 国产女主播一区| 一区二区三区中文在线观看| 在线观看精品一区| 色婷婷一区二区三区四区| 色老头久久综合| 91精品午夜视频| 一级中文字幕一区二区| 亚洲黄色录像片| 久久久亚洲国产美女国产盗摄 | 99久久99久久精品免费观看| 日韩亚洲欧美在线| 五月激情综合网| 欧美性生活一区| **性色生活片久久毛片| 成人黄色小视频在线观看| 久久久国际精品| 精品一区二区三区不卡| 日韩欧美一区二区在线视频| 丝袜美腿亚洲综合| 91精品国产综合久久久久| 人人狠狠综合久久亚洲| 欧美一区日本一区韩国一区| 亚洲欧美视频在线观看视频| 色综合色综合色综合色综合色综合 | 91.com视频| 亚洲成人777| 69堂成人精品免费视频| 久久国产欧美日韩精品| 精品国精品国产尤物美女| 国产综合久久久久久鬼色 | 88在线观看91蜜桃国自产| 日本不卡一区二区| 精品久久久久久久久久久院品网 | 亚洲女同一区二区| 91极品视觉盛宴| 丝袜美腿亚洲色图| 日韩精品在线一区二区| 国产精品亚洲成人| 亚洲免费毛片网站| 91精品一区二区三区在线观看| 久久精品久久99精品久久| 久久天堂av综合合色蜜桃网| www.综合网.com| 亚洲午夜久久久| 337p粉嫩大胆噜噜噜噜噜91av | 中文字幕日本不卡| 91.com在线观看| 国产在线不卡一区| 亚洲黄色小视频| 欧美不卡一区二区三区四区| a在线欧美一区| 亚洲第一福利视频在线| 欧美sm极限捆绑bd| 成人国产亚洲欧美成人综合网| 亚洲已满18点击进入久久| 日韩欧美一区二区久久婷婷| 国产91精品久久久久久久网曝门| 亚洲综合区在线| 久久这里只有精品视频网| 99国产精品国产精品毛片| 日本欧美一区二区| 成人欧美一区二区三区黑人麻豆| 欧美高清视频一二三区| 粉嫩一区二区三区性色av| 亚洲成人综合视频| 国产精品理论在线观看| 91精品久久久久久蜜臀| 日本久久电影网| 国产成人在线视频免费播放| 天天色综合成人网| 亚洲日本在线观看| 国产精品视频第一区| 日韩视频在线一区二区| 欧美亚洲一区三区| 9色porny自拍视频一区二区| 国产在线看一区| 欧美aaa在线| 亚洲一区免费视频| 精品污污网站免费看| 日本不卡的三区四区五区| 一区二区三区在线观看视频| 国产精品日韩精品欧美在线| 精品国产乱码久久久久久老虎| 欧美日韩一二三| 欧美自拍丝袜亚洲| 91看片淫黄大片一级| 99这里都是精品| 成人黄色一级视频| 成人激情免费网站| 波多野结衣欧美| 成人app网站| 大胆亚洲人体视频| 国产成a人亚洲| 国产成人免费在线视频| 国产裸体歌舞团一区二区| 国产在线播精品第三| 韩国在线一区二区| 国产精品自在在线| 国产一区二区福利视频| 国产精品夜夜嗨| 不卡高清视频专区| 972aa.com艺术欧美| 99国产精品一区| 欧美三级电影在线看| 欧美日韩成人在线一区| 在线成人免费视频| 日韩一卡二卡三卡国产欧美| 欧美一级在线观看| 日韩三区在线观看| 久久亚洲私人国产精品va媚药| 久久综合久久综合久久| 国产亚洲欧美日韩俺去了| 久久久久国产精品人| 国产欧美日韩精品在线| 国产精品污www在线观看| 国产精品第四页| 伊人色综合久久天天| 午夜国产不卡在线观看视频| 秋霞电影网一区二区| 狠狠色丁香婷综合久久| 成人h精品动漫一区二区三区| 91免费视频网址| 欧美一区二区三区视频在线观看| 久久久久久久久99精品| 日韩一区中文字幕| 青青青爽久久午夜综合久久午夜| 精品一区二区免费| 91在线视频官网| 欧美日韩精品一区二区三区 | 久久爱www久久做| 成人免费va视频| 欧美日韩国产另类一区| 精品国产乱码久久久久久老虎| 亚洲素人一区二区| 天堂成人免费av电影一区| 国产美女一区二区三区| 91豆麻精品91久久久久久| 日韩亚洲欧美综合| 亚洲欧洲精品天堂一级| 美女性感视频久久| 91色婷婷久久久久合中文| 欧美一级黄色大片| 亚洲精品欧美专区| 麻豆精品视频在线观看免费 | 日韩精品一区二区三区四区| 国产精品久久久久久久浪潮网站| 亚洲h在线观看| www.视频一区| 欧美成人女星排名| 亚洲一区中文在线| 东方aⅴ免费观看久久av| 欧美日韩国产综合久久| 国产精品国产三级国产aⅴ无密码| 日韩精品欧美精品| 色8久久精品久久久久久蜜| 久久久久久久久岛国免费| 偷窥少妇高潮呻吟av久久免费| aaa欧美色吧激情视频| 26uuu国产日韩综合| 日韩精品一级二级| 欧美在线综合视频| 国产精品国产三级国产三级人妇 | 日韩国产高清影视| 色综合一个色综合亚洲| 国产日产亚洲精品系列| 毛片av中文字幕一区二区| 精品视频色一区| 一区二区激情小说| thepron国产精品| 国产欧美日本一区二区三区| 久久99精品久久久| 日韩女同互慰一区二区| 日韩av在线免费观看不卡| 欧美亚洲综合在线| 亚洲午夜成aⅴ人片| 欧美在线高清视频| 亚洲主播在线观看| 欧美在线免费播放| 亚洲一区二区在线免费看| 91啪在线观看| 亚洲精品久久嫩草网站秘色| 91日韩一区二区三区| 亚洲精品免费在线观看| 91美女视频网站| 一二三区精品福利视频| 在线观看不卡一区| 亚洲第一电影网|