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

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

?? drawobj.cpp

?? 連接oracle
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// drawobj.cpp - implementation for drawing objects
//
// This is a part of the Microsoft Foundation Classes C++ library.
// Copyright (C) 1992-1997 Microsoft Corporation
// All rights reserved.
//
// This source code is only intended as a supplement to the
// Microsoft Foundation Classes Reference and related
// electronic documentation provided with the library.
// See these sources for detailed information regarding the
// Microsoft Foundation Classes product.


#include "stdafx.h"
#include "drawcli.h"

#include "drawdoc.h"
#include "drawvw.h"
#include "drawobj.h"

#include "cntritem.h"
#include "rectdlg.h"
#include "math.h"

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 = 1;
	m_logpen.lopnWidth.y = 1;
	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;

	m_sWellNO = "";
	m_sXCH = "";
	m_PosIndex = -1;
}
//CDrawObj::CDrawObj( Shape pShape, const CRect &position)
//{
//}

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;
	sheet.AddPage( &dlg );

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

	m_bBrush = !dlg.m_bNoFill;
	m_bPen = dlg.m_penSize > 0;
	if (m_bPen)
	{
		m_logpen.lopnWidth.x = dlg.m_penSize;
		m_logpen.lopnWidth.y = dlg.m_penSize;
	}

	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();
}

COLORREF CDrawObj::GetFillColor()
{
	return m_logbrush.lbColor;
}

#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()
{
	if (m_ArrText.GetSize()>0)
		m_ArrText.RemoveAll();
}

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

	m_nShape = rectangle;
	m_roundness.x = 16;
	m_roundness.y = 16;
}
CDrawRect::CDrawRect(DrawShape _Shape,const CRect& position,CString pWellNO,char pSubList)
	: CDrawObj(position)
{
	ASSERT_VALID(this);

	//m_nShape = _Shape;
	switch (_Shape)
	{
	case ::rect:
		m_nShape = CDrawRect::rectangle;
		break;
	case ::ellipse:
		m_nShape = CDrawRect::ellipse;
		break;
	case ::roundRect:
		m_nShape = CDrawRect::roundRectangle;
		break;
	case ::line:
		m_nShape = CDrawRect::line;
		break;
	case ::text:			//hjq 新加文檔 2006-11
		m_nShape = CDrawRect::text;
		break;
	case ::vtext:
		m_nShape = CDrawRect::vtext;
		break;
	case ::recttext:
		m_nShape = CDrawRect::recttext;
		break;
	case ::fault_line:
		m_nShape = CDrawRect::fault_line;
		break;
	default:
		ASSERT(FALSE); // unsuported shape!
	}
	m_DShape = _Shape ;
	m_sWellNO = pWellNO;
	m_cSubList = pSubList;
	m_roundness.x = 16;
	m_roundness.y = 16;
	m_fontsize = 13;
	m_bLinkPic = TRUE;
}

