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

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

?? drawobj.cpp

?? 5個組態軟件設計樣例(VC++6.0)
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// DrawObj.cpp: implementation of the CDrawObj class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "DrawCli.h"
#include "DrawObj.h"

#include "drawdoc.h"
#include "drawvw.h"
#include "cntritem.h"
#include "rectdlg.h"

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

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

IMPLEMENT_SERIAL(CDrawObj, CObject, 0)

CDrawObj::CDrawObj()
{
}

CDrawObj::~CDrawObj()
{
}

CDrawObj::CDrawObj(const CRect& position)
{
	m_position = position;
	m_pDocument = NULL;

	m_bPen = TRUE;
	m_logpen.lopnStyle = PS_INSIDEFRAME;
	m_logpen.lopnWidth.x = 2;
	m_logpen.lopnWidth.y = 2;
	m_logpen.lopnColor = RGB(0, 0, 0);

	m_bBrush = TRUE;
	m_logbrush.lbStyle = BS_SOLID;
	m_logbrush.lbColor = RGB(192, 192, 192);
	m_logbrush.lbHatch = HS_HORIZONTAL;
}

void CDrawObj::Serialize(CArchive& ar)
{
	CObject::Serialize(ar);
	if (ar.IsStoring())
	{
		ar << m_position;
		ar << (WORD)m_bPen;
		ar.Write(&m_logpen, sizeof(LOGPEN));
		ar << (WORD)m_bBrush;
		ar.Write(&m_logbrush, sizeof(LOGBRUSH));
	}
	else
	{
		// get the document back pointer from the archive
		m_pDocument = (CDrawDoc*)ar.m_pDocument;
		ASSERT_VALID(m_pDocument);
		ASSERT_KINDOF(CDrawDoc, m_pDocument);

		WORD wTemp;
		ar >> m_position;
		ar >> wTemp; m_bPen = (BOOL)wTemp;
		ar.Read(&m_logpen,sizeof(LOGPEN));
		ar >> wTemp; m_bBrush = (BOOL)wTemp;
		ar.Read(&m_logbrush, sizeof(LOGBRUSH));
	}
}

void CDrawObj::Remove()
{
	delete this;
}

void CDrawObj::Draw(CDC*)
{
}

void CDrawObj::DrawTracker(CDC* pDC, TrackerState state)
{
	ASSERT_VALID(this);

	switch (state)
	{
	case normal:
		break;

	case selected:
	case active:
		{
			int nHandleCount = GetHandleCount();
			for (int nHandle = 1; nHandle <= nHandleCount; nHandle += 1)
			{
				CPoint handle = GetHandle(nHandle);
				pDC->PatBlt(handle.x - 3, handle.y - 3, 7, 7, DSTINVERT);
			}
		}
		break;
	}
}

// position is in logical
void CDrawObj::MoveTo(const CRect& position, CDrawView* pView)
{
	ASSERT_VALID(this);
 
	if (position == m_position)
		return;

	if (pView == NULL)
	{
		Invalidate();
		m_position = position;
		Invalidate();
	}
	else
	{
		pView->InvalObj(this);
		m_position = position;
		pView->InvalObj(this);
	}
	m_pDocument->SetModifiedFlag();
}

// Note: if bSelected, hit-codes start at one for the top-left
// and increment clockwise, 0 means no hit.
// If !bSelected, 0 = no hit, 1 = hit (anywhere)

// point is in logical coordinates
int CDrawObj::HitTest(CPoint point, CDrawView* pView, BOOL bSelected)
{
	ASSERT_VALID(this);
	ASSERT(pView != NULL);

	if (bSelected)
	{
		int nHandleCount = GetHandleCount();
		for (int nHandle = 1; nHandle <= nHandleCount; nHandle += 1)
		{
			// GetHandleRect returns in logical coords
			CRect rc = GetHandleRect(nHandle,pView);
			if (point.x >= rc.left && point.x < rc.right &&
				point.y <= rc.top && point.y > rc.bottom)
				return nHandle;
		}
	}
	else
	{
		if (point.x >= m_position.left && point.x < m_position.right &&
			point.y <= m_position.top && point.y > m_position.bottom)
			return 1;
	}
	return 0;
}

// rect must be in logical coordinates
BOOL CDrawObj::Intersects(const CRect& rect)
{
	ASSERT_VALID(this);

	CRect fixed = m_position;
	fixed.NormalizeRect();
	CRect rectT = rect;
	rectT.NormalizeRect();
	return !(rectT & fixed).IsRectEmpty();
}

