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

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

?? photogrammetryview.cpp

?? 該工程下實現了圖像的載入
?? CPP
字號:
// PhotoGrammetryView.cpp : implementation of the CPhotoGrammetryView class
//

#include "stdafx.h"
#include "PhotoGrammetry.h"

#include "PhotoGrammetryDoc.h"
#include "PhotoGrammetryView.h"
#include "MainFrm.h"

#include "MyJuanJiDlg.h"
#include "DibImage.h"
#include "MyFourial.h"

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

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView

IMPLEMENT_DYNCREATE(CPhotoGrammetryView, CScrollView)

BEGIN_MESSAGE_MAP(CPhotoGrammetryView, CScrollView)
	//{{AFX_MSG_MAP(CPhotoGrammetryView)
	ON_WM_ERASEBKGND()
	ON_COMMAND(ID_EDIT_COPY, OnEditCopy)
	ON_UPDATE_COMMAND_UI(ID_EDIT_COPY, OnUpdateEditCopy)
	ON_UPDATE_COMMAND_UI(ID_EDIT_PASTE, OnUpdateEditPaste)
	ON_COMMAND(ID_EDIT_PASTE, OnEditPaste)
	ON_COMMAND(ID_Image_JuanJi, OnImageJuanJi)
	ON_COMMAND(ID_FFT, OnFft)
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView construction/destruction

CPhotoGrammetryView::CPhotoGrammetryView()
{
	// TODO: add construction code here
	m_YuMenShow = TRUE;
}

CPhotoGrammetryView::~CPhotoGrammetryView()
{
}

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

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView drawing

void CPhotoGrammetryView::OnDraw(CDC* pDC)
{
/**/
	if(m_YuMenShow)
	{
		CPhotoGrammetryDoc* pDoc = GetDocument();
		ASSERT_VALID(pDoc);
		
		CSize sizeDibDisplay;		
		
		if(!pDoc->m_pDibInit->IsEmpty())
		{	
			sizeDibDisplay = pDoc->m_pDibInit->GetDimensions();
			pDoc->m_pDibInit->Draw(pDC,CPoint(0,0),sizeDibDisplay);	
		}
	}
	else
	{
		BeginWaitCursor();
		CPhotoGrammetryDoc* 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);			
				// 獲取打印機每英寸象素數
				int cxInch = pDC->GetDeviceCaps(LOGPIXELSX);
				int cyInch = pDC->GetDeviceCaps(LOGPIXELSY);
				
				// 計算打印圖像大小(縮放,根據頁面寬度調整圖像大小)
				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 CPhotoGrammetryView::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();
	
	CPhotoGrammetryDoc *pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	CSize sizetotal = pDoc->m_pDibInit->GetDimensions();

	SetScrollSizes(MM_TEXT,sizetotal);
	
	GetParentFrame()->RecalcLayout();
	
	ResizeParentToFit();
	
//	CSize sizeTotal;
//	// TODO: calculate the total size of this view
//	sizeTotal.cx = sizeTotal.cy = 100;
//	SetScrollSizes(MM_TEXT, sizeTotal);
}

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView printing

BOOL CPhotoGrammetryView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	pInfo->SetMaxPage(1);
	return DoPreparePrinting(pInfo);
}

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

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

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView diagnostics

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CPhotoGrammetryView message handlers

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

	CPhotoGrammetryDoc* 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中調用SelectPalette()失敗!\n");
		}
	}
	
	return 0L;
}

BOOL CPhotoGrammetryView::OnEraseBkgnd(CDC* pDC) 
{
	// TODO: Add your message handler code here and/or call default
	// 主要是為了設置子窗體默認的背景色
	// 背景色由文檔成員變量m_refColorBKG指定

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

	pDC->SelectObject(pOldBrush);                                                  

	return TRUE;
}

