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

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

?? dlgsmooth.cpp

?? 《Visual C++數字圖像獲取 處理及實踐應用》一書的源代碼
?? CPP
字號:
// DlgSmooth.cpp : implementation file
//

#include "stdafx.h"
#include "ImageProcessing.h"
#include "DlgSmooth.h"

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

/////////////////////////////////////////////////////////////////////////////
// CDlgSmooth dialog


CDlgSmooth::CDlgSmooth(CWnd* pParent /*=NULL*/)
	: CDialog(CDlgSmooth::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDlgSmooth)
	m_nTemType = 0;
	m_nSmthTemCenX = 0;
	m_nSmthTemCenY = 0;
	m_dbSmthTemCoef = 0.0;
	m_nSmthTemHeight = 0;
	m_nSmthTemWidth = 0;
	//}}AFX_DATA_INIT
}


void CDlgSmooth::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDlgSmooth)	
	DDX_Text(pDX, IDC_EDIT_SELFTEM_CEN_X, m_nSmthTemCenX);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_CEN_Y, m_nSmthTemCenY);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_COEF, m_dbSmthTemCoef);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_HEIGHT, m_nSmthTemHeight);
	DDV_MinMaxInt(pDX, m_nSmthTemHeight, 2, 5);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_WIDTH, m_nSmthTemWidth);
	DDV_MinMaxInt(pDX, m_nSmthTemWidth, 2, 5);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL0  , m_pdbTemp[0 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL1  , m_pdbTemp[1 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL2  , m_pdbTemp[2 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL3  , m_pdbTemp[3 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL4  , m_pdbTemp[4 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL5  , m_pdbTemp[5 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL6  , m_pdbTemp[6 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL7  , m_pdbTemp[7 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL8  , m_pdbTemp[8 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL9  , m_pdbTemp[9 ]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL10 , m_pdbTemp[10]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL11 , m_pdbTemp[11]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL12 , m_pdbTemp[12]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL13 , m_pdbTemp[13]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL14 , m_pdbTemp[14]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL15 , m_pdbTemp[15]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL16 , m_pdbTemp[16]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL17 , m_pdbTemp[17]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL18 , m_pdbTemp[18]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL19 , m_pdbTemp[19]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL20 , m_pdbTemp[20]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL22 , m_pdbTemp[22]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL23 , m_pdbTemp[23]);
	DDX_Text(pDX, IDC_EDIT_SELFTEM_EL24 , m_pdbTemp[24]);	
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CDlgSmooth, CDialog)
	//{{AFX_MSG_MAP(CDlgSmooth)
	ON_BN_CLICKED(IDC_RADIO_AVERTEM, OnRadioAvertem)
	ON_BN_CLICKED(IDC_RADIO_GUASSTEM, OnRadioGuasstem)
	ON_BN_CLICKED(IDC_RADIO_SELFTEM, OnRadioSelftem)
	ON_EN_KILLFOCUS(IDC_EDIT_SELFTEM_HEIGHT, OnKillfocusEditSelftemHeight)
	ON_EN_KILLFOCUS(IDC_EDIT_SELFTEM_WIDTH, OnKillfocusEditSelftemWidth)
	ON_EN_CHANGE(IDC_EDIT_SELFTEM_WIDTH, OnChangeEditSelftemWidth)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDlgSmooth message handlers


void CDlgSmooth::OnRadioAvertem() 
{
	// 設置3×3平均模板參數
	m_nTemType = 0;
	m_nSmthTemHeight = 3;
	m_nSmthTemWidth  = 3;
	m_nSmthTemCenX   = 1;
	m_nSmthTemCenY   = 1;
	m_dbSmthTemCoef  = (double)1.0/9.0;

	// 設置3×3平均模板元素
	m_pdbTemp[0] = 1.0;
	m_pdbTemp[1] = 1.0;
	m_pdbTemp[2] = 1.0;
	m_pdbTemp[3] = 0.0;
	m_pdbTemp[4] = 0.0;
	m_pdbTemp[5] = 1.0;
	m_pdbTemp[6] = 1.0;
	m_pdbTemp[7] = 1.0;
	m_pdbTemp[8] = 0.0;
	m_pdbTemp[9] = 0.0;
	m_pdbTemp[10] = 1.0;
	m_pdbTemp[11] = 1.0;
	m_pdbTemp[12] = 1.0;
	m_pdbTemp[13] = 0.0;
	m_pdbTemp[14] = 0.0;
	m_pdbTemp[15] = 0.0;
	m_pdbTemp[16] = 0.0;
	m_pdbTemp[17] = 0.0;
	m_pdbTemp[18] = 0.0;
	m_pdbTemp[19] = 0.0;
	m_pdbTemp[20] = 0.0;
	m_pdbTemp[21] = 0.0;
	m_pdbTemp[22] = 0.0;
	m_pdbTemp[23] = 0.0;
	m_pdbTemp[24] = 0.0;
	
	// 更新文本框狀態
	//UpdateEdit();
	
	// 更新
	UpdateData(FALSE);

	
}

void CDlgSmooth::OnRadioGuasstem() 
{
	// 3×3高斯模板
	m_nTemType = 1;
	m_nSmthTemHeight = 3;
	m_nSmthTemWidth  = 3;
	m_nSmthTemCenX   = 1;
	m_nSmthTemCenY   = 1;
	m_dbSmthTemCoef  = (double)(1.0/16.0);

	// 設置模板元素
	m_pdbTemp[0] = 1.0;
	m_pdbTemp[1] = 2.0;
	m_pdbTemp[2] = 1.0;
	m_pdbTemp[3] = 0.0;
	m_pdbTemp[4] = 0.0;
	m_pdbTemp[5] = 2.0;
	m_pdbTemp[6] = 4.0;
	m_pdbTemp[7] = 2.0;
	m_pdbTemp[8] = 0.0;
	m_pdbTemp[9] = 0.0;
	m_pdbTemp[10] = 1.0;
	m_pdbTemp[11] = 2.0;
	m_pdbTemp[12] = 1.0;
	m_pdbTemp[13] = 0.0;
	m_pdbTemp[14] = 0.0;
	m_pdbTemp[15] = 0.0;
	m_pdbTemp[16] = 0.0;
	m_pdbTemp[17] = 0.0;
	m_pdbTemp[18] = 0.0;
	m_pdbTemp[19] = 0.0;
	m_pdbTemp[20] = 0.0;
	m_pdbTemp[21] = 0.0;
	m_pdbTemp[22] = 0.0;
	m_pdbTemp[23] = 0.0;
	m_pdbTemp[24] = 0.0;
	
	// 更新文本框狀態
	UpdateEdit();
	
	// 更新
	UpdateData(FALSE);
}

void CDlgSmooth::OnRadioSelftem() 
{
	// TODO: Add your control notification handler code here
	// 自定義模板
	m_nTemType = 2;
	
	// 更新文本框狀態
	UpdateEdit();
}

void CDlgSmooth::OnKillfocusEditSelftemHeight() 
{
	// TODO: Add your control notification handler code here
		// 更新
	UpdateData(TRUE);
	
	// 更新文本框狀態
	UpdateEdit();
	
}

void CDlgSmooth::OnKillfocusEditSelftemWidth() 
{
	// TODO: Add your control notification handler code here
	// 更新
	UpdateData(TRUE);
	
	// 更新文本框狀態
	UpdateEdit();
}

void CDlgSmooth::OnOK() 
{
		// 獲取用戶設置(更新)
	UpdateData(TRUE);
	
	// 判斷設置是否有效
	if ((m_nSmthTemCenX  < 0) || (m_nSmthTemCenX > m_nSmthTemWidth - 1) ||
		(m_nSmthTemCenY < 0) || (m_nSmthTemCenY > m_nSmthTemHeight - 1))
	{
		// 提示用戶參數設置錯誤
		MessageBox("中心元素參數設置錯誤!", "系統提示" , 
			MB_ICONINFORMATION | MB_OK);
		
		// 返回
		return;
	}
	
	// 更新模板元素數組(將有效元素放置在數組的前面)
	for (int i = 0; i < m_nSmthTemHeight; i++)
	{
		for (int j = 0; j < m_nSmthTemWidth; j++)
		{
			m_pdbTemp[i * m_nSmthTemWidth + j] = m_pdbTemp[i * 5 + j];
		}
	}
	
	// 更新
	UpdateData(FALSE);
	
	// 退出
	CDialog::OnOK();
}

void CDlgSmooth::OnChangeEditSelftemWidth() 
{
	// TODO: If this is a RICHEDIT control, the control will not
	// send this notification unless you override the CDialog::OnInitDialog()
	// function and call CRichEditCtrl().SetEventMask()
	// with the ENM_CHANGE flag ORed into the mask.
	
	// TODO: Add your control notification handler code here
	
}


void CDlgSmooth::UpdateEdit()
{
	BOOL	bEnable;
	
	// 循環變量
	int		i;
	int		j;
	
	// 判斷是不是自定義模板
	if (m_nTemType  == 2) 
	{
		bEnable = TRUE;
	}
	else
	{
		bEnable = FALSE;
	}

	// 設置文本框可用狀態
	(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_HEIGHT)->EnableWindow(bEnable);
	(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_WIDTH)->EnableWindow(bEnable);
	(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_COEF)->EnableWindow(bEnable);
	(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_CEN_X)->EnableWindow(bEnable);
	(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_CEN_Y)->EnableWindow(bEnable);
	
	// IDC_EDIT_SELFTEM_EL0等ID其實是一個整數,它的數值定義在Resource.h中定義。

	// 設置模板元素文本框bEnable狀態
	for (i = IDC_EDIT_SELFTEM_EL0; i <= IDC_EDIT_SELFTEM_EL24; i++)
	{
		// 設置文本框不可編輯
		(CEdit *) GetDlgItem(i)->EnableWindow(bEnable);
	}
	
	// 顯示應該可見的模板元素文本框
	for (i = 0; i < m_nSmthTemHeight; i++)
	{
		for (j = 0; j < m_nSmthTemWidth; j++)
		{
			// 設置文本框可見
			(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_EL0 + i*5 + j)->ShowWindow(SW_SHOW);
		}
	}
	
	// 隱藏應該不可見的模板元素文本框(前m_nSmthTemHeight行的后幾列)
	for (i = 0; i < m_nSmthTemHeight; i++)
	{
		for (j = m_nSmthTemWidth; j < 5; j++)
		{
			// 設置不可見
			(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_EL0 + i*5 + j)->ShowWindow(SW_HIDE);
		}
	}
	
	// 隱藏應該不可見的模板元素文本框(后幾行)
	for (i = m_nSmthTemHeight; i < 5; i++)
	{
		for (j = 0; j < 5; j++)
		{
			// 設置不可見
			(CEdit *) GetDlgItem(IDC_EDIT_SELFTEM_EL0 + i*5 + j)->ShowWindow(SW_HIDE);
		}
	}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区二区电影| 一个色综合网站| 亚洲日本在线看| 免费人成精品欧美精品| 成人av动漫网站| 欧美一区二区三区四区高清| 最新中文字幕一区二区三区| 久久草av在线| 精品国产一区二区三区久久影院| 亚洲一区二区三区三| 粉嫩aⅴ一区二区三区四区五区| 91麻豆精品91久久久久久清纯| 国产精品久久久久久久久久久免费看| 麻豆国产欧美日韩综合精品二区 | 欧美一区三区四区| 亚洲精品国产一区二区精华液| 国产一区在线观看视频| 91精品国产欧美一区二区成人| 亚洲人妖av一区二区| 国产成人免费在线观看| 精品精品国产高清一毛片一天堂| 亚洲一区国产视频| 色综合中文综合网| 国产欧美久久久精品影院| 美国十次了思思久久精品导航| 欧美午夜精品久久久久久超碰| 中文字幕一区在线观看视频| 国产寡妇亲子伦一区二区| 2020国产精品自拍| 国产一区日韩二区欧美三区| 精品久久久久久最新网址| 另类小说色综合网站| 日韩视频免费观看高清完整版在线观看 | 91麻豆蜜桃一区二区三区| 国产精品久久久久久亚洲毛片 | 成人综合日日夜夜| 中文字幕av免费专区久久| 高清免费成人av| 亚洲国产成人在线| 成人av在线网站| 日韩毛片视频在线看| 99精品国产99久久久久久白柏| 亚洲欧洲性图库| 欧美午夜精品免费| 全部av―极品视觉盛宴亚洲| 日韩一级视频免费观看在线| 国产在线看一区| 国产欧美一区视频| a亚洲天堂av| 一区二区三区**美女毛片| 欧美人动与zoxxxx乱| 久久99精品国产麻豆婷婷洗澡| 久久久精品免费网站| 99久久伊人精品| 亚洲自拍偷拍九九九| 中文字幕日韩一区二区| 欧美视频三区在线播放| 免费在线观看成人| 国产精品私人自拍| 在线观看av不卡| 韩国毛片一区二区三区| 国产精品久久久久一区| 欧美色中文字幕| 国产专区欧美精品| 一区二区三区四区蜜桃| 日韩欧美国产1| 91麻豆国产精品久久| 日韩极品在线观看| 国产精品丝袜黑色高跟| 欧美人动与zoxxxx乱| 国产sm精品调教视频网站| 亚洲一级在线观看| 欧美xxxxxxxx| 欧洲色大大久久| 国产精品18久久久久久久久久久久 | 国内精品视频666| 亚洲欧美另类久久久精品2019| 91麻豆精品91久久久久久清纯| 成人av在线看| 麻豆精品在线视频| 亚洲主播在线播放| 中文字幕欧美激情一区| 欧美剧情片在线观看| 成人黄色片在线观看| 琪琪一区二区三区| 亚洲三级电影网站| 欧美国产在线观看| 久久综合九色综合97_久久久| 欧美中文一区二区三区| 99久久精品久久久久久清纯| 精品一区二区三区蜜桃| 三级久久三级久久久| 1区2区3区国产精品| 国产女人18毛片水真多成人如厕| 日韩一区二区中文字幕| 色94色欧美sute亚洲13| caoporn国产精品| 大白屁股一区二区视频| 国产精品 日产精品 欧美精品| 亚洲国产精品影院| 亚洲精品免费视频| 1024成人网| 亚洲人午夜精品天堂一二香蕉| 国产色婷婷亚洲99精品小说| 精品久久一二三区| 欧美mv日韩mv国产网站| 欧美成人乱码一区二区三区| 337p亚洲精品色噜噜狠狠| 欧美裸体一区二区三区| 欧美日韩国产影片| 欧美日韩dvd在线观看| 欧美特级限制片免费在线观看| 日韩片之四级片| 欧美日韩大陆在线| 欧美亚洲图片小说| 欧美日韩aaaaa| 日韩一区二区三| 久久久精品天堂| 中文一区二区在线观看| 国产精品乱人伦| 中文字幕日韩精品一区| 亚洲精品菠萝久久久久久久| 亚洲美女少妇撒尿| 亚洲 欧美综合在线网络| 五月天婷婷综合| 蜜桃av一区二区三区电影| 精品一区二区三区免费视频| 国产精品一区二区三区四区| 成人精品一区二区三区四区 | 日韩三级视频中文字幕| www欧美成人18+| 亚洲国产精品99久久久久久久久| 中文字幕一区三区| 亚洲一区在线免费观看| 久久精品国产久精国产| 国产精品一区三区| 在线观看国产91| 精品久久久久一区二区国产| 国产精品久线在线观看| 亚洲18影院在线观看| 精品在线播放免费| 99在线视频精品| 日韩一级二级三级精品视频| 国产日韩欧美在线一区| 亚洲在线观看免费| 精品一区二区三区香蕉蜜桃 | 欧美成人aa大片| 成人欧美一区二区三区小说| 亚洲成a人片在线观看中文| 国产成人精品亚洲日本在线桃色 | 亚洲精品第一国产综合野| 日韩成人一区二区三区在线观看| 国产原创一区二区三区| 在线观看欧美日本| 久久精品一区蜜桃臀影院| 亚瑟在线精品视频| 国产麻豆视频一区| 欧美亚洲禁片免费| 久久久久久97三级| 日韩成人一区二区| 色哟哟一区二区三区| 2023国产精品| 国产精品久久久久久久浪潮网站 | 17c精品麻豆一区二区免费| 日韩国产精品久久久久久亚洲| 国产美女av一区二区三区| 91精品在线一区二区| 午夜免费欧美电影| 国产乱子伦视频一区二区三区| 欧美亚洲愉拍一区二区| 国产精品天天看| 国产电影精品久久禁18| 欧美日韩午夜精品| 亚洲欧洲99久久| 国产91精品在线观看| 日韩欧美成人一区| 婷婷成人激情在线网| 91麻豆福利精品推荐| 国产精品女人毛片| 国内外成人在线| 日韩一级片网站| 日本成人超碰在线观看| 欧美日韩视频在线第一区 | 亚洲人成在线播放网站岛国 | 午夜激情一区二区| 日本乱人伦aⅴ精品| 亚洲三级在线看| 91在线一区二区| 日韩美女视频一区二区| yourporn久久国产精品| 国产精品天天看| 成人黄色在线视频| 中文字幕视频一区| 波多野结衣91| 亚洲欧洲日本在线| 日本高清成人免费播放| 一区二区三区精品在线观看| 日本乱人伦一区| 亚洲va欧美va国产va天堂影院| 欧美视频一区二区三区在线观看|