DiosUnitToolsDlg.cpp 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. 
  2. // DiosUnitToolsDlg.cpp: 实现文件
  3. //
  4. #include "pch.h"
  5. #include "framework.h"
  6. #include "DiosUnitTools.h"
  7. #include "DiosUnitToolsDlg.h"
  8. #include "afxdialogex.h"
  9. #include "CGeneratorDlg.h"
  10. #include "CMechanicalDlg.h"
  11. #include "CCollimatorDlg.h"
  12. #include "CSynBoxDlg.h"
  13. #include "CDetectorDlg.h"
  14. #include "CSMachineDlg.h"
  15. #ifdef _DEBUG
  16. #define new DEBUG_NEW
  17. #endif
  18. #ifndef _TOOLSINSTANCE
  19. #define _TOOLSINSTANCE
  20. #endif
  21. // CDiosUnitToolsDlg 对话框
  22. CDiosUnitToolsDlg* CDiosUnitToolsDlg::m_Singleton = nullptr;
  23. static CString m_strLog;
  24. CDiosUnitToolsDlg::CDiosUnitToolsDlg(CWnd* pParent /*=nullptr*/)
  25. : CDialogEx(IDD_DIOSUNITTOOLS_DIALOG, pParent)
  26. {
  27. InitLog();
  28. m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
  29. m_Singleton = this;
  30. }
  31. CDiosUnitToolsDlg::~CDiosUnitToolsDlg()
  32. {
  33. m_Singleton = nullptr;
  34. gal_hTopWnd = nullptr;
  35. ExitLog();
  36. }
  37. void CDiosUnitToolsDlg::DoDataExchange(CDataExchange* pDX)
  38. {
  39. CDialogEx::DoDataExchange(pDX);
  40. DDX_Control(pDX, IDC_TAB1, m_ctrTAB_UnitList);
  41. DDX_Control(pDX, IDC_EDIT2, m_editLog);
  42. DDX_Control(pDX, IDC_EDIT1, m_editMSG);
  43. }
  44. BEGIN_MESSAGE_MAP(CDiosUnitToolsDlg, CDialogEx)
  45. ON_WM_SYSCOMMAND()
  46. ON_WM_PAINT()
  47. ON_WM_QUERYDRAGICON()
  48. ON_MESSAGE(MSG_Dios_Notify_ModeInit, DiosModeInit)
  49. ON_NOTIFY(TCN_SELCHANGE, IDC_TAB1, &CDiosUnitToolsDlg::OnTcnSelchangeTab1)
  50. ON_BN_CLICKED(IDC_BUTTON1, &CDiosUnitToolsDlg::OnBnClickedButton1)
  51. ON_BN_CLICKED(IDC_BUTTON2, &CDiosUnitToolsDlg::OnBnClickedButton2)
  52. ON_BN_CLICKED(IDOK, &CDiosUnitToolsDlg::OnBnClickedOk)
  53. END_MESSAGE_MAP()
  54. // CDiosUnitToolsDlg 消息处理程序
  55. BOOL CDiosUnitToolsDlg::OnInitDialog()
  56. {
  57. CDialogEx::OnInitDialog();
  58. // 将“关于...”菜单项添加到系统菜单中。
  59. // IDM_ABOUTBOX 必须在系统命令范围内。
  60. ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
  61. ASSERT(IDM_ABOUTBOX < 0xF000);
  62. CMenu* pSysMenu = GetSystemMenu(FALSE);
  63. if (pSysMenu != nullptr)
  64. {
  65. BOOL bNameValid;
  66. CString strAboutMenu;
  67. bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
  68. ASSERT(bNameValid);
  69. if (!strAboutMenu.IsEmpty())
  70. {
  71. pSysMenu->AppendMenu(MF_SEPARATOR);
  72. pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
  73. }
  74. }
  75. // 设置此对话框的图标。 当应用程序主窗口不是对话框时,框架将自动
  76. // 执行此操作
  77. SetIcon(m_hIcon, TRUE); // 设置大图标
  78. SetIcon(m_hIcon, FALSE); // 设置小图标
  79. // TODO: 在此添加额外的初始化代码
  80. SetUnitConfig();
  81. //设置全局日志接口
  82. gal_pLogFun = &DlgLog;
  83. return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
  84. }
  85. void CDiosUnitToolsDlg::OnSysCommand(UINT nID, LPARAM lParam)
  86. {
  87. if ((nID & 0xFFF0) == IDM_ABOUTBOX)
  88. {
  89. //CAboutDlg dlgAbout;
  90. //dlgAbout.DoModal();
  91. }
  92. else
  93. {
  94. CDialogEx::OnSysCommand(nID, lParam);
  95. }
  96. }
  97. // 如果向对话框添加最小化按钮,则需要下面的代码
  98. // 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序,
  99. // 这将由框架自动完成。
  100. void CDiosUnitToolsDlg::OnPaint()
  101. {
  102. if (IsIconic())
  103. {
  104. CPaintDC dc(this); // 用于绘制的设备上下文
  105. SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
  106. // 使图标在工作区矩形中居中
  107. int cxIcon = GetSystemMetrics(SM_CXICON);
  108. int cyIcon = GetSystemMetrics(SM_CYICON);
  109. CRect rect;
  110. GetClientRect(&rect);
  111. int x = (rect.Width() - cxIcon + 1) / 2;
  112. int y = (rect.Height() - cyIcon + 1) / 2;
  113. // 绘制图标
  114. dc.DrawIcon(x, y, m_hIcon);
  115. }
  116. else
  117. {
  118. CDialogEx::OnPaint();
  119. }
  120. }
  121. //当用户拖动最小化窗口时系统调用此函数取得光标
  122. //显示。
  123. HCURSOR CDiosUnitToolsDlg::OnQueryDragIcon()
  124. {
  125. return static_cast<HCURSOR>(m_hIcon);
  126. }
  127. //输出日志:可供下层模块调用
  128. void CDiosUnitToolsDlg::DlgLog(CString strlog)
  129. {
  130. //mLog::Info("DlgLog:{$}", strlog);
  131. if (m_Singleton != nullptr)
  132. {
  133. if (m_strLog.GetLength() > 5000)
  134. {
  135. m_strLog = m_strLog.Left(500);
  136. }
  137. m_strLog = m_strLog + GetTimeStr() + " " + strlog + "\r\n";
  138. m_Singleton->m_editLog.SetWindowText(m_strLog);
  139. m_Singleton->m_editLog.LineScroll(m_Singleton->m_editLog.GetLineCount() - 1, 0);
  140. }
  141. }
  142. void CDiosUnitToolsDlg::DlgMSG(CString strKey, CString strText)
  143. {
  144. //mLog::Info("DlgMSG:{$}:strText", strKey,strText);
  145. if (m_Singleton != nullptr)
  146. {
  147. CString strMSG = GetTimeStr() + " " + strKey + ":" + strText + "\r\n";
  148. m_Singleton->m_editMSG.SetWindowText(strMSG);
  149. m_Singleton->m_editMSG.LineScroll(m_Singleton->m_editMSG.GetLineCount() - 1, 0);
  150. }
  151. }
  152. //其它设备窗口初始化另一个设备窗口
  153. LRESULT CDiosUnitToolsDlg::DiosModeInit(WPARAM wParam, LPARAM lParam)
  154. {
  155. Dev_Type modeType = (Dev_Type)wParam;
  156. bool act = (int)lParam;
  157. auto findDevcie = CDeviceSET::GetInstance()->m_CDeviceMap.find(modeType);
  158. if (findDevcie == CDeviceSET::GetInstance()->m_CDeviceMap.end())
  159. {
  160. mLog::Debug("DiosModeInit: Device type[{$}] not exist", (int)modeType);
  161. return 0;
  162. }
  163. findDevcie->second->InitPageElements(act);
  164. return 0;
  165. }
  166. //设置窗口元素显示
  167. void CDiosUnitToolsDlg::ShowPageElements(bool init, bool exit)
  168. {
  169. //init
  170. GetDlgItem(IDC_BUTTON1)->EnableWindow(init);
  171. //exit
  172. GetDlgItem(IDC_BUTTON2)->EnableWindow(exit);
  173. }
  174. //初始化
  175. void CDiosUnitToolsDlg::SetUnitConfig()
  176. {
  177. //设置当前全局环境变量
  178. //string envPath = GetProcessDirectory();
  179. //envPath += "\\PlatformModule";
  180. //AddEnvPath(envPath.c_str());
  181. //记录当前顶层窗口句柄
  182. gal_hTopWnd = this->m_hWnd;
  183. //初始化控件
  184. m_ctrTAB_UnitList.ShowWindow(SW_HIDE);
  185. GetDlgItem(IDC_STATIC1)->ShowWindow(SW_HIDE);
  186. GetDlgItem(IDC_EDIT1)->ShowWindow(SW_HIDE);
  187. GetDlgItem(IDC_STATIC2)->ShowWindow(SW_HIDE);
  188. GetDlgItem(IDC_EDIT2)->ShowWindow(SW_HIDE);
  189. //添加提示
  190. GetDlgItem(IDC_STATIC3)->SetWindowText(_T("development for Dios"));
  191. //修改分页名称,将子窗口嵌到主窗口中,并且修改下大小
  192. //CRect tableSize;
  193. //m_ctrTAB_UnitList.GetClientRect(&tableSize);
  194. //tableSize.top += 20;
  195. //获取tab control位置和大小
  196. CRect tabRect, itemRect;
  197. int nX, nY, nXc, nYc;
  198. m_ctrTAB_UnitList.GetClientRect(&tabRect);
  199. m_ctrTAB_UnitList.GetItemRect(0, &itemRect);
  200. nX = itemRect.left;
  201. nY = itemRect.bottom;
  202. nXc = tabRect.right - itemRect.left;
  203. nYc = tabRect.bottom - nY;
  204. auto HW_InitWindows = [this, nX, nY, nXc, nYc](Dev_Type DevType, int DlgNum) -> void
  205. {
  206. switch (DevType)
  207. {
  208. case Dev_Generator: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CGeneratorDlg);}break;
  209. case Dev_Mechanical: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CMechanicalDlg); }break;
  210. case Dev_Collimator: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CCollimatorDlg); }break;
  211. case Dev_SynBox: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CSynBoxDlg); }break;
  212. case Dev_Detector: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CDetectorDlg); }break;
  213. case Dev_SMachine: {CDeviceSET::GetInstance()->m_CDeviceMap[DevType].reset(new CSMachineDlg); }break;
  214. }
  215. m_ctrTAB_UnitList.InsertItem(DevType, _T(CDeviceSET::GetInstance()->m_CDeviceMap[DevType]->m_strName.c_str()));
  216. CDeviceSET::GetInstance()->m_CDeviceMap[DevType]->Create(DlgNum, &m_ctrTAB_UnitList);
  217. //m_pDlgGenerator->MoveWindow(&tableSize);
  218. CDeviceSET::GetInstance()->m_CDeviceMap[DevType]->SetWindowPos(&wndTop, nX, nY, nXc, nYc, SWP_SHOWWINDOW);
  219. //滚动条
  220. CDialogTemplate dlTemp;
  221. SIZE szPixelsRes = { 0 };
  222. dlTemp.Load(MAKEINTRESOURCE(DlgNum)); // 子对话框的资源 ID
  223. dlTemp.GetSizeInPixels(&szPixelsRes); //直接从资源读取对话框获取原始像素尺寸,无需分辨率转换
  224. CDeviceSET::GetInstance()->m_CDeviceMap[DevType]->UpdateScrollInfo(0, szPixelsRes.cy);
  225. };
  226. HW_InitWindows(Dev_Generator, IDD_DIALOG1);
  227. HW_InitWindows(Dev_Mechanical, IDD_DIALOG2);
  228. HW_InitWindows(Dev_Collimator, IDD_DIALOG3);
  229. HW_InitWindows(Dev_SynBox, IDD_DIALOG4);
  230. HW_InitWindows(Dev_Detector, IDD_DIALOG5);
  231. HW_InitWindows(Dev_SMachine, IDD_DIALOG6);
  232. SwitchTable(Dev_Type::Dev_Generator);
  233. }
  234. //初始化日志模块
  235. bool CDiosUnitToolsDlg::InitLog()
  236. {
  237. string strLogPath = GetProcessDirectory() + UnitTool_LogPath;
  238. //Log4CPP::ThreadContext::Map::Set("LogFileName", cfgKey.c_str());
  239. Log4CPP::GlobalContext::Map::Set(ECOM::Utility::Hash(UnitTool_LogFileName), UnitTool_LogName);
  240. auto rc = Log4CPP::LogManager::LoadConfigFile(strLogPath.c_str());
  241. mLog::gLogger = Log4CPP::LogManager::GetLogger(UnitTool_LogName);
  242. string version;
  243. if (GetVersion(version))
  244. {
  245. mLog::Info("===============log begin : [{$}] version:{$} ===================\n", UnitTool_LogName, version.c_str());
  246. }
  247. else
  248. {
  249. mLog::Info("===============log begin : [{$}] version:0.0.0.0 ===================\n", UnitTool_LogName);
  250. }
  251. return true;
  252. }
  253. void CDiosUnitToolsDlg::ExitLog()
  254. {
  255. if (mLog::gLogger)
  256. {
  257. mLog::Info("===============log end ===================");
  258. mLog::Close();
  259. mLog::gLogger = nullptr;
  260. }
  261. }
  262. //统一切换接口
  263. void CDiosUnitToolsDlg::SwitchTable(Dev_Type unitType)
  264. {
  265. if(Dev_Type::Dev_TypeNULL == unitType)
  266. {
  267. unitType = (Dev_Type)m_ctrTAB_UnitList.GetCurSel();
  268. }
  269. for (auto& item : CDeviceSET::GetInstance()->m_CDeviceMap)
  270. {
  271. if(item.second->m_enuType == unitType)
  272. item.second->ShowWindow(SW_SHOW);
  273. else
  274. item.second->ShowWindow(SW_HIDE);
  275. }
  276. }
  277. //切换设备窗口
  278. void CDiosUnitToolsDlg::OnTcnSelchangeTab1(NMHDR* pNMHDR, LRESULT* pResult)
  279. {
  280. // TODO: 在此添加控件通知处理程序代码
  281. *pResult = 0;
  282. SwitchTable();
  283. }
  284. //创建设备窗口
  285. void CDiosUnitToolsDlg::OnBnClickedButton1()
  286. {
  287. m_ctrTAB_UnitList.ShowWindow(SW_SHOW);
  288. GetDlgItem(IDC_STATIC1)->ShowWindow(SW_SHOW);
  289. GetDlgItem(IDC_EDIT1)->ShowWindow(SW_SHOW);
  290. GetDlgItem(IDC_STATIC2)->ShowWindow(SW_SHOW);
  291. GetDlgItem(IDC_EDIT2)->ShowWindow(SW_SHOW);
  292. GetDlgItem(IDC_STATIC3)->ShowWindow(SW_HIDE);
  293. CDeviceSET::GetToolDefaultConfig();
  294. ShowPageElements(FALSE, TRUE);
  295. }
  296. //关闭设备窗口
  297. void CDiosUnitToolsDlg::OnBnClickedButton2()
  298. {
  299. m_ctrTAB_UnitList.ShowWindow(SW_HIDE);
  300. GetDlgItem(IDC_STATIC1)->ShowWindow(SW_HIDE);
  301. GetDlgItem(IDC_EDIT1)->ShowWindow(SW_HIDE);
  302. GetDlgItem(IDC_STATIC2)->ShowWindow(SW_HIDE);
  303. GetDlgItem(IDC_EDIT2)->ShowWindow(SW_HIDE);
  304. GetDlgItem(IDC_STATIC3)->ShowWindow(SW_SHOW);
  305. CDeviceSET::SetToolDefaultConfig();
  306. ShowPageElements(TRUE, FALSE);
  307. }
  308. //保存并退出
  309. void CDiosUnitToolsDlg::OnBnClickedOk()
  310. {
  311. CDeviceSET::SetToolDefaultConfig();
  312. CDialogEx::OnOK();
  313. }