void CPhotoGrammetryView::OnEditCopy() 
{
	// TODO: Add your command handler code here
	CPhotoGrammetryDoc* pDoc = GetDocument();
	
	if (OpenClipboard())
	{
		BeginWaitCursor();
		EmptyClipboard();
		
		// 復制當前圖像到剪貼板
		SetClipboardData (CF_DIB, pDoc->GetDibImage()->
			CopyHandle((HANDLE) pDoc->GetHDIB()) );

		CloseClipboard();
		EndWaitCursor();
	}
}

void CPhotoGrammetryView::OnUpdateEditCopy(CCmdUI* pCmdUI) 
{
	// TODO: Add your command update UI handler code here
	pCmdUI->Enable(GetDocument()->GetHDIB() != NULL);
}

void CPhotoGrammetryView::OnUpdateEditPaste(CCmdUI* pCmdUI) 
{
	// TODO: Add your command update UI handler code here
	pCmdUI->Enable(::IsClipboardFormatAvailable(CF_DIB));
}

void CPhotoGrammetryView::OnEditPaste() 
{
	// TODO: Add your command handler code here
	HDIB hNewDIB = NULL;
	CPhotoGrammetryDoc* 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大小和調色板		
			pDoc->SetModifiedFlag(TRUE);	// 設置臟標記	
			SetScrollSizes(MM_TEXT, pDoc->GetDocSize());	// 重新設置滾動視圖大小		
			OnDoRealize((WPARAM)m_hWnd,0);	// 實現新的調色板		
			pDoc->UpdateAllViews(NULL);		// 更新視圖
		}

		EndWaitCursor();
	}
}

void CPhotoGrammetryView::CalcWindowRect(LPRECT lpClientRect, UINT nAdjustType) 
{
	// TODO: Add your specialized code here and/or call the base class
	CScrollView::OnInitialUpdate();
	ASSERT(GetDocument() != NULL);

	SetScrollSizes(MM_TEXT,GetDocument()->GetDocSize());
}

void CPhotoGrammetryView::OnActivateView(BOOL bActivate, CView* pActivateView, CView* pDeactiveView) 
{
	// TODO: Add your specialized code here and/or call the base class
	if (bActivate)
	{
		ASSERT(pDeactiveView == this);
		OnDoRealize((WPARAM)m_hWnd,0);
	}
	CScrollView::OnActivateView(bActivate, pActivateView, pDeactiveView);
	
}

void CPhotoGrammetryView::OnImageJuanJi() 
{
	CMyJuanJiDlg dlg;

	if (dlg.DoModal() != IDOK) {
		return ;
	}
	delete dlg;
	BeginWaitCursor();

	CPhotoGrammetryDoc *pDoc = GetDocument();

	LPSTR lpDIB =  (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());

	CDib* pDib = pDoc->m_pDibInit;

	////////////////////////////////////////////////////////////////////

	// the model array
	float pdpTemp[9];
	pdpTemp[0] = (float)dlg.m_Num0;
	pdpTemp[1] = (float)dlg.m_Num1;
	pdpTemp[2] = (float)dlg.m_Num2;
	pdpTemp[3] = (float)dlg.m_Num3;
	pdpTemp[4] = (float)dlg.m_Num4;
	pdpTemp[5] = (float)dlg.m_Num5;
	pdpTemp[6] = (float)dlg.m_Num6;
	pdpTemp[7] = (float)dlg.m_Num7;
	pdpTemp[8] = (float)dlg.m_Num8;

	float modelFc = 0.0;
	for (int i = 0; i < 9; i++)
	{
		modelFc += pdpTemp[i];
	}
	modelFc = modelFc / 9;
	
	CDibImage my_JuanJi;
	if (my_JuanJi.JuanJi(pDib,pdpTemp,modelFc))
	{
		pDoc->SetModifiedFlag(TRUE);

		pDoc->UpdateAllViews(NULL);
	}
	else
	{
		MessageBox("分配內存失敗","系統提示",MB_ICONINFORMATION | MB_OK);
	}
	EndWaitCursor();
}

