📄 srvritem.cpp
字号:
//////////////////////////////////////////////////////////////////////
//
// File: SrvrItem.cpp
//
// $Archive: /ComemL/Util/PCfg/SrvrItem.cpp $
//
// Purpose:
//
// $Author: Tpm $
//
// $History: SrvrItem.cpp $
//
// ***************** Version 1 *****************
// User: Tpm Date: 7/13/98 Time: 8:38a
// Created in $/ComemL/Util/PCfg
//
// ***************** Version 4 *****************
// User: Stevek Date: 10/22/97 Time: 12:27p
// Updated in $/Comem/Mapper
// Added header blocks to all files at once!
//
// Copyright (c) 1997 Anchor Chips, Inc. May not be reproduced without
// permission. See the license agreement for more details.
//
//////////////////////////////////////////////////////////////////////
// SrvrItem.cpp : implementation of the CMapperSrvrItem class
//
#include "stdafx.h"
#include "mapper.h"
#include "SrvrItem.h"
#include "CntrItem.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CMapperSrvrItem implementation
IMPLEMENT_DYNAMIC(CMapperSrvrItem, COleServerItem)
CMapperSrvrItem::CMapperSrvrItem(CMapperDoc* pContainerDoc)
: COleServerItem(pContainerDoc, TRUE)
{
// TODO: add one-time construction code here
// (eg, adding additional clipboard formats to the item's data source)
}
CMapperSrvrItem::~CMapperSrvrItem()
{
// TODO: add cleanup code here
}
void CMapperSrvrItem::Serialize(CArchive& ar)
{
// CMapperSrvrItem::Serialize will be called by the framework if
// the item is copied to the clipboard. This can happen automatically
// through the OLE callback OnGetClipboardData. A good default for
// the embedded item is simply to delegate to the document's Serialize
// function. If you support links, then you will want to serialize
// just a portion of the document.
if (!IsLinkedItem())
{
CMapperDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
pDoc->Serialize(ar);
}
}
BOOL CMapperSrvrItem::OnGetExtent(DVASPECT dwDrawAspect, CSize& rSize)
{
// Most applications, like this one, only handle drawing the content
// aspect of the item. If you wish to support other aspects, such
// as DVASPECT_THUMBNAIL (by overriding OnDrawEx), then this
// implementation of OnGetExtent should be modified to handle the
// additional aspect(s).
if (dwDrawAspect != DVASPECT_CONTENT)
return COleServerItem::OnGetExtent(dwDrawAspect, rSize);
// CMapperSrvrItem::OnGetExtent is called to get the extent in
// HIMETRIC units of the entire item. The default implementation
// here simply returns a hard-coded number of units.
CMapperDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: replace this arbitrary size
rSize = CSize(3000, 3000); // 3000 x 3000 HIMETRIC units
return TRUE;
}
BOOL CMapperSrvrItem::OnDraw(CDC* pDC, CSize& rSize)
{
CMapperDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: set mapping mode and extent
// (The extent is usually the same as the size returned from OnGetExtent)
pDC->SetMapMode(MM_ANISOTROPIC);
pDC->SetWindowOrg(0,0);
pDC->SetWindowExt(3000, 3000);
// TODO: add drawing code here. Optionally, fill in the HIMETRIC extent.
// All drawing takes place in the metafile device context (pDC).
// TODO: also draw embedded CMapperCntrItem objects.
// The following code draws the first item at an arbitrary position.
// TODO: remove this code when your real drawing code is complete
POSITION pos = pDoc->GetStartPosition();
CMapperCntrItem* pItem = (CMapperCntrItem*)pDoc->GetNextClientItem(pos);
if (pItem != NULL)
pItem->Draw(pDC, CRect(10, 10, 1010, 1010));
return TRUE;
}
/////////////////////////////////////////////////////////////////////////////
// CMapperSrvrItem diagnostics
#ifdef _DEBUG
void CMapperSrvrItem::AssertValid() const
{
COleServerItem::AssertValid();
}
void CMapperSrvrItem::Dump(CDumpContext& dc) const
{
COleServerItem::Dump(dc);
}
#endif
/////////////////////////////////////////////////////////////////////////////
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -