www.pudn.com > mischat.rar > mischat.cpp


// mischat.cpp : Defines the class behaviors for the application. 
// 
 
#include "stdafx.h" 
#include "mischat.h" 
#include "MainFrm.h" 
 
#include "mischatDoc.h" 
#include "mischatView.h" 
 
#ifdef _DEBUG 
#define new DEBUG_NEW 
#endif 
 
 
// CmischatApp 
 
BEGIN_MESSAGE_MAP(CmischatApp, CWinApp) 
	ON_COMMAND(ID_APP_ABOUT, OnAppAbout) 
	// Standard file based document commands 
	//ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew) 
	//ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen) 
	// Standard print setup command 
	//ON_COMMAND(ID_FILE_PRINT_SETUP, CWinApp::OnFilePrintSetup) 
END_MESSAGE_MAP() 
 
 
// CmischatApp construction 
 
CmischatApp::CmischatApp() : 
	CBCGPWorkspace (TRUE /* m_bResourceSmartUpdate */) 
{ 
	// TODO: add construction code here, 
	// Place all significant initialization in InitInstance 
} 
 
 
// The one and only CmischatApp object 
 
CmischatApp theApp; 
 
// CmischatApp initialization 
 
BOOL CmischatApp::InitInstance() 
{ 
	if (!AfxInitRichEdit()) 
	{ 
		return FALSE; 
	} 
	// InitCommonControls() is required on Windows XP if an application 
	// manifest specifies use of ComCtl32.dll version 6 or later to enable 
	// visual styles.  Otherwise, any window creation will fail. 
	InitCommonControls(); 
 
	CWinApp::InitInstance(); 
 
	// Initialize OLE libraries 
	if (!AfxOleInit()) 
	{ 
		AfxMessageBox(IDP_OLE_INIT_FAILED); 
		return FALSE; 
	} 
	AfxEnableControlContainer(); 
	// 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 
	// Change the registry key under which our settings are stored 
	// TODO: You should modify this string to be something appropriate 
	// such as the name of your company or organization 
	SetRegistryKey(_T("装备维修信息管理")); 
	//LoadStdProfileSettings(4);  // Load standard INI file options (including MRU) 
 
	SetRegistryBase (_T("Settings")); 
 
	// Initialize all Managers for usage. They are automatically constructed 
	// if not yet present 
	// Register the application's document templates.  Document templates 
	//  serve as the connection between documents, frame windows and views 
	CSingleDocTemplate* pDocTemplate; 
	pDocTemplate = new CSingleDocTemplate( 
		IDR_MAINFRAME, 
		RUNTIME_CLASS(CmischatDoc), 
		RUNTIME_CLASS(CMainFrame),       // main SDI frame window 
		RUNTIME_CLASS(CmischatView)); 
	AddDocTemplate(pDocTemplate); 
	// Parse command line for standard shell commands, DDE, file open 
	CCommandLineInfo cmdInfo; 
	ParseCommandLine(cmdInfo); 
	// Dispatch commands specified on the command line.  Will return FALSE if 
	// app was launched with /RegServer, /Register, /Unregserver or /Unregister. 
	if (!ProcessShellCommand(cmdInfo)) 
		return FALSE; 
	// The one and only window has been initialized, so show and update it 
	m_pMainWnd->ShowWindow(SW_SHOW); 
	m_pMainWnd->UpdateWindow(); 
	// call DragAcceptFiles only if there's a suffix 
	//  In an SDI app, this should occur after ProcessShellCommand 
	return TRUE; 
} 
 
// CmischatApp message handlers 
 
int CmischatApp::ExitInstance()  
{ 
	BCGCBProCleanUp(); 
 
	return CWinApp::ExitInstance(); 
} 
 
// CAboutDlg dialog used for App About 
 
class CAboutDlg : public CDialog 
{ 
public: 
	CAboutDlg(); 
 
// Dialog Data 
	enum { IDD = IDD_ABOUTBOX }; 
	CBCGPURLLinkButton m_btnURL; 
 
protected: 
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support 
 
// Implementation 
protected: 
	DECLARE_MESSAGE_MAP() 
}; 
 
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD) 
{ 
} 
 
void CAboutDlg::DoDataExchange(CDataExchange* pDX) 
{ 
	CDialog::DoDataExchange(pDX); 
	DDX_Control(pDX, IDC_COMPANY_URL, m_btnURL); 
} 
 
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog) 
END_MESSAGE_MAP() 
 
// App command to run the dialog 
void CmischatApp::OnAppAbout() 
{ 
	CAboutDlg aboutDlg; 
	aboutDlg.DoModal(); 
} 
 
 
// CmischatApp message handlers 
 
 
void CmischatApp::PreLoadState () 
{ 
}