IntervalToSend.cpp 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. // IntervalToSend.cpp : 定义应用程序的类行为。
  2. //
  3. #include "stdafx.h"
  4. #include "IntervalToSend.h"
  5. #include "IntervalToSendDlg.h"
  6. #ifdef _DEBUG
  7. #define new DEBUG_NEW
  8. #endif
  9. // CIntervalToSendApp
  10. BEGIN_MESSAGE_MAP(CIntervalToSendApp, CWinApp)
  11. ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
  12. END_MESSAGE_MAP()
  13. // CIntervalToSendApp 构造
  14. CIntervalToSendApp::CIntervalToSendApp()
  15. {
  16. // 支持重新启动管理器
  17. m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART;
  18. // TODO: 在此处添加构造代码,
  19. // 将所有重要的初始化放置在 InitInstance 中
  20. }
  21. // 唯一的一个 CIntervalToSendApp 对象
  22. CIntervalToSendApp theApp;
  23. CUDPSocket g_udpSocket;
  24. CLNHanlder* g_pHandle;
  25. CLNBuffer g_Buffer;
  26. // CIntervalToSendApp 初始化
  27. BOOL CIntervalToSendApp::InitInstance()
  28. {
  29. // 如果一个运行在 Windows XP 上的应用程序清单指定要
  30. // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
  31. //则需要 InitCommonControlsEx()。 否则,将无法创建窗口。
  32. INITCOMMONCONTROLSEX InitCtrls;
  33. InitCtrls.dwSize = sizeof(InitCtrls);
  34. // 将它设置为包括所有要在应用程序中使用的
  35. // 公共控件类。
  36. InitCtrls.dwICC = ICC_WIN95_CLASSES;
  37. InitCommonControlsEx(&InitCtrls);
  38. CWinApp::InitInstance();
  39. if (!AfxSocketInit())
  40. {
  41. AfxMessageBox(IDP_SOCKETS_INIT_FAILED);
  42. return FALSE;
  43. }
  44. AfxEnableControlContainer();
  45. // 创建 shell 管理器,以防对话框包含
  46. // 任何 shell 树视图控件或 shell 列表视图控件。
  47. CShellManager *pShellManager = new CShellManager;
  48. // 激活“Windows Native”视觉管理器,以便在 MFC 控件中启用主题
  49. CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows));
  50. // 标准初始化
  51. // 如果未使用这些功能并希望减小
  52. // 最终可执行文件的大小,则应移除下列
  53. // 不需要的特定初始化例程
  54. // 更改用于存储设置的注册表项
  55. // TODO: 应适当修改该字符串,
  56. // 例如修改为公司或组织名
  57. SetRegistryKey(_T("应用程序向导生成的本地应用程序"));
  58. g_pHandle = new CLNHanlder;
  59. g_udpSocket.SetProtocolHandler(g_pHandle);
  60. if (g_udpSocket.Open(0, nullptr) == FALSE)
  61. return FALSE;
  62. CIntervalToSendDlg dlg;
  63. m_pMainWnd = &dlg;
  64. INT_PTR nResponse = dlg.DoModal();
  65. if (nResponse == IDOK)
  66. {
  67. // TODO: 在此放置处理何时用
  68. // “确定”来关闭对话框的代码
  69. }
  70. else if (nResponse == IDCANCEL)
  71. {
  72. // TODO: 在此放置处理何时用
  73. // “取消”来关闭对话框的代码
  74. }
  75. else if (nResponse == -1)
  76. {
  77. TRACE(traceAppMsg, 0, "警告: 对话框创建失败,应用程序将意外终止。\n");
  78. TRACE(traceAppMsg, 0, "警告: 如果您在对话框上使用 MFC 控件,则无法 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS。\n");
  79. }
  80. // 删除上面创建的 shell 管理器。
  81. if (pShellManager != NULL)
  82. {
  83. delete pShellManager;
  84. }
  85. // 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序,
  86. // 而不是启动应用程序的消息泵。
  87. return FALSE;
  88. }