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

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

?? dlglinerpara.cpp

?? VC++實際編程的源代碼 多種圖像邊緣檢測與分割處理
?? CPP
字號:
// DlgLinerPara.cpp : implementation file
//

#include "stdafx.h"
#include "Dip.h"
#include "DlgLinerPara.h"

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

/////////////////////////////////////////////////////////////////////////////
// CDlgLinerPara dialog


CDlgLinerPara::CDlgLinerPara(CWnd* pParent /*=NULL*/)
	: CDialog(CDlgLinerPara::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDlgLinerPara)
	m_fA = 0.0f;
	m_fB = 0.0f;
	//}}AFX_DATA_INIT
}


void CDlgLinerPara::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDlgLinerPara)
	DDX_Text(pDX, IDC_EDIT_A, m_fA);
	DDX_Text(pDX, IDC_EDIT_B, m_fB);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CDlgLinerPara, CDialog)
	//{{AFX_MSG_MAP(CDlgLinerPara)
	ON_WM_PAINT()
	ON_EN_KILLFOCUS(IDC_EDIT_A, OnKillfocusEditA)
	ON_EN_KILLFOCUS(IDC_EDIT_B, OnKillfocusEditB)
	ON_WM_LBUTTONDOWN()
	ON_WM_LBUTTONUP()
	ON_WM_MOUSEMOVE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDlgLinerPara message handlers

BOOL CDlgLinerPara::OnInitDialog() 
{
	
	// 調用默認OnInitDialog函數
	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;
	
	// 設置接受鼠標事件的有效區域
	m_MouseRect.top += 25;
	m_MouseRect.left += 10;
	m_MouseRect.bottom = m_MouseRect.top + 255;
	m_MouseRect.right = m_MouseRect.left + 256;
	
	// 初始化拖動狀態
	m_bIsDraging = FALSE;
	
	// 返回TRUE
	return TRUE; 
}

void CDlgLinerPara::OnKillfocusEditA() 
{
	// 保存用戶設置
	UpdateData(TRUE);
	
	// 重繪
	InvalidateRect(m_MouseRect, TRUE);
}

void CDlgLinerPara::OnKillfocusEditB() 
{
	// 保存用戶設置
	UpdateData(TRUE);
	
	// 重繪
	InvalidateRect(m_MouseRect, TRUE);
}

void CDlgLinerPara::OnLButtonDown(UINT nFlags, CPoint point) 
{
	// 當用戶單擊鼠標左鍵開始拖動
	if(m_MouseRect.PtInRect(point))
	{
		// 保存當前鼠標位置
		m_p1 = point;
		
		// 轉換坐標系
		m_p1.x = m_p1.x - m_MouseRect.left + 10;
		m_p1.y = m_p1.y - m_MouseRect.top + 25;
		
		// 設置拖動狀態
		m_bIsDraging = TRUE;
		
		// 設置m_bDrawed為FALSE
		m_bDrawed = FALSE;
			
		// 更改光標
		::SetCursor(::LoadCursor(NULL, IDC_CROSS));
		
		// 開始跟蹤鼠標事件(保證當鼠標移動到窗體外時也可以接收到鼠標釋放事件)
		SetCapture();
	}
	
	// 默認單擊鼠標左鍵處理事件
	CDialog::OnLButtonDown(nFlags, point);
}