int CDrawObj::GetHandleCount()
{
	ASSERT_VALID(this);
	return 8;
}

// returns logical coords of center of handle
CPoint CDrawObj::GetHandle(int nHandle)
{
	ASSERT_VALID(this);
	int x, y, xCenter, yCenter;

	// this gets the center regardless of left/right and top/bottom ordering
	xCenter = m_position.left + m_position.Width() / 2;
	yCenter = m_position.top + m_position.Height() / 2;

	switch (nHandle)
	{
	default:
		ASSERT(FALSE);

	case 1:
		x = m_position.left;
		y = m_position.top;
		break;

	case 2:
		x = xCenter;
		y = m_position.top;
		break;

	case 3:
		x = m_position.right;
		y = m_position.top;
		break;

	case 4:
		x = m_position.right;
		y = yCenter;
		break;

	case 5:
		x = m_position.right;
		y = m_position.bottom;
		break;

	case 6:
		x = xCenter;
		y = m_position.bottom;
		break;

	case 7:
		x = m_position.left;
		y = m_position.bottom;
		break;

	case 8:
		x = m_position.left;
		y = yCenter;
		break;
	}

	return CPoint(x, y);
}

// return rectange of handle in logical coords
CRect CDrawObj::GetHandleRect(int nHandleID, CDrawView* pView)
{
	ASSERT_VALID(this);
	ASSERT(pView != NULL);

	CRect rect;
	// get the center of the handle in logical coords
	CPoint point = GetHandle(nHandleID);
	// convert to client/device coords
	pView->DocToClient(point);
	// return CRect of handle in device coords
	rect.SetRect(point.x-3, point.y-3, point.x+3, point.y+3);
	pView->ClientToDoc(rect);

	return rect;
}

HCURSOR CDrawObj::GetHandleCursor(int nHandle)
{
	ASSERT_VALID(this);

	LPCTSTR id;
	switch (nHandle)
	{
	default:
		ASSERT(FALSE);

	case 1:
	case 5:
		id = IDC_SIZENWSE;
		break;

	case 2:
	case 6:
		id = IDC_SIZENS;
		break;

	case 3:
	case 7:
		id = IDC_SIZENESW;
		break;

	case 4:
	case 8:
		id = IDC_SIZEWE;
		break;
	}

	return AfxGetApp()->LoadStandardCursor(id);
}

// point must be in logical
void CDrawObj::MoveHandleTo(int nHandle, CPoint point, CDrawView* pView)
{
	ASSERT_VALID(this);

	CRect position = m_position;
	switch (nHandle)
	{
	default:
		ASSERT(FALSE);

	case 1:
		position.left = point.x;
		position.top = point.y;
		break;

	case 2:
		position.top = point.y;
		break;

	case 3:
		position.right = point.x;
		position.top = point.y;
		break;

	case 4:
		position.right = point.x;
		break;

	case 5:
		position.right = point.x;
		position.bottom = point.y;
		break;

	case 6:
		position.bottom = point.y;
		break;

	case 7:
		position.left = point.x;
		position.bottom = point.y;
		break;

	case 8:
		position.left = point.x;
		break;
	}

	MoveTo(position, pView);
}

void CDrawObj::Invalidate()
{
	ASSERT_VALID(this);
	m_pDocument->UpdateAllViews(NULL, HINT_UPDATE_DRAWOBJ, this);
}

CDrawObj* CDrawObj::Clone(CDrawDoc* pDoc)
{
	ASSERT_VALID(this);
 
	CDrawObj* pClone = new CDrawObj(m_position);

	pClone->m_bPen = m_bPen;
	pClone->m_logpen = m_logpen;
	pClone->m_bBrush = m_bBrush;
	pClone->m_logbrush = m_logbrush;
	ASSERT_VALID(pClone);

	if (pDoc != NULL)
		pDoc->Add(pClone);

	return pClone;

}

