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

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

?? tinmap.cpp

?? 并行TIN生成算法, 基于DeWall算法理論實現(xiàn)
?? CPP
字號:
// TinMap.cpp : implementation of the CTinMap class
//

#include "stdafx.h"
#include "TinApp.h"

#include "TinDoc.h"
#include "TinMap.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

/////////////////////////////////////////////////////////////////////////////
// CTinMap

IMPLEMENT_DYNCREATE(CTinMap, CView)

BEGIN_MESSAGE_MAP(CTinMap, CView)
	ON_WM_SIZE()
	ON_WM_LBUTTONDOWN()
	ON_WM_LBUTTONUP()
	ON_WM_MOUSEMOVE()
	ON_WM_MOUSEWHEEL()
	ON_WM_SETCURSOR()
	ON_COMMAND(ID_ZOOM_INT, OnZoomInt)
	ON_UPDATE_COMMAND_UI(ID_ZOOM_INT, OnUpdateZoomInt)
	ON_COMMAND(ID_ZOOM_OUT, OnZoomOut)
	ON_UPDATE_COMMAND_UI(ID_ZOOM_OUT, OnUpdateZoomOut)
	ON_COMMAND(ID_MOVE_PAN, OnMovePan)
	ON_UPDATE_COMMAND_UI(ID_MOVE_PAN, OnUpdateMovePan)
	// 標準打印命令
	ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CTinMap 構造/析構

CTinMap::CTinMap()
{
	m_dw = m_dh = MoveX = MoveY = 0;
	m_pMemDC = 0;	m_pMemBM = 0;

	m_nTool1 = m_nTool2 = 0;

}

CTinMap::~CTinMap()
{
	if(m_pMemDC)	delete m_pMemDC;
	if(m_pMemBM)	delete m_pMemBM;
}

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

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CTinMap 繪制

void CTinMap::OnDraw(CDC* pDC)
{
	CTinDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	if (m_pMemDC)
	{
		pDC->BitBlt(0, 0, m_cw, m_ch, m_pMemDC, MoveX, -MoveY, SRCCOPY);
	}
}

/////////////////////////////////////////////////////////////////////////////
// CTinMap 打印

BOOL CTinMap::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

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

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

/////////////////////////////////////////////////////////////////////////////
// CTinMap 診斷

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

void CTinMap::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CTinDoc* CTinMap::GetDocument() const // 非調試版本是內聯(lián)的
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTinDoc)));
	return (CTinDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CTinMap 消息處理程序

void CTinMap::OnInitialUpdate() 
{
	CView::OnInitialUpdate();
	
	m_dw = GetSystemMetrics(SM_CXSCREEN);
	m_dh = GetSystemMetrics(SM_CYSCREEN);
	if (m_dw == 0 || m_dh == 0)	return;

	m_pMemDC = new CDC;	m_pMemBM = new CBitmap;
	if (m_pMemDC && m_pMemBM)
	{
		CDC *pDC = GetDC();
		if (pDC == NULL)
		{
			delete m_pMemDC;	delete m_pMemBM;
			m_pMemDC = 0;	m_pMemBM = 0;
		}
		else
		{
			long bInit = 1;
			if (m_pMemDC->CreateCompatibleDC(pDC))
			{
				if (m_pMemBM->CreateCompatibleBitmap(pDC, m_dw, m_dh))
				{
					if (m_pMemDC->SelectObject(m_pMemBM))
						m_pMemDC->SetStretchBltMode(COLORONCOLOR);
					else
						bInit = 0;
				}
				else
					bInit = 0;
			}
			else
				bInit = 0;

			if (!bInit)
			{
				delete m_pMemDC;	delete m_pMemBM;
				m_pMemDC = 0;	m_pMemBM = 0;
			}

			ReleaseDC(pDC);	
		}
	}
	else
	{
		if (m_pMemDC)	delete m_pMemDC;
		if (m_pMemBM)	delete m_pMemBM;
		m_pMemDC = 0;	m_pMemBM = 0;
	}
}

void CTinMap::OnSize(UINT nType, int cx, int cy) 
{
	CView::OnSize(nType, cx, cy);
	
	m_cw = cx;	m_ch = cy;

	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);
	if (pDoc && m_pMemDC)
	{
		pDoc->SetViewportExt(m_cw, m_ch);

		PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
		pDoc->Move(m_pMemDC, 0, 0);

		Invalidate(0);
	}	
}

void CTinMap::OnUpdate(CView* pSender, LPARAM lHint, CObject* pHint) 
{
	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);

	m_nTool1 = m_nTool2 = 0;

	if (pDoc && m_pMemDC)
	{
		pDoc->SetViewportExt(m_cw, m_ch);

		PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
		pDoc->Move(m_pMemDC, 0, 0);

		Invalidate(1);
	}
}