void CPhotoGrammetryView::OnFft() 
{
	// TODO: Add your command handler code here
	
	m_YuMenShow =  FALSE;
    // 圖像付立葉變換
	CPhotoGrammetryDoc* pFFTDoc = GetDocument();
		
	LPSTR	lpDIB;				// 指向DIB的指針	
	LPSTR    lpDIBBits;			// 指向DIB象素指針

	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pFFTDoc->GetHDIB());
	
	// 找到DIB圖像象素起始位置
	lpDIBBits = pFFTDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖的付立葉變換,其它的可以類推)
	if (pFFTDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("not 256 colors", "system alarm", MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pFFTDoc->GetHDIB());

		return;
	}
	
	LONG lWidth  = pFFTDoc->GetDibImage()->DIBWidth(lpDIB);
	LONG lHeight = pFFTDoc->GetDibImage()->DIBWidth(lpDIB);;
	
	BeginWaitCursor();
	
	// 調用Fourier()函數進行付立葉變換
	CMyFourial MyFoural;
	
	MyFoural.Fourier(lpDIBBits,lWidth, lHeight);
	
	pFFTDoc->SetModifiedFlag(TRUE);		// 設置臟標記
	pFFTDoc->UpdateAllViews(NULL);			// 更新視圖
	
	::GlobalUnlock((HGLOBAL) pFFTDoc->GetHDIB());

	EndWaitCursor();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品一区二区三区| 亚洲精品国产成人久久av盗摄| 日本少妇一区二区| 5月丁香婷婷综合| 久久精品国产在热久久| 日韩欧美国产午夜精品| 国产成人亚洲综合a∨婷婷| 国产色综合一区| av在线播放成人| 亚洲一区在线播放| 欧美一区二区三区婷婷月色 | 欧美一区二区精美| 麻豆91免费看| 久久久久国产精品厨房| 91在线观看污| 天天综合日日夜夜精品| 欧美精品一区二区久久久| 9i在线看片成人免费| 亚洲一区二区精品3399| 欧美草草影院在线视频| 成人sese在线| 天天av天天翘天天综合网 | 日韩福利电影在线| www国产成人免费观看视频 深夜成人网| 国产高清成人在线| 亚洲最大色网站| 久久青草欧美一区二区三区| 97超碰欧美中文字幕| 日韩电影在线观看网站| 国产欧美日韩在线观看| 欧美色精品天天在线观看视频| 国产曰批免费观看久久久| 亚洲情趣在线观看| 精品国产伦一区二区三区观看方式 | 最好看的中文字幕久久| 欧美日韩免费电影| 成人在线一区二区三区| 美女精品自拍一二三四| 综合久久久久综合| 日韩精品一区二区三区swag| 色综合视频一区二区三区高清| 久久aⅴ国产欧美74aaa| 亚洲精品亚洲人成人网在线播放| 精品少妇一区二区三区在线播放| 色狠狠色狠狠综合| 国产传媒一区在线| 丝袜国产日韩另类美女| 亚洲乱码一区二区三区在线观看| 久久精品一区蜜桃臀影院| 欧美军同video69gay| 91国在线观看| 成人黄色一级视频| 九九国产精品视频| 亚洲成人动漫在线观看| 亚洲女人小视频在线观看| 中文字幕第一区| 久久久久久久电影| 欧美一级二级三级乱码| 欧美喷水一区二区| 在线看日韩精品电影| 成人av网站在线观看免费| 九色综合狠狠综合久久| 久久精品国产成人一区二区三区| 亚洲一区二区在线播放相泽| 日韩一区日韩二区| 日本一二三不卡| 国产亚洲欧美日韩日本| 久久新电视剧免费观看| 精品国产第一区二区三区观看体验| 91.com视频| 日韩一区二区在线观看视频| 欧美一卡2卡三卡4卡5免费| 6080日韩午夜伦伦午夜伦| 91精品国产欧美日韩| 欧美三电影在线| 久久久精品综合| 欧美一区二区三区免费观看视频 | 日韩欧美高清一区| 欧美精品久久99| 欧美一区二区三区四区在线观看 | 在线观看亚洲成人| 91美女精品福利| 色老汉一区二区三区| 欧美性色黄大片| 欧美日韩日日夜夜| 日韩女同互慰一区二区| 久久综合色一综合色88| 国产欧美1区2区3区| 国产日本欧美一区二区| 亚洲欧洲色图综合| 夜夜爽夜夜爽精品视频| 亚洲成人资源在线| 六月丁香婷婷色狠狠久久| 精品在线一区二区| 国产精品一区二区三区网站| 99精品视频在线免费观看| 色妞www精品视频| 欧美日韩激情在线| 日韩一级免费观看| 国产日韩亚洲欧美综合| 亚洲欧美日韩系列| 天使萌一区二区三区免费观看| 男人的天堂亚洲一区| 国产美女视频一区| 日本高清不卡aⅴ免费网站| 在线综合+亚洲+欧美中文字幕| 日韩一区二区电影在线| 国产欧美日韩激情| 一区二区三区欧美久久| 久久精品免费观看| 99re亚洲国产精品| 日韩午夜激情视频| 国产精品家庭影院| 日韩精品成人一区二区三区| 国产一区二区三区黄视频 | 欧美激情一区二区在线| 一区二区三区免费网站| 蜜桃av一区二区在线观看 | 天堂一区二区在线| 黄页网站大全一区二区| 一本大道久久a久久综合婷婷| 欧美日韩国产不卡| 国产精品久久午夜夜伦鲁鲁| 秋霞电影网一区二区| 成人av电影在线网| 欧美一区二区三区在线电影| 中文字幕日本乱码精品影院| 青青草原综合久久大伊人精品优势| 成人看片黄a免费看在线| 91精品中文字幕一区二区三区 | 一区二区三区中文字幕在线观看| 免费一级片91| 91成人免费电影| 精品女同一区二区| 亚洲一区二区三区视频在线 | 久久se精品一区二区| 色成年激情久久综合| 日本一区二区三区免费乱视频| 五月婷婷综合激情| 一本一道波多野结衣一区二区| 久久精品欧美一区二区三区麻豆| 午夜av一区二区三区| 91色.com| 中文欧美字幕免费| 久草热8精品视频在线观看| 欧美日韩一区二区在线视频| 中文字幕亚洲精品在线观看| 国产精品一线二线三线| 日韩免费成人网| 午夜国产不卡在线观看视频| 91久久香蕉国产日韩欧美9色| 国产精品欧美综合在线| 国产在线精品一区二区不卡了 | 懂色一区二区三区免费观看| 日韩免费看网站| 日韩主播视频在线| 欧美亚洲日本一区| 亚洲欧美日韩国产综合| 成人黄色av电影| 欧美激情一区三区| 国产91丝袜在线观看| 国产日韩欧美综合一区| 国产成人午夜99999| 久久青草国产手机看片福利盒子 | av一本久道久久综合久久鬼色| 日韩亚洲欧美成人一区| 午夜精品免费在线| 欧美日韩性生活| 亚洲成av人片在线观看| 欧美另类高清zo欧美| 亚洲福利一区二区| 欧美日韩精品一区二区三区蜜桃| 香蕉成人伊视频在线观看| 在线电影院国产精品| 久色婷婷小香蕉久久| 久久久蜜桃精品| 成人性生交大片| 亚洲日本乱码在线观看| 色婷婷国产精品久久包臀| 亚洲乱码日产精品bd| 欧美三级乱人伦电影| 天堂资源在线中文精品| 日韩一区二区免费在线电影| 国内外成人在线| 中文字幕日韩欧美一区二区三区| 91麻豆免费看片| 日本亚洲欧美天堂免费| 26uuu另类欧美亚洲曰本| 国产69精品久久777的优势| 亚洲美腿欧美偷拍| 欧美色网一区二区| 久久99久国产精品黄毛片色诱| 精品国产乱码久久久久久老虎 | 在线亚洲免费视频| 日韩在线播放一区二区| 久久综合999| 北条麻妃国产九九精品视频| 亚洲人吸女人奶水| 欧美一级一区二区| 成人黄色在线看|