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

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

?? dynsplitview2.cpp

?? 圖像處理算法相關(guān)VC程序 VC++圖像處理程序設(shè)計(jì)配套光盤
?? CPP
字號(hào):
// DynSplitView2.cpp : implementation file
//

#include "stdafx.h"
#include "DSplit.h"
#include "DynSplitView2.h"
#include "XiaoChuHeiDian.h"
#include "THREETHREEJUNZHI.h"
#include "NNJUNZHI.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2

IMPLEMENT_DYNCREATE(CDynSplitView2, CView)

CDynSplitView2::CDynSplitView2()
{
	state2=0;
}

void CDynSplitView2::clearmem()
{
	CDSplitDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc ->statedoc=0;
    state2=1;
	CDibNew1=&pDoc->CDibNew;
    CDib1=&pDoc->CDib;
	long int  size=CDib1->GetHeight()*CDib1->GetDibWidthBytes();
	memcpy(CDibNew1->m_pData,CDib1->m_pData,size);

}

CPalette * CDynSplitView2::CreateBitmapPalette(ZaoShengXiaoChuDib * pBitmap)
	{
		struct
		{
			WORD Version;
			WORD NumberOfEntries;
			PALETTEENTRY aEntries[256];
		} palette = { 0x300, 256 };
		
		LPRGBQUAD pRGBTable = pBitmap->GetRGB();
		UINT numberOfColors = pBitmap->GetNumberOfColors();
		
		for(UINT x=0; x<numberOfColors; ++x)
		{
			palette.aEntries[x].peRed =
				pRGBTable[x].rgbRed;
			palette.aEntries[x].peGreen =
				pRGBTable[x].rgbGreen;
			palette.aEntries[x].peBlue =
				pRGBTable[x].rgbBlue;
			palette.aEntries[x].peFlags = 0;
		}
		
			hPalette.CreatePalette((LPLOGPALETTE)&palette);
		//CPalette hPale=&hPalette;
		return &hPalette;
	}

CDynSplitView2::~CDynSplitView2()
{
}
CDSplitDoc* CDynSplitView2::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CDSplitDoc)));
	return (CDSplitDoc*)m_pDocument;
}


BEGIN_MESSAGE_MAP(CDynSplitView2, CView)
	//{{AFX_MSG_MAP(CDynSplitView2)
	ON_WM_ERASEBKGND()
	ON_COMMAND(ID_FILESAVE, OnFilesave)
	ON_COMMAND(ID_XIAOCHUHEIDIAN, OnXiaochuheidian)
	ON_COMMAND(ID_33JUNZHI, On33junzhi)
	ON_COMMAND(ID_NNJUNZHI, OnNnjunzhi)
	ON_COMMAND(ID_JUBUPINGJUN, OnJubupingjun)
	ON_COMMAND(ID_NNZHONGZHI, OnNnzhongzhi)
	ON_COMMAND(ID_SHIZI, OnShizi)
	ON_COMMAND(ID_NNZUIDA, OnNnzuida)
	ON_COMMAND(ID_SUIJIZAOSHENG, OnSuijizaosheng)
	ON_COMMAND(ID_JIAOYANZAOSHENG, OnJiaoyanzaosheng)
	ON_COMMAND(ID_FANZHUAN, OnFanzhuan)
	ON_COMMAND(ID_CHAOXIAN, OnChaoxian)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 drawing

void CDynSplitView2::OnDraw(CDC* pDC)
{	
	CDSplitDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	if(!pDoc ->statedoc&&state2==1)
	{
 	    int m_scale=1;
        BYTE* pBitmapData = CDibNew1->GetData();
        LPBITMAPINFO pBitmapInfo = CDibNew1->GetInfo();
        int bitmapHeight = CDibNew1->GetHeight();
        int bitmapWidth = CDibNew1->GetWidth();
		int scaledWidth = (int)(bitmapWidth * m_scale);
		int scaledHeight = (int)(bitmapHeight * m_scale);
		if (CDibNew1->GetRGB()) // Has a color table
		{
	  		CPalette * hPalette=CreateBitmapPalette(CDibNew1);
            CPalette * hOldPalette =
                pDC->SelectPalette(hPalette, true);
            pDC->RealizePalette();
			::StretchDIBits(pDC->GetSafeHdc(),0,0,scaledWidth,scaledHeight,
               0,0,bitmapWidth,bitmapHeight,
				pBitmapData,pBitmapInfo,
				DIB_RGB_COLORS, SRCCOPY);
            pDC->SelectPalette(hOldPalette, true);
            ::DeleteObject(hPalette);
		}
		else
		{
            StretchDIBits(pDC->GetSafeHdc(),
                0, 0, scaledWidth, scaledHeight,
                0, 0, bitmapWidth, bitmapHeight,
				pBitmapData, pBitmapInfo,
				DIB_RGB_COLORS, SRCCOPY);
		}
	}
}


/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 diagnostics

#ifdef _DEBUG
void CDynSplitView2::AssertValid() const
{
	CView::AssertValid();
}

void CDynSplitView2::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CDynSplitView2 message handlers

