【VC开源代码栏目提醒】:以下是网学会员为您推荐的VC开源代码-fullServer.cpp,希望本篇文章对您学习有所帮助。
// fullServer.cpp : 定义应用程序的类行为。
//
#include "stdafx.h"
#include "fullServer.h"
#include "MainFrm.h"
#include "IpFrame.h"
#include "fullServerDoc.h"
#include "fullServerView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// CfullServerApp
BEGIN_MESSAGE_MAP(CfullServerApp, CWinApp)
ON_COMMAND(ID_APP_ABOUT, OnAppAbout)
// 基于文件的标准文档命令
ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew)
ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen)
// 标准打印设置命令
ON_COMMAND(ID_FILE_PRINT_SETUP, CWinApp::OnFilePrintSetup)
END_MESSAGE_MAP()
// CfullServerApp 构造
CfullServerApp::CfullServerApp()
{
// TODO: 在此处添加构造代码,
// 将所有重要的初始化放置在 InitInstance 中
}
// 唯一的一个 CfullServerApp 对象
CfullServerApp theApp;
// 生成的此标识符在统计上对于您的应用程序是唯一的
// 如果您更愿选择一个特定的标识符,则可以更改它
// {661D4945-D1A1-4F69-8FAD-D97AE093C219}
static const CLSID clsid =
{ 0x661D4945, 0xD1A1, 0x4F69, { 0x8F, 0xAD, 0xD9, 0x7A, 0xE0, 0x93, 0xC2, 0x19 } };
// CfullServerApp 初始化
BOOL CfullServerApp::InitInstance()
{
// 如果一个运行在 Windows XP 上的应用程序清单指定要
// 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
//则需要 InitCommonControls()。否则,将无法创建窗口。
InitCommonControls();
CWinApp::InitInstance();
// 初始化 OLE 库
if (!AfxOleInit())
{
AfxMessageBox(IDP_OLE_INIT_FAILED);
return FALSE;
}
AfxEnableControlContainer();
// 标准初始化
// 如果未使用这些功能并希望减小
// 最终可执行文件的大小,则应移除下列
// 不需要的特定初始化例程
// 更改用于存储设置的注册表项
// TODO: 应适当修改该字符串,
// 例如修改为公司或组织名
SetRegistryKey(_T("应用程序向导生成的本地应用程序"));
LoadStdProfileSettings(4); // 加载标准 INI 文件选项(包括 MRU)
// 注册应用程序的文档模板。文档模板
// 将用作文档、框架窗口和视图之间的连接
CSingleDocTemplate* pDocTemplate;
pDocTemplate = new CSingleDocTemplate(
IDR_MAINFRAME,
RUNTIME_CLASS(CfullServerDoc),
RUNTIME_CLASS(CMainFrame), // 主 SDI 框架窗口
RUNTIME_CLASS(CfullServerView));
if (!pDocTemplate)
return FALSE;
pDocTemplate->SetServerInfo(
IDR_SRVR_EMBEDDED, IDR_SRVR_INPLACE,
RUNTIME_CLASS(CInPlaceFrame));
AddDocTemplate(pDocTemplate);
// 将 COleTemplateServer 连接到文档模板
// COleTemplateServer 通过使用
// 文档模板中指定的信息来为
// 请求 OLE 容器创建新文档
m_server.ConnectTemplate(clsid, pDocTemplate, TRUE);
// 注意: 仅当命令行中存在 /Embedding
// 或 /Automation 时,SDI 应用程序才注册服务器对象
// 分析标准外壳命令、DDE、打开文件操作的命令行
CCommandLineInfo cmdInfo;
ParseCommandLine(cmdInfo);
// 应用程序是用 /Embedding 或 /Automation 开关启动的。
//使应用程序作为自动化服务器运行。
if (cmdInfo.m_bRunEmbedded || cmdInfo.m_bRunAutomated)
{
// 将所有的 OLE 服务器工厂注册为正在运行。这将启用
// OLE 库以从其他应用程序中创建对象
COleTemplateServer::RegisterAll();
// 不显示主窗口
return TRUE;
}
// 使用 /Unregserver 或 /Unregister 开关启动应用程序。 注销
// 类型库。其他注销操作在 ProcessShellCommand() 中发生。
else if (cmdInfo.m_nShellCommand == CCommandLineInfo::AppUnregister)
{
m_server.UpdateRegistry(OAT_INPLACE_SERVER, NULL, NULL, FALSE);
}
// 应用程序是以独立方式或用其他开关(如 /Register
// 或 /Regserver)启动的。更新注册表项,包括类型库。
else
{
m_server.UpdateRegistry(OAT_INPLACE_SERVER);
}
// 调度在命令行中指定的命令。如果
// 用 /RegServer、/Register、/Unregserver 或 /Unregister 启动应用程序,则返回 FALSE。
if (!ProcessShellCommand(cmdInfo))
return FALSE;
// 唯一的一个窗口已初始化,因此显示它并对其进行更新
m_pMainWnd->ShowWindow(SW_SHOW);
m_pMainWnd->UpdateWindow();
// 仅当存在后缀时才调用 DragAcceptFiles,
// 在 SDI 应用程序中,这应在 ProcessShellCommand 之后发生
return TRUE;
}
// 用于应用程序“关于”菜单项的 CAboutDlg 对话框
class CAboutDlg : public CDialog
{
public:
CAboutDlg();
// 对话框数据
enum { IDD = IDD_ABOUTBOX };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
// 实现
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP()
// 用于运行对话框的应用程序命令
void CfullServerApp::OnAppAbout()
{
CAboutDlg aboutDlg;
aboutDlg.DoModal();
}
// CfullServerApp 消息处理程序
上一篇:
ImgButtons.pas
下一篇:
试析影响公路路面平整度的因素及应采取的施工措施