CntrItem.cpp
上传用户:sycq158
上传日期:2008-10-22
资源大小:15361k
文件大小:4k
- // CntrItem.cpp : implementation of the CMyCntrItem class
- //
- #include "stdafx.h"
- #include "新二十四点.h"
- #include "新二十四点Doc.h"
- #include "新二十四点View.h"
- #include "CntrItem.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- /////////////////////////////////////////////////////////////////////////////
- // CMyCntrItem implementation
- IMPLEMENT_SERIAL(CMyCntrItem, COleClientItem, 0)
- CMyCntrItem::CMyCntrItem(CMyDoc* pContainer)
- : COleClientItem(pContainer)
- {
- // TODO: add one-time construction code here
-
- }
- CMyCntrItem::~CMyCntrItem()
- {
- // TODO: add cleanup code here
-
- }
- void CMyCntrItem::OnChange(OLE_NOTIFICATION nCode, DWORD dwParam)
- {
- ASSERT_VALID(this);
- COleClientItem::OnChange(nCode, dwParam);
- // When an item is being edited (either in-place or fully open)
- // it sends OnChange notifications for changes in the state of the
- // item or visual appearance of its content.
- // TODO: invalidate the item by calling UpdateAllViews
- // (with hints appropriate to your application)
- GetDocument()->UpdateAllViews(NULL);
- // for now just update ALL views/no hints
- }
- BOOL CMyCntrItem::OnChangeItemPosition(const CRect& rectPos)
- {
- ASSERT_VALID(this);
- // During in-place activation CMyCntrItem::OnChangeItemPosition
- // is called by the server to change the position of the in-place
- // window. Usually, this is a result of the data in the server
- // document changing such that the extent has changed or as a result
- // of in-place resizing.
- //
- // The default here is to call the base class, which will call
- // COleClientItem::SetItemRects to move the item
- // to the new position.
- if (!COleClientItem::OnChangeItemPosition(rectPos))
- return FALSE;
- // TODO: update any cache you may have of the item's rectangle/extent
- return TRUE;
- }
- void CMyCntrItem::OnGetItemPosition(CRect& rPosition)
- {
- ASSERT_VALID(this);
- // During in-place activation, CMyCntrItem::OnGetItemPosition
- // will be called to determine the location of this item. The default
- // implementation created from AppWizard simply returns a hard-coded
- // rectangle. Usually, this rectangle would reflect the current
- // position of the item relative to the view used for activation.
- // You can obtain the view by calling CMyCntrItem::GetActiveView.
- // TODO: return correct rectangle (in pixels) in rPosition
- rPosition.SetRect(10, 10, 210, 210);
- }
- void CMyCntrItem::OnActivate()
- {
- // Allow only one inplace activate item per frame
- CMyView* pView = GetActiveView();
- ASSERT_VALID(pView);
- COleClientItem* pItem = GetDocument()->GetInPlaceActiveItem(pView);
- if (pItem != NULL && pItem != this)
- pItem->Close();
-
- COleClientItem::OnActivate();
- }
- void CMyCntrItem::OnDeactivateUI(BOOL bUndoable)
- {
- COleClientItem::OnDeactivateUI(bUndoable);
- // Hide the object if it is not an outside-in object
- DWORD dwMisc = 0;
- m_lpObject->GetMiscStatus(GetDrawAspect(), &dwMisc);
- if (dwMisc & OLEMISC_INSIDEOUT)
- DoVerb(OLEIVERB_HIDE, NULL);
- }
- void CMyCntrItem::Serialize(CArchive& ar)
- {
- ASSERT_VALID(this);
- // Call base class first to read in COleClientItem data.
- // Since this sets up the m_pDocument pointer returned from
- // CMyCntrItem::GetDocument, it is a good idea to call
- // the base class Serialize first.
- COleClientItem::Serialize(ar);
- // now store/retrieve data specific to CMyCntrItem
- if (ar.IsStoring())
- {
- // TODO: add storing code here
- }
- else
- {
- // TODO: add loading code here
- }
- }
- /////////////////////////////////////////////////////////////////////////////
- // CMyCntrItem diagnostics
- #ifdef _DEBUG
- void CMyCntrItem::AssertValid() const
- {
- COleClientItem::AssertValid();
- }
- void CMyCntrItem::Dump(CDumpContext& dc) const
- {
- COleClientItem::Dump(dc);
- }
- #endif
- /////////////////////////////////////////////////////////////////////////////