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

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

?? linetransview.cpp

?? 神經(jīng)網(wǎng)絡(luò)代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// LineTransView.cpp : implementation of the CLineTransView class
//

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

#include "LineTransDoc.h"
#include "LineTransView.h"
#include "mainfrm.h"

#include "IntensityDlg.h"
#include "LinerParaDlg.h"
#include "PointStreDlg.h"
#include "PointThreDlg.h"
#include "PointWinDlg.h"

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

/////////////////////////////////////////////////////////////////////////////
// CLineTransView

IMPLEMENT_DYNCREATE(CLineTransView, CScrollView)

BEGIN_MESSAGE_MAP(CLineTransView, CScrollView)
	//{{AFX_MSG_MAP(CLineTransView)
	ON_WM_ERASEBKGND()
	ON_COMMAND(ID_EDIT_COPY, OnEditCopy)
	ON_UPDATE_COMMAND_UI(ID_EDIT_COPY, OnUpdateEditCopy)
	ON_COMMAND(ID_EDIT_PASTE, OnEditPaste)
	ON_UPDATE_COMMAND_UI(ID_EDIT_PASTE, OnUpdateEditPaste)
	ON_COMMAND(ID_VIEW_INTENSITY, OnViewIntensity)
	ON_COMMAND(ID_POINT_EQUA, OnPointEqua)
	ON_COMMAND(ID_POINT_INVERT, OnPointInvert)
	ON_COMMAND(ID_POINT_LINER, OnPointLiner)
	ON_COMMAND(ID_POINT_STRE, OnPointStre)
	ON_COMMAND(ID_POINT_THRE, OnPointThre)
	ON_COMMAND(ID_POINT_WIND, OnPointWind)
	ON_COMMAND(ID_CHANGETOGRAY, OnChangetogray)
	ON_COMMAND(ID_BICOLOUR, OnBicolour)
	ON_COMMAND(ID_DENOISE, OnDenoise)
	ON_COMMAND(ID_RUIHUA, OnRuihua)
	ON_COMMAND(ID_SLOPEADJUST, OnSlopeadjust)
	ON_COMMAND(ID_CHARSEGEMT, OnCharsegemt)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CScrollView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CLineTransView construction/destruction

CLineTransView::CLineTransView()
{
	// TODO: add construction code here

}

CLineTransView::~CLineTransView()
{
}

BOOL CLineTransView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CLineTransView drawing

void CLineTransView::OnDraw(CDC* pDC)
{
	BeginWaitCursor();

	CLineTransDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	HDIB hDIB = pDoc->GetHDIB();
	if (hDIB != NULL)
	{
		LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) hDIB);
		int cxDIB = (int) pDoc->GetDibImage()->DIBWidth(lpDIB);
		int cyDIB = (int) pDoc->GetDibImage()->DIBHeight(lpDIB);

		::GlobalUnlock((HGLOBAL) hDIB);
		
		CRect rcDIB;
		rcDIB.top = rcDIB.left = 0;
		rcDIB.right = cxDIB;
		rcDIB.bottom = cyDIB;
		
		CRect rcDest;
		
		if (pDC->IsPrinting())
		{
			// 是打印,計算輸出圖像的位置和大小,以便符合頁面
			
			// 獲取打印頁面的水平寬度(象素)
			int cxPage = pDC->GetDeviceCaps(HORZRES);			
			// 獲取打印頁面的垂直高度(象素)
			int cyPage = pDC->GetDeviceCaps(VERTRES);			
			// 獲取打印機每英寸象素數(shù)
			int cxInch = pDC->GetDeviceCaps(LOGPIXELSX);
			int cyInch = pDC->GetDeviceCaps(LOGPIXELSY);
			
			// 計算打印圖像大小(縮放,根據(jù)頁面寬度調(diào)整圖像大小)
			rcDest.top = rcDest.left = 0;
			rcDest.bottom = (int)(((double)cyDIB * cxPage * cyInch)
					/ ((double)cxDIB * cxInch));
			rcDest.right = cxPage;
			
			// 計算打印圖像位置(垂直居中)
			int temp = cyPage - (rcDest.bottom - rcDest.top);
			rcDest.bottom += temp/2;
			rcDest.top += temp/2;
		}
		else   
		{
			// 不必縮放圖像
			rcDest = rcDIB;
		}
		
		pDoc->GetDibImage()->PaintDIB(pDC->m_hDC, &rcDest, pDoc->GetHDIB(),
			&rcDIB, pDoc->GetDocPalette());
	}
	
	EndWaitCursor();
}

