IDE.cpp 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876
  1. // IDE.cpp : 定义应用程序的类行为。
  2. //
  3. #include "stdafx.h"
  4. //#include <vld.h>
  5. #include "IDE.h"
  6. #include "MainFrm.h"
  7. #include "ChildFrm.h"
  8. #include "IDEDoc.h"
  9. #include "IDEView.h"
  10. #include "SysLib.h"
  11. #include ".\ide.h"
  12. #include "StartupDlg.h"
  13. #include "Login.h"
  14. #include "gooddc.h"
  15. #include "public.h"
  16. #include "md5class.h"
  17. //#include "conv.h"
  18. #ifdef _DEBUG
  19. #define new DEBUG_NEW
  20. #endif
  21. HANDLE g_hScriptThread = NULL; //线程对象
  22. #if IS_MULTHREAD_REQUEST
  23. HANDLE *g_pFreshVarThread = NULL;
  24. #else
  25. HANDLE g_hFreshVarThread = NULL;
  26. HANDLE g_hFreshVarCurPicThread = NULL;
  27. #endif
  28. HANDLE g_hReConnectSrvThread = NULL;
  29. INT g_nFreshVarThreadCount = 0;
  30. DWORD WINAPI FreshVarThread( void *pData );
  31. DWORD WINAPI FreshVarCurPicThread( void *pData );
  32. DWORD WINAPI ReConnectSrvThread( void *pData );
  33. extern CStringArray g_saCurPicVar;
  34. extern CRITICAL_SECTION g_CSLimit;
  35. // CIDEApp
  36. BEGIN_MESSAGE_MAP(CIDEApp, CWinApp)
  37. ON_COMMAND(ID_APP_ABOUT, OnAppAbout)
  38. // 基于文件的标准文档命令
  39. ON_COMMAND(ID_FILE_NEW, CWinApp::OnFileNew)
  40. ON_COMMAND(ID_FILE_OPEN, CWinApp::OnFileOpen)
  41. // 标准打印设置命令
  42. ON_COMMAND(ID_FILE_PRINT_SETUP, CWinApp::OnFilePrintSetup)
  43. ON_COMMAND(ID_APP_EXIT, OnAppExit)
  44. END_MESSAGE_MAP()
  45. // CIDEApp 构造
  46. CIDEApp::CIDEApp()
  47. {
  48. // TODO: 在此处添加构造代码,
  49. // 将所有重要的初始化放置在 InitInstance 中
  50. }
  51. // 唯一的一个 CIDEApp 对象
  52. CIDEApp theApp;
  53. CMainFrame *g_pMainFrm = NULL;
  54. int InitClientTTS()
  55. {
  56. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  57. wsprintf(strFile, "%s\\TTSDll.dll", g_strDirectory);
  58. //wsprintf(strFile, "E:\\Work\\version\\new_server\\dll\\TTSDll.dll");
  59. g_hTTSModule = AfxLoadLibrary(strFile);
  60. if (NULL != g_hTTSModule)
  61. {
  62. pStoneUDllRegisterTTS = (MySTONEU_DLLRegisterTTS)::GetProcAddress(g_hTTSModule, "STONEU_DLLRegisterTTS");
  63. pStoneUDllUnRegisterTTS = (MySTONEU_DLLUnRegisterTTS)::GetProcAddress(g_hTTSModule, "STONEU_DLLUnRegisterTTS");
  64. pStoneUDLLTxtToWav = (MySTONEU_DLLTxtToWav)::GetProcAddress(g_hTTSModule, "STONEU_DLLTxtToWav");
  65. }
  66. if( ( NULL != g_hTTSModule ) && ( NULL != pStoneUDllRegisterTTS ) )
  67. {
  68. pStoneUDllRegisterTTS();
  69. }
  70. else
  71. {
  72. FreeLibrary( g_hTTSModule );
  73. g_hTTSModule = NULL;
  74. }
  75. return 0;
  76. }
  77. int UnInitClientTTS()
  78. {
  79. if( NULL != g_hTTSModule && NULL != pStoneUDllUnRegisterTTS )
  80. {
  81. pStoneUDllUnRegisterTTS();
  82. AfxFreeLibrary( g_hTTSModule );
  83. g_hTTSModule = NULL;
  84. }
  85. return 0;
  86. }
  87. // CIDEApp 初始化
  88. HANDLE hMutex;
  89. BOOL CIDEApp::InitInstance()
  90. {
  91. // 如果一个运行在 Windows XP 上的应用程序清单指定要
  92. // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
  93. //则需要 InitCommonControls()。否则,将无法创建窗口。
  94. CString StrName="StoneU_IDE";
  95. hMutex=OpenMutex(MUTEX_ALL_ACCESS,FALSE,StrName);
  96. if(hMutex==NULL)
  97. {
  98. hMutex=::CreateMutex(NULL,NULL,StrName);
  99. }
  100. else
  101. {
  102. MessageBox(NULL,"IDE已经打开!","温馨提示",MB_ICONINFORMATION);
  103. return FALSE;
  104. }
  105. InitializeCriticalSection(&g_CSLimit);
  106. InitCommonControls();
  107. CoInitialize( NULL );
  108. CWinApp::InitInstance();
  109. //// 初始化 OLE 库
  110. if (!AfxOleInit())
  111. {
  112. AfxMessageBox(IDP_OLE_INIT_FAILED);
  113. return FALSE;
  114. }
  115. AfxEnableControlContainer();
  116. // 标准初始化
  117. // 如果未使用这些功能并希望减小
  118. // 最终可执行文件的大小,则应移除下列
  119. // 不需要的特定初始化例程
  120. // 更改用于存储设置的注册表项
  121. // TODO: 应适当修改该字符串,
  122. // 例如修改为公司或组织名
  123. SetRegistryKey(g_strAppwizardCreateApp);
  124. LoadStdProfileSettings(4); // 加载标准 INI 文件选项(包括 MRU)
  125. // START GDI+ SUB SYSTEM
  126. GdiplusStartup(&m_gdiplusToken, &m_gdiplusStartupInput, NULL);
  127. MTVERIFY( g_hRunObject = ::CreateEvent(
  128. NULL, /* Security */
  129. TRUE, /* Manual event */
  130. 0, /* Clear on creation */
  131. "IDE::g_hRunObject") );
  132. //InitPrintQueue();
  133. GetSysData();
  134. if( !g_FindProcess( "eBusShortCut.exe" ) )
  135. {
  136. CString sTemp;
  137. sTemp = g_strDirectory;
  138. sTemp += "\\eBusShortCut.exe";//
  139. ShellExecute( NULL, NULL, sTemp,0,NULL, SW_SHOWNORMAL );
  140. }
  141. CString strFileName;
  142. strFileName.Format("%s\\log4crc", g_strDirectory);
  143. ///设置日志配置文件名
  144. LOG4C_PARAM_CFG_FILE_NAME(strFileName);
  145. ///设置日志级别
  146. LOG4C_PARAM_LOG_LEVEL("unknown");
  147. ///设置日志文件大小
  148. LOG4C_PARAM_LOG_FILE_SIZE(10240);
  149. ///设置生成日志文件个数,达到最大个数将自动覆盖最旧的日志
  150. LOG4C_PARAM_LOG_FILE_NUM(5);
  151. ///设置每次记录日志都重新读取日志配置文件
  152. LOG4C_PARAM_REREAD_LOG_CFG_FILE(1);
  153. ///带参数日志模块初始化,以上所有设置了的参数都将生效,没有设置的采用缺省值
  154. LOG4C_INIT_WITH_PARAM();
  155. LOG4C((LOG_NOTICE, "系统成功启动!"));
  156. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  157. if( strcmp(g_strLanguage, "CHS") == 0 )
  158. {
  159. wsprintf(strFile, "%s\\ChineseRes.dll", g_strDirectory);
  160. }
  161. else if( strcmp(g_strLanguage, "CHT") == 0 )
  162. {
  163. wsprintf(strFile, "%s\\TaiwanRes.dll", g_strDirectory);
  164. }
  165. else if( strcmp(g_strLanguage, "ENG") == 0 )
  166. {
  167. wsprintf(strFile, "%s\\EnglishRes.dll", g_strDirectory);
  168. }
  169. g_hLangDLL = ::LoadLibrary(strFile);
  170. AfxSetResourceHandle(g_hLangDLL);
  171. GetResourceString();
  172. if( g_nIsDemo == 0 )
  173. {
  174. if( !CDBConnection::GetInstancePtr()->OpenDataBase(g_strConnectString) )
  175. {
  176. MessageBox(NULL,g_strMsgDBConnectionFail, g_strTip, MB_ICONWARNING);
  177. return FALSE;
  178. }
  179. CDBConnection::GetInstancePtr()->DBConnectionCheckThreadStart();
  180. CDBInterface::GetInstancePtr()->SetDBType(g_strDBType);
  181. }
  182. CStartupDlg dlg;
  183. dlg.Create(IDD_STARTUP);
  184. char* lpBmpFile = "Bitmap\\tryto.bmp";
  185. BITMAPFILEHEADER bf;
  186. BITMAPINFOHEADER bi;
  187. FILE* fp = fopen(lpBmpFile,"rb");
  188. if (fp)
  189. {
  190. fread(&bf,sizeof(bf),1,fp);
  191. fread(&bi,sizeof(bi),1,fp);
  192. fclose(fp);
  193. int nCX = GetSystemMetrics(SM_CXSCREEN);
  194. int nCY = GetSystemMetrics(SM_CYSCREEN);
  195. int nW = bi.biWidth;
  196. int nH = bi.biHeight;
  197. dlg.MoveWindow((nCX-nW)/2,(nCY-nH)/2,nW,nH);
  198. }
  199. dlg.ShowWindow(TRUE);
  200. CDC* pDC = dlg.GetDC();
  201. CRect rect;
  202. dlg.GetClientRect(rect);
  203. int screenx=GetSystemMetrics(SM_CXSCREEN);
  204. int screeny=GetSystemMetrics(SM_CYSCREEN);
  205. DisplayBMP(pDC, 0, 0, rect.Width(), rect.Height(), lpBmpFile, FALSE);
  206. dlg.ReleaseDC(pDC);
  207. Sleep(3000);
  208. dlg.ShowWindow(FALSE);
  209. PMS_InitSDK();
  210. CDBInterface::GetInstancePtr()->AddGroupToDll();
  211. CDBInterface::GetInstancePtr()->AddUserToDll();
  212. if( g_nIsDemo == 0 )
  213. {
  214. // 登录
  215. int nRet = IsNoDlgLogin();
  216. if( nRet!=1 )
  217. {
  218. CLogin udlg;
  219. if( udlg.DoModal() != IDOK )
  220. {
  221. return FALSE;
  222. }
  223. CString sContent;
  224. sContent.Format("用戶< %s >登录",udlg.m_sUserID );
  225. CDBInterface::GetInstancePtr()->InsertLogRecord( LOG_LOGIN,0,"",(char *)(LPCTSTR)sContent );
  226. //检查控制,设置是否有密码
  227. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  228. wsprintf(strFile, "%s\\clientset.ini", g_strDirectory);
  229. CHAR strPwd[MAX_PASSWORD_LENGTH + 1] = "";
  230. GetPrivateProfileString("User", "ControlPwd","", strPwd,sizeof(strPwd), strFile );
  231. if( (CString)strPwd=="d41d8cd98f00b204e9800998ecf8427e" )
  232. g_bHaveControlPwd = false;
  233. }
  234. }
  235. if( g_nIsDemo == 0 )
  236. {
  237. if( g_nAlarmModeIsSound == 1 )
  238. {
  239. InitClientTTS();
  240. }
  241. }
  242. // 注册应用程序的文档模板。文档模板
  243. // 将用作文档、框架窗口和视图之间的连接
  244. CMultiDocTemplate* pDocTemplate;
  245. pDocTemplate = new CMultiDocTemplate(IDR_MAINFRAME,
  246. RUNTIME_CLASS(CIDEDoc),
  247. RUNTIME_CLASS(CChildFrame), // 自定义 MDI 子框架
  248. RUNTIME_CLASS(CIDEView));
  249. AddDocTemplate(pDocTemplate);
  250. // 创建主 MDI 框架窗口
  251. CMainFrame* pMainFrame = new CMainFrame;
  252. pMainFrame->m_pDoc = (CIDEDoc *)pDocTemplate->CreateNewDocument();
  253. if (!pMainFrame || !pMainFrame->LoadFrame(IDR_MAINFRAME))
  254. {
  255. MessageBox(NULL,"资源文件不对1", g_strTip, MB_ICONWARNING);
  256. return FALSE;
  257. }
  258. m_pMainWnd = pMainFrame;
  259. // 仅当具有后缀时才调用 DragAcceptFiles
  260. // 在 MDI 应用程序中,这应在设置 m_pMainWnd 之后立即发生
  261. // 分析标准外壳命令、DDE、打开文件操作的命令行
  262. CCommandLineInfo cmdInfo;
  263. ParseCommandLine(cmdInfo);
  264. // 调度在命令行中指定的命令。如果
  265. // 用 /RegServer、/Register、/Unregserver 或 /Unregister 启动应用程序,则返回 FALSE。
  266. cmdInfo.m_nShellCommand = CCommandLineInfo::FileNothing;
  267. if (!ProcessShellCommand(cmdInfo))
  268. {
  269. MessageBox(NULL,"资源文件不对2", g_strTip, MB_ICONWARNING);
  270. return FALSE;
  271. }
  272. // 主窗口已初始化,因此显示它并对其进行更新
  273. m_pMainWnd->SetWindowText(g_strStoneuIspcms);
  274. pMainFrame->ShowWindow(m_nCmdShow);
  275. //if( g_bFullScreen )
  276. //{
  277. // m_pMainWnd->ShowWindow(SW_SHOWMAXIMIZED);//窗口最大化 关于全屏
  278. //}
  279. pMainFrame->UpdateWindow();
  280. g_pMainFrm = pMainFrame;
  281. if( g_nIsDemo == 0 )
  282. {
  283. #if IS_MULTHREAD_REQUEST
  284. // 每个串口或IP 一个变量刷新线程
  285. int nFreshVarThreadCount = 0;
  286. int nChannelSize = pDevicesManager->m_channels.GetSize();
  287. for( int i = 0; i < nChannelSize; i++ )
  288. {
  289. CChannel *pChannel = pDevicesManager->m_channels[i];
  290. int nDeviceSize = pChannel->m_Devices.GetSize();
  291. for( int j = 0; j < nDeviceSize; j++ )
  292. {
  293. CDevice *pDevice = pChannel->m_Devices[j];
  294. nFreshVarThreadCount++;
  295. }
  296. }
  297. g_pFreshVarThread = new HANDLE[nFreshVarThreadCount];
  298. for( int i = 0; i < nChannelSize; i++ )
  299. {
  300. CChannel *pChannel = pDevicesManager->m_channels[i];
  301. int nDeviceSize = pChannel->m_Devices.GetSize();
  302. for( int j = 0; j < nDeviceSize; j++ )
  303. {
  304. CDevice *pDevice = pChannel->m_Devices[j];
  305. MTVERIFY( g_pFreshVarThread[g_nFreshVarThreadCount] =
  306. ::CreateThread(
  307. NULL,
  308. 0,
  309. FreshVarThread,
  310. (char *)(LPCTSTR)pDevice->m_strUID,
  311. 0,
  312. 0) );
  313. g_nFreshVarThreadCount++;
  314. }
  315. }
  316. #else
  317. //MTVERIFY( g_hFreshVarThread =
  318. // ::CreateThread(
  319. // NULL,
  320. // 0,
  321. // FreshVarThread,
  322. // 0,
  323. // 0,
  324. // 0) );
  325. MTVERIFY( g_hFreshVarCurPicThread =
  326. ::CreateThread(
  327. NULL,
  328. 0,
  329. FreshVarCurPicThread,
  330. 0,
  331. 0,
  332. 0) );
  333. #endif
  334. MTVERIFY( g_hReConnectSrvThread = ::CreateThread(NULL, 0, ReConnectSrvThread, 0, 0, 0) );
  335. DWORD thredid;
  336. g_hScriptThread = (HANDLE) ::CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)ScriptRunProc,NULL,0,&thredid); //脚本处理
  337. }
  338. return TRUE;
  339. }
  340. int CIDEApp::ExitInstance()
  341. {
  342. // TODO: 在此添加专用代码和/或调用基类
  343. LOG4C((LOG_NOTICE, "ExitInstance!"));
  344. if( g_hRunObject )
  345. MTVERIFY( SetEvent( g_hRunObject ) );
  346. if( pDevicesManager != NULL )
  347. {
  348. if( g_nIsDemo == 0 )
  349. {
  350. //if (g_bStartRun)
  351. {
  352. #if 1
  353. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  354. {
  355. CString sPortTemp;
  356. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  357. pDevicesManager->DisConnection(sPortTemp);
  358. }
  359. #else
  360. int nVarSize = pVariantsManager->m_analog.GetSize();
  361. int nVarUseSize=0;
  362. for( int i=0;i<nVarSize;i++ )
  363. {
  364. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice==NULL )
  365. continue;
  366. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice->m_bUsed )
  367. nVarUseSize++;
  368. }
  369. int nPortSize = nVarUseSize/VARNUM2PORT;
  370. if( nPortSize%VARNUM2PORT==0 && nPortSize>0 )
  371. nPortSize--;
  372. for( int iPortIndex=0;iPortIndex<=nPortSize;iPortIndex++ )
  373. {
  374. CString sPortTemp;
  375. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  376. pDevicesManager->DisConnection(sPortTemp);
  377. }
  378. #endif
  379. }
  380. }
  381. }
  382. if( g_nIsDemo == 0 )
  383. {
  384. if( g_nAlarmModeIsSound == 1 )
  385. {
  386. UnInitClientTTS();
  387. }
  388. if( g_hScriptThread != NULL )
  389. {
  390. if( g_hScriptThread )
  391. {
  392. MTVERIFY( WaitForSingleObject( g_hScriptThread, INFINITE ) != WAIT_FAILED );
  393. MTVERIFY( CloseHandle(g_hScriptThread) );
  394. }
  395. g_hScriptThread = NULL;
  396. // 清除脚本队列
  397. POSITION pos = g_ScriptParamList.GetHeadPosition();
  398. while (pos != NULL)
  399. {
  400. POSITION tmpPos = pos;
  401. ScriptParam* pScriptParam = g_ScriptParamList.GetNext( pos );
  402. g_ScriptParamList.RemoveAt( tmpPos );
  403. delete pScriptParam;
  404. }
  405. }
  406. #if IS_MULTHREAD_REQUEST
  407. for( int i = 0; i < g_nFreshVarThreadCount; i++ )
  408. {
  409. if( g_pFreshVarThread[i] != NULL )
  410. {
  411. MTVERIFY( WaitForSingleObject( g_pFreshVarThread[i], INFINITE ) != WAIT_FAILED );
  412. MTVERIFY( CloseHandle( g_pFreshVarThread[i] ) );
  413. g_pFreshVarThread[i] = NULL;
  414. }
  415. }
  416. if( g_pFreshVarThread )
  417. {
  418. delete []g_pFreshVarThread;
  419. g_pFreshVarThread = NULL;
  420. }
  421. #else
  422. if( g_hFreshVarThread != NULL )
  423. {
  424. MTVERIFY( WaitForSingleObject( g_hFreshVarThread, INFINITE ) != WAIT_FAILED );
  425. MTVERIFY( CloseHandle( g_hFreshVarThread ) );
  426. g_hFreshVarThread = NULL;
  427. }
  428. if( g_hFreshVarCurPicThread != NULL )
  429. {
  430. MTVERIFY( WaitForSingleObject( g_hFreshVarCurPicThread, INFINITE ) != WAIT_FAILED );
  431. MTVERIFY( CloseHandle( g_hFreshVarCurPicThread ) );
  432. g_hFreshVarCurPicThread = NULL;
  433. }
  434. #endif
  435. if( g_hReConnectSrvThread != NULL )
  436. {
  437. MTVERIFY( WaitForSingleObject( g_hReConnectSrvThread, INFINITE ) != WAIT_FAILED );
  438. MTVERIFY( CloseHandle( g_hReConnectSrvThread ) );
  439. g_hReConnectSrvThread = NULL;
  440. }
  441. }
  442. if( pDevicesManager != NULL )
  443. {
  444. //chn mem
  445. #if 1
  446. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  447. {
  448. CString sPortTemp;
  449. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  450. pDevicesManager->Release( sPortTemp );
  451. }
  452. #else
  453. int nVarSize = pVariantsManager->m_analog.GetSize();
  454. int nVarUseSize=0;
  455. for( int i=0;i<nVarSize;i++ )
  456. {
  457. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice==NULL )
  458. continue;
  459. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice->m_bUsed )
  460. nVarUseSize++;
  461. }
  462. int nPortSize = nVarUseSize/VARNUM2PORT;
  463. if( nPortSize%VARNUM2PORT==0 && nPortSize>0 )
  464. nPortSize--;
  465. for( int iPortIndex=0;iPortIndex<=nPortSize;iPortIndex++ )
  466. {
  467. CString sPortTemp;
  468. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  469. pDevicesManager->Release( sPortTemp );
  470. }
  471. #endif
  472. delete pDevicesManager;
  473. pDevicesManager = NULL;
  474. }
  475. //chn mem
  476. CDBInterface::GetInstancePtr()->Release();
  477. if( pVariantsManager != NULL )
  478. {
  479. delete pVariantsManager;
  480. pVariantsManager = NULL;
  481. }
  482. if( pEventServer != NULL )
  483. {
  484. delete pEventServer;
  485. pEventServer = NULL;
  486. }
  487. if( g_hRunObject )
  488. MTVERIFY( CloseHandle( g_hRunObject ) );
  489. //UninitPrintQueue();
  490. if( g_nIsDemo == 0 )
  491. {
  492. CDBConnection::GetInstancePtr()->DBConnectionCheckThreadStop();
  493. //DBConnectionThreadEnd();
  494. //chn mem
  495. CDBConnection::GetInstancePtr()->Release();
  496. }
  497. if(g_hLangDLL)
  498. {
  499. AfxFreeLibrary(g_hLangDLL);
  500. }
  501. LOG4C((LOG_NOTICE, "系统成功退出!"));
  502. ///关闭日志模块防止内存/资源泄漏
  503. LOG4C_FINI();
  504. // Shutdown GDI+ subystem
  505. GdiplusShutdown(m_gdiplusToken);
  506. //释放权限所占的内存
  507. PMS_UnInitSDK();
  508. ::CloseHandle( hMutex );
  509. hMutex = NULL;
  510. DeleteCriticalSection( &g_CSLimit );
  511. CoUninitialize();
  512. return CWinApp::ExitInstance();
  513. }
  514. void CIDEApp::OnAppExit()
  515. {
  516. // TODO: 在此添加命令处理程序代码
  517. CMainFrame *pMainFrm=(CMainFrame*)m_pMainWnd;
  518. pMainFrm->m_nViewCount = 0;
  519. pMainFrm->OnSuperEnd();
  520. }
  521. // 用于应用程序“关于”菜单项的 CAboutDlg 对话框
  522. class CAboutDlg : public CDialog
  523. {
  524. public:
  525. CAboutDlg();
  526. // 对话框数据
  527. enum { IDD = IDD_ABOUTBOX };
  528. protected:
  529. virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持
  530. // 实现
  531. protected:
  532. DECLARE_MESSAGE_MAP()
  533. public:
  534. virtual BOOL OnInitDialog();
  535. };
  536. CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
  537. {
  538. }
  539. void CAboutDlg::DoDataExchange(CDataExchange* pDX)
  540. {
  541. CDialog::DoDataExchange(pDX);
  542. }
  543. BOOL CAboutDlg::OnInitDialog()
  544. {
  545. CDialog::OnInitDialog();
  546. // TODO: 在此添加额外的初始化
  547. CString str;
  548. str.Format("Ver:%s",g_strVersion );
  549. GetDlgItem(IDC_STA_VERSION)->SetWindowText(str);
  550. return TRUE; // return TRUE unless you set the focus to a control
  551. // 异常: OCX 属性页应返回 FALSE
  552. }
  553. BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
  554. END_MESSAGE_MAP()
  555. // 用于运行对话框的应用程序命令
  556. void CIDEApp::OnAppAbout()
  557. {
  558. CAboutDlg aboutDlg;
  559. aboutDlg.DoModal();
  560. }
  561. // My:向服务器请求视图的最新值;
  562. DWORD WINAPI FreshVarThread( void *pData )
  563. {
  564. #if IS_MULTHREAD_REQUEST
  565. CString strUid = CString((char *)pData);
  566. #else
  567. CString strUid = "";
  568. #endif
  569. do
  570. {
  571. if (g_bStartRun)
  572. {
  573. if( g_bRun )
  574. {
  575. //TRACE("设备Uid=%s\r\n", strUid);
  576. pVariantsManager->Fresh(strUid);
  577. }
  578. }
  579. Sleep(10);
  580. }while( WaitForSingleObject( g_hRunObject, 10L ) == WAIT_TIMEOUT );
  581. return 0;
  582. }
  583. //读取当前画面的变量 ....My:向服务器请求当前画面最新的变量值;
  584. DWORD WINAPI FreshVarCurPicThread( void *pData )
  585. {
  586. #if IS_MULTHREAD_REQUEST
  587. CString strUid = CString((char *)pData);
  588. #else
  589. CString strUid = "";
  590. #endif
  591. do
  592. {
  593. if (g_bStartRun)
  594. {
  595. if( g_bRun )
  596. {
  597. //TRACE("设备Uid=%s\r\n", strUid);
  598. EnterCriticalSection( &g_CSLimit );
  599. pVariantsManager->FreshCurPic( g_saCurPicVar );
  600. LeaveCriticalSection( &g_CSLimit );
  601. }
  602. }
  603. Sleep(10);
  604. }while( WaitForSingleObject( g_hRunObject, 10L ) == WAIT_TIMEOUT );
  605. return 0;
  606. }
  607. // My:
  608. DWORD WINAPI ReConnectSrvThread( void *pData )
  609. {
  610. do
  611. {
  612. //if (g_bStartRun)
  613. {
  614. #if 1
  615. for( int iPortIndex=0;iPortIndex<2;iPortIndex++ )
  616. {
  617. CString sPortTemp;
  618. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  619. // 判断与服务Socket的连接状态;
  620. if( FALSE == pDevicesManager->GetSocketStatus(sPortTemp) )
  621. {
  622. pVariantsManager->SetSysComunicationVar( 1.0 );
  623. if( pDevicesManager->GetOpenStatus(sPortTemp) == TRUE )
  624. {
  625. pDevicesManager->DisConnection(sPortTemp);
  626. }
  627. if( !pDevicesManager->Connection(g_strServerIP, sPortTemp) )
  628. {
  629. pDevicesManager->SetSocketStatus(FALSE,sPortTemp);
  630. }
  631. else
  632. {
  633. pVariantsManager->SetSysComunicationVar( 0.0 );
  634. pDevicesManager->SetSocketStatus(TRUE,sPortTemp);
  635. }
  636. }
  637. }
  638. #else
  639. int nVarSize = pVariantsManager->m_analog.GetSize();
  640. int nVarUseSize=0;
  641. for( int i=0;i<nVarSize;i++ )
  642. {
  643. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice==NULL )
  644. continue;
  645. if( pVariantsManager->m_analog.GetAt(i)->m_pDevice->m_bUsed )
  646. nVarUseSize++;
  647. }
  648. int nPortSize = nVarUseSize/VARNUM2PORT;
  649. if( nPortSize%VARNUM2PORT==0 && nPortSize>0 )
  650. nPortSize--;
  651. for( int iPortIndex=0;iPortIndex<=nPortSize;iPortIndex++ )
  652. {
  653. CString sPortTemp;
  654. sPortTemp.Format("%d",atoi(g_strServerPort)+iPortIndex );
  655. if( FALSE == pDevicesManager->GetSocketStatus(sPortTemp) )
  656. {
  657. pVariantsManager->SetSysComunicationVar( 1.0 );
  658. if( pDevicesManager->GetOpenStatus(sPortTemp) == TRUE )
  659. {
  660. pDevicesManager->DisConnection(sPortTemp);
  661. }
  662. if( !pDevicesManager->Connection(g_strServerIP, sPortTemp) )
  663. {
  664. pDevicesManager->SetSocketStatus(FALSE,sPortTemp);
  665. }
  666. else
  667. {
  668. pVariantsManager->SetSysComunicationVar( 0.0 );
  669. pDevicesManager->SetSocketStatus(TRUE,sPortTemp);
  670. }
  671. }
  672. }
  673. #endif
  674. }
  675. //Sleep(2000);
  676. }while( WaitForSingleObject( g_hRunObject, 125L ) == WAIT_TIMEOUT );
  677. return 0;
  678. }
  679. // CIDEApp 消息处理程序
  680. int CIDEApp::IsNoDlgLogin()//是否是没对话框登录 -1:不是 0:失败 1:成功
  681. {
  682. int nRet = -1;
  683. CHAR strFile[MAX_FILE_LENGTH + 1] = "";
  684. wsprintf(strFile, "%s\\clientset.ini", g_strDirectory);
  685. char RUN[MAX_PATH] = {0};
  686. memset(RUN, 0, sizeof(RUN));
  687. //是否是没对话框登录
  688. if ( GetPrivateProfileString("User", "NoDlgLogin","",RUN, 10, strFile) != 0)
  689. {
  690. if( RUN[0] == '0' )
  691. return nRet;
  692. }
  693. WritePrivateProfileString("User", "NoDlgLogin", "0", strFile);
  694. GetPrivateProfileString("User", "UserID","", g_strLoginUserID,sizeof(g_strLoginUserID), strFile );
  695. memset(g_strDefaultUserID, 0, sizeof(g_strDefaultUserID) );
  696. strcpy(g_strDefaultUserID, g_strLoginUserID);
  697. GetPrivateProfileString("User", "UserPwd","", g_strLoginPwd,sizeof(g_strLoginPwd), strFile );
  698. memset(g_strDefaultUserPwd, 0, sizeof(g_strDefaultUserPwd) );
  699. strcpy(g_strDefaultUserPwd, g_strLoginPwd);
  700. CString sUserID,sUserPwd;
  701. sUserID = g_strLoginUserID;
  702. sUserPwd = g_strLoginPwd;
  703. if( sUserID=="" || sUserPwd=="" )
  704. return nRet;
  705. ///////////////////////////////////////////////////////////////////////////////
  706. char Path[_MAX_PATH] = {0};
  707. strcat(Path, g_strDirectory);
  708. strcat(Path,"\\");
  709. strcat(Path, _PROJECTDIR);
  710. strcat(Path,"\\");
  711. strcat(Path, "runpara.ini");
  712. //CString str;
  713. if ( GetPrivateProfileString("RUNPARA", "STARTRUN","",RUN, 10, Path) != 0)
  714. {
  715. g_bStartRun = (RUN[0] == '1' ? true:false);
  716. }
  717. if ( GetPrivateProfileString("RUNPARA", "FULLSCREEN","",RUN, 10, Path) != 0)
  718. {
  719. g_bFullScreen = RUN[0] == '1' ? true:false;
  720. }
  721. CMD5 md5;
  722. md5.setPlainText( (char *)(LPCTSTR)sUserPwd );
  723. if( ( ( strcmp(g_strDefaultUserPwd, "") != 0 ) && (strcmp(g_strLoginUserID, (char*)(LPCTSTR)sUserID) != 0 ) ) ||
  724. ( strcmp(g_strDefaultUserPwd, "") == 0 ) ||
  725. (strcmp(g_strLoginUserID, (char*)(LPCTSTR)sUserID) != 0 ) ||
  726. ( strcmp(g_strDefaultUserPwd, sUserPwd) != 0 ) ||
  727. (strcmp(g_strLoginUserID, "") == 0) )
  728. {
  729. sUserPwd = CString(md5.getMD5Digest());
  730. }
  731. nRet = CDBInterface::GetInstancePtr()->ValidateUser((char*)(LPCTSTR)sUserID, (char *)(LPCTSTR)sUserPwd);
  732. //LOG4C((LOG_NOTICE, "ValidateUser return %d", nRet));
  733. if( nRet < 1 )
  734. {
  735. MessageBox(NULL,g_strMsgUserInvalid, g_strTip, MB_ICONWARNING);
  736. return 0;
  737. }
  738. CHAR chStatus[MAX_STATUS_LENGTH + 1] = {0};
  739. CDBInterface::GetInstancePtr()->ValidateUserEnable( (char*)(LPCTSTR)sUserID, chStatus );
  740. if( atoi(chStatus) == 1 )
  741. {
  742. MessageBox(NULL,g_strMsgUserDisable, g_strTip, MB_ICONWARNING);
  743. return 0;
  744. }
  745. //cHn add
  746. CDBInterface::GetInstancePtr()->GetUserIDByName( sUserID,g_nUserID );
  747. if( g_bStartRun==0 && -1==PMS_VerifyUserPermit( g_nUserID,PMS_EDIT_STATUS_MANAGE,"" ) )
  748. {
  749. MessageBox(NULL,g_strNoPermit, g_strTip, MB_ICONWARNING);
  750. return 0;
  751. }
  752. return 1;
  753. }