// ActiveDesktop.cpp : Defines the class behaviors for the application. // #include "stdafx.h" #include "ActiveDesktop.h" #include "ActiveDesktopDlg.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CActiveDesktopApp BEGIN_MESSAGE_MAP(CActiveDesktopApp, CWinApp) //{{AFX_MSG_MAP(CActiveDesktopApp) // NOTE - the ClassWizard will add and remove mapping macros here. // DO NOT EDIT what you see in these blocks of generated code! //}}AFX_MSG ON_COMMAND(ID_HELP, CWinApp::OnHelp) END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CActiveDesktopApp construction CActiveDesktopApp::CActiveDesktopApp() { // TODO: add construction code here, // Place all significant initialization in InitInstance } ///////////////////////////////////////////////////////////////////////////// // The one and only CActiveDesktopApp object CActiveDesktopApp theApp; static HINSTANCE g_hRichEdDLL=NULL; ///////////////////////////////////////////////////////////////////////////// // CActiveDesktopApp initialization BOOL CActiveDesktopApp::InitInstance() { AfxEnableControlContainer(); // Initialize RichEdit control // for About Dialog if(g_hRichEdDLL==NULL) { g_hRichEdDLL=::LoadLibrary(_T("RICHED32.DLL")); if(g_hRichEdDLL==NULL) TRACE(_T("Cannot load library to display RichEditTextControl")); } HRESULT hRslt=::CoInitialize(NULL); if (FAILED(hRslt)) { TRACE0("::CoInitialize() failed.\n"); } // Standard initialization // If you are not using these features and wish to reduce the size // of your final executable, you should remove from the following // the specific initialization routines you do not need. #if _MSC_VER < 1400 #ifdef _AFXDLL Enable3dControls(); // Call this when using MFC in a shared DLL #else Enable3dControlsStatic(); // Call this when linking to MFC statically #endif #endif CActiveDesktopDlg dlg; m_pMainWnd = &dlg; switch(dlg.DoModal()) { case IDOK: { // TODO: Place code here to handle when the dialog is // dismissed with OK } break; case IDCANCEL: { // TODO: Place code here to handle when the dialog is // dismissed with Cancel } break; } // Since the dialog has been closed, return FALSE so that we exit the // application, rather than start the application's message pump. return FALSE; } int CActiveDesktopApp::ExitInstance() { ::CoUninitialize(); // unload the library if(g_hRichEdDLL!=NULL) ::FreeLibrary(g_hRichEdDLL); return CWinApp::ExitInstance(); }