void CTinMap::OnLButtonDown(UINT nFlags, CPoint point) 
{
	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);
	m_bLBDown = 1;	m_prePoint = point;	m_midPoint = point;	MoveX = 0;	MoveY = 0;
	
	if (m_nTool1 == ID_ZOOM_INT || m_nTool1 == ID_ZOOM_OUT || m_nTool1 == ID_MOVE_PAN)
		SetCapture();
	
	CView::OnLButtonDown(nFlags, point);
}

void CTinMap::OnLButtonUp(UINT nFlags, CPoint point) 
{
	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);
	if (m_nTool1 == ID_ZOOM_INT || m_nTool1 == ID_ZOOM_OUT || m_nTool1 == ID_MOVE_PAN)
		ReleaseCapture();

	if (m_bLBDown)
	{
		if (m_nTool1 == ID_ZOOM_INT || m_nTool1 == ID_ZOOM_OUT)	// 放大或縮小
		{
			CDC* pDC = GetDC();
			CPen *oldPen, newPen;

			newPen.CreatePen(PS_DOT, 1, RGB(0, 255, 0));
			oldPen = pDC->SelectObject(&newPen);	long oldRop = pDC->SetROP2(R2_NOTXORPEN);
			
			pDC->Rectangle(CRect(m_prePoint.x, m_prePoint.y, m_midPoint.x, m_midPoint.y));
			m_midPoint = point;
			
			pDC->SetROP2(oldRop);	pDC->SelectObject(oldPen);		newPen.DeleteObject();
			ReleaseDC(pDC);
			
			long mx, my;	double xs, ys;

			my = m_ch / 2 - (m_midPoint.y + m_prePoint.y) / 2;
			mx = m_cw / 2 - (m_midPoint.x + m_prePoint.x) / 2;
			ys = m_ch / (1.0 * abs(m_midPoint.y - m_prePoint.y));
			xs = m_cw / (1.0 * abs(m_midPoint.x - m_prePoint.x));
			if (abs(m_midPoint.x - m_prePoint.x) < 4 || abs(m_midPoint.y - m_prePoint.y) < 4)
				xs = ys = 1.5;
			
			PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
			if (m_nTool1 == ID_ZOOM_INT)
			{
				if (xs > ys)
					pDoc->Zoom(m_pMemDC, mx, -my, xs, xs, TRUE);
				else
					pDoc->Zoom(m_pMemDC, mx, -my, ys, ys, TRUE);
			}
			else
			{
				if (xs < ys)
					pDoc->Zoom(m_pMemDC, mx, -my, xs, xs, FALSE);
				else
					pDoc->Zoom(m_pMemDC, mx, -my, ys, ys, FALSE);
			}
			Invalidate(0);
		}
		else if (m_nTool1 == ID_MOVE_PAN) // 地圖漫游
		{
			MoveX = m_prePoint.x - point.x;
			MoveY = point.y - m_prePoint.y;

			PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
			pDoc->Move(m_pMemDC, MoveX, MoveY);

			MoveX = 0;		MoveY = 0;
			Invalidate(0);
		}
	}

	m_bLBDown = 0;
	
	CView::OnLButtonUp(nFlags, point);
}

void CTinMap::OnMouseMove(UINT nFlags, CPoint point) 
{
	if (m_bLBDown)
	{
		if (m_nTool1 == ID_ZOOM_INT || m_nTool1 == ID_ZOOM_OUT)	// 放大或縮小或分割
		{
			CDC* pDC = GetDC();
			CPen *oldPen, newPen;

			newPen.CreatePen(PS_DOT, 1, RGB(0, 255, 0));
			oldPen = pDC->SelectObject(&newPen);	int oldRop = pDC->SetROP2(R2_NOTXORPEN);
			
			pDC->Rectangle(CRect(m_prePoint.x, m_prePoint.y, m_midPoint.x, m_midPoint.y));
			
			m_midPoint = point;
			pDC->Rectangle(CRect(m_prePoint.x, m_prePoint.y, m_midPoint.x, m_midPoint.y));
			
			pDC->SetROP2(oldRop);	pDC->SelectObject(oldPen);	newPen.DeleteObject();
			ReleaseDC(pDC);
		}
		else if (m_nTool1 == ID_MOVE_PAN) // 地圖漫游
		{
			long dx = point.x - m_midPoint.x;
			long dy = point.y - m_midPoint.y;
			
			MoveX = m_prePoint.x - point.x;
			MoveY = point.y - m_prePoint.y;
			
			ScrollWindow(dx, dy, NULL, NULL);
			
			m_midPoint = point;
		}
	}
	
	CView::OnMouseMove(nFlags, point);
}

