Artigo: 173974 - Última revisão: quinta-feira, 2 de Junho de 2005 - Revisão: 3.0

Como adicionar suporte MFC a um projecto ATL no Visual C++

Dica do SistemaEste artigo aplica-se a um sistema operativo diferente do que está a utilizar. Foi desactivado o conteúdo do artigo, que pode não ser relevante para si.

Nesta página

Expandir tudo | Reduzir tudo

Sumário

Quando criar um projecto ATL EXE utilizando o AppWizard, a caixa de verificação suporte MFC está desactivada. Este artigo explica como adicionar suporte MFC a um projecto ATL EXE. Este artigo também explica como adicionar suporte MFC a um projecto ATL DLL se falhar inicialmente seleccione a caixa de verificação "suporte MFC" no AppWizard.

Mais Informação

Adicionar suporte de MFC para um projecto ATL EXE

  1. Adicione o seguinte # include directivas para StdAfx.h antes para incluindo Atlbase.h:
          #include <afxwin.h>   // MFC core and standard components
          #include <afxext.h>   // MFC extensions
          #include <afxdisp.h>  // MFC Automation extensions
    					
  2. Alterar definições de projecto para utilizar o MFC. Caixa de diálogo Definições do Project , clique no separador Geral e altere a definição na caixa de listagem " Microsoft Foundation Classes " para MFC.
  3. Adicionar uma classe derivada de CWinApp e declarar uma variável global desse tipo da seguinte forma:
    class CMyApp : public CWinApp
          {
          public:
             virtual BOOL InitInstance();
             virtual int ExitInstance();
          protected:
          BOOL m_bRun;
    };
    					
  4. Substituir a função _tWinMain com o seguinte código InitInstance e ExitInstance:
    BOOL CMyApp::InitInstance()
    {
    	// Initialize OLE libraries.
    	if (!AfxOleInit())
    	{
    		AfxMessageBox(_T("OLE Initialization Failed!"));
    		return FALSE;
    	}
    
    	// Initialize CcomModule.
    	_Module.Init(ObjectMap, m_hInstance);
    	_Module.dwThreadID = GetCurrentThreadId();
    
    	// Check command line arguments.
    	TCHAR szTokens[] = _T("-/");
    	m_bRun = TRUE;
    	LPCTSTR lpszToken = FindOneOf(m_lpCmdLine, szTokens);
    	while (lpszToken != NULL)
    	{
    		// Register ATL and MFC class factories.
    		if (lstrcmpi(lpszToken, _T("Embedding"))==0 ||
    		lstrcmpi(lpszToken, _T("Automation"))==0)
    		{
    			AfxOleSetUserCtrl(FALSE);
    			break;
    		}
    	// Unregister servers.
    	// There is no unregistration code for MFC
    	// servers. Refer to <WWLINK TYPE="ARTICLE" VALUE="Q186212">Q186212</WWLINK> "How To  Unregister MFC
    	// Automation Servers" for adding unregistration
    	// code.
    		else if (lstrcmpi(lpszToken, _T("UnregServer"))==0)
    		{
    			VERIFY(SUCCEEDED(_Module.UpdateRegistryFromResource(IDR_ServerS2B, FALSE)));
    //Replace  IDR_ServerS2B with your project specific resource ID for the registry script resource
    			VERIFY(SUCCEEDED(_Module.UnregisterServer(TRUE)));
    			m_bRun = FALSE;
    			break;
    		}
    	// Register ATL and MFC objects in the registry.
    		else if (lstrcmpi(lpszToken, _T("RegServer"))==0)
    		{
    			VERIFY(SUCCEEDED(_Module.UpdateRegistryFromResource(IDR_ServerS2B, TRUE)));
    			VERIFY(SUCCEEDED(_Module.RegisterServer(TRUE)));
    			COleObjectFactory::UpdateRegistryAll();
    			m_bRun = FALSE;
    			break;
    		}
    		lpszToken = FindOneOf(lpszToken, szTokens);
    	}
    	if (m_bRun)
    	{
    		// Comment out the next line if not using VC 6-generated
    		// code.
    		_Module.StartMonitor();
    
    		VERIFY(SUCCEEDED(_Module.RegisterClassObjects(CLSCTX_LOCAL_SERVER, REGCLS_MULTIPLEUSE)));
    		VERIFY(COleObjectFactory::RegisterAll());
    		// To run the EXE standalone, you need to create a window
    		// and assign the CWnd* to m_pMainWnd.
    		LPCTSTR szClass = AfxRegisterWndClass(NULL);
    		m_pMainWnd = new CWnd;
    		m_pMainWnd->CreateEx(0, szClass, _T("SomeName"), 0, CRect(0, 0, 0, 0), NULL, 1234);
    	}
    	return TRUE;
    }
    
    int CMyApp::ExitInstance()
    {
    	// MFC's class factories registration is
    	// automatically revoked by MFC itself.
    	if (m_bRun)
    	{
    		_Module.RevokeClassObjects();
            Sleep(dwPause); //wait for any threads to finish
        }
    
        _Module.Term();
    	return 0;
    }
    					
  5. Para Unicode cria, certifique-se que o ponto de entrada está definido para wWinMainCRTStartup na categoria de saída do campo de ligação na caixa de diálogo Definições do Project . Para obter mais informações, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
    125750  (http://support.microsoft.com/kb/125750/ ) Recebe uma mensagem de erro "não resolvido símbolo externo _WinMain@16" quando tenta criar uma aplicação MFC com suporte de Unicode no Visual C++
  6. Adicione a seguinte linha de código o início de cada função de membro de uma interface COM, procedimento de janela e função exportada:
    AFX_MANAGE_STATE(AfxGetAppModuleState());
    						
    para obter mais informações sobre como AFX_MANAGE_STATE, consulte a documentação online VC ++.
Para mais informações sobre como adicionar suporte MFC a um projecto ATL COM AppWizard, consulte o seguinte artigo na base de dados de conhecimento da Microsoft:
181505  (http://support.microsoft.com/kb/181505/EN-US/ ) PROBLEMA: ATL COM AppWizard não oferecer suporte MFC .exe

Adicionar suporte de MFC para um projecto ATL DLL

Siga os passos 1 a 3 de cima.

  1. Mova o código de DllMain AppWizard geradas DLL_PROCESS_ATTACH e DLL_PROCESS_DETACH o CMyApp InitInstance e ExitInstance e remover o DllMain da seguinte forma:
          BOOL CMyApp::InitInstance()
          {
             _Module.Init(ObjectMap, m_hInstance);
             return CWinApp::InitInstance();
          }
    
     int CMyApp::ExitInstance()
    {
        // MFC's class factories registration is
        // automatically revoked by MFC itself.
        if (m_bRun)
            _Module.RevokeClassObjects();
    
    
    					
  2. Adicione a seguinte linha de código o início de cada função de membro de uma interface COM, procedimento de janela e função exportada:
    AFX_MANAGE_STATE(AfxGetStaticModuleState());
    						
    Para obter mais informações, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
    140850  (http://support.microsoft.com/kb/140850/ ) Como exportar correctamente funções utilizando biblioteca partilhada de MFC
NOTA: Para todas as versões de edição, certifique-se de que a definição de pré-processador _ATL_MIN_CRT foi removida. Pode encontrar estas definições na categoria de pré-processador do separador C/C ++ na caixa de diálogo Definições do Project .

Quando adicionar uma classe derivada de uma MFC classe utilizando ClassWizard para um EXE ATL projecto ou a um projecto ATL DLL sem "MFC Support", o compilador emitirá um erro de C2504.

Referências

Exemplo de MFCATL incluído no Visual C++ 5.0.

Para obter mais informações, clique no número de artigo que se segue para visualizar o artigo na Microsoft Knowledge Base:
186212  (http://support.microsoft.com/kb/186212/ ) A anular o registo de servidores de automatização de MFC
(c) 1997 Microsoft Corporation, todos os direitos reservados. Contribuições de Chuck Bell, Microsoft Corporation.


A informação contida neste artigo aplica-se a:
  • Microsoft ActiveX Template Library 3.0 nas seguintes plataformas
    • Microsoft Visual C++ 5.0 Enterprise Edition
    • Microsoft Visual C++ 6.0 Enterprise Edition
    • Microsoft Visual C++ 5.0 Professional Edition
    • Microsoft Visual C++ 6.0 Professional Edition
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
  • Microsoft ActiveX Template Library 2.0 nas seguintes plataformas
    • Microsoft Visual C++ 5.0 Enterprise Edition
    • Microsoft Visual C++ 6.0 Enterprise Edition
    • Microsoft Visual C++ 5.0 Professional Edition
    • Microsoft Visual C++ 6.0 Professional Edition
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
  • Microsoft ActiveX Template Library 2.1 nas seguintes plataformas
    • Microsoft Visual C++ 5.0 Enterprise Edition
    • Microsoft Visual C++ 6.0 Enterprise Edition
    • Microsoft Visual C++ 5.0 Professional Edition
    • Microsoft Visual C++ 6.0 Professional Edition
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
Palavras-chave: 
kbmt kbinfo kbhowto KB173974 KbMtpt
Tradução automáticaTradução automática
IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine translation ou MT), não tendo sido portanto revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática? erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 173974  (http://support.microsoft.com/kb/173974/en-us/ )