void CDrawRect::Serialize(CArchive& ar)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人涩涩免费视频| 韩国女主播成人在线| 亚洲欧洲制服丝袜| 依依成人精品视频| 亚洲欧美经典视频| 中文一区二区完整视频在线观看| 欧美日韩精品欧美日韩精品| 国产成人丝袜美腿| 日韩精品色哟哟| 国产日韩欧美精品一区| 久久久久国产精品人| 欧美激情资源网| 亚洲综合另类小说| 亚洲一区二区三区视频在线 | 欧美韩日一区二区三区四区| 精品国产伦一区二区三区观看方式| 毛片av中文字幕一区二区| 国产欧美日韩麻豆91| 国产欧美日韩在线看| 国产日韩成人精品| 国产精品丝袜一区| 亚洲永久精品国产| 青青青伊人色综合久久| 麻豆国产精品777777在线| 日本欧美在线观看| 成人av网址在线观看| 国产成人午夜高潮毛片| 91色porny在线视频| 一本大道综合伊人精品热热| 欧美日韩国产综合一区二区| 久久精品人人做人人综合| 日本一区二区三区免费乱视频| 国产精品福利av| 日韩av网站免费在线| 91在线看国产| 久久久一区二区| 免费的国产精品| 日本精品一级二级| 欧美国产成人精品| 亚洲专区一二三| 成+人+亚洲+综合天堂| 欧美精品v国产精品v日韩精品| 国产日韩欧美综合一区| 免费欧美在线视频| 日韩一二在线观看| 日韩美女视频一区| 麻豆国产精品视频| 欧美tickle裸体挠脚心vk| 丝袜亚洲另类丝袜在线| 国产成a人亚洲精| 亚洲欧美在线aaa| 在线不卡免费欧美| 成人午夜私人影院| 激情偷乱视频一区二区三区| 4438x亚洲最大成人网| 成人午夜在线免费| 美女精品一区二区| 3atv在线一区二区三区| 午夜欧美在线一二页| 制服丝袜亚洲色图| 成人动漫一区二区在线| 一区二区三区免费| 欧美中文字幕一区二区三区亚洲| 亚洲一区二区欧美| 欧美美女bb生活片| 亚洲欧美视频一区| 国产91精品免费| 中文子幕无线码一区tr| 91丨porny丨蝌蚪视频| 日韩福利视频网| 一区精品在线播放| 日韩三区在线观看| 成人a免费在线看| 首页欧美精品中文字幕| 欧美国产97人人爽人人喊| 色综合天天视频在线观看| 亚洲欧洲色图综合| 国产精品久久毛片av大全日韩| 91蜜桃免费观看视频| 久久这里都是精品| 国产aⅴ精品一区二区三区色成熟| 欧美亚洲禁片免费| 久久精品人人爽人人爽| 99久久久精品免费观看国产蜜| 久久精品视频一区二区| 顶级嫩模精品视频在线看| 国产欧美一区二区精品性| 99re在线精品| 成人国产精品免费观看| 久久机这里只有精品| 一区二区三区四区国产精品| 国产欧美日韩亚州综合 | 久久夜色精品国产噜噜av| 成人性生交大片免费看视频在线 | 欧美日韩免费视频| 99re热视频精品| 91免费看`日韩一区二区| 成人免费视频播放| 97se亚洲国产综合自在线| 91尤物视频在线观看| 国产一区二区三区免费观看| 日韩经典中文字幕一区| 尤物视频一区二区| 五月天婷婷综合| 久久国产婷婷国产香蕉| 国产河南妇女毛片精品久久久| 奇米精品一区二区三区在线观看一 | 看电影不卡的网站| 国产一区二区三区免费看 | 成人美女在线观看| 成人av在线网站| 6080午夜不卡| 国产精品久久久久三级| 国产亚洲自拍一区| 婷婷综合另类小说色区| 紧缚奴在线一区二区三区| 国产成人精品免费在线| 欧美日韩国产美女| 久久天堂av综合合色蜜桃网| 中文在线一区二区| 亚洲欧洲精品天堂一级| 免费观看30秒视频久久| 成人精品鲁一区一区二区| 678五月天丁香亚洲综合网| 国产亚洲综合色| 亚洲成人免费av| 在线免费亚洲电影| 精品久久人人做人人爽| 亚洲男女毛片无遮挡| 久久99精品久久久久| 日韩欧美一卡二卡| 高清在线成人网| 亚洲曰韩产成在线| 欧美va在线播放| jlzzjlzz亚洲日本少妇| 亚洲国产三级在线| 欧美精品日韩一区| 青青草视频一区| www激情久久| 成人动漫精品一区二区| 亚洲精品ww久久久久久p站| 99久久免费精品高清特色大片| 国产精品久久久久久久久免费相片 | 美腿丝袜亚洲色图| 国产视频一区在线观看| 91天堂素人约啪| 国产精品久久久久久久久果冻传媒| 欧美怡红院视频| 国产成人综合在线观看| 亚洲一区在线观看网站| 欧美精品一区男女天堂| 9久草视频在线视频精品| 亚洲成av人片一区二区梦乃 | 91精品国产综合久久福利 | 色综合天天性综合| 五月激情六月综合| 亚洲男同性视频| 制服丝袜av成人在线看| 91片在线免费观看| 成人黄色小视频在线观看| 精品一区二区在线播放| 久久激情五月婷婷| 国产在线精品一区二区夜色| 日韩精品一级二级 | 色综合天天综合在线视频| 日本大胆欧美人术艺术动态| 亚洲天堂免费在线观看视频| 日韩欧美一卡二卡| 日韩一区二区三区电影| 色94色欧美sute亚洲13| 久久国产精品区| 国产精品一区二区果冻传媒| 日韩国产欧美在线观看| 亚洲大片在线观看| 日韩高清国产一区在线| 日本vs亚洲vs韩国一区三区 | 久久国产精品72免费观看| 亚洲aaa精品| 国产成人在线观看| 欧美日韩视频一区二区| 日韩一区二区三区四区| 久久精品免视看| 日韩免费观看2025年上映的电影| 国产一区中文字幕| 亚洲午夜在线观看视频在线| 亚洲码国产岛国毛片在线| 欧美精品乱码久久久久久| 日本不卡123| 欧美一二三区在线| 91香蕉视频在线| 亚洲午夜国产一区99re久久| 日韩欧美成人一区二区| 91在线观看美女| 蜜桃视频在线观看一区| 亚洲天堂网中文字| 日本一区二区三区四区在线视频 | 亚洲精品成人悠悠色影视| 欧美精品在线观看播放| 99精品欧美一区二区三区小说| 五月婷婷另类国产|