BOOL CTinMap::OnMouseWheel(UINT nFlags, short zDelta, CPoint pt) 
{
	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);

	if (zDelta > 0)
	{
		PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
		pDoc->Zoom(m_pMemDC, 0, 0, 1.05, 1.05, TRUE);
	}
	else
	{
		PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
		pDoc->Zoom(m_pMemDC, 0, 0, 1.05, 1.05, FALSE);
	}
	Invalidate();	UpdateWindow();
	
	return CView::OnMouseWheel(nFlags, zDelta, pt);
}

BOOL CTinMap::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message) 
{
	CWinApp *winApp = AfxGetApp();

	if (m_nTool1 != 0)
	{
		if		(m_nTool1 == ID_ZOOM_INT)
		{	SetCursor(winApp->LoadCursor(129));	return FALSE;	}
		else if (m_nTool1 == ID_ZOOM_OUT)
		{	SetCursor(winApp->LoadCursor(130));	return FALSE;	}
		else if (m_nTool1 == ID_MOVE_PAN)
		{	SetCursor(winApp->LoadCursor(132));	return FALSE;	}
	}
	
	return CView::OnSetCursor(pWnd, nHitTest, message);
}

void CTinMap::MoveTo(double x, double y)
{
	CTinDoc* pDoc = GetDocument();	ASSERT_VALID(pDoc);

	PatBlt(m_pMemDC->m_hDC, 0, 0, m_dw, m_dh, WHITENESS);
	pDoc->MoveTo(m_pMemDC, x, y);
	Invalidate(0);
}

void CTinMap::OnZoomInt() 
{
	if (m_nTool1 != ID_ZOOM_INT)	m_nTool1 = ID_ZOOM_INT;
	else							m_nTool1 = 0;
}

void CTinMap::OnUpdateZoomInt(CCmdUI* pCmdUI) 
{
	if (m_nTool1 == ID_ZOOM_INT)	pCmdUI->SetCheck(1);
	else							pCmdUI->SetCheck(0);
}

void CTinMap::OnZoomOut() 
{
	if (m_nTool1 != ID_ZOOM_OUT)	m_nTool1 = ID_ZOOM_OUT;
	else							m_nTool1 = 0;
}

void CTinMap::OnUpdateZoomOut(CCmdUI* pCmdUI) 
{
	if (m_nTool1 == ID_ZOOM_OUT)	pCmdUI->SetCheck(1);
	else							pCmdUI->SetCheck(0);
}

void CTinMap::OnMovePan() 
{
	if (m_nTool1 != ID_MOVE_PAN)	m_nTool1 = ID_MOVE_PAN;
	else							m_nTool1 = 0;
}

