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

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

?? dynsplitterwnd.cpp

?? 此程序詳細的列出模式識別中的最基本的一些方法,是初學模式識別的人很好的教材,全部用C++實現
?? CPP
字號:
// SAGA Incorporated MFC Goodies
//
// SAGA Incorporated (saga@gis.net) MFC Goodies
// Developed by Andrew Slivker for www.codeguru.com
// 
// DynSplitterWnd.cpp : implementation file
//
// Version:			1.0
// Revision:		02/03/98
// 2005.1.13-16:02 By Superman 

#include "stdafx.h"
#include <afxext.h>
#include "DynSplitterWnd.h"

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

#define CX_BORDER	1
#define CY_BORDER	1

#define FAR_POINT_XY		-10000


/////////////////////////////////////////////////////////////////////////////
// CDynSplitterWnd

CDynSplitterWnd::CDynSplitterWnd() 
	:m_OldPoint(FAR_POINT_XY,FAR_POINT_XY), m_bDynSplit(TRUE)
{
}

CDynSplitterWnd::~CDynSplitterWnd()
{
}


void CDynSplitterWnd::OnInvertTracker(const CRect& rect)
{
	if(!m_bDynSplit)
		CSplitterWnd::OnInvertTracker(rect);
	else
		return;
}

void CDynSplitterWnd::StartTracking(int ht)
{
	if(!m_bDynSplit)
	{
		CSplitterWnd::StartTracking(ht);
		return;
	}

	ASSERT_VALID(this);
	if (ht == noHit)
		return;

	// GetHitRect will restrict 'm_rectLimit' as appropriate
	GetInsideRect(m_rectLimit);

	if (ht >= splitterIntersection1 && ht <= splitterIntersection225)
	{
		// split two directions (two tracking rectangles)
		int row = (ht - splitterIntersection1) / 15;
		int col = (ht - splitterIntersection1) % 15;

		GetHitRect(row + vSplitterBar1, m_rectTracker);
		int yTrackOffset = m_ptTrackOffset.y;
		m_bTracking2 = TRUE;
		GetHitRect(col + hSplitterBar1, m_rectTracker2);
		m_ptTrackOffset.y = yTrackOffset;
	}
	else if (ht == bothSplitterBox)
	{
		// hit on splitter boxes (for keyboard)
		GetHitRect(vSplitterBox, m_rectTracker);
		int yTrackOffset = m_ptTrackOffset.y;
		m_bTracking2 = TRUE;
		GetHitRect(hSplitterBox, m_rectTracker2);
		m_ptTrackOffset.y = yTrackOffset;

		// center it
		m_rectTracker.OffsetRect(0, m_rectLimit.Height()/2);
		m_rectTracker2.OffsetRect(m_rectLimit.Width()/2, 0);
	}
	else
	{
		// only hit one bar
		GetHitRect(ht, m_rectTracker);
	}

	// steal focus and capture
	SetCapture();

	// set tracking state and appropriate cursor
	m_bTracking = TRUE;
	m_htTrack = ht;
	SetSplitCursor(ht);
}


void CDynSplitterWnd::StopTracking(BOOL bAccept)
{
	ASSERT_VALID(this);

	if (!m_bTracking)
		return;

	ReleaseCapture();

	// erase tracker rectangle
	OnInvertTracker(m_rectTracker);
	if (m_bTracking2)
		OnInvertTracker(m_rectTracker2);
	m_bTracking = m_bTracking2 = FALSE;

	// save old active view
	CWnd* pOldActiveView = GetActivePane();

	// m_rectTracker is set to the new splitter position (without border)
	// (so, adjust relative to where the border will be)
	m_rectTracker.OffsetRect(-CX_BORDER , -CY_BORDER);
	m_rectTracker2.OffsetRect(-CX_BORDER, -CY_BORDER);

	if (bAccept)
	{
		if (m_htTrack == vSplitterBox)
		{
			SplitRow(m_rectTracker.top);
		}
		else if (m_htTrack >= vSplitterBar1 && m_htTrack <= vSplitterBar15)
		{
			// set row height
			TrackRowSize(m_rectTracker.top, m_htTrack - vSplitterBar1);
			RecalcLayout();
		}
		else if (m_htTrack == hSplitterBox)
		{
			SplitColumn(m_rectTracker.left);
		}
		else if (m_htTrack >= hSplitterBar1 && m_htTrack <= hSplitterBar15)
		{
			// set column wide
			TrackColumnSize(m_rectTracker.left, m_htTrack - hSplitterBar1);
			RecalcLayout();
		}
		else if (m_htTrack >= splitterIntersection1 &&
			m_htTrack <= splitterIntersection225)
		{
			// set row height and column wide
			int row = (m_htTrack - splitterIntersection1) / 15;
			int col = (m_htTrack - splitterIntersection1) % 15;

			TrackRowSize(m_rectTracker.top, row);
			TrackColumnSize(m_rectTracker2.left, col);
			RecalcLayout();
		}
		else if (m_htTrack == bothSplitterBox)
		{
			// rectTracker is vSplitter (splits rows)
			// rectTracker2 is hSplitter (splits cols)
			SplitRow(m_rectTracker.top);
			SplitColumn(m_rectTracker2.left);
		}
	}

	if ( (pOldActiveView == GetActivePane()) &&
	     (pOldActiveView != NULL)
	   )
			SetActivePane(-1, -1, pOldActiveView); // re-activate
}