void CDrawObj::OnEditProperties()
{
	ASSERT_VALID(this);
   
	CPropertySheet sheet( _T("對象顯示屬性") );
	CRectDlg dlg;
	dlg.m_bNoFill = !m_bBrush;
	dlg.m_penSize = m_bPen ? m_logpen.lopnWidth.x : 0;
	dlg.m_LineColor = m_logpen.lopnColor;	  
    dlg.m_FillColor = m_logbrush.lbColor;	  

	sheet.AddPage( &dlg );

	if (sheet.DoModal() != IDOK)
		return;


	m_bBrush = !dlg.m_bNoFill;
	m_bPen = dlg.m_penSize > 0;
	m_logbrush.lbColor = dlg.m_FillColor;   
	if (m_bPen)
	{
	    m_logpen.lopnWidth.x = dlg.m_penSize;
		m_logpen.lopnWidth.y = dlg.m_penSize;
		m_logpen.lopnColor = dlg.m_LineColor;   

 	}

	Invalidate();
	m_pDocument->SetModifiedFlag(); 
}

void CDrawObj::OnOpen(CDrawView* /*pView*/ )
{
	OnEditProperties();
}

void CDrawObj::SetLineColor(COLORREF color)
{
	ASSERT_VALID(this);

	m_logpen.lopnColor = color;
	Invalidate();
	m_pDocument->SetModifiedFlag();
}

void CDrawObj::SetFillColor(COLORREF color)
{
	ASSERT_VALID(this);

	m_logbrush.lbColor = color;
	Invalidate();
	m_pDocument->SetModifiedFlag();
}

#ifdef _DEBUG
void CDrawObj::AssertValid()
{
	ASSERT(m_position.left <= m_position.right);
	ASSERT(m_position.bottom <= m_position.top);
}
#endif

////////////////////////////////////////////////////////////////////////////
// CDrawRect

IMPLEMENT_SERIAL(CDrawRect, CDrawObj, 0)

CDrawRect::CDrawRect()
{
}

CDrawRect::CDrawRect(const CRect& position)
	: CDrawObj(position)
{
	ASSERT_VALID(this);

	m_nShape = rectangle;
	m_roundness.x = 16;
	m_roundness.y = 16;
}