void CDlgLinerPara::OnMouseMove(UINT nFlags, CPoint point) 
{
	// 判斷當前光標是否在繪制區域
	if(m_MouseRect.PtInRect(point))
	{
		// 更改光標
		::SetCursor(::LoadCursor(NULL, IDC_CROSS));
			
		// 判斷是否正在拖動
		if (m_bIsDraging)
		{
			// 獲取繪圖的標簽
			CWnd* pWnd = GetDlgItem(IDC_COORD);
			
			// 獲取設備上下文
			CDC* pDC = pWnd->GetDC();
			
			// 設置繪制方式為異或模式
			int nOldDrawMode = pDC->SetROP2(R2_XORPEN);

			// 創建新的畫筆
			CPen* pPen = new CPen;
			pPen->CreatePen(PS_DOT,1,RGB(0,0,0));
			
			// 選中新畫筆
			CGdiObject* pOldPen = pDC->SelectObject(pPen);
			
			// 判斷是否已經畫過橡皮筋線
			if (m_bDrawed)
			{
				// 擦去以前的橡皮筋線
				pDC->MoveTo(m_p1);
				pDC->LineTo(m_p2);
			}
			
			// 保存當前的坐標
			m_p2 = point;
			
			// 轉換坐標系
			m_p2.x = m_p2.x - m_MouseRect.left + 10;
			m_p2.y = m_p2.y - m_MouseRect.top + 25;
			
			// 繪制一條新橡皮筋線
			pDC->MoveTo(m_p1);
			pDC->LineTo(m_p2);
			
			// 設置m_bDrawed為TRUE
			m_bDrawed = TRUE;
			
			// 選回以前的畫筆
			pDC->SelectObject(pOldPen);
			
			// 恢復成以前的繪制模式
			pDC->SetROP2(nOldDrawMode);
			
			delete pPen;
			ReleaseDC(pDC);
		}
	}
	else
	{
		// 判斷是否正在拖動
		if (m_bIsDraging)
		{
			// 更改光標
			::SetCursor(::LoadCursor(NULL, IDC_NO));
		}
	}
	
	// 默認鼠標移動處理事件
	CDialog::OnMouseMove(nFlags, point);
}

void CDlgLinerPara::OnLButtonUp(UINT nFlags, CPoint point) 
{
	// 當用戶釋放鼠標左鍵停止拖動
	if (m_bIsDraging)
	{
		// 判斷當前光標是否在繪制區域
		if(m_MouseRect.PtInRect(point))
		{
			// 保存當前鼠標位置
			m_p2 = point;
			
			// 轉換坐標系
			m_p2.x = m_p2.x - m_MouseRect.left + 10;
			m_p2.y = m_p2.y - m_MouseRect.top + 25;
			
			if ((m_p1 != m_p2) && (m_p1.x != m_p2.x))
			{
				// 轉換坐標系
				m_p1.x = m_p1.x - 10;
				m_p1.y = 280 - m_p1.y;
				m_p2.x = m_p2.x - 10;
				m_p2.y = 280 - m_p2.y;
				
				// 計算斜率和截距
				m_fA = (float) (m_p2.y - m_p1.y) / (m_p2.x - m_p1.x);
				m_fB = m_p1.y - m_fA * m_p1.x;
				
				// 保存變動
				UpdateData(FALSE);
			}
			
			// 重繪
			InvalidateRect(m_MouseRect, TRUE);
		}
		else
		{
			// 用戶在繪制區域外放開鼠標左鍵
			
			// 獲取繪圖的標簽
			CWnd* pWnd = GetDlgItem(IDC_COORD);
			
			// 獲取設備上下文
			CDC* pDC = pWnd->GetDC();
			
			// 設置繪制方式為異或模式
			int nOldDrawMode = pDC->SetROP2(R2_XORPEN);

			// 創建新的畫筆
			CPen* pPen = new CPen;
			pPen->CreatePen(PS_DOT,1,RGB(0,0,0));
			
			// 選中新畫筆
			CGdiObject* pOldPen = pDC->SelectObject(pPen);
			
			// 判斷是否已經畫過橡皮筋線
			if (m_bDrawed)
			{
				// 擦去以前的橡皮筋線
				pDC->MoveTo(m_p1);
				pDC->LineTo(m_p2);
			}
			
			// 選回以前的畫筆
			pDC->SelectObject(pOldPen);
			
			// 恢復成以前的繪制模式
			pDC->SetROP2(nOldDrawMode);
			
			delete pPen;
			ReleaseDC(pDC);
			
		}
		
		// 解除對鼠標事件的跟蹤
		::ReleaseCapture();
		
		// 重置拖動狀態
		m_bIsDraging = FALSE;
	}
	
	// 默認釋放鼠標左鍵處理事件
	CDialog::OnLButtonUp(nFlags, point);
}