BEGIN_MESSAGE_MAP(CDynSplitterWnd, CSplitterWnd)
	//{{AFX_MSG_MAP(CDynSplitterWnd)
	ON_WM_MOUSEMOVE()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()


/////////////////////////////////////////////////////////////////////////////
// CDynSplitterWnd message handlers


void CDynSplitterWnd::OnMouseMove(UINT nFlags, CPoint pt) 
{
	if(!m_bDynSplit)
	{
		CSplitterWnd::OnMouseMove(nFlags, pt);
		return;
	}

	if (GetCapture() != this)
		StopTracking(FALSE);

	if (m_bTracking)
	{
		// move tracker to current cursor position
		pt.Offset(m_ptTrackOffset); // pt is the upper right of hit detect
		// limit the point to the valid split range
		if (pt.y < m_rectLimit.top)
			pt.y = m_rectLimit.top;
		else if (pt.y > m_rectLimit.bottom)
			pt.y = m_rectLimit.bottom;
		if (pt.x < m_rectLimit.left)
			pt.x = m_rectLimit.left;
		else if (pt.x > m_rectLimit.right)
			pt.x = m_rectLimit.right;

		if (m_htTrack == vSplitterBox ||
			m_htTrack >= vSplitterBar1 && m_htTrack <= vSplitterBar15)
		{
			if (m_rectTracker.top != pt.y)
			{
				OnInvertTracker(m_rectTracker);
				m_rectTracker.OffsetRect(0, pt.y - m_rectTracker.top);
				OnInvertTracker(m_rectTracker);
			}
		}
		else if (m_htTrack == hSplitterBox ||
			m_htTrack >= hSplitterBar1 && m_htTrack <= hSplitterBar15)
		{
			if (m_rectTracker.left != pt.x)
			{
				OnInvertTracker(m_rectTracker);
				m_rectTracker.OffsetRect(pt.x - m_rectTracker.left, 0);
				OnInvertTracker(m_rectTracker);
			}
		}
		else if (m_htTrack == bothSplitterBox ||
		   (m_htTrack >= splitterIntersection1 &&
			m_htTrack <= splitterIntersection225))
		{
			if (m_rectTracker.top != pt.y)
			{
				OnInvertTracker(m_rectTracker);
				m_rectTracker.OffsetRect(0, pt.y - m_rectTracker.top);
				OnInvertTracker(m_rectTracker);
			}
			if (m_rectTracker2.left != pt.x)
			{
				OnInvertTracker(m_rectTracker2);
				m_rectTracker2.OffsetRect(pt.x - m_rectTracker2.left, 0);
				OnInvertTracker(m_rectTracker2);
			}
		}

		OnLButtonUp(MK_LBUTTON,pt);
		OnLButtonDown(MK_LBUTTON,pt);
		if(m_OldPoint != pt)
		{
			RedrawWindow(NULL, NULL, RDW_ALLCHILDREN | RDW_UPDATENOW);
			m_OldPoint = pt;
		}
	}
	else
	{
		// simply hit-test and set appropriate cursor
		int ht = HitTest(pt);
		SetSplitCursor(ht);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区在线看| 欧美午夜精品久久久| 91精品91久久久中77777| 91精品在线免费观看| 亚洲欧洲成人精品av97| 激情文学综合插| 欧美在线视频不卡| 亚洲欧洲日本在线| 国产精品一级黄| 日韩欧美一二区| 天天综合天天综合色| 99精品国产热久久91蜜凸| 久久欧美一区二区| 韩国精品主播一区二区在线观看| 欧美挠脚心视频网站| 亚洲免费色视频| 成人自拍视频在线| 久久午夜羞羞影院免费观看| 美女一区二区视频| 日韩一卡二卡三卡| 亚洲成a人v欧美综合天堂| 一本大道久久a久久精二百| 欧美国产日韩精品免费观看| 国产福利电影一区二区三区| 久久伊人蜜桃av一区二区| 精品中文字幕一区二区小辣椒| 欧美精三区欧美精三区| 亚洲成人动漫av| 欧美精品乱码久久久久久按摩| 亚洲在线视频网站| 欧美中文字幕一区二区三区| 亚洲一二三区不卡| 欧美日韩一区小说| 午夜精品123| 91精品在线麻豆| 免费一区二区视频| 91精品国产一区二区三区蜜臀| 午夜精品久久久久影视| 欧美一区二区三区视频免费播放| 免费久久精品视频| 精品国精品国产| 国产成人在线电影| 国产精品久久久久影院| 97精品久久久午夜一区二区三区 | 88在线观看91蜜桃国自产| 亚洲影院久久精品| 9191精品国产综合久久久久久| 日韩在线一区二区三区| 日韩欧美国产一区二区三区| 国产一区久久久| 国产欧美一区二区精品性色超碰| www.欧美精品一二区| 亚洲综合视频网| 日韩欧美视频一区| 国产福利一区二区三区视频在线| 中文字幕一区二区三区乱码在线| 91精彩视频在线| 久久成人麻豆午夜电影| 中文字幕在线视频一区| 欧美无砖砖区免费| 国产激情视频一区二区三区欧美| **网站欧美大片在线观看| 欧美日韩免费观看一区二区三区| 久久国产精品99久久久久久老狼| 国产日韩欧美一区二区三区乱码| 在线欧美小视频| 国产原创一区二区| 一区二区三区四区在线播放| 欧美成人精品二区三区99精品| 丁香桃色午夜亚洲一区二区三区| 亚洲国产视频网站| 国产三区在线成人av| 欧美午夜寂寞影院| 不卡一区二区在线| 免费在线看成人av| 夜夜爽夜夜爽精品视频| xvideos.蜜桃一区二区| 欧美日韩国产免费一区二区| 成人精品一区二区三区中文字幕| 天天综合色天天综合| 亚洲欧美综合另类在线卡通| 日韩欧美在线影院| 色八戒一区二区三区| 国产成人在线视频网址| 全国精品久久少妇| 亚洲精选视频免费看| 久久精品日产第一区二区三区高清版| 欧美日韩夫妻久久| 91蝌蚪porny九色| 盗摄精品av一区二区三区| 久久精品国产一区二区三| 亚洲永久精品国产| 亚洲精品ww久久久久久p站| 国产亚洲一二三区| 精品国产凹凸成av人导航| 777xxx欧美| 欧美欧美欧美欧美首页| 色婷婷av一区二区三区gif| 成人精品鲁一区一区二区| 久久成人免费网| 久久er99精品| 美女国产一区二区| 免费观看在线色综合| 午夜不卡av免费| 亚洲丶国产丶欧美一区二区三区| 亚洲女人小视频在线观看| 亚洲日穴在线视频| 亚洲欧洲精品一区二区精品久久久| 中文字幕巨乱亚洲| 国产精品丝袜91| 国产精品久久久一区麻豆最新章节| 国产欧美久久久精品影院| 日本一区二区三区四区| 欧美国产日本韩| 欧美国产精品劲爆| 国产精品美女久久久久久久| 国产精品国产自产拍在线| 国产精品国产三级国产普通话蜜臀| 欧美极品另类videosde| 国产精品丝袜久久久久久app| 国产精品天天看| 中文字幕在线观看不卡| 亚洲乱码中文字幕| 亚洲国产毛片aaaaa无费看 | 91精品国产综合久久久蜜臀图片| 欧美精品1区2区3区| 欧美一级高清大全免费观看| 欧美一区二区性放荡片| 精品国产免费一区二区三区四区| 精品美女被调教视频大全网站| 久久久久久免费| 国产精品久久一级| 亚洲精品视频一区二区| 亚洲国产精品自拍| 精品一区二区三区蜜桃| 国产成人在线观看免费网站| 91丝袜呻吟高潮美腿白嫩在线观看| 91视频.com| 欧美三级三级三级爽爽爽| 日韩一区二区麻豆国产| 日本一区二区三区视频视频| 一区二区三区中文免费| 青青草97国产精品免费观看无弹窗版 | 蜜臀av一区二区在线观看| 国产原创一区二区| 色噜噜狠狠色综合中国| 欧美一区二区私人影院日本| 国产午夜精品福利| 亚洲一区视频在线观看视频| 久久国产麻豆精品| 色哟哟一区二区在线观看| 91精品国产色综合久久不卡电影| 久久蜜桃av一区精品变态类天堂 | 久久精品一区四区| 亚洲一区二区三区四区五区黄| 精品制服美女丁香| 91麻豆免费观看| 精品av久久707| 亚洲专区一二三| 激情五月婷婷综合| 欧美伊人精品成人久久综合97| 久久久蜜桃精品| 亚洲第一激情av| 99久久久久久99| 2021久久国产精品不只是精品| 一区二区三区日韩精品视频| 精品伊人久久久久7777人| 91成人看片片| 中文字幕免费一区| 麻豆久久一区二区| 色狠狠综合天天综合综合| 国产亚洲精品超碰| 蜜臀久久99精品久久久画质超高清| 色综合天天性综合| 久久日一线二线三线suv| 丝袜a∨在线一区二区三区不卡| 成人午夜av电影| 欧美v日韩v国产v| 日韩精品91亚洲二区在线观看 | 亚洲精品免费视频| 夫妻av一区二区| 欧美xxxx老人做受| 久久精品国产免费| 欧美老人xxxx18| 亚洲午夜在线电影| 精品视频1区2区| 亚洲精品高清在线观看| 成人精品国产一区二区4080| 国产亚洲精品免费| 国产麻豆视频一区| 久久这里都是精品| 激情欧美一区二区| 亚洲精品在线免费播放| 乱一区二区av| 精品人伦一区二区色婷婷| 精品在线观看视频| 国产亚洲综合在线| 懂色av中文字幕一区二区三区 | 日韩免费在线观看| 免费视频一区二区|