// [!output CONTAINER_ITEM_IMPL] : [!output CONTAINER_ITEM_CLASS] 类的实现 // #include "stdafx.h" #include "[!output APP_HEADER]" [!if OLEDB_RECORD_VIEW || ODBC_RECORD_VIEW] #include "[!output ROWSET_HEADER]" [!endif] #include "[!output DOC_HEADER]" #include "[!output VIEW_HEADER]" #include "[!output CONTAINER_ITEM_HEADER]" #ifdef _DEBUG #define new DEBUG_NEW #endif // [!output CONTAINER_ITEM_CLASS] 的实现 IMPLEMENT_SERIAL([!output CONTAINER_ITEM_CLASS], [!output CONTAINER_ITEM_BASE_CLASS], 0) [!if RICH_EDIT_VIEW] [!output CONTAINER_ITEM_CLASS]::[!output CONTAINER_ITEM_CLASS](REOBJECT* preo, [!output DOC_CLASS]* pContainer) : [!output CONTAINER_ITEM_BASE_CLASS](preo, pContainer) [!else] [!output CONTAINER_ITEM_CLASS]::[!output CONTAINER_ITEM_CLASS]([!output DOC_CLASS]* pContainer) : [!output CONTAINER_ITEM_BASE_CLASS](pContainer) [!endif] { // TODO: 在此添加一次性构造代码 } [!output CONTAINER_ITEM_CLASS]::~[!output CONTAINER_ITEM_CLASS]() { // TODO: 在此处添加清除代码 } [!if !RICH_EDIT_VIEW] void [!output CONTAINER_ITEM_CLASS]::OnChange(OLE_NOTIFICATION nCode, DWORD dwParam) { ASSERT_VALID(this); [!output CONTAINER_ITEM_BASE_CLASS]::OnChange(nCode, dwParam); // 在编辑某项时(就地编辑或完全打开进行编辑), // 该项将就其自身状态的更改 // 或其内容的可视外观状态的更改发送 OnChange 通知。 // TODO: 通过调用 UpdateAllViews 使该项无效 // (包括适合您的应用程序的提示) GetDocument()->UpdateAllViews(NULL); // 现在只更新所有视图/无提示 } BOOL [!output CONTAINER_ITEM_CLASS]::OnChangeItemPosition(const CRect& rectPos) { ASSERT_VALID(this); // 就地激活期间,服务器调用 [!output CONTAINER_ITEM_CLASS]::OnChangeItemPosition // 以更改就地 // 窗口的位置。这通常是由于服务器 // 文档中的数据更改而导致范围改变或是 // 就地调整大小所引起的。 // // 此处的默认设置调用基类,该基类将调用 // [!output CONTAINER_ITEM_BASE_CLASS]::SetItemRects 以将该项 // 移动到新的位置。 if (![!output CONTAINER_ITEM_BASE_CLASS]::OnChangeItemPosition(rectPos)) return FALSE; // TODO: 更新您在该项的矩形/范围内可具有的任何缓存 return TRUE; } [!if !ACTIVE_DOC_CONTAINER] void [!output CONTAINER_ITEM_CLASS]::OnGetItemPosition(CRect& rPosition) { ASSERT_VALID(this); // 就地激活期间,将调用 [!output CONTAINER_ITEM_CLASS]::OnGetItemPosition // 以决定该项的位置。通常, // 该矩形会反映与激活所用视图 // 相关项的当前位置。调用 // [!output CONTAINER_ITEM_CLASS]::GetActiveView 可得到视图。 // TODO: 返回 rPosition 中的正确矩形(以像素表示) CSize size; rPosition.SetRectEmpty(); if (SUCCEEDED(GetExtent(&size, m_nDrawAspect))) { [!output VIEW_CLASS]* pView = GetActiveView(); ASSERT_VALID(pView); if (!pView) return; CDC *pDC = pView->GetDC(); ASSERT(pDC); if (!pDC) return; pDC->HIMETRICtoLP(&size); rPosition.SetRect(10, 10, size.cx + 10, size.cy + 10); } else rPosition.SetRect(10, 10, 210, 210); } [!endif] void [!output CONTAINER_ITEM_CLASS]::OnActivate() { [!if !ACTIVE_DOC_CONTAINER] // 每个框架只能有一个就地激活项 [!output VIEW_CLASS]* pView = GetActiveView(); ASSERT_VALID(pView); if (!pView) return; COleClientItem* pItem = GetDocument()->GetInPlaceActiveItem(pView); if (pItem != NULL && pItem != this) pItem->Close(); [!output CONTAINER_ITEM_BASE_CLASS]::OnActivate(); [!endif] } void [!output CONTAINER_ITEM_CLASS]::OnDeactivateUI(BOOL bUndoable) { [!output CONTAINER_ITEM_BASE_CLASS]::OnDeactivateUI(bUndoable); DWORD dwMisc = 0; m_lpObject->GetMiscStatus(GetDrawAspect(), &dwMisc); if (dwMisc & OLEMISC_INSIDEOUT) DoVerb(OLEIVERB_HIDE, NULL); } #ifndef _WIN32_WCE_NO_ARCHIVE_SUPPORT void [!output CONTAINER_ITEM_CLASS]::Serialize(CArchive& ar) { ASSERT_VALID(this); // 首先调用基类以读取 [!output CONTAINER_ITEM_BASE_CLASS] 数据。 // 因为这样会设置从 [!output CONTAINER_ITEM_CLASS]::GetDocument 返回的 m_pDocument 指针, // 所以最好先调用 // 基类 Serialize。 [!output CONTAINER_ITEM_BASE_CLASS]::Serialize(ar); // 现在存储/检索特定于 [!output CONTAINER_ITEM_CLASS] 的数据 if (ar.IsStoring()) { // TODO: 在此添加存储代码 } else { // TODO: 在此添加加载代码 } } #endif // _WIN32_WCE [!if CONTAINER_SERVER] BOOL [!output CONTAINER_ITEM_CLASS]::CanActivate() { // 当服务器本身处于就地编辑模式时,就地编辑无效且不受支持。 // 因此,在这种情况下禁用就地 // 激活。 [!output DOC_CLASS]* pDoc = GetDocument(); ASSERT_VALID(pDoc); if (!pDoc) return FALSE; ASSERT_KINDOF(COleServerDoc, pDoc); if (!pDoc->IsKindOf(RUNTIME_CLASS(COleServerDoc))) { return FALSE; } if (pDoc->IsInPlaceActive()) return FALSE; // 否则,依赖默认行为 return COleClientItem::CanActivate(); } [!endif] [!endif] // [!output CONTAINER_ITEM_CLASS] 诊断 #ifdef _DEBUG void [!output CONTAINER_ITEM_CLASS]::AssertValid() const { [!output CONTAINER_ITEM_BASE_CLASS]::AssertValid(); } #endif