void CLineTransView::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();

	// TODO: calculate the total size of this view

}

/////////////////////////////////////////////////////////////////////////////
// CLineTransView printing

BOOL CLineTransView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// 設(shè)置總頁數(shù)為一。
	pInfo->SetMaxPage(1);

	return DoPreparePrinting(pInfo);
}

void CLineTransView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CLineTransView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CLineTransView diagnostics

#ifdef _DEBUG
void CLineTransView::AssertValid() const
{
	CScrollView::AssertValid();
}

void CLineTransView::Dump(CDumpContext& dc) const
{
	CScrollView::Dump(dc);
}

CLineTransDoc* CLineTransView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CLineTransDoc)));
	return (CLineTransDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CLineTransView message handlers

BOOL CLineTransView::OnEraseBkgnd(CDC* pDC) 
{
	// 主要是為了設(shè)置子窗體默認(rèn)的背景色
	// 背景色由文檔成員變量m_refColorBKG指定

	CLineTransDoc* pDoc = GetDocument();
	CBrush brush(pDoc->m_refColorBKG);                                              
	CBrush* pOldBrush = pDC->SelectObject(&brush);
		
	CRect rectClip;
	pDC->GetClipBox(&rectClip);			// 獲取重繪區(qū)域	
	pDC->PatBlt(rectClip.left, rectClip.top, rectClip.Width(), 
		rectClip.Height(), PATCOPY);

	pDC->SelectObject(pOldBrush);                                                  

	return TRUE;
}

void CLineTransView::OnEditCopy() 
{
	// 復(fù)制當(dāng)前圖像

	CLineTransDoc* pDoc = GetDocument();
	
	if (OpenClipboard())
	{
		BeginWaitCursor();
		EmptyClipboard();
		
		// 復(fù)制當(dāng)前圖像到剪貼板
		SetClipboardData (CF_DIB, pDoc->GetDibImage()->
			CopyHandle((HANDLE) pDoc->GetHDIB()) );

		CloseClipboard();
		EndWaitCursor();
	}
}

void CLineTransView::OnUpdateEditCopy(CCmdUI* pCmdUI) 
{
	// 如果當(dāng)前DIB對象不空,復(fù)制菜單項有效
	pCmdUI->Enable(GetDocument()->GetHDIB() != NULL);
}

void CLineTransView::OnEditPaste() 
{
	// 粘貼圖像
	
	HDIB hNewDIB = NULL;
	CLineTransDoc* pDoc = GetDocument();
	
	if (OpenClipboard())
	{
		BeginWaitCursor();

		// 讀取剪貼板中的圖像
		hNewDIB = (HDIB)pDoc->GetDibImage()->CopyHandle(::GetClipboardData(CF_DIB));

		CloseClipboard();
		
		if (hNewDIB != NULL)
		{
			pDoc->ReplaceHDIB(hNewDIB);		// 替換DIB,同時釋放舊DIB對象		
			pDoc->InitDIBData();			// 更新DIB大小和調(diào)色板		
			pDoc->SetModifiedFlag(TRUE);	// 設(shè)置臟標(biāo)記	
			SetScrollSizes(MM_TEXT, pDoc->GetDocSize());	// 重新設(shè)置滾動視圖大小		
			OnDoRealize((WPARAM)m_hWnd,0);	// 實現(xiàn)新的調(diào)色板		
			pDoc->UpdateAllViews(NULL);		// 更新視圖
		}

		EndWaitCursor();
	}
}

void CLineTransView::OnUpdateEditPaste(CCmdUI* pCmdUI) 
{
	// 如果當(dāng)前剪貼板中有DIB對象,粘貼菜單項有效
	pCmdUI->Enable(::IsClipboardFormatAvailable(CF_DIB));
}

LRESULT CLineTransView::OnDoRealize(WPARAM wParam, LPARAM)
{
	ASSERT(wParam != NULL);

	CLineTransDoc* pDoc = GetDocument();	
	if (pDoc->GetHDIB() == NULL)
	{
		return 0L;
	}
	
	CPalette* pPal = pDoc->GetDocPalette();
	if (pPal != NULL)
	{
		CMainFrame* pAppFrame = (CMainFrame*) AfxGetApp()->m_pMainWnd;
		ASSERT_KINDOF(CMainFrame, pAppFrame);
		
		CClientDC appDC(pAppFrame);

		// All views but one should be a background palette.
		// wParam contains a handle to the active view, so the SelectPalette
		// bForceBackground flag is FALSE only if wParam == m_hWnd (this view)
		CPalette* oldPalette = appDC.SelectPalette(pPal,((HWND)wParam)!=m_hWnd);	
		if (oldPalette != NULL)
		{
			UINT nColorsChanged = appDC.RealizePalette();
			if (nColorsChanged > 0)
			{
				pDoc->UpdateAllViews(NULL);
			}
			appDC.SelectPalette(oldPalette, TRUE);
		}
		else
		{
			TRACE0("\tCCh1_1View::OnPaletteChanged中調(diào)用SelectPalette()失敗!\n");
		}
	}
	
	return 0L;
}

void CLineTransView::OnActivateView(BOOL bActivate, CView* pActivateView, CView* pDeactiveView) 
{
	CScrollView::OnActivateView(bActivate, pActivateView, pDeactiveView);

	if (bActivate)
	{
		ASSERT(pActivateView == this);
		OnDoRealize((WPARAM)m_hWnd, 0);   // same as SendMessage(WM_DOREALIZE);
	}
}

void CLineTransView::CalcWindowRect(LPRECT lpClientRect, UINT nAdjustType) 
{
	CScrollView::OnInitialUpdate();
	ASSERT(GetDocument() != NULL);
	
	SetScrollSizes(MM_TEXT, GetDocument()->GetDocSize());
}

void CLineTransView::OnViewIntensity() 
{
	// 查看當(dāng)前圖像灰度直方圖

	CLineTransDoc* pDoc = GetDocument();
	
	LPSTR lpDIB;			// 指向DIB的指針	
	LPSTR    lpDIBBits;		// 指向DIB象素指針
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());	
	// 找到DIB圖像象素起始位置
	lpDIBBits = pDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖,其它的可以類推)
	if (pDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("目前只支持查看256色位圖灰度直方圖!", "系統(tǒng)提示" , 
			MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
		
		return;
	}
	
	BeginWaitCursor();

	CIntensityDlg dlgPara;
	dlgPara.m_lpDIBBits = lpDIBBits;
	dlgPara.m_lWidth = pDoc->GetDibImage()->DIBWidth(lpDIB);
	dlgPara.m_lHeight = pDoc->GetDibImage()->DIBHeight(lpDIB);
	dlgPara.m_iLowGray = 0;
	dlgPara.m_iUpGray = 255;
	
	// 顯示對話框,提示用戶設(shè)定平移量
	if (dlgPara.DoModal() != IDOK)
	{
		return;
	}

	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	EndWaitCursor();
}

