COleDispatchDriver::CreateDispatch
Cria um objeto de interface de IDispatch e anexá-la ao objeto de COleDispatchDriver .
BOOL CreateDispatch(
REFCLSID clsid,
COleException* pError = NULL
);
BOOL CreateDispatch(
LPCTSTR lpszProgID,
COleException* pError = NULL
);
Parâmetros
clsid
Classifique a identificação do objeto de conexão de IDispatch a ser criado.pError
Um ponteiro para OLE objeto de exceção, que contém o código de status resultantes de design.lpszProgID
Ponteiro para o identificador de programação, como “,” Excel.Document.5 de objeto de automação para que o objeto de distribuição deve ser criada.
Valor de retorno
Diferente de zero em êxito; se não 0.
Exemplo
void COleContainerView::OnCreateDispatch()
{
COleDispatchDriver disp;
COleException* pe = new COleException;
try
{
// Create instance of Microsoft System Information Control
// by using ProgID.
if (disp.CreateDispatch(_T("WMPlayer.OCX"), pe))
{
//Get uiMode.
CString strUIMode;
disp.InvokeHelper(23, DISPATCH_PROPERTYGET, VT_BSTR,
(void*)&strUIMode, NULL);
CString strMsg;
strMsg.Format(_T("WMP uiMode is %s."), strUIMode);
AfxMessageBox(strMsg);
}
else
{
throw pe;
}
}
//Catch control-specific exceptions.
catch (COleDispatchException* pe)
{
CString cStr;
if (!pe->m_strSource.IsEmpty())
cStr = pe->m_strSource + _T(" - ");
if (!pe->m_strDescription.IsEmpty())
cStr += pe->m_strDescription;
else
cStr += _T("unknown error");
AfxMessageBox(cStr, MB_OK,
(pe->m_strHelpFile.IsEmpty()) ? 0 : pe->m_dwHelpContext);
pe->Delete();
}
//Catch all MFC exceptions, including COleExceptions.
// OS exceptions will not be caught.
catch (CException* pe)
{
TRACE(_T("%s(%d): OLE Execption caught: SCODE = %x"),
__FILE__, __LINE__, COleException::Process(pe));
pe->Delete();
}
pe->Delete();
}
Requisitos
Cabeçalho: afxdisp.h
Consulte também
Referência
COleDispatchDriver::DetachDispatch
COleDispatchDriver::ReleaseDispatch