//********************************************************************** // File name: HLP_IOPS.cxx // // Implementation file for COleInPlaceSite // // Functions: // // See IOIPS.H for class Definition // // Copyright (c) 1992 - 1993 Microsoft Corporation. All rights reserved. //********************************************************************** #include "hlp_pre.hxx" #include "hlp_iocs.hxx" #include "hlp_ias.hxx" #include "hlp_iopf.hxx" #include "hlp_iops.hxx" #include "hlp_app.hxx" #include "hlp_site.hxx" #include "hlp_doc.hxx" //********************************************************************** // // COleInPlaceSite::QueryInterface // // Purpose: // // Used for interface negotiation // // Parameters: // // REFIID riid - A reference to the interface that is // being queried. // // LPVOID FAR* ppvObj - An out parameter to return a pointer to // the interface. // // Return Value: // // S_OK - The interface is supported. // S_FALSE - The interface is not supported // // Function Calls: // Function Location // // OutputDebugString Windows API // CSimpleSite::QueryInterface SITE.cxx // // //******************************************************************** STDMETHODIMP COleInPlaceSite::QueryInterface(REFIID riid, LPVOID FAR* ppvObj) { DEBUGOUT(TEXT("In IOIPS::QueryInterface\r\n")); // delegate to the container Site return m_pSite->QueryInterface(riid, ppvObj); } //********************************************************************** // // COleInPlaceSite::AddRef // // Purpose: // // Increments the reference count of the CSimpleSite. Since // COleInPlaceSite is a nested class of CSimpleSite, we don't need an // extra reference count for COleInPlaceSite. We can safely use the // reference count of CSimpleSite. // // Parameters: // // None // // Return Value: // // ULONG - The new reference count of CSimpleSite // // Function Calls: // Function Location // // OutputDebugString Windows API // CSimpleSite::QueryInterface SITE.cxx // // //******************************************************************** STDMETHODIMP_(ULONG) COleInPlaceSite::AddRef() { DEBUGOUT(TEXT("In IOIPS::AddRef\r\n")); // delegate to the container Site return m_pSite->AddRef(); } //********************************************************************** // // COleInPlaceSite::Release // // Purpose: // // Decrements the reference count of the CSimpleSite. Since // COleInPlaceSite is a nested class of CSimpleSite, we don't need an // extra reference count for COleInPlaceSite. We can safely use the // reference count of CSimpleSite. // // Parameters: // // None // // Return Value: // // ULONG - The new reference count of CSimpleSite // // Function Calls: // Function Location // // OutputDebugString Windows API // CSimpleSite::Release SITE.cxx // // //******************************************************************** STDMETHODIMP_(ULONG) COleInPlaceSite::Release() { DEBUGOUT(TEXT("In IOIPS::Release\r\n")); // delegate to the container Site return m_pSite->Release(); } //********************************************************************** // // COleInPlaceSite::GetWindow // // Purpose: // // Returns the Window Handle of the client site // // Parameters: // // HWND FAR* lphwnd - place to return the handle // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::GetWindow (HWND FAR* lphwnd) { DEBUGOUT(TEXT("In IOIPS::GetWindow\r\n")); // return the handle to our editing window. *lphwnd = m_pSite->m_lpDoc->m_hDocWnd; return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::ContextSensitiveHelp // // Purpose: // set/reset context sensitive help mode // // Parameters: // // BOOL fEnterMode - TRUE for entering Context Sensitive help mode // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // // Comments: // // Be sure to read the technotes included with the OLE toolkit. // //******************************************************************** STDMETHODIMP COleInPlaceSite::ContextSensitiveHelp (BOOL fEnterMode) { DEBUGOUT(TEXT("In IOIPS::ContextSensitiveHelp\r\n")); if (m_pSite->m_lpDoc->m_lpApp->m_fCSHMode != fEnterMode) m_pSite->m_lpDoc->m_lpApp->m_fCSHMode = fEnterMode; return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::CanInPlaceActivate // // Purpose: // // Object calls to find out if the container can InPlace activate // // Parameters: // // None // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::CanInPlaceActivate () { DEBUGOUT(TEXT("In IOIPS::CanInPlaceActivate\r\n")); // return S_OK to indicate we can in-place activate return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::OnInPlaceActivate // // Purpose: // // Called by the object on InPlace Activation // // Parameters: // // None // // Return Value: // // S_OK - if the interface can be found // E_FAIL - otherwise // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // IOleObject::QueryInterface Object // // //******************************************************************** STDMETHODIMP COleInPlaceSite::OnInPlaceActivate () { HRESULT hrErr; DEBUGOUT(TEXT("In IOIPS::OnInPlaceActivate\r\n")); hrErr = m_pSite->m_lpOleObject->QueryInterface( IID_IOleInPlaceObject, (LPVOID FAR *)&m_pSite->m_lpInPlaceObject); if (hrErr != NOERROR) return ResultFromScode(E_FAIL); // return S_OK to indicate we can in-place activate. return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::OnUIActivate // // Purpose: // // Object calls this method when it displays it's UI. // // Parameters: // // None. // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // IOleInPlaceObject::GetWindow Object // // //******************************************************************** STDMETHODIMP COleInPlaceSite::OnUIActivate () { DEBUGOUT(TEXT("In IOIPS::OnUIActivate\r\n")); m_pSite->m_lpDoc->m_fAddMyUI=FALSE; m_pSite->m_lpDoc->m_fInPlaceActive = TRUE; m_pSite->m_fInPlaceActive = TRUE; m_pSite->m_lpInPlaceObject->GetWindow((HWND FAR*)&m_pSite->m_hwndIPObj); // return S_OK to continue in-place activation return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::GetWindowContext // // Purpose: // // Called by the object to get information for InPlace Negotiation. // // Parameters: // // LPOLEINPLACEFRAME FAR* lplpFrame - Location to return a pointer // to IOleInPlaceFrame. // // LPOLEINPLACEUIWINDOW FAR* lplpDoc - Location to return a pointer // to IOleInPlaceUIWindow. // // LPRECT lprcPosRect - The rect that the object // occupies // // LPRECT lprcClipRect - The clipping rect // // LPOLEINPLACEFRAMEINFO lpFrameInfo - Pointer to FRAMEINFO // // // Return Value: // // S_OK // // Function Calls: // Function Location // // COleInPlaceFrame::AddRef IOIPF.cxx // CSimpleSite::GetObjRect SITE.cxx // OutputDebugString Windows API // CopyRect Windows API // GetClientRect Windows API // ResultFromScode OLE API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::GetWindowContext ( LPOLEINPLACEFRAME FAR* lplpFrame, LPOLEINPLACEUIWINDOW FAR* lplpDoc, LPRECT lprcPosRect, LPRECT lprcClipRect, LPOLEINPLACEFRAMEINFO lpFrameInfo) { RECT rect; DEBUGOUT(TEXT("In IOIPS::GetWindowContext\r\n")); // the frame is associated with the application object. // need to AddRef() it... m_pSite->m_lpDoc->m_lpApp->m_OleInPlaceFrame.AddRef(); *lplpFrame = &m_pSite->m_lpDoc->m_lpApp->m_OleInPlaceFrame; *lplpDoc = NULL; // must be NULL, cause we're SDI. // get the size of the object in pixels m_pSite->GetObjRect(&rect); // Copy this to the passed buffer CopyRect(lprcPosRect, &rect); // fill the clipping region GetClientRect(m_pSite->m_lpDoc->m_hDocWnd, &rect); CopyRect(lprcClipRect, &rect); // fill the FRAMEINFO lpFrameInfo->fMDIApp = FALSE; lpFrameInfo->hwndFrame = m_pSite->m_lpDoc->m_lpApp->m_hAppWnd; lpFrameInfo->haccel = m_pSite->m_lpDoc->m_lpApp->m_hAccel; lpFrameInfo->cAccelEntries = SIMPCNTR_ACCEL_CNT; return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::Scroll // // Purpose: // // Not Implemented // // Parameters: // // SIZE scrollExtent - number of pixels scrolled in X and Y direction // // Return Value: // // E_FAIL // // Function Calls: // Function Location // // OutputDebugString Windows API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::Scroll (SIZE scrollExtent) { DEBUGOUT(TEXT("In IOIPS::Scroll\r\n")); return ResultFromScode(E_FAIL); } //********************************************************************** // // COleInPlaceSite::OnUIDeactivate // // Purpose: // // Called by the object when its UI goes away // // Parameters: // // BOOL fUndoable // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // CSimpleAPP::QueryNewPalette APP.cxx // CSimpleAPP::AddFrameLevelUI APP.cxx // ResultFromScode OLE API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::OnUIDeactivate (BOOL fUndoable) { DEBUGOUT(TEXT("In IOIPS::OnUIDeactivate\r\n")); // need to clear this flag first m_pSite->m_lpDoc->m_fInPlaceActive = FALSE; m_pSite->m_fInPlaceActive = FALSE; m_pSite->m_lpDoc->m_lpApp->QueryNewPalette(); m_pSite->m_lpDoc->m_lpApp->AddFrameLevelUI(); return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::OnInPlaceDeactivate // // Purpose: // // Called when the inplace session is over // // Parameters: // // None // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // ResultFromScode OLE API // IOleInPlaceObject::Release Object // // //******************************************************************** STDMETHODIMP COleInPlaceSite::OnInPlaceDeactivate () { DEBUGOUT(TEXT("In IOIPS::OnInPlaceDeactivate\r\n")); if (m_pSite->m_lpInPlaceObject) { m_pSite->m_lpInPlaceObject->Release(); m_pSite->m_lpInPlaceObject = NULL; } return ResultFromScode(S_OK); } //********************************************************************** // // COleInPlaceSite::DiscardUndoState // // Purpose: // // Not Implemented // // Parameters: // // None // // Return Value: // // E_FAIL // // Function Calls: // Function Location // // OutputDebugString Windows API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::DiscardUndoState () { DEBUGOUT(TEXT("In IOIPS::DiscardUndoState\r\n")); return ResultFromScode(E_FAIL); } //********************************************************************** // // COleInPlaceSite::DeactivateAndUndo // // Purpose: // // Not Implemented // // Parameters: // // None // // Return Value: // // E_FAIL // // Function Calls: // Function Location // // OutputDebugString Windows API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::DeactivateAndUndo () { DEBUGOUT(TEXT("In IOIPS::DeactivateAndUndo\r\n")); return ResultFromScode(E_FAIL); } //********************************************************************** // // COleInPlaceSite::OnPosRectChange // // Purpose: // // The object calls this method when it's size changes during an // InPlace Session // // Parameters: // // LPCRECT lprcPosRect - The new object rect // // Return Value: // // S_OK // // Function Calls: // Function Location // // OutputDebugString Windows API // GetClientRect Windows API // IOleObject::GetExtent Object // IOleInPlaceObject::SetObjectRects Object // ResultFromScode OLE API // // //******************************************************************** STDMETHODIMP COleInPlaceSite::OnPosRectChange (LPCRECT lprcPosRect) { DEBUGOUT(TEXT("In IOIPS::OnPosRectChange\r\n")); // update the size in the document object // NOTE: here we must call IOleObject::GetExtent to get actual extents // of the running object. IViewObject2::GetExtent returns the // last cached extents. m_pSite->m_lpOleObject->GetExtent(DVASPECT_CONTENT, &m_pSite->m_sizel); RECT rect; GetClientRect(m_pSite->m_lpDoc->m_hDocWnd, &rect); // tell the object its new size m_pSite->m_lpInPlaceObject->SetObjectRects(lprcPosRect, &rect); return ResultFromScode(S_OK); }