BOOL CDynSplitView2::OnEraseBkgnd(CDC* pDC) 
{
	CRect rect;
	GetClientRect(&rect);
	pDC->FillSolidRect(&rect,::GetSysColor(COLOR_WINDOW));
	return TRUE;
}



void CDynSplitView2::OnFilesave() 
{
	CFileDialog dlg(FALSE,_T("BMP"),_T("*.BMP"),OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,_T("位圖文件(*.BMP)|*.BMP|"));	
    if(IDOK==dlg.DoModal())
	CString  filename;
    filename.Format ("%s",dlg.GetPathName() );    
    CDibNew1->SaveFile(filename);
	state2=1;
	Invalidate();

}

void CDynSplitView2::OnFanzhuan() //二值圖像的黑白點(diǎn)噪
{
	clearmem();
 	CDibNew1->HeiBaiFanZhuan();//二值圖像的黑白點(diǎn)噪
	Invalidate();	
}
void CDynSplitView2::OnXiaochuheidian() 
{
	clearmem();
    XiaoChuHeiDian dlg;
    if(IDOK==dlg.DoModal())
	{
		int connec=dlg.n;
	    CDibNew1->black(connec);//消除圖像的孤立黑點(diǎn)
		Invalidate();	
	}
}
void CDynSplitView2::On33junzhi() 
{
	clearmem();
 	CDibNew1->threethree();//對(duì)圖像進(jìn)行3*3均值濾波
	Invalidate();	

}

void CDynSplitView2::OnChaoxian() 
{
	clearmem();
    THREETHREEJUNZHI dlg;
    if(IDOK==dlg.DoModal())
	{
		int t=dlg.m_T;
	    CDibNew1->Chaoxian(t);//超限鄰域平均法
		Invalidate();	
	}	
}

void CDynSplitView2::OnNnjunzhi() 
{
	clearmem();
    NNJUNZHI dlg;
    if(IDOK==dlg.DoModal())
    {
		CDibNew1->nn(dlg.m_n);//對(duì)圖像進(jìn)行n*n均值濾波
		Invalidate();	
	}
}

void CDynSplitView2::OnJubupingjun() 
{
	clearmem();
    CDibNew1->jubupingjun();//對(duì)圖像進(jìn)行有選擇局部平均化
	Invalidate();	
}

void CDynSplitView2::OnNnzhongzhi() 
{
	clearmem();
    NNJUNZHI dlg;
    if(IDOK==dlg.DoModal())
    {
		CDibNew1->nnzhong(dlg.m_n);//對(duì)圖像進(jìn)行N*N中值濾波
		Invalidate();	
	}
}

void CDynSplitView2::OnShizi() 
{
	clearmem();
    NNJUNZHI dlg;
    if(IDOK==dlg.DoModal())
    {
		CDibNew1->shizi(dlg.m_n);//對(duì)圖像進(jìn)行十字型中值濾波
		Invalidate();	
	}
}

void CDynSplitView2::OnNnzuida() 
{
	clearmem();
    NNJUNZHI dlg;
    if(IDOK==dlg.DoModal())
    {
		CDibNew1->nnzuida(dlg.m_n);//對(duì)圖像進(jìn)行N*N最大濾波
		Invalidate();	
	}
}

void CDynSplitView2::OnSuijizaosheng() 
{
	clearmem();
    CDibNew1->suijizaosheng();//對(duì)圖像產(chǎn)生隨機(jī)噪聲
	Invalidate();	
}

