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

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

?? dynsplitterwnd.cpp

?? 圖像處理算法相關VC程序 VC++圖像處理程序設計配套光盤
?? 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

#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 width
			TrackColumnSize(m_rectTracker.left, m_htTrack - hSplitterBar1);
			RecalcLayout();
		}
		else if (m_htTrack >= splitterIntersection1 &&
			m_htTrack <= splitterIntersection225)
		{
			// set row height and column width
			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精品二区三区| 日产国产高清一区二区三区| 欧美日韩视频一区二区| 国产精品一区二区久久不卡| 一个色在线综合| 久久综合九色综合久久久精品综合| 成人黄动漫网站免费app| 日本在线播放一区二区三区| 中文字幕一区二区三区av| 精品精品欲导航| 欧美色视频在线观看| 国产盗摄一区二区| 日韩国产成人精品| 亚洲影院久久精品| 欧美韩国日本一区| 精品国产乱码久久| 欧美欧美欧美欧美| 欧美专区在线观看一区| 成人h动漫精品| 国产精品乡下勾搭老头1| 免费在线观看一区二区三区| 亚洲一二三区不卡| 亚洲精品日产精品乱码不卡| 日本一区二区免费在线观看视频| 欧美大片在线观看一区二区| 欧美性色欧美a在线播放| www.欧美日韩| 丰满白嫩尤物一区二区| 国产一区二区91| 麻豆成人91精品二区三区| 亚洲国产精品欧美一二99| 亚洲欧美欧美一区二区三区| 国产精品高潮呻吟| 中文字幕高清不卡| 中文字幕国产一区二区| 国产精品丝袜91| 亚洲国产精品成人综合| 国产亲近乱来精品视频| 久久久99精品免费观看不卡| 欧美tk丨vk视频| 精品国产污网站| 久久久无码精品亚洲日韩按摩| 精品久久久久久久久久久院品网 | 色综合久久久久久久久久久| 国v精品久久久网| 成人手机在线视频| 成人蜜臀av电影| av一区二区三区四区| 91色乱码一区二区三区| 99精品视频在线播放观看| av一区二区久久| 91精品办公室少妇高潮对白| 欧美性生交片4| 91精品国产综合久久国产大片| 3751色影院一区二区三区| 日韩视频免费直播| 337p日本欧洲亚洲大胆精品| 国产婷婷色一区二区三区在线| 日本一区二区三区免费乱视频| 中文字幕亚洲一区二区va在线| 亚洲少妇屁股交4| 亚洲国产乱码最新视频| 蜜臀av国产精品久久久久| 国产一区欧美二区| 丁香啪啪综合成人亚洲小说| 91一区在线观看| 欧美日本乱大交xxxxx| 日韩欧美国产一区二区在线播放 | 久久嫩草精品久久久精品| 欧美国产综合一区二区| 亚洲视频电影在线| 视频一区二区欧美| 国产成人综合网| 一本色道综合亚洲| 91精品婷婷国产综合久久性色| 精品国产电影一区二区| 亚洲欧美偷拍另类a∨色屁股| 天堂一区二区在线| 国产乱码精品一区二区三| 91在线你懂得| 制服丝袜亚洲播放| 国产精品美女一区二区在线观看| 亚洲一区二区三区国产| 黄一区二区三区| 色天天综合久久久久综合片| 欧美大片一区二区三区| 国产精品久久久久久久午夜片| 亚洲一卡二卡三卡四卡 | av影院午夜一区| 91精品久久久久久久久99蜜臂| 中文字幕巨乱亚洲| 日韩av一区二区三区四区| 99久久久久久| 精品人在线二区三区| 一区二区久久久久| 国产精品一级在线| 欧美日韩一区二区三区视频| 国产亚洲精品aa| 青娱乐精品视频| 色八戒一区二区三区| 久久久久国产精品人| 五月婷婷另类国产| 99在线精品一区二区三区| 精品88久久久久88久久久| 亚洲制服丝袜av| 成人一级片网址| 欧美sm极限捆绑bd| 五月婷婷激情综合网| 91女人视频在线观看| 久久综合五月天婷婷伊人| 视频一区中文字幕国产| 色综合色综合色综合 | 天天爽夜夜爽夜夜爽精品视频| 成人av在线电影| 国产亚洲自拍一区| 美脚の诱脚舐め脚责91| 欧美日高清视频| 亚洲精品精品亚洲| 成人免费视频网站在线观看| 欧美不卡一区二区| 免费视频一区二区| 欧美美女直播网站| 午夜精品视频在线观看| 欧美性受xxxx黑人xyx性爽| 中文字幕一区二区三区视频| 国产成人亚洲综合a∨猫咪| 精品少妇一区二区三区视频免付费 | 欧美日韩精品一区二区三区四区| 自拍偷拍国产精品| caoporm超碰国产精品| 国产欧美视频在线观看| 国产精品综合久久| 久久这里只有精品视频网| 裸体一区二区三区| 日韩一级视频免费观看在线| 日本在线不卡视频一二三区| 日韩一区二区在线看| 日韩专区一卡二卡| 欧美一区二区久久| 美日韩黄色大片| 日韩女优av电影在线观看| 久久精品国产一区二区三区免费看| 7878成人国产在线观看| 蜜臀久久99精品久久久久宅男 | 欧美在线观看一区| 亚洲一级在线观看| 欧美一区二区三区四区五区| 日本va欧美va精品| xfplay精品久久| www.爱久久.com| 一区二区三区欧美在线观看| 欧美亚洲尤物久久| 午夜精品视频在线观看| 日韩一区二区三区精品视频| 国产综合色在线| 中文久久乱码一区二区| 91猫先生在线| 婷婷亚洲久悠悠色悠在线播放| 91精品国产色综合久久不卡电影| 久久99精品国产| 久久精品亚洲一区二区三区浴池| 成人美女视频在线观看18| 一区二区三区日本| 欧美一级日韩一级| 国产精品99久久久久久有的能看| 国产精品大尺度| 欧美理论电影在线| 国产一区福利在线| 亚洲色图清纯唯美| 日韩一区二区不卡| 成人午夜精品一区二区三区| 一区二区三区在线视频播放 | 亚洲精品福利视频网站| 欧美日韩另类一区| 国产精品自在在线| 一区二区视频在线| 精品国产网站在线观看| 成人激情小说网站| 视频一区视频二区中文| 中文文精品字幕一区二区| 欧美在线看片a免费观看| 麻豆精品一二三| 亚洲乱码国产乱码精品精可以看| 91精品国产高清一区二区三区| 国产精品99久久久| 婷婷综合在线观看| 国产精品免费人成网站| 日韩一区二区在线观看| 91在线精品一区二区| 久久精品国产第一区二区三区| 国产精品二区一区二区aⅴ污介绍| 91.成人天堂一区| 99天天综合性| 国产一区美女在线| 三级精品在线观看| 亚洲桃色在线一区| 久久色.com| 欧美一区二区久久久| 在线亚洲一区二区| 成人自拍视频在线|