void CLineTransView::OnPointEqua() 
{
	// 灰度均衡

	CLineTransDoc* pDoc = GetDocument();
		
	LPSTR	lpDIB;				// 指向DIB的指針	
	LPSTR    lpDIBBits;			// 指向DIB象素指針
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());
	// 找到DIB圖像象素起始位置
	lpDIBBits = pDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖的直方圖均衡,其它的可以類推)
	if (pDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("目前只支持256色位圖的直方圖均衡!", "系統(tǒng)提示" , 
			MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());

		return;
	}
	
	BeginWaitCursor();
	
	// 調(diào)用InteEqualize()函數(shù)進行直方圖均衡
	pDoc->GetDibImage()->InteEqualize(lpDIBBits,pDoc->GetDibImage()->DIBWidth(lpDIB), 
		pDoc->GetDibImage()->DIBHeight(lpDIB));

	pDoc->SetModifiedFlag(TRUE);	// 設(shè)置臟標(biāo)記	
	pDoc->UpdateAllViews(NULL);		// 更新視圖
	
	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	EndWaitCursor();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产欧美日韩| 欧美日韩中文一区| 亚洲成人激情av| 欧美精品一区二区三区四区| 色综合咪咪久久| 国产成人亚洲精品青草天美| 亚洲福利视频一区二区| 国产欧美日本一区二区三区| 欧美丰满嫩嫩电影| 色又黄又爽网站www久久| 国产真实精品久久二三区| 亚洲成av人在线观看| 亚洲欧美偷拍另类a∨色屁股| 精品国产乱码久久久久久老虎| 欧美日韩久久一区| 95精品视频在线| 国产iv一区二区三区| 蜜桃久久久久久| 五月天网站亚洲| 夜夜亚洲天天久久| 亚洲三级在线看| 中文字幕久久午夜不卡| 久久亚洲精华国产精华液| 337p亚洲精品色噜噜狠狠| 欧亚洲嫩模精品一区三区| 99久久精品免费| 成人网在线免费视频| 国产成人午夜精品5599| 国产一区二区在线看| 久久精品国产第一区二区三区| 午夜电影久久久| 日韩国产欧美在线播放| 午夜精品福利久久久| 亚洲国产综合在线| 亚洲午夜久久久久久久久电影院 | 日本特黄久久久高潮 | 天天综合日日夜夜精品| 一级做a爱片久久| 亚洲日本乱码在线观看| 欧美韩国日本一区| 中文久久乱码一区二区| 国产精品麻豆视频| 中文字幕日韩av资源站| 亚洲欧美一区二区三区极速播放 | 一区二区三区在线观看动漫| 亚洲日韩欧美一区二区在线| 亚洲色图.com| 樱花草国产18久久久久| 亚洲网友自拍偷拍| 婷婷一区二区三区| 热久久国产精品| 韩日欧美一区二区三区| 国产成人自拍网| 成人免费看片app下载| 91麻豆福利精品推荐| 色综合久久天天| 欧美三级电影在线看| 欧美疯狂性受xxxxx喷水图片| 日韩视频不卡中文| 久久久久久久久蜜桃| 中文字幕乱码日本亚洲一区二区| 日韩美女久久久| 午夜精品久久久| 国产精品一线二线三线| 成人午夜精品在线| 色婷婷狠狠综合| 欧美一二三在线| 国产欧美中文在线| 亚洲男人天堂av| 日本视频中文字幕一区二区三区| 精久久久久久久久久久| av影院午夜一区| 欧美日韩免费高清一区色橹橹| 日韩欧美国产精品一区| 亚洲国产精品成人久久综合一区| 亚洲男同1069视频| 美国av一区二区| 99r精品视频| 91精品国产一区二区三区蜜臀| 久久综合色之久久综合| 亚洲免费在线视频| 国内精品国产成人国产三级粉色| 色综合久久久久综合体| 欧美videossexotv100| 亚洲欧洲日产国码二区| 亚洲444eee在线观看| 国产精品911| 3atv一区二区三区| 中文字幕综合网| 国产综合一区二区| 欧洲人成人精品| 久久久99精品久久| 日韩高清在线电影| 色婷婷久久久综合中文字幕| 久久日韩粉嫩一区二区三区 | 亚洲三级在线看| 经典三级在线一区| 欧美午夜视频网站| 中文字幕在线不卡视频| 蜜臀av性久久久久av蜜臀妖精| 972aa.com艺术欧美| 精品日韩欧美在线| 午夜伦欧美伦电影理论片| 不卡视频一二三| 337p日本欧洲亚洲大胆色噜噜| 亚洲18女电影在线观看| 成人国产精品免费观看动漫| 欧美成人精品福利| 亚洲成a人片在线不卡一二三区 | 亚洲国产成人av| av不卡在线播放| 久久久一区二区三区捆绑**| 婷婷综合五月天| 色欧美片视频在线观看| 国产精品另类一区| 国产成人综合视频| 久久综合精品国产一区二区三区| 日本欧美一区二区三区| 欧美性欧美巨大黑白大战| 亚洲你懂的在线视频| av午夜精品一区二区三区| 久久免费午夜影院| 九九**精品视频免费播放| 欧美一区在线视频| 午夜久久久影院| 欧美日韩国产片| 亚洲综合成人在线| 在线免费观看日本一区| 亚洲欧美日韩久久精品| 95精品视频在线| 亚洲免费视频成人| 一本到高清视频免费精品| 中文字幕在线播放不卡一区| 北岛玲一区二区三区四区| 国产日韩欧美一区二区三区综合| 国产激情一区二区三区桃花岛亚洲 | 国产一区二区91| 国产亚洲综合色| 高清在线观看日韩| 中文字幕精品一区二区精品绿巨人 | 欧美激情一区二区三区全黄| 国产精品正在播放| 中文子幕无线码一区tr| 成人av网在线| 亚洲欧美另类久久久精品2019| 91在线视频网址| 亚洲一区二区三区四区五区黄| 欧美无砖砖区免费| 日韩精品一级中文字幕精品视频免费观看| 欧美日韩一二三| 蜜臀久久99精品久久久久久9| 欧美xxxx在线观看| 国产suv精品一区二区6| 亚洲人妖av一区二区| 欧美午夜在线一二页| 91亚洲精品乱码久久久久久蜜桃 | 亚洲视频一区二区在线| 欧美在线综合视频| 免费欧美高清视频| 久久精品一二三| 91亚洲精品乱码久久久久久蜜桃| 亚洲大片在线观看| 精品国产91洋老外米糕| 成人午夜在线视频| 亚洲超丰满肉感bbw| www国产精品av| 波波电影院一区二区三区| 亚洲va韩国va欧美va精品| 亚洲乱码国产乱码精品精的特点| 欧美日韩亚州综合| 国内精品伊人久久久久影院对白| 国产精品久久三| 91麻豆精品国产91久久久更新时间| 久久99热狠狠色一区二区| 国产精品乱码久久久久久| 欧美男男青年gay1069videost| 黄一区二区三区| 一区二区三区美女| 久久精品视频免费观看| 在线视频综合导航| 国产精品18久久久久久vr| 洋洋av久久久久久久一区| 久久综合久久99| 欧美丝袜丝交足nylons图片| 国产九色sp调教91| 亚洲国产一区二区三区| 国产欧美日韩久久| 欧美一区二区在线视频| thepron国产精品| 日本sm残虐另类| 亚洲精品videosex极品| 国产亚洲欧美激情| 欧美精品亚洲二区| 91亚洲国产成人精品一区二区三| 91精品国产欧美一区二区 | 日韩视频一区二区三区在线播放| 国产成人精品影院| 亚洲成人综合在线| 中文字幕精品在线不卡| 欧美成人官网二区|