FIX: Framer Sample Does Not Handle Activation CorrectlyID: Q160920
|
The Framer sample that comes with the ActiveX SDK does not handle Wm_Activateapp. As a result, the contained DocObject is unable to determine if the container is active or not. This becomes a problem when, for example, Word is started within Framer and outside Framer. Actions that you perform in the contained instance of Word, such as bringing up a dialog box, actually occur in the standalone instance instead.
The solution to this problem involves notifying the contained DocObject of activation changes by calling IOleInPlaceActiveObject::OnFrameWindowActivate() and passing as a parameter True if framer is activating and False if it is deactivating. The following code can be added to Framer.cpp in the FrameWndProc function to handle this:
case WM_ACTIVATEAPP:
if (NULL != pFR->m_pIOleIPActiveObject)
{
HRESULT hr;
hr = pFR->m_pIOleIPActiveObject->OnFrameWindowActivate((BOOL)wParam);
}
break;
Microsoft has confirmed this to be a problem in the Framer sample supplied with the ActiveX SDK. This problem has been fixed in the version of the Framer sample provided with the Internet Client SDK for Internet Explorer 4.0.
Additional query words:
Keywords : kbIE300 kbIE400 kbIE401 kbIE500 AXSDKDocObjects
Version : Win:1.0
Platform : WINDOWS
Issue type : kbbug
Last Reviewed: April 17, 1999