void CDlgLinerPara::OnPaint() 
{
	// 字符串
	CString str;
	
	// 直線和坐標軸二個交點坐標
	int x1, y1, x2, y2;
	
	// 設備上下文
	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;
	
	// 紅色畫筆
	pPenRed->CreatePen(PS_SOLID,2,RGB(255,0,0));
	
	// 創建畫筆對象
	CPen* pPenBlue = new CPen;
	
	// 藍色畫筆
	pPenBlue->CreatePen(PS_SOLID,2,RGB(0,0, 255));
	
	// 選中當前紅色畫筆,并保存以前的畫筆
	CGdiObject* pOldPen = pDC->SelectObject(pPenRed);
	
	// 繪制坐標軸
	pDC->MoveTo(10,6);
	
	// 垂直軸
	pDC->LineTo(10,276);
	
	// 水平軸
	pDC->LineTo(320,276);
	
	// 寫坐標
	str.Format("0");
	pDC->TextOut(10, 277, str);
	
	str.Format("255");
	pDC->TextOut(265, 277, str);
	pDC->TextOut(11, 21, str);
	
	// 繪制X軸箭頭
	pDC->LineTo(315,271);
	pDC->MoveTo(320,276);
	pDC->LineTo(315,281);
	
	// 繪制X軸箭頭
	pDC->MoveTo(10,6);
	pDC->LineTo(5,11);
	pDC->MoveTo(10,6);
	pDC->LineTo(15,11);
	
	// 更改成藍色畫筆
	pDC->SelectObject(pPenBlue);	
	
	// 計算直線和坐標軸二個交點坐標
	if (m_fA >= 0)
	{
		if (((m_fA * 255 + m_fB) >= 0) && (m_fB < 255))
		{
			// 計算(x1, y1)坐標
			if (m_fB < 0)
			{
				x1 = (int) (- m_fB/m_fA + 0.5);
				y1 = 0;
			}
			else
			{
				x1 = 0;
				y1 = (int) (m_fB + 0.5);
			}
			
			// 計算(x2, y2)坐標
			if ((m_fA * 255 + m_fB) > 255)
			{
				x2 = (int) ((255- m_fB)/m_fA + 0.5);
				y2 = 255;
			}
			else
			{
				x2 = 255;
				y2 = (int) (255* m_fA + m_fB + 0.5);
			}
		}
		else if(((m_fA * 255 + m_fB) < 0))
		{
			// 轉換后所有象素值都小于0,直接設置為0
			x1 = 0;
			y1 = 0;
			x2 = 255;
			y2 = 0;
		}
		else
		{
			// 轉換后所有象素值都大于255,直接設置為255
			x1 = 0;
			y1 = 255;
			x2 = 255;
			y2 = 255;
		}
	}
	else  // 斜率小于0
	{
		if ((m_fB > 0) && (255* m_fA + m_fB < 255))
		{
			// 計算(x1, y1)坐標
			if (m_fB > 255)
			{
				x1 = (int) ((255- m_fB)/m_fA + 0.5);
				y1 = 255;
			}
			else
			{
				x1 = 0;
				y1 = (int) (m_fB + 0.5);
			}
			
			// 計算(x2, y2)坐標
			if ((m_fA * 255 + m_fB) < 0)
			{
				x2 = (int) (- m_fB/m_fA + 0.5);
				y2 = 0;
			}
			else
			{
				x2 = 255;
				y2 = (int) (255* m_fA + m_fB + 0.5);
			}
		}
		else if (m_fB <=0)
		{
			// 轉換后所有象素值都小于0,直接設置為0
			x1 = 0;
			y1 = 0;
			x2 = 255;
			y2 = 0;
		}
		else
		{
			// 轉換后所有象素值都大于255,直接設置為255
			x1 = 0;
			y1 = 255;
			x2 = 255;
			y2 = 255;
		}
	}
	
	// 繪制坐標值
	str.Format("(%d, %d)", x1, y1);
	pDC->TextOut(x1 + 10, 276 - y1 + 1, str);
	str.Format("(%d, %d)", x2, y2);
	pDC->TextOut(x2 + 10, 276 - y2 + 1, str);
	
	// 繪制用戶指定的線性變換直線(注意轉換坐標系)
	pDC->MoveTo(x1 + 10, 276 - y1);
	pDC->LineTo(x2 + 10, 276 - y2);
	
	// 恢復以前的畫筆
	pDC->SelectObject(pOldPen);	
	
	// 繪制邊緣
	pDC->MoveTo(10,21);
	pDC->LineTo(265,21);
	pDC->LineTo(265,276);
	
	// 刪除新的畫筆
	delete pPenRed;
	delete pPenBlue;
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品午夜一区二区三区在线观看| 夜夜夜精品看看| 国内精品伊人久久久久影院对白| 欧美老年两性高潮| 视频一区视频二区在线观看| 欧美高清视频不卡网| 日本亚洲电影天堂| 久久久久久久综合日本| 成人黄色在线网站| 亚洲欧美激情小说另类| 欧美日韩国产综合一区二区三区| 亚洲成在线观看| 日韩一区二区三区视频在线 | 亚洲一区二区三区四区在线免费观看 | 日韩视频免费观看高清完整版 | 午夜成人免费电影| 91精品在线观看入口| 国产裸体歌舞团一区二区| 国产精品美女久久久久av爽李琼| 色视频欧美一区二区三区| 亚洲r级在线视频| 精品国产乱码久久久久久夜甘婷婷 | 久久综合九色综合97婷婷| 国产精品亚洲第一区在线暖暖韩国| 国产精品美女久久久久久久久 | 欧美成人乱码一区二区三区| 国产精品影视在线| 亚洲国产精品影院| 国产日韩欧美a| 色88888久久久久久影院野外| 亚洲不卡一区二区三区| 国产日韩亚洲欧美综合| 欧洲视频一区二区| 激情综合一区二区三区| 亚洲精品高清在线观看| 精品国产不卡一区二区三区| 在线一区二区三区四区| 国产在线精品免费av| 亚洲五月六月丁香激情| 欧美激情一区二区三区| 欧美一区午夜视频在线观看| 99久久综合色| 国产精品主播直播| 日韩国产在线观看| 一区二区三区久久久| 日本一区二区三区在线观看| 欧美精品色一区二区三区| 本田岬高潮一区二区三区| 麻豆成人av在线| 综合久久综合久久| 久久影院午夜片一区| 欧美日韩国产高清一区二区| av电影天堂一区二区在线观看| 男人的j进女人的j一区| 一区二区国产视频| 中文字幕va一区二区三区| 91精品在线免费| 欧美日精品一区视频| 99久久精品费精品国产一区二区| 精一区二区三区| 奇米影视一区二区三区小说| 性久久久久久久久久久久| 亚洲欧美日韩国产成人精品影院| 国产日产欧美一区| 久久久影视传媒| 久久免费电影网| 亚洲精品一区二区三区在线观看| 91精品国产欧美一区二区| 欧美久久久久久蜜桃| 欧美日韩综合在线| 欧美日本精品一区二区三区| 欧美影视一区在线| 91福利区一区二区三区| 欧美主播一区二区三区| 一本久久a久久精品亚洲| 99久久亚洲一区二区三区青草 | 亚洲综合丝袜美腿| 亚洲欧美色图小说| 亚洲精品国久久99热| 综合久久综合久久| 一区二区三区四区在线播放| 亚洲精品久久久蜜桃| 亚洲一区二区欧美| 亚洲综合一二区| 日韩成人精品视频| 久久精品国产精品亚洲红杏| 久久精品国产亚洲一区二区三区 | 国产色91在线| 国产欧美一区二区三区鸳鸯浴| 国产日韩欧美在线一区| 国产亚洲视频系列| 亚洲国产精品高清| 亚洲激情欧美激情| 日韩成人午夜电影| 激情图区综合网| 粉嫩高潮美女一区二区三区| 99久久精品99国产精品| 欧美人妇做爰xxxⅹ性高电影| 91精品国产综合久久久久久| 日韩亚洲欧美在线| 国产欧美一区二区精品性色| 亚洲欧美在线视频| 首页国产丝袜综合| 国产毛片精品视频| 91视频一区二区| 制服丝袜国产精品| 中文字幕乱码久久午夜不卡 | 欧美剧情电影在线观看完整版免费励志电影 | 日韩午夜激情免费电影| 欧美精品一区二区三区一线天视频 | 视频一区欧美精品| 国产乱人伦精品一区二区在线观看| eeuss国产一区二区三区| 欧美在线视频不卡| 精品国产91乱码一区二区三区 | 日本亚洲一区二区| 岛国一区二区在线观看| 欧美三级电影在线观看| 久久精品在线免费观看| 一区二区三区日韩精品视频| 精品一区二区三区日韩| 91啪在线观看| 久久综合色之久久综合| 亚洲激情五月婷婷| 国产一区二区在线观看免费| 在线一区二区三区四区五区| 久久先锋影音av| 亚洲成va人在线观看| 国产成人精品免费在线| 欧美日韩中文另类| 中文字幕在线一区| 麻豆精品一区二区av白丝在线| 96av麻豆蜜桃一区二区| 欧美刺激午夜性久久久久久久| 又紧又大又爽精品一区二区| 国产福利精品一区二区| 9191成人精品久久| 亚洲综合成人在线视频| 成人免费视频网站在线观看| 日韩欧美国产系列| 午夜电影网亚洲视频| 在线中文字幕一区| 国产精品对白交换视频 | 成人国产电影网| 精品奇米国产一区二区三区| 亚洲黄色免费电影| 99re视频精品| 欧美国产成人精品| 国产综合久久久久影院| 欧美老女人第四色| 亚洲gay无套男同| 91久久线看在观草草青青| 中文字幕一区二区在线播放| 国产成都精品91一区二区三| 精品对白一区国产伦| 麻豆国产欧美一区二区三区| 欧美高清视频一二三区| 日日夜夜免费精品| 欧美手机在线视频| 亚洲一区二区三区四区在线观看 | 欧美va在线播放| 亚洲国产精品久久久男人的天堂| 一本久久a久久精品亚洲| 亚洲精品国产第一综合99久久| 91日韩精品一区| 亚洲精品免费在线观看| 欧日韩精品视频| 亚洲不卡在线观看| 欧美一区二区精品在线| 视频在线在亚洲| 欧美高清精品3d| 久久精品免费观看| 久久久久久免费网| 成人毛片视频在线观看| 亚洲天堂免费在线观看视频| 色婷婷一区二区三区四区| 亚洲在线免费播放| 在线播放日韩导航| 极品瑜伽女神91| 国产校园另类小说区| av动漫一区二区| 亚洲一区影音先锋| 欧美一区二区视频在线观看2022| 琪琪久久久久日韩精品| 国产三级欧美三级日产三级99| 不卡大黄网站免费看| 一区二区三区精品在线观看| 欧美偷拍一区二区| 久久er99精品| 亚洲欧美一区二区在线观看| 在线观看视频一区二区| 日韩国产一区二| 欧美国产一区二区在线观看| 欧洲在线/亚洲| 另类成人小视频在线| 国产精品久久久久永久免费观看| 欧美专区日韩专区| 麻豆高清免费国产一区| 成人欧美一区二区三区1314| 欧美日韩一区高清|