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

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

?? dlglinerpara.cpp

?? 《VC++數字圖像處理》人民郵電大學出版社 何斌 馬天予 王遠堅 朱紅蓮
?? CPP
字號:
// DlgLinerPara.cpp : implementation file
//

#include "stdafx.h"
#include "ch1_1.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,10);
	
	// 垂直軸
	pDC->LineTo(10,280);
	
	// 水平軸
	pDC->LineTo(320,280);
	
	// 寫坐標
	str.Format("0");
	pDC->TextOut(10, 281, str);
	
	str.Format("255");
	pDC->TextOut(265, 281, str);
	pDC->TextOut(11, 25, str);
	
	// 繪制X軸箭頭
	pDC->LineTo(315,275);
	pDC->MoveTo(320,280);
	pDC->LineTo(315,285);
	
	// 繪制X軸箭頭
	pDC->MoveTo(10,10);
	pDC->LineTo(5,15);
	pDC->MoveTo(10,10);
	pDC->LineTo(15,15);
	
	// 更改成藍色畫筆
	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, 280 - y1 + 1, str);
	str.Format("(%d, %d)", x2, y2);
	pDC->TextOut(x2 + 10, 280 - y2 + 1, str);
	
	// 繪制用戶指定的線性變換直線(注意轉換坐標系)
	pDC->MoveTo(x1 + 10, 280 - y1);
	pDC->LineTo(x2 + 10, 280 - y2);
	
	// 恢復以前的畫筆
	pDC->SelectObject(pOldPen);	
	
	// 繪制邊緣
	pDC->MoveTo(10,25);
	pDC->LineTo(265,25);
	pDC->LineTo(265,280);
	
	// 刪除新的畫筆
	delete pPenRed;
	delete pPenBlue;
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久欧美一区二区| 国产综合成人久久大片91| 国内精品久久久久影院薰衣草 | 国产一区二区影院| 欧美综合视频在线观看| 亚洲色图色小说| 色激情天天射综合网| 国产精品久久久久久亚洲毛片 | 久久国产视频网| 欧美一区二区三区在线观看| 天堂午夜影视日韩欧美一区二区| 暴力调教一区二区三区| 久久久亚洲欧洲日产国码αv| 国产在线精品一区二区| 日韩精品在线网站| 成人性色生活片免费看爆迷你毛片| 久久精品亚洲国产奇米99| 国产一区不卡精品| 亚洲天天做日日做天天谢日日欢 | 久久精品国产一区二区三区免费看| 91精品国产福利在线观看| 视频一区免费在线观看| 欧美电视剧在线看免费| 国产一区二区中文字幕| 2023国产精品| 国产精品羞羞答答xxdd| 亚洲精品欧美二区三区中文字幕| 色综合久久综合网97色综合 | 亚洲午夜电影在线| 91精品在线免费| 狠狠色狠狠色综合日日91app| 国产精品麻豆99久久久久久| 91美女精品福利| 亚洲电影第三页| 欧美国产日产图区| 欧美在线色视频| 强制捆绑调教一区二区| 国产精品天美传媒| 欧美三级在线播放| 久久国产视频网| 久久久天堂av| 在线精品视频免费观看| 久久av中文字幕片| 国产欧美一区二区三区在线老狼| 欧美日韩中文字幕一区| 国内外成人在线视频| 久久免费午夜影院| 欧美精品日日鲁夜夜添| 国产精品影视网| 亚洲第一av色| 国产精品久久久久久久第一福利| 欧美在线观看禁18| 国产美女在线精品| 同产精品九九九| 国产欧美精品一区二区色综合 | 欧美一区二区三区免费视频| 高清av一区二区| 亚洲图片自拍偷拍| 亚洲免费观看高清在线观看| 91精品国产91热久久久做人人| 成人免费高清在线| 九九精品视频在线看| 一区二区三区日韩欧美| 久久一区二区三区国产精品| 99热这里都是精品| 成人高清视频在线| 美女免费视频一区| 亚洲视频每日更新| 亚洲啪啪综合av一区二区三区| 日韩精品一区二区三区蜜臀| 在线精品视频免费观看| 色网站国产精品| 国产一区视频在线看| 亚洲色图视频网站| 日本成人在线网站| 亚洲综合久久av| 国产精品久久国产精麻豆99网站| 欧美成人福利视频| 欧美日韩性生活| 91国偷自产一区二区三区观看 | 天天色图综合网| 亚洲欧美视频在线观看| 日本一区二区电影| 精品乱人伦一区二区三区| 91精品国产综合久久久久久| av在线播放成人| 色综合久久中文字幕| 成人污污视频在线观看| 久久99精品网久久| 日本不卡一区二区三区| 一区二区三区免费网站| 亚洲欧洲av色图| 欧美亚州韩日在线看免费版国语版| 国产激情视频一区二区在线观看| 日韩精品一二三区| 自拍偷拍欧美激情| 亚洲欧洲性图库| 综合久久久久久| 亚洲少妇最新在线视频| 亚洲视频中文字幕| 久久久综合精品| 日韩欧美国产系列| 精品国产污污免费网站入口 | 亚洲欧洲无码一区二区三区| 精品免费日韩av| 久久久综合精品| 中文欧美字幕免费| 久久久久久亚洲综合影院红桃| 精品国产人成亚洲区| 精品av综合导航| 久久精品亚洲麻豆av一区二区| 欧美日韩久久久一区| 欧美理论在线播放| 日韩精品一区二区三区视频播放 | 欧美国产日产图区| 亚洲欧美日韩中文字幕一区二区三区 | 国产精品一区在线观看乱码| 国产一区二区三区高清播放| 国产91精品精华液一区二区三区| 成人午夜碰碰视频| 色综合中文综合网| 亚洲网友自拍偷拍| 日本美女视频一区二区| 国产乱人伦精品一区二区在线观看 | 成人av在线网站| 91丝袜美女网| 欧美性生活久久| 欧美少妇bbb| 精品av综合导航| 最新国产精品久久精品| 一区二区三区在线播| 久久精品国产网站| 东方aⅴ免费观看久久av| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产精品一级片在线观看| 91色在线porny| 欧美午夜在线观看| 久久久久久久久久久久电影| 亚洲人成网站色在线观看| 蜜桃精品在线观看| 色综合久久久久综合体桃花网| 欧美久久高跟鞋激| 日本一区二区三区dvd视频在线| 亚洲一区二区av在线| 国产一区二区三区香蕉| 91电影在线观看| 日韩一级大片在线观看| 亚洲欧美精品午睡沙发| 久久精品国产色蜜蜜麻豆| 粉嫩aⅴ一区二区三区四区| 欧美电视剧在线观看完整版| 亚洲视频在线观看三级| 国产一区二区剧情av在线| 欧美亚一区二区| 国产精品高潮呻吟| 久久99精品国产.久久久久久| 免费人成在线不卡| 91美女片黄在线观看91美女| 欧美成人精品3d动漫h| 久久综合九色综合97婷婷| 亚洲色图在线播放| 国产一区二区导航在线播放| 欧美日韩国产精选| 一区二区三区中文字幕在线观看| 国产麻豆91精品| 精品国产网站在线观看| 极品少妇一区二区三区精品视频 | 亚洲成人精品一区| 国产麻豆精品视频| 久久婷婷色综合| 毛片一区二区三区| 欧美日韩国产一级片| 亚洲精品国产精品乱码不99| 国产成人在线视频免费播放| 欧美电影免费观看高清完整版在| 日韩专区在线视频| 欧美日韩一区二区电影| 自拍偷拍国产亚洲| 99精品久久久久久| 国产精品久久精品日日| 成人精品gif动图一区| 久久婷婷久久一区二区三区| 亚洲成人精品一区二区| 欧美一区二区福利在线| 男人的j进女人的j一区| 欧美一区在线视频| 美女网站一区二区| 日韩一区二区三区av| 亚洲最快最全在线视频| 欧美日韩一级片在线观看| 亚洲一卡二卡三卡四卡五卡| 欧洲av一区二区嗯嗯嗯啊| 夜夜嗨av一区二区三区四季av| 在线影院国内精品| 亚洲激情图片qvod| 欧美日韩综合不卡| 国产美女精品一区二区三区| 中文字幕免费在线观看视频一区| 春色校园综合激情亚洲| 国产精品国产a|