void CDynSplitView2::OnJiaoyanzaosheng() 
{
	clearmem();
    CDibNew1->jiaoyanzaosheng();//對(duì)圖像產(chǎn)生椒鹽噪聲
	Invalidate();	
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线视频中文字幕一区二区| 亚洲品质自拍视频| 国产精品久久久久影院亚瑟| 视频一区中文字幕| 色狠狠av一区二区三区| 26uuu精品一区二区| 日韩电影一区二区三区| 91激情在线视频| 国产免费成人在线视频| 精品无人区卡一卡二卡三乱码免费卡| 91免费看`日韩一区二区| 国产视频一区不卡| 韩国av一区二区三区四区| 91精品国产综合久久精品图片 | 精品国产一区二区三区四区四 | 17c精品麻豆一区二区免费| 精久久久久久久久久久| 欧美一区二区久久久| 婷婷开心激情综合| 欧美在线你懂得| 亚洲精品成人a在线观看| 99麻豆久久久国产精品免费优播| 2020国产精品| 黑人巨大精品欧美黑白配亚洲| 日韩欧美国产1| 老色鬼精品视频在线观看播放| 欧美精品久久久久久久多人混战 | 久久超碰97中文字幕| 制服丝袜亚洲网站| 青草av.久久免费一区| 91精品国产日韩91久久久久久| 日日夜夜一区二区| 欧美一区二区大片| 老司机精品视频一区二区三区| 日韩亚洲欧美在线| 韩国v欧美v亚洲v日本v| 国产视频一区不卡| 成人妖精视频yjsp地址| 国产精品电影院| 91久久精品网| 日韩av在线播放中文字幕| 日韩三级精品电影久久久| 黑人巨大精品欧美一区| 国产精品视频观看| 色伊人久久综合中文字幕| 亚洲一二三区在线观看| 欧美一区二区免费观在线| 国产美女娇喘av呻吟久久| 国产精品系列在线| 欧美午夜片在线看| 日本不卡高清视频| 国产欧美精品区一区二区三区| 成人精品小蝌蚪| 亚洲成人免费电影| 日韩精品中文字幕一区 | 久久国产精品无码网站| 国产亚洲午夜高清国产拍精品| www..com久久爱| 亚洲国产日韩a在线播放| 日韩欧美国产三级电影视频| 国产盗摄一区二区三区| 一区二区三区在线观看网站| 日韩一区二区在线观看视频| 国产成a人亚洲| 亚洲成人av电影在线| 日韩视频123| 91色乱码一区二区三区| 美腿丝袜在线亚洲一区| 亚洲人午夜精品天堂一二香蕉| 欧美一区二区啪啪| 97精品久久久午夜一区二区三区 | 成人av在线观| 午夜电影网一区| 中文在线一区二区| 欧美美女一区二区三区| 不卡在线视频中文字幕| 日韩福利电影在线| 最好看的中文字幕久久| 精品久久久久久久久久久久久久久| 99久久精品情趣| 精品中文字幕一区二区小辣椒| 亚洲最新在线观看| 欧美—级在线免费片| 日韩欧美一区二区在线视频| 99re6这里只有精品视频在线观看| 久久99精品国产麻豆不卡| 亚洲在线免费播放| 18涩涩午夜精品.www| 国产亚洲一区字幕| 精品捆绑美女sm三区| 欧美日韩一区二区欧美激情| 99国产精品国产精品毛片| 国产中文一区二区三区| 蜜臀av一区二区在线免费观看| 亚洲自拍另类综合| 亚洲裸体xxx| 国产精品视频一区二区三区不卡| 亚洲精品一区二区在线观看| 欧美一级搡bbbb搡bbbb| 欧美视频在线观看一区二区| 99re这里只有精品6| 成人午夜又粗又硬又大| 国产成人99久久亚洲综合精品| 国产综合色精品一区二区三区| 奇米亚洲午夜久久精品| 欧美aa在线视频| 日本伊人色综合网| 日本一道高清亚洲日美韩| 视频精品一区二区| 美女一区二区久久| 奇米色一区二区三区四区| 奇米影视一区二区三区| 蜜桃视频在线一区| 黄网站免费久久| 处破女av一区二区| 成人app在线观看| 99国产精品久久久久| 色一区在线观看| 欧美日韩高清影院| 91精品麻豆日日躁夜夜躁| 欧美一级片在线| 久久久久97国产精华液好用吗| 久久精品免视看| 中文字幕日韩一区二区| 亚洲精品一二三四区| 亚洲一区中文日韩| 麻豆91在线播放免费| 国产经典欧美精品| 91在线视频在线| 欧美日韩亚洲综合一区二区三区 | 国产精品情趣视频| 亚洲精品欧美专区| 日本中文字幕一区二区有限公司| 精品一区二区三区免费观看 | 制服视频三区第一页精品| 亚洲精品在线三区| 国产精品美女久久久久久久网站| 亚洲一区二区三区中文字幕| 久久国产视频网| 91一区二区三区在线播放| 欧美日本乱大交xxxxx| 欧美精品一区视频| 成人免费在线视频观看| 日韩中文字幕av电影| 国产精品一级黄| 欧美亚洲免费在线一区| 精品国产乱码久久久久久久| 亚洲人快播电影网| 九九**精品视频免费播放| 99re热这里只有精品免费视频| 在线不卡一区二区| 国产欧美日韩不卡免费| 五月激情六月综合| 成人自拍视频在线观看| 欧美性极品少妇| 国产精品网站在线观看| 日韩精品亚洲一区| 色综合久久综合网| 久久综合九色综合欧美98 | 亚洲三级理论片| 日本va欧美va精品| 91色porny蝌蚪| 久久久久久久久伊人| 日韩av不卡一区二区| 在线观看亚洲a| 国产人久久人人人人爽| 日精品一区二区| 91蜜桃视频在线| 日本一区二区三区四区 | 9191成人精品久久| 亚洲欧美日韩一区| 成人一级视频在线观看| 亚洲精品一区二区三区四区高清| 亚洲bdsm女犯bdsm网站| 91麻豆精东视频| 国产精品久久久久久久久搜平片 | 国产欧美日韩精品a在线观看| 午夜久久电影网| 色综合久久久久综合体| 国产精品美女一区二区在线观看| 精品系列免费在线观看| 欧美一区二区精品| 亚洲va欧美va国产va天堂影院| 91色|porny| 亚洲乱码中文字幕| 色综合久久久久| 亚洲三级在线免费观看| 99精品偷自拍| 中文字幕一区二区三区不卡| 国产suv精品一区二区6| 欧美国产精品久久| 成人小视频在线| 中日韩av电影| av一区二区三区在线| 自拍偷拍亚洲激情| 日本韩国视频一区二区| 亚洲永久免费视频| 91精品午夜视频| 久久99最新地址| 久久伊人中文字幕|