IDE.cpp 18 KB

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