TestWizardToolDlg.cpp 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252
  1. // TestWizardToolDlg.cpp : 实现文件
  2. //
  3. #include "stdafx.h"
  4. #include "TestWizardTool.h"
  5. #include "TestWizardToolDlg.h"
  6. #ifdef _DEBUG
  7. #define new DEBUG_NEW
  8. #endif
  9. #define MINIMUM_WINDOWS_X 395
  10. #define MINIMUM_WINDOWS_Y 535
  11. #define MAX_SWITCH_LEN 16
  12. unsigned char TwoHexChar2Char(char ch1, char ch2)
  13. {
  14. char Numb1;
  15. char Numb2;
  16. if (ch1 >= 'A')
  17. Numb1 = (toupper(ch1) - '0' - 7) * 16;
  18. else
  19. Numb1 = (ch1 - '0') * 16;
  20. if (ch2 >= 'A')
  21. Numb2 = (toupper(ch2) - '0' - 7);
  22. else
  23. Numb2 = (ch2 - '0');
  24. return (Numb1 + Numb2);
  25. }
  26. COLORREF HexColor2RGB(std::string strHexColor)
  27. {
  28. DWORD r = TwoHexChar2Char(strHexColor[0], strHexColor[1]);
  29. DWORD g = TwoHexChar2Char(strHexColor[2], strHexColor[3]);
  30. DWORD b = TwoHexChar2Char(strHexColor[4], strHexColor[5]);
  31. return RGB(r, g, b);
  32. }
  33. BOOL GetSysSerialPort(std::vector<std::string>& vtports)
  34. {
  35. HKEY hKey;
  36. LSTATUS lReg = 0;
  37. DWORD dwMaxValLen = 0;
  38. DWORD dwValNum = 0;
  39. lReg = RegOpenKeyExA(HKEY_LOCAL_MACHINE, "HARDWARE\\DEVICEMAP\\SERIALCOMM", 0, KEY_QUERY_VALUE, &hKey);
  40. if (lReg != ERROR_SUCCESS)
  41. {
  42. return FALSE;
  43. }
  44. lReg = RegQueryInfoKeyA(hKey, NULL, NULL, NULL, NULL, NULL, NULL, &dwValNum, &dwMaxValLen, NULL, NULL, NULL);
  45. if (lReg != ERROR_SUCCESS)
  46. {
  47. return FALSE;
  48. }
  49. if (vtports.size())
  50. {
  51. vtports.clear();
  52. }
  53. LPSTR lpValName, lpComNum;
  54. DWORD dwValName, dwValSize = 6;
  55. for (DWORD i = 0; i < dwValNum; i++)
  56. {
  57. dwValName = dwMaxValLen + 1;
  58. dwValSize = 6;
  59. lpValName = (LPSTR)VirtualAlloc(NULL, dwValName, MEM_COMMIT, PAGE_READWRITE);
  60. lReg = RegEnumValueA(hKey, i, lpValName, &dwValName, NULL, NULL, NULL, NULL);
  61. if ((lReg != ERROR_SUCCESS) && (lReg != ERROR_NO_MORE_ITEMS))
  62. {
  63. continue;
  64. }
  65. lpComNum = (LPSTR)VirtualAlloc(NULL, 6, MEM_COMMIT, PAGE_READWRITE);
  66. lReg = RegQueryValueExA(hKey, lpValName, NULL, NULL, (LPBYTE)lpComNum, &dwValSize);
  67. if (lReg != ERROR_SUCCESS)
  68. {
  69. continue;
  70. }
  71. vtports.push_back(lpComNum);
  72. VirtualFree(lpValName, 0, MEM_RELEASE);
  73. VirtualFree(lpComNum, 0, MEM_RELEASE);
  74. }
  75. return TRUE;
  76. }
  77. // 用于应用程序“关于”菜单项的 CAboutDlg 对话框
  78. class CAboutDlg : public CDialog
  79. {
  80. public:
  81. CAboutDlg();
  82. // 对话框数据
  83. enum { IDD = IDD_ABOUTBOX };
  84. protected:
  85. virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
  86. // 实现
  87. protected:
  88. DECLARE_MESSAGE_MAP()
  89. };
  90. CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
  91. {
  92. }
  93. void CAboutDlg::DoDataExchange(CDataExchange* pDX)
  94. {
  95. CDialog::DoDataExchange(pDX);
  96. }
  97. BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
  98. END_MESSAGE_MAP()
  99. // CTestWizardToolDlg 对话框
  100. CTestWizardToolDlg::CTestWizardToolDlg(CWnd* pParent /*=NULL*/)
  101. : CDialog(CTestWizardToolDlg::IDD, pParent)
  102. {
  103. m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
  104. m_nCols = 3;
  105. m_nTopMargin = 8;
  106. m_nLeftMargin = 8;
  107. m_nComboHeight = 20;
  108. m_nDefaultWidth = 360;
  109. m_nDefaultHeight = 600;
  110. m_bFindTestWizardPort = false;
  111. m_bFindSwitcherPort = false;
  112. }
  113. void CTestWizardToolDlg::DoDataExchange(CDataExchange* pDX)
  114. {
  115. CDialog::DoDataExchange(pDX);
  116. DDX_Control(pDX, COMBO_COM, m_cbCOMTW);
  117. DDX_Control(pDX, COMBO_SINGALS, m_cbSignals);
  118. DDX_Control(pDX, BTN_OPEN_COM, m_btnOpenTW);
  119. DDX_Control(pDX, BTN_RELOAD_SIGNAL, m_btnReload);
  120. DDX_Control(pDX, IDC_STATIC_GROUP, m_stGroup);
  121. DDX_Control(pDX, BTN_OPEN_COM2, m_btnOpenUSB);
  122. DDX_Control(pDX, COMBO_COM2, m_cbUSBPort);
  123. }
  124. BEGIN_MESSAGE_MAP(CTestWizardToolDlg, CDialog)
  125. ON_WM_SYSCOMMAND()
  126. ON_WM_PAINT()
  127. ON_WM_DEVICECHANGE()
  128. ON_WM_QUERYDRAGICON()
  129. //}}AFX_MSG_MAP
  130. ON_WM_SIZE()
  131. ON_WM_SIZING()
  132. ON_WM_GETMINMAXINFO()
  133. // 信号按钮;
  134. ON_COMMAND_RANGE(BTNID, BTNID + 100, OnSignalBtnClick)
  135. ON_BN_CLICKED(BTN_OPEN_COM, &CTestWizardToolDlg::OnBnClickedOpenCom)
  136. ON_CBN_SELCHANGE(COMBO_SINGALS, &CTestWizardToolDlg::OnCbnSelchangeSingals)
  137. ON_BN_CLICKED(BTN_RELOAD_SIGNAL, &CTestWizardToolDlg::OnBnClickedReloadSignal)
  138. ON_WM_DESTROY()
  139. ON_WM_TIMER()
  140. ON_BN_CLICKED(BTN_OPEN_COM2, &CTestWizardToolDlg::OnBnClickedOpenCom2)
  141. ON_BN_CLICKED(IDC_CHECK_A, &CTestWizardToolDlg::OnBnClickedCheckA)
  142. ON_BN_CLICKED(IDC_CHECK_B, &CTestWizardToolDlg::OnBnClickedCheckB)
  143. END_MESSAGE_MAP()
  144. // CTestWizardToolDlg 消息处理程序
  145. BOOL CTestWizardToolDlg::OnInitDialog()
  146. {
  147. CDialog::OnInitDialog();
  148. // 将“关于...”菜单项添加到系统菜单中。
  149. // IDM_ABOUTBOX 必须在系统命令范围内。
  150. ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
  151. ASSERT(IDM_ABOUTBOX < 0xF000);
  152. CMenu* pSysMenu = GetSystemMenu(FALSE);
  153. if (pSysMenu != NULL)
  154. {
  155. BOOL bNameValid;
  156. CString strAboutMenu;
  157. bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
  158. ASSERT(bNameValid);
  159. if (!strAboutMenu.IsEmpty())
  160. {
  161. pSysMenu->AppendMenu(MF_SEPARATOR);
  162. pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
  163. }
  164. }
  165. // 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动
  166. // 执行此操作
  167. SetIcon(m_hIcon, TRUE); // 设置大图标
  168. SetIcon(m_hIcon, FALSE); // 设置小图标
  169. // TODO: 在此添加额外的初始化代码
  170. InitBtnStyle();
  171. m_stGroup.GetWindowRect(m_rcGroup);
  172. ScreenToClient(m_rcGroup);
  173. LoadSignals();
  174. m_cbSignals.SelectString(0, Global::g_Config.twUseSignal.c_str());
  175. LoadKeyInfo(m_vtKeyInfo, Global::g_Config.twSignaldir + _T("\\") + Global::g_Config.twUseSignal + _T(".xml"));
  176. SetTimer(0, 100, NULL);
  177. return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
  178. }
  179. void CTestWizardToolDlg::OnSysCommand(UINT nID, LPARAM lParam)
  180. {
  181. if ((nID & 0xFFF0) == IDM_ABOUTBOX)
  182. {
  183. CAboutDlg dlgAbout;
  184. dlgAbout.DoModal();
  185. }
  186. else
  187. {
  188. CDialog::OnSysCommand(nID, lParam);
  189. }
  190. }
  191. // 如果向对话框添加最小化按钮,则需要下面的代码
  192. // 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
  193. // 这将由框架自动完成。
  194. void CTestWizardToolDlg::OnPaint()
  195. {
  196. if (IsIconic())
  197. {
  198. CPaintDC dc(this); // 用于绘制的设备上下文
  199. SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
  200. // 使图标在工作区矩形中居中
  201. int cxIcon = GetSystemMetrics(SM_CXICON);
  202. int cyIcon = GetSystemMetrics(SM_CYICON);
  203. CRect rect;
  204. GetClientRect(&rect);
  205. int x = (rect.Width() - cxIcon + 1) / 2;
  206. int y = (rect.Height() - cyIcon + 1) / 2;
  207. // 绘制图标
  208. dc.DrawIcon(x, y, m_hIcon);
  209. }
  210. else
  211. {
  212. CDialog::OnPaint();
  213. }
  214. }
  215. //当用户拖动最小化窗口时系统调用此函数取得光标
  216. //显示。
  217. HCURSOR CTestWizardToolDlg::OnQueryDragIcon()
  218. {
  219. return static_cast<HCURSOR>(m_hIcon);
  220. }
  221. BOOL CTestWizardToolDlg::OnDeviceChange(UINT nEventType, DWORD_PTR dwData)
  222. {
  223. //DEV_BROADCAST_DEVICEINTERFACE* pdbd = (DEV_BROADCAST_DEVICEINTERFACE*)dwData;
  224. DEV_BROADCAST_PORT *pbdp = (DEV_BROADCAST_PORT*)dwData;
  225. if ( pbdp && _tcsstr(pbdp->dbcp_name, _T("COM")) )
  226. {
  227. {
  228. // 查找是否有添加过该项;
  229. int nIndex = m_cbCOMTW.FindString(0, pbdp->dbcp_name);
  230. // 删除和新增前,先获取当前选中的项;
  231. CString strCurCOM = _T("");
  232. int nCurIndex = m_cbCOMTW.GetCurSel();
  233. if ( nCurIndex != CB_ERR )
  234. m_cbCOMTW.GetLBText(nCurIndex, strCurCOM);
  235. if ( nEventType == DBT_DEVICEREMOVECOMPLETE )
  236. {// 串口拨掉;
  237. TRACE(_T("串口拨掉\n"));
  238. if ( nIndex != CB_ERR )
  239. {
  240. m_cbCOMTW.DeleteString(nIndex);
  241. // 删除后, 由于索引变化了,要重新设置选中项;
  242. if ( nCurIndex != CB_ERR )
  243. m_cbCOMTW.SelectString(0, strCurCOM);
  244. }
  245. }
  246. else if ( nEventType == DBT_DEVICEARRIVAL )
  247. {// 串口插入;
  248. TRACE(_T("串口插入\n"));
  249. if ( nIndex == CB_ERR )
  250. {
  251. m_cbCOMTW.AddString(pbdp->dbcp_name);
  252. // 新增后,由于索引变化了,要重新设置选中项;
  253. if ( nCurIndex != CB_ERR )
  254. m_cbCOMTW.SelectString(0, strCurCOM);
  255. else
  256. {
  257. IsTestWizardPort(pbdp->dbcp_name);
  258. }
  259. }
  260. }
  261. }
  262. {
  263. // 查找是否有添加过该项;
  264. int nIndex = m_cbUSBPort.FindString(0, pbdp->dbcp_name);
  265. // 删除和新增前,先获取当前选中的项;
  266. CString strCurCOM = _T("");
  267. int nCurIndex = m_cbUSBPort.GetCurSel();
  268. if ( nCurIndex != CB_ERR )
  269. m_cbUSBPort.GetLBText(nCurIndex, strCurCOM);
  270. if ( nEventType == DBT_DEVICEREMOVECOMPLETE )
  271. {// 串口拨掉;
  272. TRACE(_T("串口拨掉\n"));
  273. if ( nIndex != CB_ERR )
  274. {
  275. m_cbUSBPort.DeleteString(nIndex);
  276. // 删除后, 由于索引变化了,要重新设置选中项;
  277. if ( nCurIndex != CB_ERR )
  278. m_cbUSBPort.SelectString(0, strCurCOM);
  279. }
  280. }
  281. else if ( nEventType == DBT_DEVICEARRIVAL )
  282. {// 串口插入;
  283. TRACE(_T("串口插入\n"));
  284. if ( nIndex == CB_ERR )
  285. {
  286. m_cbUSBPort.AddString(pbdp->dbcp_name);
  287. // 新增后,由于索引变化了,要重新设置选中项;
  288. if ( nCurIndex != CB_ERR )
  289. m_cbUSBPort.SelectString(0, strCurCOM);
  290. else
  291. {
  292. IsUSBSwitchPort(pbdp->dbcp_name);
  293. }
  294. }
  295. }
  296. }
  297. }
  298. TRACE(_T("OnDeviceChange\n"));
  299. return TRUE;
  300. }
  301. void CTestWizardToolDlg::InitSerialCombobox()
  302. {
  303. m_cbCOMTW.ResetContent();
  304. m_cbUSBPort.ResetContent();
  305. for (std::vector<std::string>::iterator it = m_vtPorts.begin(); it != m_vtPorts.end(); it++)
  306. {
  307. m_cbCOMTW.AddString(it->c_str());
  308. m_cbUSBPort.AddString(it->c_str());
  309. }
  310. }
  311. void CTestWizardToolDlg::AdjustLayout()
  312. {
  313. if (GetSafeHwnd() == NULL || (AfxGetMainWnd() != NULL && AfxGetMainWnd()->IsIconic()) || !m_vtKeyInfo.size())
  314. {
  315. return;
  316. }
  317. CRect rectClient;
  318. GetClientRect(rectClient);
  319. TRACE2(_T("更新后的大小:%d,%d\n"), rectClient.Width(), rectClient.Height());
  320. int sx = 0, sy = m_rcGroup.bottom + m_nTopMargin;
  321. int i = 0, id = 10000;
  322. int nWidth = (rectClient.Width() - 25) / m_nCols;
  323. DWORD dwStyle = WS_CHILD | WS_VISIBLE;
  324. for (std::vector<KeyInfo>::iterator it = m_vtKeyInfo.begin(); it != m_vtKeyInfo.end(); it++)
  325. {
  326. if (it->pbtnInfo->pBTN == NULL)
  327. continue;
  328. if (i != 0 && i % m_nCols == 0)
  329. {//换行;
  330. sy += it->height + m_nRowSpacing;
  331. }
  332. //sx = m_nLeftMargin + (i % m_nCols) * nWidth + (i % m_nCols + 1) * m_nColSpacing;
  333. sx = m_nLeftMargin + (i % m_nCols) * (nWidth + m_nColSpacing);
  334. it->pbtnInfo->pBTN->SetWindowPos(NULL, sx, sy, nWidth, it->height, SWP_NOACTIVATE | SWP_NOZORDER);
  335. i++;
  336. }
  337. }
  338. void CTestWizardToolDlg::LoadSignals()
  339. {
  340. filehelper fh;
  341. m_vtTWSignal.clear();
  342. fh.getfiles_findout_subfolder(Global::g_Config.twSignaldir.c_str(), _T("*.xml"), &m_vtTWSignal);
  343. m_cbSignals.ResetContent();
  344. for (std::vector<std::string>::iterator it = m_vtTWSignal.begin(); it != m_vtTWSignal.end(); it++ )
  345. {
  346. m_cbSignals.AddString(fh.getfilename(it->c_str()).c_str());
  347. }
  348. AutoSetDroppedWidth(&m_cbSignals);
  349. }
  350. void CTestWizardToolDlg::LoadKeyInfo(std::vector<KeyInfo> &vtKeyInfo, std::string path)
  351. {
  352. // 解析xml;
  353. tinyxml2::XMLDocument doc;
  354. if (tinyxml2::XML_SUCCESS != doc.LoadFile(path.c_str()))
  355. {
  356. return;
  357. }
  358. vtKeyInfo.clear();
  359. std::string data;
  360. tinyxml2::XMLElement* pXmlRoot = NULL;
  361. if ((pXmlRoot = doc.RootElement()) != NULL)
  362. {
  363. if (_tcsicmp(pXmlRoot->Value(), "KeyList") == 0)
  364. {
  365. //////////////////////////////////////////////////////////////////////////
  366. // 获取属性;
  367. m_nCols = _tstoi(pXmlRoot->Attribute("cols") ? pXmlRoot->Attribute("cols") : "3");
  368. m_nRowSpacing = _tstoi(pXmlRoot->Attribute("rowSpacing") ? pXmlRoot->Attribute("rowSpacing") : "5");
  369. m_nColSpacing = _tstoi(pXmlRoot->Attribute("colSpacing") ? pXmlRoot->Attribute("colSpacing") : "5");
  370. m_nTopMargin = _tstoi(pXmlRoot->Attribute("topMargin") ? pXmlRoot->Attribute("topMargin") : "8");
  371. m_nLeftMargin = _tstoi(pXmlRoot->Attribute("leftMargin") ? pXmlRoot->Attribute("leftMargin") : "8");
  372. int nWidth = _tstoi(pXmlRoot->Attribute("with") ? pXmlRoot->Attribute("with") : "58");
  373. int nHeight = _tstoi(pXmlRoot->Attribute("height") ? pXmlRoot->Attribute("height") : "25");
  374. //////////////////////////////////////////////////////////////////////////
  375. // 子项;
  376. tinyxml2::XMLElement* pXmlElent = pXmlRoot->FirstChildElement();
  377. while (pXmlElent)
  378. {
  379. if (_tcsicmp(pXmlElent->Value(), _T("ITEM")) == 0)
  380. {
  381. KeyInfo keyInfo;
  382. // 获取属性值;
  383. keyInfo.width = pXmlElent->Attribute("with") ? _ttol(pXmlElent->Attribute("with")) : nWidth;
  384. keyInfo.height = pXmlElent->Attribute("height") ? _ttol(pXmlElent->Attribute("height")) : nHeight;
  385. keyInfo.color = HexColor2RGB(pXmlElent->Attribute("color") ? pXmlElent->Attribute("color") : "87CEFA");
  386. tinyxml2::XMLElement* pItem = pXmlElent->FirstChildElement();
  387. while (pItem)
  388. {
  389. if (_tcsicmp(pItem->Value(), _T("NAME")) == 0)
  390. {
  391. keyInfo.strName = pItem->GetText();
  392. }
  393. else if (_tcsicmp(pItem->Value(), _T("USE")) == 0)
  394. {
  395. keyInfo.bUse = pItem->BoolText(true);
  396. }
  397. else if (_tcsicmp(pItem->Value(), _T("DESC")) == 0)
  398. {
  399. keyInfo.strDesc = pItem->GetText();
  400. }
  401. else if (_tcsicmp(pItem->Value(), _T("TYPE")) == 0)
  402. {
  403. keyInfo.strType = pItem->GetText();
  404. }
  405. else if (_tcsicmp(pItem->Value(), _T("VALUE")) == 0)
  406. {
  407. keyInfo.strValue = pItem->GetText();
  408. }
  409. pItem = pItem->NextSiblingElement();
  410. }
  411. keyInfo.pbtnInfo = GetUnUseBTN();
  412. if ( keyInfo.pbtnInfo == NULL)
  413. {
  414. BTNInfo *pbtnInfo = new BTNInfo();
  415. pbtnInfo->pBTN = new CMFCButton();
  416. m_vtBTNInfo.push_back(pbtnInfo);
  417. keyInfo.pbtnInfo = pbtnInfo;
  418. }
  419. SetBTNStatus(keyInfo.pbtnInfo, TRUE);
  420. vtKeyInfo.push_back(keyInfo);
  421. }
  422. pXmlElent = pXmlElent->NextSiblingElement();
  423. }
  424. }
  425. }
  426. int sx = 0, sy = m_rcGroup.bottom + m_nTopMargin;
  427. int i = 0, id = 10000;
  428. DWORD dwStyle = WS_CHILD | WS_VISIBLE;
  429. int maxX = 0, maxY = 0;
  430. for (std::vector<KeyInfo>::iterator it = vtKeyInfo.begin(); it != vtKeyInfo.end(); it++)
  431. {
  432. if (i != 0 && i % m_nCols == 0)
  433. {//换行;
  434. sy += it->height + m_nRowSpacing;
  435. }
  436. sx = (i % m_nCols) * it->width + (i % m_nCols + 1) * m_nColSpacing;
  437. //m_nDefaultWidth = m_nLeftMargin + m_nCols * it->width + m_nCols * m_nColSpacing;
  438. if ( !it->pbtnInfo->bCreated )
  439. {
  440. it->pbtnInfo->pBTN->Create(it->strName.c_str(), dwStyle, CRect(sx, sy, sx + it->width, sy + it->height), this, BTNID + i);
  441. it->pbtnInfo->bCreated = true;
  442. // 设置透明false以显示背景色
  443. it->pbtnInfo->pBTN->m_bTransparent = FALSE;
  444. it->pbtnInfo->pBTN->m_bDontUseWinXPTheme = TRUE;
  445. // 消除单击时黑色内圈;
  446. it->pbtnInfo->pBTN->m_bDrawFocus = FALSE;
  447. // 设置按钮扁平样式;
  448. it->pbtnInfo->pBTN->m_nFlatStyle = CMFCButton::FlatStyle::BUTTONSTYLE_FLAT;
  449. // 设置鼠标形状;
  450. it->pbtnInfo->pBTN->SetMouseCursorHand();
  451. }
  452. else
  453. {
  454. it->pbtnInfo->pBTN->SetWindowText(it->strName.c_str());
  455. }
  456. // 设置背景色;
  457. it->pbtnInfo->pBTN->SetFaceColor(it->color, TRUE);
  458. // 显示窗口;
  459. it->pbtnInfo->pBTN->ShowWindow(SW_SHOW);
  460. // 是否禁用;
  461. it->pbtnInfo->pBTN->EnableWindow(it->bUse);
  462. // 存入map中;
  463. m_map_key.insert(std::pair<UINT, KeyInfo*>(BTNID + i, &*it));
  464. i++;
  465. }
  466. std::vector<KeyInfo>::iterator it = vtKeyInfo.begin();
  467. m_nDefaultHeight = m_rcGroup.bottom + 15 + (vtKeyInfo.size()/m_nCols + (vtKeyInfo.size()%m_nCols > 0 ? 1 : 0)) * (it->height + m_nRowSpacing);
  468. m_nDefaultHeight = m_nDefaultHeight < MINIMUM_WINDOWS_Y ? MINIMUM_WINDOWS_Y : m_nDefaultHeight;
  469. m_nDefaultWidth = m_nLeftMargin*2 + m_nCols * it->width + m_nCols * m_nColSpacing;
  470. m_nDefaultWidth = m_nDefaultWidth < MINIMUM_WINDOWS_X ? MINIMUM_WINDOWS_X : m_nDefaultWidth;
  471. // 获取标题栏高度;
  472. int nCaptionHeight = 39; //GetSystemMetrics(SM_CYCAPTION);不准 GetWindowRect - GetClientRect
  473. // 设置窗口大小;
  474. SetWindowPos(NULL, 0, 0, m_nDefaultWidth, m_nDefaultHeight + nCaptionHeight, SWP_NOMOVE|SWP_FRAMECHANGED); //SWP_NOACTIVATE | SWP_NOZORDER
  475. AdjustLayout();
  476. }
  477. void CTestWizardToolDlg::ConvertOldSignalsToNew(std::string strOldSignal, std::string strNewSignal)
  478. {
  479. typedef struct
  480. {
  481. std::string name;
  482. std::string protocol;
  483. std::string key;
  484. //std::string color;
  485. }OldXML, *pOldXML;
  486. std::vector<OldXML> vtOldXML;
  487. tinyxml2::XMLDocument doc;
  488. if (tinyxml2::XML_SUCCESS != doc.LoadFile(strOldSignal.c_str()))
  489. {
  490. return;
  491. }
  492. tinyxml2::XMLElement* pXmlRoot = NULL;
  493. if ((pXmlRoot = doc.RootElement()) != NULL)
  494. {
  495. if (_tcsicmp(pXmlRoot->Value(), "KeyList") == 0)
  496. {
  497. // 子项;
  498. tinyxml2::XMLElement* pXmlElent = pXmlRoot->FirstChildElement();
  499. while (pXmlElent)
  500. {
  501. if (_tcsicmp(pXmlElent->Value(), _T("ITEM")) == 0)
  502. {
  503. OldXML oldxml;
  504. tinyxml2::XMLElement* pItem = pXmlElent->FirstChildElement();
  505. while (pItem)
  506. {
  507. if (_tcsicmp(pItem->Value(), _T("KeyName")) == 0)
  508. {
  509. oldxml.name = pItem->GetText();
  510. }
  511. else if (_tcsicmp(pItem->Value(), _T("KeyType")) == 0)
  512. {
  513. oldxml.protocol = pItem->GetText();
  514. }
  515. else if (_tcsicmp(pItem->Value(), _T("KeyCode")) == 0)
  516. {
  517. oldxml.key = pItem->GetText();
  518. }
  519. else if (_tcsicmp(pItem->Value(), _T("KeyCode")) == 0)
  520. {
  521. oldxml.key = pItem->GetText();
  522. }
  523. pItem = pItem->NextSiblingElement();
  524. }
  525. vtOldXML.push_back(oldxml);
  526. }
  527. pXmlElent = pXmlElent->NextSiblingElement();
  528. }
  529. }
  530. }
  531. if ( vtOldXML.size() == 0 )
  532. return;
  533. // 创建新的xml文件;
  534. const char* declaration = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
  535. doc.Parse(declaration); // 覆盖之前的xml;
  536. pXmlRoot = doc.NewElement("KeyList");
  537. if ( pXmlRoot )
  538. {
  539. pXmlRoot->SetAttribute(_T("cols"), _T("4"));
  540. pXmlRoot->SetAttribute(_T("with"), _T("60"));
  541. pXmlRoot->SetAttribute(_T("height"), _T("25"));
  542. pXmlRoot->SetAttribute(_T("rowSpacing"), _T("5"));
  543. pXmlRoot->SetAttribute(_T("colSpacing"), _T("3"));
  544. pXmlRoot->SetAttribute(_T("leftMargin"), _T("8"));
  545. pXmlRoot->SetAttribute(_T("topMargin"), _T("8"));
  546. pXmlRoot->SetAttribute(_T("ver"), _T("1.0.0.1"));
  547. pXmlRoot->SetAttribute(_T("desc"), _T("key info"));
  548. doc.InsertEndChild(pXmlRoot);
  549. for (std::vector<OldXML>::iterator it = vtOldXML.begin(); it != vtOldXML.end(); it++ )
  550. {
  551. tinyxml2::XMLElement* pXmlElent = doc.NewElement("ITEM");
  552. if ( pXmlElent )
  553. {
  554. pXmlElent->SetAttribute(_T("color"), _T("87CEFA"));
  555. // 赋值各元素节点;
  556. tinyxml2::XMLElement *pUse = doc.NewElement("USE");
  557. pUse->SetText(1);
  558. pXmlElent->InsertEndChild(pUse);
  559. tinyxml2::XMLElement *pName = doc.NewElement("NAME");
  560. pName->SetText(it->name.c_str());
  561. pXmlElent->InsertEndChild(pName);
  562. tinyxml2::XMLElement *pDesc = doc.NewElement("DESC");
  563. pDesc->SetText(_T(""));
  564. pXmlElent->InsertEndChild(pDesc);
  565. tinyxml2::XMLElement *pType = doc.NewElement("TYPE");
  566. pType->SetText(it->protocol.c_str());
  567. pXmlElent->InsertEndChild(pType);
  568. tinyxml2::XMLElement *pValue = doc.NewElement("VALUE");
  569. pValue->SetText(it->key.c_str());
  570. pXmlElent->InsertEndChild(pValue);
  571. pXmlRoot->InsertEndChild(pXmlElent);
  572. }
  573. }
  574. }
  575. doc.SaveFile(strNewSignal.c_str());
  576. }
  577. BTNInfo *CTestWizardToolDlg::GetUnUseBTN()
  578. {
  579. for (std::vector<BTNInfo*>::iterator it = m_vtBTNInfo.begin(); it != m_vtBTNInfo.end(); it++ )
  580. {
  581. if ( !(*it)->bUsed )
  582. return *it;
  583. }
  584. return NULL;
  585. }
  586. void CTestWizardToolDlg::SetBTNStatus(BTNInfo *pbtnInfo, BOOL bStatus /* = TRUE */)
  587. {
  588. if ( pbtnInfo )
  589. {
  590. pbtnInfo->bUsed = bStatus;
  591. }
  592. }
  593. void CTestWizardToolDlg::SetAllBTNUnUsed()
  594. {
  595. BTNInfo *pbtnInfo = NULL;
  596. for (std::vector<BTNInfo*>::iterator it = m_vtBTNInfo.begin(); it != m_vtBTNInfo.end(); it++ )
  597. {
  598. pbtnInfo = (*it);
  599. if ( pbtnInfo )
  600. {
  601. pbtnInfo->bUsed = false;
  602. if ( pbtnInfo->bCreated )
  603. {
  604. pbtnInfo->pBTN->ShowWindow(SW_HIDE);
  605. }
  606. }
  607. }
  608. }
  609. void CTestWizardToolDlg::ClearAllBTNInfo()
  610. {
  611. BTNInfo *pbtnInfo = NULL;
  612. for (std::vector<BTNInfo*>::iterator it = m_vtBTNInfo.begin(); it != m_vtBTNInfo.end(); it++ )
  613. {
  614. pbtnInfo = (*it);
  615. if ( pbtnInfo )
  616. {
  617. pbtnInfo->pBTN->DestroyWindow();
  618. delete pbtnInfo->pBTN;
  619. pbtnInfo->pBTN = NULL;
  620. }
  621. delete pbtnInfo;
  622. pbtnInfo = NULL;
  623. }
  624. m_vtBTNInfo.clear();
  625. }
  626. void CTestWizardToolDlg::OnSize(UINT nType, int cx, int cy)
  627. {
  628. CDialog::OnSize(nType, cx, cy);
  629. // TODO: 在此处添加消息处理程序代码
  630. AdjustLayout();
  631. }
  632. void CTestWizardToolDlg::OnSizing(UINT fwSide, LPRECT pRect)
  633. {
  634. CDialog::OnSizing(fwSide, pRect);
  635. // TODO: 在此处添加消息处理程序代码
  636. }
  637. void CTestWizardToolDlg::OnGetMinMaxInfo(MINMAXINFO* lpMMI)
  638. {
  639. // TODO: 在此添加消息处理程序代码和/或调用默认值
  640. int cx = GetSystemMetrics(SM_CXSCREEN);
  641. int cy = GetSystemMetrics(SM_CYSCREEN);
  642. int nShellHight = 0;
  643. //获取任务栏
  644. CWnd* pTaskWnd = FindWindow( _T("Shell_TrayWnd"), NULL );
  645. if (pTaskWnd != NULL)
  646. {
  647. LONG lStyle = GetWindowLong( pTaskWnd->GetSafeHwnd(), GWL_STYLE );
  648. //如果任务栏存在且可见,要减去任务栏高度
  649. if( lStyle & WS_VISIBLE )
  650. {
  651. //任务栏可见
  652. RECT TastRect;
  653. pTaskWnd->GetWindowRect(&TastRect); //任务栏的尺寸
  654. nShellHight = TastRect.bottom - TastRect.top;
  655. }
  656. else
  657. {
  658. //任务栏隐藏 不做处理
  659. }
  660. }
  661. cy -= nShellHight;
  662. lpMMI->ptMaxSize.x = cx; // 设置窗口最大化时的宽度
  663. lpMMI->ptMaxSize.y = cy; // 设置窗口最大化时的高度
  664. lpMMI->ptMaxPosition.x = 0; // 设置窗口最大化时x坐标
  665. lpMMI->ptMaxPosition.y = 0; // 设置窗口最大化时y坐标
  666. lpMMI->ptMinTrackSize.x = MINIMUM_WINDOWS_X; // 设置窗口最小宽度
  667. lpMMI->ptMinTrackSize.y = MINIMUM_WINDOWS_Y; // 设置窗口最小高度
  668. lpMMI->ptMaxTrackSize.x = cx; // 设置窗口最大宽度
  669. lpMMI->ptMaxTrackSize.y = cy; // 设置窗口最大高度
  670. CDialog::OnGetMinMaxInfo(lpMMI);
  671. }
  672. void CTestWizardToolDlg::OnSignalBtnClick(UINT uId) // 发送遥控信号;
  673. {
  674. CWnd* pWnd = GetFocus();
  675. int id = pWnd->GetDlgCtrlID();
  676. if (id >= BTNID && id <= BTNID + 100)
  677. {
  678. CString text;
  679. pWnd->GetWindowText(text);
  680. KeyInfo *pKey = m_map_key.find(id)->second;
  681. if ( m_SerialTW.IsOpen() ){
  682. m_SerialTW.SetTimeouts();
  683. // 封装发送包;
  684. byte szSendData[MAX_PATH] = {0};
  685. _stprintf_s((TCHAR*)szSendData, MAX_PATH, _T("*INPUT %s %s\r"), pKey->strType.c_str(), pKey->strValue.c_str());
  686. // 发送单信号;
  687. if ( m_SerialTW.WriteSync(szSendData, _tcslen((TCHAR*)szSendData)) )
  688. {
  689. memset(szSendData, 0, MAX_PATH);
  690. m_SerialTW.ReadSync(szSendData, MAX_PATH);
  691. TRACE("发送单信号成功\n");
  692. }
  693. else
  694. {
  695. TRACE("发送单信号失败\n");
  696. }
  697. }
  698. else
  699. {
  700. MessageBox(_T("The serial port is not open."), _T("Warnning"), MB_OK|MB_ICONWARNING);
  701. }
  702. }
  703. }
  704. void CTestWizardToolDlg::OnBnClickedOpenCom() // 打开串口;
  705. {
  706. // TODO: 在此添加控件通知处理程序代码
  707. CString strText = _T("");
  708. GetDlgItemText(BTN_OPEN_COM, strText);
  709. if ( strText == _T("Open") )
  710. {
  711. int nCurSel = m_cbCOMTW.GetCurSel();
  712. if ( nCurSel != CB_ERR )
  713. {
  714. m_SerialTW.SetIOMode();
  715. m_cbCOMTW.GetLBText(nCurSel,strText);
  716. if ( m_SerialTW.Open(atol(strText.Mid(3).GetString()), 115200) )
  717. {
  718. SetDlgItemText(BTN_OPEN_COM, _T("Close"));
  719. m_cbCOMTW.EnableWindow(FALSE);
  720. m_SerialTW.SetBufferSize(1024,1024);
  721. WritePrivateProfileString("TestWizard", "Com", strText.GetString(), Global::g_szConfig);
  722. }
  723. }
  724. }
  725. else
  726. {
  727. m_cbCOMTW.EnableWindow();
  728. SetDlgItemText(BTN_OPEN_COM, _T("Open"));
  729. if ( m_SerialTW.IsOpen() )
  730. m_SerialTW.Close();
  731. }
  732. }
  733. void CTestWizardToolDlg::OnCbnSelchangeSingals()
  734. {
  735. // TODO: 在此添加控件通知处理程序代码
  736. CString strSignal;
  737. int nCurSel = m_cbSignals.GetCurSel();
  738. if (nCurSel != CB_ERR)
  739. {
  740. std::string signalpath;
  741. m_cbSignals.GetLBText(nCurSel, strSignal);
  742. // 保存到配置文件中;
  743. Global::g_Config.twUseSignal = strSignal.GetString();
  744. WritePrivateProfileString("TestWizard", "useSignal", strSignal.GetString(), Global::g_szConfig);
  745. SetAllBTNUnUsed();
  746. LoadKeyInfo(m_vtKeyInfo, Global::g_Config.twSignaldir + _T("\\") + Global::g_Config.twUseSignal + _T(".xml"));
  747. }
  748. }
  749. void CTestWizardToolDlg::OnBnClickedReloadSignal() // 重新加载;
  750. {
  751. // TODO: 在此添加控件通知处理程序代码
  752. LoadSignals();
  753. m_cbSignals.SelectString(0, Global::g_Config.twUseSignal.c_str());
  754. }
  755. void CTestWizardToolDlg::OnDestroy()
  756. {
  757. CDialog::OnDestroy();
  758. // TODO: 在此处添加消息处理程序代码
  759. ClearAllBTNInfo();
  760. }
  761. void CTestWizardToolDlg::OnOK()
  762. {
  763. // TODO: 在此添加专用代码和/或调用基类
  764. //CDialog::OnOK();
  765. }
  766. void CTestWizardToolDlg::InitBtnStyle()
  767. {
  768. // 设置透明false以显示背景色
  769. m_btnOpenTW.m_bTransparent = FALSE;
  770. //m_btnOpen.m_bDontUseWinXPTheme = TRUE;
  771. // 消除单击时黑色内圈;
  772. m_btnOpenTW.m_bDrawFocus = FALSE;
  773. // 设置按钮扁平样式;
  774. //m_btnOpen.m_nFlatStyle = CMFCButton::FlatStyle::BUTTONSTYLE_FLAT;
  775. // 设置鼠标形状;
  776. m_btnOpenTW.SetMouseCursorHand();
  777. // 设置背景色;
  778. m_btnOpenTW.SetFaceColor(RGB(250,80,80), TRUE);
  779. // 显示窗口;
  780. m_btnOpenTW.ShowWindow(SW_SHOW);
  781. m_btnOpenTW.SetTooltip(_T("Open the serial port"));
  782. // 设置透明false以显示背景色
  783. m_btnReload.m_bTransparent = FALSE;
  784. //m_btnReload.m_bDontUseWinXPTheme = TRUE;
  785. // 消除单击时黑色内圈;
  786. m_btnReload.m_bDrawFocus = FALSE;
  787. // 设置按钮扁平样式;
  788. //m_btnReload.m_nFlatStyle = CMFCButton::FlatStyle::BUTTONSTYLE_FLAT;
  789. // 设置鼠标形状;
  790. m_btnReload.SetMouseCursorHand();
  791. // 设置背景色;
  792. m_btnReload.SetFaceColor(RGB(135,220,238), TRUE);
  793. // 显示窗口;
  794. m_btnReload.ShowWindow(SW_SHOW);
  795. m_btnReload.SetTooltip(_T("Reload the signal file"));
  796. // 设置透明false以显示背景色
  797. m_btnOpenUSB.m_bTransparent = FALSE;
  798. //m_btnOpen.m_bDontUseWinXPTheme = TRUE;
  799. // 消除单击时黑色内圈;
  800. m_btnOpenUSB.m_bDrawFocus = FALSE;
  801. // 设置按钮扁平样式;
  802. //m_btnOpen.m_nFlatStyle = CMFCButton::FlatStyle::BUTTONSTYLE_FLAT;
  803. // 设置鼠标形状;
  804. m_btnOpenUSB.SetMouseCursorHand();
  805. // 设置背景色;
  806. m_btnOpenUSB.SetFaceColor(RGB(230,100,80), TRUE);
  807. // 显示窗口;
  808. m_btnOpenUSB.ShowWindow(SW_SHOW);
  809. m_btnOpenUSB.SetTooltip(_T("Open the usbmodel port"));
  810. }
  811. BOOL CTestWizardToolDlg::PreTranslateMessage(MSG* pMsg)
  812. {
  813. // TODO: 在此添加专用代码和/或调用基类
  814. if (pMsg->message == WM_KEYDOWN)
  815. {
  816. if (pMsg->wParam == VK_F3)
  817. {
  818. // 查找目录文件;
  819. filehelper fh;
  820. std::vector<std::string> vtSignals;
  821. fh.getfiles_findout_subfolder(Global::g_Config.twOldSignaldir.c_str(), _T("*.xml"), &vtSignals);
  822. // 逐个文件转换;
  823. for ( std::vector<std::string>::iterator it = vtSignals.begin(); it != vtSignals.end(); it++ )
  824. {
  825. std::string newfile = Global::g_Config.twSignaldir + _T("\\") + filehelper::getfilename(it->c_str()) + _T(".xml");
  826. ConvertOldSignalsToNew(*it, newfile);
  827. }
  828. MessageBox(_T("Convert old signals ok!"), _T("Convert"), MB_OK);
  829. OnBnClickedReloadSignal();
  830. return TRUE;
  831. }
  832. }
  833. return CDialog::PreTranslateMessage(pMsg);
  834. }
  835. void CTestWizardToolDlg::AutoSetDroppedWidth(CComboBox* pCombobox)
  836. {
  837. if (!pCombobox)
  838. return;
  839. // Find the longest string in the combo box.
  840. CString str;
  841. CSize sz;
  842. int dx = 0;
  843. TEXTMETRIC tm = { 0 };
  844. CDC* pDC = pCombobox->GetDC();
  845. CFont* pFont = pCombobox->GetFont();
  846. // Select the listbox font, save the old font
  847. CFont* pOldFont = pDC->SelectObject(pFont);
  848. // Get the text metrics for avg char width
  849. pDC->GetTextMetrics(&tm);
  850. for (int i = 0; i < pCombobox->GetCount(); i++)
  851. {
  852. pCombobox->GetLBText(i, str);
  853. sz = pDC->GetTextExtent(str);
  854. // Add the avg width to prevent clipping
  855. sz.cx += tm.tmAveCharWidth;
  856. if (sz.cx > dx)
  857. dx = sz.cx;
  858. }
  859. // Select the old font back into the DC
  860. pDC->SelectObject(pOldFont);
  861. pCombobox->ReleaseDC(pDC);
  862. // Set the horizontal extent so every character of all strings can
  863. // be scrolled to.
  864. pCombobox->SetHorizontalExtent(dx);
  865. }
  866. bool CTestWizardToolDlg::IsTestWizardPort(CString strCOMPort)
  867. {
  868. CString strText = _T("");
  869. GetDlgItemText(BTN_OPEN_COM, strText);
  870. if ( strText == _T("Close") )
  871. {// 串口已打开;
  872. return false;
  873. }
  874. /*
  875. 发送:
  876. *about
  877. 返回:
  878. *about
  879. Product name: Test Wizard
  880. Firmware version: v3.6.210811
  881. SN: 30FF6B064243393036140457
  882. Active state: Activated
  883. Developer: sun shengpeng
  884. Email: sunsp@tcl.com
  885. */
  886. m_SerialTW.SetIOMode();
  887. if ( m_SerialTW.Open(atol(strCOMPort.Mid(3).GetString()), 115200) )
  888. {
  889. // 快速响应读写,不需要设置过长的超时;
  890. m_SerialTW.SetTimeouts(0,1,20,1,150);
  891. // 封装发送包;
  892. byte szSendData[MAX_PATH] = _T("*about\r");
  893. if ( m_SerialTW.WriteSync(szSendData, _tcslen((TCHAR*)szSendData)) )
  894. {
  895. memset(szSendData, 0, MAX_PATH);
  896. m_SerialTW.ReadSync(szSendData, MAX_PATH);
  897. if ( _tcsstr((TCHAR*)szSendData, _T("Product name: Test Wizard\r")) )
  898. {
  899. // 设置当前串口为选中状态;
  900. m_cbCOMTW.SelectString(0, strCOMPort);
  901. Global::g_Config.twPort = strCOMPort;
  902. WritePrivateProfileString("TestWizard", "Com", strCOMPort.GetString(), Global::g_szConfig);
  903. // SetDlgItemText(BTN_OPEN_COM, _T("Close"));
  904. // m_cbCOM.EnableWindow(FALSE);
  905. // 关闭后,重新打开在设置超时值;
  906. m_SerialTW.Close();
  907. return true;
  908. }
  909. TRACE("发送单信号成功\n");
  910. }
  911. else
  912. {
  913. TRACE("发送单信号失败\n");
  914. }
  915. m_SerialTW.Close();
  916. }
  917. return false;
  918. }
  919. bool CTestWizardToolDlg::IsUSBSwitchPort(CString strCOMPort)
  920. {
  921. CString strText = _T("");
  922. GetDlgItemText(BTN_OPEN_COM2, strText);
  923. if ( strText == _T("Close") )
  924. {// 串口已打开;
  925. return false;
  926. }
  927. /*
  928. 发送:
  929. *SET PORT A\r
  930. 返回:
  931. set PORT A\r\n
  932. */
  933. m_SerialUSB.SetIOMode();
  934. if ( m_SerialUSB.Open(atol(strCOMPort.Mid(3).GetString()), 115200) )
  935. {
  936. // 快速响应读写,不需要设置过长的超时;
  937. m_SerialUSB.SetTimeouts(0,1,20,1,150);
  938. // 封装发送包;
  939. byte szSendData[MAX_PATH] = _T("*SET PORT A\r");
  940. if ( m_SerialUSB.WriteSync(szSendData, _tcslen((TCHAR*)szSendData)) )
  941. {
  942. memset(szSendData, 0, MAX_PATH);
  943. m_SerialUSB.ReadSync(szSendData, MAX_PATH);
  944. if ( _tcscmp((TCHAR*)szSendData, _T("set PORT A\r\n")) == 0 )
  945. {
  946. // 设置当前串口为选中状态;
  947. m_cbUSBPort.SelectString(0, strCOMPort);
  948. Global::g_Config.switchPort = strCOMPort;
  949. WritePrivateProfileString("Switcher", "Com", strCOMPort.GetString(), Global::g_szConfig);
  950. // SetDlgItemText(BTN_OPEN_COM, _T("Close"));
  951. // m_cbCOM.EnableWindow(FALSE);
  952. // 关闭后,重新打开在设置超时值;
  953. m_SerialUSB.Close();
  954. return true;
  955. }
  956. TRACE("发送单信号成功\n");
  957. }
  958. else
  959. {
  960. TRACE("发送单信号失败\n");
  961. }
  962. m_SerialUSB.Close();
  963. }
  964. return false;
  965. }
  966. void CTestWizardToolDlg::SwitchUSB(BOOL bCheckA)
  967. {
  968. if ( m_SerialUSB.IsOpen() )
  969. {
  970. m_SerialUSB.SetTimeouts(0,2,50,1,150);
  971. // 封装发送包;
  972. byte szSendData[MAX_SWITCH_LEN] = {0};
  973. _stprintf_s((TCHAR*)szSendData, MAX_SWITCH_LEN, _T("*SET PORT %c\r"), bCheckA ? 'A':'B');
  974. // 发送单信号;
  975. if ( m_SerialUSB.WriteSync(szSendData, _tcslen((TCHAR*)szSendData)) )
  976. {
  977. memset(szSendData, 0, MAX_SWITCH_LEN);
  978. m_SerialUSB.ReadSync(szSendData, MAX_SWITCH_LEN);
  979. TRACE("切换U盘成功\n");
  980. }
  981. else
  982. {
  983. TRACE("切换U盘失败\n");
  984. }
  985. }
  986. }
  987. void CTestWizardToolDlg::OnTimer(UINT_PTR nIDEvent)
  988. {
  989. // TODO: 在此添加消息处理程序代码和/或调用默认值
  990. if ( nIDEvent == 0 )
  991. {
  992. KillTimer(nIDEvent);
  993. GetSysSerialPort(m_vtPorts);
  994. InitSerialCombobox();
  995. if ( CB_ERR == m_cbCOMTW.SelectString(0, Global::g_Config.twPort.c_str()) )
  996. {
  997. for (std::vector<std::string>::iterator it = m_vtPorts.begin(); it != m_vtPorts.end(); it++)
  998. {
  999. if ( !m_bFindTestWizardPort )
  1000. {
  1001. m_bFindTestWizardPort = IsTestWizardPort(it->c_str());
  1002. }
  1003. if ( !m_bFindSwitcherPort )
  1004. {
  1005. m_bFindSwitcherPort = IsUSBSwitchPort(it->c_str());
  1006. }
  1007. }
  1008. if ( !m_bFindTestWizardPort )
  1009. MessageBox(_T("No Test Wizard found"), _T("Prompt"), MB_OK);
  1010. }
  1011. if ( CB_ERR == m_cbUSBPort.SelectString(0, Global::g_Config.switchPort.c_str()) )
  1012. {
  1013. for (std::vector<std::string>::iterator it = m_vtPorts.begin(); it != m_vtPorts.end(); it++)
  1014. {
  1015. if ( !m_bFindSwitcherPort )
  1016. {
  1017. m_bFindSwitcherPort = IsUSBSwitchPort(it->c_str());
  1018. }
  1019. }
  1020. if ( !m_bFindSwitcherPort )
  1021. MessageBox(_T("No USB Switcher found"), _T("Prompt"), MB_OK);
  1022. }
  1023. }
  1024. CDialog::OnTimer(nIDEvent);
  1025. }
  1026. void CTestWizardToolDlg::OnBnClickedOpenCom2() // 打开USB模块串口;
  1027. {
  1028. // TODO: 在此添加控件通知处理程序代码
  1029. CString strText = _T("");
  1030. GetDlgItemText(BTN_OPEN_COM2, strText);
  1031. if ( strText == _T("Open") )
  1032. {
  1033. int nCurSel = m_cbUSBPort.GetCurSel();
  1034. if ( nCurSel != CB_ERR )
  1035. {
  1036. m_SerialUSB.SetIOMode();
  1037. m_cbUSBPort.GetLBText(nCurSel,strText);
  1038. if ( m_SerialUSB.Open(atol(strText.Mid(3).GetString()), 115200) )
  1039. {
  1040. SetDlgItemText(BTN_OPEN_COM2, _T("Close"));
  1041. m_cbUSBPort.EnableWindow(FALSE);
  1042. m_SerialUSB.SetBufferSize(1024,1024);
  1043. WritePrivateProfileString("Switcher", "Com", strText.GetString(), Global::g_szConfig);
  1044. // 启用复选框;
  1045. GetDlgItem(IDC_CHECK_A)->EnableWindow();
  1046. GetDlgItem(IDC_CHECK_B)->EnableWindow();
  1047. }
  1048. }
  1049. }
  1050. else
  1051. {
  1052. m_cbUSBPort.EnableWindow();
  1053. SetDlgItemText(BTN_OPEN_COM2, _T("Open"));
  1054. if ( m_SerialUSB.IsOpen() )
  1055. m_SerialUSB.Close();
  1056. // 启用复选框;
  1057. GetDlgItem(IDC_CHECK_A)->EnableWindow(FALSE);
  1058. GetDlgItem(IDC_CHECK_B)->EnableWindow(FALSE);
  1059. }
  1060. }
  1061. void CTestWizardToolDlg::OnBnClickedCheckA()
  1062. {
  1063. // TODO: 在此添加控件通知处理程序代码
  1064. CButton *pChckA = (CButton*)GetDlgItem(IDC_CHECK_A);
  1065. BOOL bChecA = pChckA->GetCheck();
  1066. pChckA->SetCheck(bChecA);
  1067. ((CButton*)GetDlgItem(IDC_CHECK_B))->SetCheck(!bChecA);
  1068. SwitchUSB(bChecA);
  1069. }
  1070. void CTestWizardToolDlg::OnBnClickedCheckB()
  1071. {
  1072. // TODO: 在此添加控件通知处理程序代码
  1073. CButton *pChckB = (CButton*)GetDlgItem(IDC_CHECK_B);
  1074. BOOL bChecB = pChckB->GetCheck();
  1075. pChckB->SetCheck(bChecB);
  1076. ((CButton*)GetDlgItem(IDC_CHECK_A))->SetCheck(!bChecB);
  1077. SwitchUSB(!bChecB);
  1078. }