void CTinMap::OnUpdateMovePan(CCmdUI* pCmdUI) 
{
	if (m_nTool1 == ID_MOVE_PAN)	pCmdUI->SetCheck(1);
	else							pCmdUI->SetCheck(0);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久国产综合精品色伊| 欧美日韩国产免费| 色哟哟日韩精品| 日韩一级片网址| 亚洲欧美日韩小说| 国产一区二区网址| 制服丝袜亚洲精品中文字幕| 中文字幕一区二区不卡| 久久国产婷婷国产香蕉| 欧美偷拍一区二区| 中文字幕在线一区| 国产一区二区伦理| 欧美一区二区三区婷婷月色| 一级女性全黄久久生活片免费| 国产一区二区三区黄视频 | 欧美日韩中文国产| 亚洲国产高清在线| 国产一区免费电影| 日韩精品一区国产麻豆| 亚洲成在人线在线播放| 91麻豆.com| 成人免费在线播放视频| 国产精品综合二区| 欧美mv日韩mv国产| 日韩电影在线观看网站| 欧美在线观看一二区| 亚洲人精品午夜| av一区二区三区黑人| 欧美极品美女视频| 国产a精品视频| 26uuu另类欧美亚洲曰本| 老鸭窝一区二区久久精品| 911精品国产一区二区在线| 亚洲美女少妇撒尿| 色综合色狠狠综合色| 美女在线观看视频一区二区| 在线观看精品一区| 亚洲制服欧美中文字幕中文字幕| 99久久精品费精品国产一区二区| 国产精品超碰97尤物18| av在线播放一区二区三区| 国产精品乱码一区二三区小蝌蚪| 国产91精品一区二区麻豆网站| 国产婷婷色一区二区三区在线| 精品一区二区三区视频| 久久这里只有精品首页| 国产高清久久久| 中文字幕av一区 二区| 成人毛片视频在线观看| 亚洲图片欧美激情| 在线观看www91| 日韩**一区毛片| 2020国产精品自拍| 91一区二区在线| 亚洲国产日日夜夜| 精品免费一区二区三区| 国产福利精品一区二区| 亚洲欧洲精品天堂一级| 欧美亚洲一区三区| 蜜臀久久久99精品久久久久久| 久久久久久久久蜜桃| 91在线观看污| 日日骚欧美日韩| 国产日本一区二区| 欧美三级在线看| 激情伊人五月天久久综合| 国产精品女同互慰在线看 | 韩国中文字幕2020精品| 欧美国产欧美综合| 欧美性大战久久久久久久蜜臀| 麻豆一区二区三| 国产精品成人一区二区三区夜夜夜| 欧美在线观看视频一区二区| 欧洲国内综合视频| 韩国成人福利片在线播放| 亚洲色图一区二区| 精品国产1区二区| 91成人在线免费观看| 激情小说亚洲一区| 亚洲成av人片观看| 中文av一区二区| 在线观看91精品国产麻豆| 国产91丝袜在线播放| 日本欧洲一区二区| 亚洲日本免费电影| 精品国产第一区二区三区观看体验 | 国产精品乡下勾搭老头1| 一区二区三区四区激情| 欧美激情艳妇裸体舞| 91精品国产欧美一区二区| 99久久精品免费精品国产| 极品瑜伽女神91| 亚洲国产美国国产综合一区二区| 国产欧美日韩在线观看| 日韩视频在线你懂得| 欧美系列日韩一区| 91在线看国产| 国v精品久久久网| 国产曰批免费观看久久久| 性久久久久久久久| 亚洲综合小说图片| 日韩美女视频19| 国产精品美日韩| 久久亚洲二区三区| 精品三级在线看| 日韩欧美亚洲另类制服综合在线| 欧美午夜电影在线播放| 91免费视频网| 91免费观看视频在线| 大尺度一区二区| 国产乱子轮精品视频| 国产一区二区美女| 91老师片黄在线观看| 成人精品小蝌蚪| 夫妻av一区二区| 99re热这里只有精品视频| 成人av在线电影| www.亚洲国产| 色婷婷综合在线| 欧美日韩一区高清| 欧美一区二区视频在线观看2020| 欧美男人的天堂一二区| 7777精品伊人久久久大香线蕉的 | 亚洲一二三区在线观看| 夜夜嗨av一区二区三区| 亚洲国产成人tv| 午夜精品aaa| 老司机午夜精品99久久| 国产剧情一区二区三区| 国产成人av影院| 色综合久久精品| 欧美日韩和欧美的一区二区| 欧美精品免费视频| 欧美mv和日韩mv的网站| 国产精品色婷婷| 亚洲精品网站在线观看| 午夜欧美在线一二页| 久久不见久久见免费视频7| 国产乱码一区二区三区| thepron国产精品| 欧洲一区二区av| 日韩欧美在线网站| 日本一区二区久久| 亚洲精品国产高清久久伦理二区| 香蕉久久夜色精品国产使用方法| 久久草av在线| 91麻豆精品国产自产在线 | 欧美日韩三级视频| 欧美精品一区二区在线观看| 国产精品理论片| 亚洲va欧美va天堂v国产综合| 蜜桃视频一区二区| av不卡一区二区三区| 欧美一区二区三区四区五区 | 国产欧美日韩亚州综合| 一区二区激情小说| 国内精品免费**视频| 91片黄在线观看| 精品国产乱码久久久久久闺蜜| 综合久久综合久久| 国内久久婷婷综合| 欧美三级日韩三级国产三级| 国产日产欧美一区二区三区| 午夜不卡av免费| 99精品一区二区| 久久一夜天堂av一区二区三区| 亚洲免费观看高清| 国产福利一区在线| 制服.丝袜.亚洲.中文.综合| 成人欧美一区二区三区小说| 蜜臀av性久久久久蜜臀av麻豆| 91在线精品一区二区三区| 亚洲精品在线观看网站| 亚洲国产视频在线| 91亚洲大成网污www| 久久精品一区二区三区不卡| 亚洲va韩国va欧美va| 色综合一区二区| 国产午夜精品久久久久久免费视| 日韩国产精品大片| 欧美怡红院视频| 国产精品一区二区在线观看不卡| 欧美综合一区二区三区| 国产精品国产精品国产专区不蜜| 国内外成人在线| 欧美一卡二卡三卡四卡| 亚洲动漫第一页| 在线精品国精品国产尤物884a| 国产精品国产三级国产aⅴ原创 | 亚洲va欧美va天堂v国产综合| 成人免费黄色大片| 2020日本不卡一区二区视频| 免费久久精品视频| 欧美精品色综合| 日韩黄色免费电影| 在线成人小视频| 日韩精品国产精品| 欧美一卡2卡3卡4卡| 日本视频中文字幕一区二区三区| 欧美撒尿777hd撒尿|