void CDrawRect::Serialize(CArchive& ar)
{
	ASSERT_VALID(this);

	CDrawObj::Serialize(ar);
	if (ar.IsStoring())
	{
		ar << (WORD) m_nShape;
		ar << m_roundness;
	}
	else
	{
		WORD wTemp;
		ar >> wTemp; m_nShape = (Shape)wTemp;
		ar >> m_roundness;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品影院| 精品日韩欧美一区二区| 精品国产区一区| 亚洲不卡av一区二区三区| 国产成人午夜99999| 成人av在线网站| 日韩女优av电影在线观看| 美女视频一区二区| 精品久久人人做人人爱| 国产成人免费视频一区| 久久精品亚洲一区二区三区浴池| 亚洲三级免费电影| 在线观看一区日韩| 婷婷亚洲久悠悠色悠在线播放 | 国产成人精品综合在线观看| 精品成人在线观看| 99久久综合精品| 石原莉奈在线亚洲二区| 欧美影视一区在线| 国产自产视频一区二区三区| 午夜欧美2019年伦理| 欧美午夜精品久久久| 国产精品中文有码| 国产欧美一区二区在线| 欧美三级蜜桃2在线观看| 91在线丨porny丨国产| 777久久久精品| 久久成人久久鬼色| 久久99这里只有精品| 91精品国产欧美一区二区| 日韩va欧美va亚洲va久久| 99re热这里只有精品视频| 国产欧美精品一区| www.视频一区| 亚洲欧美在线观看| 色狠狠色狠狠综合| 亚洲综合精品自拍| 欧美精品一二三| 日本欧美在线看| 欧美一级高清片| 国内一区二区视频| 欧美极品少妇xxxxⅹ高跟鞋| 成人午夜视频免费看| 国产精品黄色在线观看| 色婷婷综合久久久| 性做久久久久久| 日韩一区二区影院| 国产精品一区二区久久不卡| 中文字幕久久午夜不卡| 91免费观看视频| 亚洲综合一二区| 日韩一级精品视频在线观看| 精品一区二区免费视频| 国产亚洲成av人在线观看导航| 波多野结衣在线aⅴ中文字幕不卡| 国产精品丝袜一区| 欧美日韩一级大片网址| 久久99久久精品| 中文字幕日本不卡| 欧美卡1卡2卡| 国产激情一区二区三区| 亚洲免费av高清| 欧美一二三在线| 成人av资源在线| 婷婷综合久久一区二区三区| 久久精品人人做| 在线免费观看一区| 久久精品免费观看| 日韩毛片在线免费观看| 欧美高清精品3d| 国产乱码精品一区二区三区忘忧草 | 精品制服美女丁香| 亚洲欧美激情视频在线观看一区二区三区| 51精品视频一区二区三区| 国产不卡在线播放| 日韩国产欧美在线视频| 国产精品福利一区二区三区| 欧美日韩三级一区二区| 成人网在线免费视频| 午夜精品久久久久影视| 自拍偷拍亚洲欧美日韩| 欧美videos大乳护士334| 欧美性色综合网| 成人性生交大片免费看视频在线| 日韩电影网1区2区| 一区二区理论电影在线观看| 久久久久九九视频| 欧美一区二区精品| 欧美综合色免费| 不卡的电视剧免费网站有什么| 免费日本视频一区| 亚洲成av人影院| 亚洲人成7777| 天天av天天翘天天综合网色鬼国产| 久久久久久久久久电影| 日韩一区二区电影| 8x8x8国产精品| 欧美网站大全在线观看| 91免费观看视频| av一区二区不卡| 国产成人免费在线视频| 开心九九激情九九欧美日韩精美视频电影| 亚洲狠狠爱一区二区三区| 国产精品乱码一区二区三区软件 | 久久综合中文字幕| 成人黄色一级视频| 国产精品美女久久福利网站| 在线精品视频免费观看| 亚洲第一狼人社区| 一区二区三区**美女毛片| 日韩精品一区二区三区在线 | 日韩精品一区二区在线| 精品亚洲成av人在线观看| 亚洲欧美成人一区二区三区| 欧美久久久久久久久中文字幕| 久久99精品视频| 日韩精品一二三区| 亚洲sss视频在线视频| 欧美国产精品劲爆| 国产片一区二区| 欧美国产欧美综合| 中文字幕欧美国产| 亚洲国产婷婷综合在线精品| 天天操天天干天天综合网| 国产丶欧美丶日本不卡视频| caoporen国产精品视频| 国产91综合一区在线观看| 亚洲国产精品精华液2区45| www.欧美.com| 国产精品香蕉一区二区三区| 麻豆一区二区在线| 风间由美一区二区三区在线观看| 日韩三级精品电影久久久 | 99久久国产综合精品麻豆| 成人性生交大片免费看视频在线| 成人动漫中文字幕| 在线中文字幕一区| 欧美一区二区三区视频| 精品久久久久久最新网址| 国产精品视频一区二区三区不卡| 亚洲欧洲日韩av| 日韩国产成人精品| 处破女av一区二区| 在线观看成人免费视频| 日韩一区二区视频| 国产精品国产三级国产aⅴ中文| 一区二区三区美女| 久久机这里只有精品| 99久久综合精品| 日韩欧美久久久| 亚洲色图一区二区| 日本中文字幕一区二区视频 | 精品国产一区二区精华| 国产精品久久久久久妇女6080| 一区二区三区国产精品| 另类人妖一区二区av| 91小视频免费看| 日韩一区二区免费在线观看| 国产精品视频麻豆| 奇米影视在线99精品| eeuss影院一区二区三区| 制服丝袜一区二区三区| 国产精品污www在线观看| 亚洲国产综合色| 国产成人av电影在线观看| 在线观看成人免费视频| 国产日韩综合av| 午夜精品久久久久影视| aa级大片欧美| 26uuu国产在线精品一区二区| 亚洲视频中文字幕| 国产激情精品久久久第一区二区 | 亚洲第一搞黄网站| 99久久国产综合精品色伊 | 777a∨成人精品桃花网| 亚洲婷婷综合色高清在线| 国产精品资源网站| 日韩一区二区精品葵司在线| 亚洲一区二区三区视频在线| 成人18视频在线播放| 国产日产亚洲精品系列| 精品一区二区三区的国产在线播放| 91欧美激情一区二区三区成人| 久久精品亚洲精品国产欧美| 免费av网站大全久久| 欧美三区免费完整视频在线观看| 国产精品伦一区二区三级视频| 国产精品主播直播| 精品国产免费一区二区三区四区| 五月综合激情日本mⅴ| 欧美性三三影院| 亚洲一级在线观看| 在线观看成人小视频| 亚洲久本草在线中文字幕| 91香蕉视频在线| 亚洲黄色性网站| 91精品91久久久中77777| 亚洲三级理论片| 在线观看免费视频综合| 亚洲黄一区二区三区|