FrmMainF.cpp 80 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #pragma hdrstop
  4. #include <psapi.h>
  5. #include <windows.h>
  6. #include <stdio.h>
  7. #include <time.h>
  8. //---------------------------------------------------------------------------
  9. #include "AppGlobalF.h"
  10. #include "VmsDataTypeF.h"
  11. #include "FrmMainF.h"
  12. #include "VMSProtocolF.h"
  13. #include "DMCOMMF.h"
  14. #include "CommThread.h"
  15. #include "FrmOptionF.h"
  16. #include "FrmSysLogF.h"
  17. #include "FrmVmsInfoF.h"
  18. //---------------------------------------------------------------------------
  19. #pragma package(smart_init)
  20. #pragma resource "*.dfm"
  21. TFrmMain *FrmMain;
  22. //---------------------------------------------------------------------------
  23. __fastcall TFrmMain::TFrmMain(TComponent* Owner)
  24. : TForm(Owner)
  25. {
  26. ::CoInitialize(NULL);
  27. FServerRun = false;
  28. FTickState = 0;
  29. g_AppCfg.bAppLoad = false;
  30. g_AppCfg.bAppClose = false;
  31. Caption = " " + g_AppCfg.sTitle + " - " + Now().DateTimeString();;
  32. VmsManager = new TVmsCtlrManager();
  33. ImageManager = new TCDSImageManager();
  34. FormManager = new TCDSFormManager();
  35. FontManager = new TCDSFontManager();
  36. IfscManager = new TCDSIfscManager();
  37. FCur5Min = StrToInt(Now().FormatString("nn"));;
  38. }
  39. //---------------------------------------------------------------------------
  40. void __fastcall TFrmMain::FormCreate(TObject *Sender)
  41. {
  42. Application->ShowMainForm = false;
  43. try {
  44. Application->Icon->LoadFromResourceName(((unsigned int)HInstance), "MAINICON");
  45. } catch(...) { ShowMessage("LoadFromResourceName failed"); }
  46. SYS_WritePidFile((long)Handle);
  47. g_AppCfg.lMainWinHandle = (long)Handle;
  48. FrmSysLog = new TFrmSysLog(pnlLog);
  49. FrmSysLog->Parent = pnlLog;
  50. FrmSysLog->Show();
  51. FrmVmsInfo = new TFrmVmsInfo(pnlVms);
  52. FrmVmsInfo->Parent = pnlVms;
  53. FrmVmsInfo->Show();
  54. Application->ShowMainForm = true;
  55. }
  56. //---------------------------------------------------------------------------
  57. bool __fastcall TFrmMain::StartJobThread()
  58. {
  59. TCommThread *pCommThread = new TCommThread();
  60. m_CommThreadID = pCommThread->ThreadID;
  61. m_CommHandle = pCommThread->Handle;
  62. if (m_CommThreadID == NULL)
  63. {
  64. LERROR("CommThread initialization fail");
  65. return false;
  66. }
  67. LINFO("Job thread started.");
  68. return true;
  69. }
  70. //---------------------------------------------------------------------------
  71. void __fastcall TFrmMain::FormShow(TObject *Sender)
  72. {
  73. StartJobThread();
  74. CheckResource((g_AppCfg.MaxMemory * 1024), g_AppCfg.MaxHandle, g_AppCfg.MaxThread, g_AppCfg.MaxGdi);
  75. //CheckManagerApp();
  76. tmrAppState->Enabled = true;
  77. }
  78. //---------------------------------------------------------------------------
  79. void __fastcall TFrmMain::FormCloseQuery(TObject *Sender, bool &CanClose)
  80. {
  81. if (!g_AppCfg.bAppClose)
  82. {
  83. String strMsg;
  84. strMsg = Caption + "\r\n\r\nAre you sure you want to exit the program?\r\nIf the Process Manager is running the program will be restarted automatically!!!";
  85. //if (Application->MessageBox(strMsg.c_str(), L"Confirm program exit", MB_YESNO|MB_ICONQUESTION) == IDYES)
  86. {
  87. FServerRun = false;
  88. g_AppCfg.bThrExit = true;
  89. g_AppCfg.bAppClose = true;
  90. }
  91. CanClose = false;
  92. }
  93. }
  94. //---------------------------------------------------------------------------
  95. void __fastcall TFrmMain::FormClose(TObject *Sender, TCloseAction &Action)
  96. {
  97. CommClose();
  98. ::CoUninitialize();
  99. Action = caFree;
  100. FrmMain = NULL;
  101. }
  102. //---------------------------------------------------------------------------
  103. void __fastcall TFrmMain::CommClose()
  104. {
  105. try
  106. {
  107. SYS_WriteConfigInfo("LOG", "LOGDAY", Now().FormatString("dd"), g_AppCfg.sConfigFile);
  108. if (VmsManager)
  109. {
  110. VmsManager->FLists.Lock();
  111. FOR_STL(TVmsCtlr*, pObj, VmsManager->FLists)
  112. {
  113. //SAFE_DELETE(pObj->FLogFile);
  114. }
  115. VmsManager->FLists.UnLock();
  116. }
  117. //SAFE_DELETE(VmsManager);
  118. if (ImageManager)
  119. {
  120. }
  121. //SAFE_DELETE(ImageManager);
  122. }
  123. catch(Exception &e)
  124. {
  125. }
  126. }
  127. //---------------------------------------------------------------------------
  128. bool __fastcall TFrmMain::InitApplication(void)
  129. {
  130. String sTitle, sMsg;
  131. int nResult;
  132. LINFO("Program initialize start...");
  133. m_bAction = state_normal;
  134. m_bComm = state_error;
  135. m_bDB = state_normal;
  136. FTickState = 0;
  137. FServerRun = true;
  138. CommUtil_MakeBasisTime(m_oTimer, VMS_CHECK_TIME, 0);
  139. CommUtil_MakeBasisTime(m_tTimer, g_AppCfg.nTrafficCycleTime, g_AppCfg.nTrafficBasisTime);
  140. m_rTimer = Now();
  141. LINFO("VMS Information initialize...");
  142. g_SysInfo->State.CommThreadID = m_CommThreadID;
  143. LINFO("Center communication initialize...");
  144. //통신초기화를 최초 수행한 후 디비읽어서 처리
  145. nResult = VComm_Initialize((long)Handle, g_AppCfg.sSystemId, "VMS", g_AppCfg.comm.nCenterPort, g_AppCfg.sLogDay);
  146. if (VERR_NONE != nResult)
  147. {
  148. sMsg.printf(L"Center communication initialize failed: error %d", nResult);
  149. LERROR(AnsiString(sMsg).c_str());
  150. return false;
  151. }
  152. if (!DMCOMM->DbConnect(g_AppCfg.db.sConnectStr))
  153. {
  154. sTitle = "Process initialize failed...";
  155. sMsg = "Database connect failed.\r\nProgram exit.\r\n";
  156. //sMsg += DMComm->ErrorString;
  157. LERROR(AnsiString(sMsg).c_str());
  158. return false;
  159. }
  160. if (DMCOMM->GetVmsInfo() != VERR_NONE)
  161. {
  162. DMCOMM->DbClose();
  163. sTitle = "Process initialize failed...";
  164. sMsg = "VMS information initialize failed.\r\nProgram exit.\r\n";
  165. //sMsg += DMComm->ErrorString;
  166. LERROR(AnsiString(sMsg).c_str());
  167. return false;
  168. }
  169. if (DMCOMM->GetVmsIfscInfo() != VERR_NONE)
  170. {
  171. DMCOMM->DbClose();
  172. sTitle = "Process initialize failed...";
  173. sMsg = "VMS IFSC information initialize failed.\r\nProgram exit.\r\n";
  174. //sMsg += DMComm->ErrorString;
  175. LERROR(AnsiString(sMsg).c_str());
  176. return false;
  177. }
  178. if (DMCOMM->GetProcessInfo() != SYS_ERR_NONE)
  179. {
  180. DMCOMM->DbClose();
  181. sTitle = "Process initialize failed...";
  182. sMsg = "Center communication process load failed.\r\nProgram exit.\r\n";
  183. //sMsg += DMComm->ErrorString;
  184. LERROR(AnsiString(sMsg).c_str());
  185. return false;
  186. }
  187. if (DMCOMM->GetVmsImage() != VERR_NONE)
  188. {
  189. DMCOMM->DbClose();
  190. sTitle = "Process initialize failed...";
  191. sMsg = "VMS image information initialize failed.\r\nProgram exit.\r\n";
  192. //sMsg += DMComm->ErrorString;
  193. LERROR(AnsiString(sMsg).c_str());
  194. return false;
  195. }
  196. if (DMCOMM->LoadVmsForm() != VERR_NONE)
  197. {
  198. DMCOMM->DbClose();
  199. sTitle = "Process initialize failed...";
  200. sMsg = "VMS form information initialize failed.\r\nProgram exit.\r\n";
  201. //sMsg += DMComm->ErrorString;
  202. LERROR(AnsiString(sMsg).c_str());
  203. return false;
  204. }
  205. if (DMCOMM->GetFontInfo() != VERR_NONE)
  206. {
  207. DMCOMM->DbClose();
  208. sTitle = "Process initialize failed...";
  209. sMsg = "VMS Font initialize failed.\r\nProgram exit.\r\n";
  210. //sMsg += DMComm->ErrorString;
  211. LERROR(AnsiString(sMsg).c_str());
  212. return false;
  213. }
  214. DMCOMM->DbClose();
  215. //LoadOldVmsInfo();
  216. //LoadFtpVmsInfo();
  217. //LoadFontVmsInfo();
  218. //LoadBitmapVmsInfo();
  219. //이미지로 저장하는 경우에 대한 Ftp다운로드 처리여부 확인
  220. VmsIterator it;
  221. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  222. {
  223. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  224. if (pObj->FBmpDownload)
  225. {
  226. if (pObj->FIsOldProtocol)
  227. {
  228. //이전 버전중 레도것이 아닌경우는 모두 ftp를 사용함
  229. pObj->FIsFtpDownload = true;
  230. }
  231. }
  232. else
  233. {
  234. //FtpVMS.inf에 등록된 VMS만 FTP로 다운로드하면 된다
  235. }
  236. }
  237. FrmVmsInfo->InitVmsList();
  238. if (VERR_NONE != VComm_Open())//g_AppCfg.comm.nCenterPort))
  239. {
  240. sMsg.printf(L"Center communication open failed: error %d", nResult);
  241. LERROR(AnsiString(sMsg).c_str());
  242. return false;
  243. }
  244. SendInitial();
  245. ProvideEvent(provide_event, NULL, NULL);
  246. //통신서버 시작
  247. tbConnectClick(this);
  248. LINFO("Program initialize success...[Completed]");
  249. return true;
  250. }
  251. //---------------------------------------------------------------------------
  252. void __fastcall TFrmMain::tmrAppStateTimer(TObject *Sender)
  253. {
  254. tmrAppState->Enabled = false;
  255. plTime->Caption = Now().DateTimeString();
  256. if (!g_AppCfg.bAppLoad)
  257. {
  258. if (!InitApplication())
  259. {
  260. g_AppCfg.bAppClose = true;
  261. TerminateApplication();
  262. Sleep(500);
  263. Close();
  264. return;
  265. }
  266. // 초기화작업완료
  267. CheckResource((g_AppCfg.MaxMemory * 1024), g_AppCfg.MaxHandle, g_AppCfg.MaxThread, g_AppCfg.MaxGdi);
  268. g_AppCfg.bAppLoad = true; // 프로그램이 로딩되었음을 확인
  269. tmrAppState->Interval = 1000; // 프로그램 상태점검주기=1초
  270. tmrAppState->Enabled = true;
  271. DMCOMM->MonitoringVms(FServerRun);
  272. DMCOMM->MonitoringVmsClient(FServerRun);
  273. CheckCommState(); //통신상태정보 체크
  274. return;
  275. }
  276. if (g_AppCfg.bAppClose)
  277. {
  278. // 응용프로그램 종료
  279. g_AppCfg.bThrExit = true;
  280. Sleep(500);
  281. TerminateApplication();
  282. Close();
  283. return;
  284. }
  285. g_AppCfg.lMainWinHandle = (long)Handle;
  286. UpdateProcessStatePanel();
  287. if (!(++FTickState % 5))
  288. {
  289. DMCOMM->MonitoringVms(FServerRun);
  290. DMCOMM->MonitoringVmsClient(FServerRun);
  291. CheckCommState(); //통신상태정보 체크
  292. }
  293. #if 0
  294. FCurMin = StrToInt(Now().FormatString("nn"));
  295. if (!(FCurMin % 5))
  296. {
  297. if (FCur5Min != FCurMin)
  298. {
  299. FCur5Min = FCurMin;
  300. SendProcessState();
  301. SendDbThreadMessage(WM_EQUIP_STATE_ALL, NULL, NULL);
  302. }
  303. }
  304. #endif
  305. if (!(FTickState % 60))
  306. {
  307. FSendMsg = SEND_MSG_NONE;
  308. //1분주기 상태정보를 업데이트 한다.
  309. //if (!(FSendMsg & SEND_MSG_PROCESS))
  310. {
  311. SendProcessState();
  312. }
  313. //if (!(FSendMsg & SEND_MSG_EQUIP))
  314. {
  315. SendDbThreadMessage(WM_EQUIP_STATE_ALL, NULL, NULL);
  316. LINFO(">>>>>>>>>>>>>>> SendEquipStateAll");
  317. }
  318. #if 0
  319. if (m_bDB != state_normal)
  320. {
  321. SendDbThreadMessage(WM_DATABASE_REFLASH, NULL, NULL);
  322. }
  323. #endif
  324. if (CheckResource((g_AppCfg.MaxMemory * 1024), g_AppCfg.MaxHandle, g_AppCfg.MaxThread, g_AppCfg.MaxGdi))
  325. {
  326. LERROR("Resource error");
  327. #if 0
  328. AutoClose();
  329. #endif
  330. }
  331. FTickState++;
  332. }
  333. #if 0
  334. //PASIG에서는 사용하지 않음
  335. if (CheckBasisTime(m_oTimer, VMS_CHECK_TIME, 0))
  336. {
  337. SendDbThreadMessage(WM_GET_ONOFF, NULL, NULL);
  338. SendDbThreadMessage(WM_DOWNLOAD_PROC, NULL, NULL);
  339. }
  340. #endif
  341. if (CheckBasisTime(m_tTimer, g_AppCfg.nTrafficCycleTime, g_AppCfg.nTrafficBasisTime))
  342. {
  343. if (CommUtil_TimeDiff(m_rTimer) > g_AppCfg.nTrafficCycleTime)
  344. {
  345. LINFO("*** VMS Traffic Timer Acitve");
  346. ProvideEvent(provide_event, NULL, NULL);
  347. FTickState++;
  348. }
  349. }
  350. CheckProvideSave();
  351. tmrAppState->Enabled = true;
  352. }
  353. //---------------------------------------------------------------------------
  354. void __fastcall TFrmMain::AutoClose()
  355. {
  356. g_AppCfg.bAppClose = true;
  357. //Close();
  358. }
  359. //---------------------------------------------------------------------------
  360. void __fastcall TFrmMain::tbConnectClick(TObject *Sender)
  361. {
  362. FServerRun = true;
  363. g_AppCfg.bThrExit = false;
  364. tbConnect->Enabled = false;
  365. tbDisconnect->Enabled = true;
  366. //m_bAction = state_normal;
  367. SendProcessState();
  368. }
  369. //---------------------------------------------------------------------------
  370. void __fastcall TFrmMain::tbDisconnectClick(TObject *Sender)
  371. {
  372. FServerRun = false;
  373. g_AppCfg.bThrExit = true;
  374. tbDisconnect->Enabled = false;
  375. DMCOMM->TerminateVms();
  376. Sleep(500);
  377. DMCOMM->TerminateVms();
  378. DMCOMM->TerminateVmsClient();
  379. //m_bAction = state_error;
  380. SendProcessState();
  381. tbConnect->Enabled = true;
  382. }
  383. //---------------------------------------------------------------------------
  384. void __fastcall TFrmMain::tbOptionsClick(TObject *Sender)
  385. {
  386. FrmOption = new TFrmOption(this);
  387. FrmOption->Left = FrmMain->Left + 80;
  388. FrmOption->Top = FrmMain->Top + 80;
  389. FrmOption->ShowModal();
  390. if (FrmOption->FUpdate)
  391. {
  392. try
  393. {
  394. ITSLog->FLogCfg = g_LogCfg;
  395. FDbLog->FLogCfg = g_LogCfg;
  396. VmsIterator it;
  397. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  398. {
  399. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  400. if (!pObj->FDispLog)
  401. {
  402. pObj->FCLog->FLogCfg = g_LogCfg;
  403. pObj->FSLog->FLogCfg = g_LogCfg;
  404. }
  405. }
  406. }
  407. catch(Exception &e)
  408. {
  409. }
  410. }
  411. delete FrmOption;
  412. FrmOption = NULL;
  413. }
  414. //---------------------------------------------------------------------------
  415. int __fastcall TFrmMain::ChangePosition(TVmsFormObj *AVmsObj)
  416. {
  417. TLabel *pLabel = NULL;
  418. int nWidth;
  419. if (AVmsObj->TextData == "") return VERR_NONE;
  420. try
  421. {
  422. pLabel = new TLabel(NULL);
  423. if (pLabel == NULL) return VERR_OTHER;
  424. try
  425. {
  426. pLabel->AutoSize = true;
  427. pLabel->Font->Name = CodeToFont(AVmsObj->TextFontName);
  428. pLabel->Font->Size = AVmsObj->TextFontSize;
  429. pLabel->Caption = AVmsObj->TextData;
  430. if (AVmsObj->TextFontBold)
  431. pLabel->Font->Style = TFontStyles() << fsBold;
  432. else
  433. pLabel->Font->Style = TFontStyles();
  434. nWidth = AVmsObj->Width - pLabel->Width;
  435. if (nWidth > 0)
  436. {
  437. switch(AVmsObj->TextAlign)
  438. {
  439. case text_align_right: AVmsObj->PosX += nWidth; break;
  440. case text_align_center: AVmsObj->PosX += (nWidth / 2); break;
  441. }
  442. }
  443. }
  444. catch(Exception &e)
  445. {
  446. }
  447. }
  448. __finally
  449. {
  450. SAFE_DELETE(pLabel);
  451. }
  452. return VERR_NONE;
  453. }
  454. //---------------------------------------------------------------------------
  455. int __fastcall TFrmMain::MakeVmsDownloadForm()
  456. {
  457. int nFormCnt;
  458. int nSaveVmsCnt, nSaveFormCnt;
  459. TCDSForm *pCDSForm;
  460. TVmsForm *pVmsForm;
  461. TVmsFormObj *pVmsObj;
  462. VMS_SCHEDULE_INFO *pSch;
  463. VMS_SCHEDULE_DETL *pSchUnit;
  464. LINFO("MakeVmsDownloadForm: Start");
  465. //CheckResource((g_AppCfg.MaxMemory * 1024), g_AppCfg.MaxHandle, g_AppCfg.MaxThread, g_AppCfg.MaxGdi);
  466. //LINFO("MakeVmsDownloadForm: Memory_S(%u)", FMemSize);
  467. nSaveVmsCnt = 0;
  468. nSaveFormCnt= 0;
  469. //VMS스케줄에 대하여 다운로드 폼을 생성한다.
  470. VmsIterator it;
  471. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  472. {
  473. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  474. if (pObj->Server.UseFlag != bit_enable) continue;
  475. if (!pObj->FProvide) continue;
  476. nSaveVmsCnt++;
  477. //운영모드 변경
  478. pObj->RSTATE.OprMode = pObj->CTLMODE->Control;
  479. pSch = pObj->SCHEDULE;
  480. pObj->CTLMODE->MaxDisplayForm = pSch->Count;
  481. if (pObj->CTLMODE->MaxDisplayForm > pObj->VMS_MAX_PHSE_NUM)
  482. {
  483. LWARN("VMS Form Max count over1: %s, %d EA", pObj->VmsNo.c_str(), pObj->CTLMODE->MaxDisplayForm);
  484. pObj->CTLMODE->MaxDisplayForm = pObj->VMS_MAX_PHSE_NUM;
  485. }
  486. if (pObj->CTLMODE->MaxDisplayForm > INT_MAX_VMS_FORM)
  487. {
  488. LWARN("VMS Form Max count over2: %s, %d EA", pObj->VmsNo.c_str(), pObj->CTLMODE->MaxDisplayForm);
  489. pObj->CTLMODE->MaxDisplayForm = INT_MAX_VMS_FORM;
  490. }
  491. try
  492. {
  493. pObj->pForms->Lock();
  494. //최대 제공 메시지 갯수만큼 생성
  495. for (int ii = 0; ii < pSch->Count && ii < pObj->CTLMODE->MaxDisplayForm; ii++)
  496. {
  497. nFormCnt = pObj->pForms->Count();
  498. pSchUnit = &pSch->Unit[ii];
  499. AnsiString sFormId = pSchUnit->VMS_FORM_ID;
  500. pCDSForm = FormManager->FLists.Find(sFormId);
  501. if (!pCDSForm)
  502. {
  503. LERROR("VMS Schedule Form Not found: VmsNmbr(%s), FormId(%s) %d", pObj->VmsNo.c_str(), sFormId.c_str(), ii);
  504. continue;
  505. }
  506. //소통정보 표출폼 인 경우 표출할 구간의 소통정보가 존재하지 않는 경우
  507. //폼을 생성하지 않도록 한다.
  508. switch(pCDSForm->VMS_FORM_TYPE_CD)
  509. {
  510. case enFormKindTrfRow1:// = 11, // 소통상황(1단)
  511. case enFormKindTrfRow2:// = 12, // 소통상황(2단)
  512. case enFormKindTrfRow3:// = 13, // 소통상황(3단)
  513. case enFormKindTrfRow4:// = 14, // 소통상황(4단)
  514. {
  515. int ss;
  516. bool bNoData = true;
  517. AnsiString sVmsIfscId[4];
  518. for (ss = 0; ss < 4; ss++)
  519. sVmsIfscId[ss] = "";
  520. sVmsIfscId[0] = pSchUnit->FRST_VMS_IFSC_ID;
  521. sVmsIfscId[1] = pSchUnit->SECD_VMS_IFSC_ID;
  522. sVmsIfscId[2] = pSchUnit->THIR_VMS_IFSC_ID;
  523. sVmsIfscId[3] = pSchUnit->FOUR_VMS_IFSC_ID;
  524. for (ss = 0; ss < 4; ss++)
  525. {
  526. if (sVmsIfscId[ss] == "") continue;
  527. TCDSIfsc *pTmpIfsc = IfscManager->FLists.Find(sVmsIfscId[ss]);
  528. if (pTmpIfsc)
  529. {
  530. if (pTmpIfsc->CMTR_GRAD_CD != "0") bNoData = false;
  531. }
  532. }
  533. if (bNoData)
  534. {
  535. LWARN("VMS Schedule Form No Traffic: VmsNmbr(%s), FormId(%s)", pObj->VmsNo.c_str(), sFormId.c_str());
  536. continue;
  537. }
  538. }
  539. break;
  540. }
  541. nSaveFormCnt++;
  542. //폼생성
  543. //pVmsForm = new TVmsForm();
  544. pVmsForm = pObj->pForms->AddForm();
  545. pVmsForm->ScenarioSeq = nFormCnt; /* 폼 표출순서 */
  546. pVmsForm->FormId = pCDSForm->VMS_FORM_ID; /* 폼 ID */
  547. pVmsForm->DisplayTime = pSchUnit->DSPL_HH; /* 표출시간(초) */
  548. pVmsForm->DisplayMode = AnsiString(pCDSForm->VMS_MSG_DSPL_MTHD_CD); /* 표출기능 */
  549. pVmsForm->DisplayDir = AnsiString(pCDSForm->VMS_MSG_DSPL_DRCT_CD); /* 표출방향 */
  550. pVmsForm->FormKind = pCDSForm->VMS_FORM_TYPE_CD; /* 폼 종류 */
  551. pVmsForm->BkColor = pCDSForm->VMS_FORM_BCKG_HUE_CD; /* 배경색상 */
  552. pVmsForm->Width = pObj->WIDTH; /* 폼넓이 */
  553. pVmsForm->Height = pObj->HEIGHT; /* 폼높이 */
  554. pVmsForm->SvcRes = false;
  555. pVmsForm->FtpRes = false;
  556. //pObj->pForms->AddFormA(pVmsForm);
  557. pVmsForm->Lock();
  558. //폼객체생성
  559. FOR_STL(TCDSFormObj*, pCDSObj, pCDSForm->FLists)
  560. {
  561. if (pVmsForm->Count() >= MAX_VMS_OBJ_LIST)
  562. {
  563. continue;
  564. }
  565. //도형식 배경소통정보 폼인 경우 하단에 표출할 정보가 없는 경우
  566. //하단 소통정보 객체는 생성하지 않도록 하자.
  567. if (pVmsForm->FormKind == enFormKindTrfImg)
  568. {
  569. switch(pCDSObj->VMS_FORM_OBJECT_TYPE_CD)
  570. {
  571. case 0: //문자열
  572. case 1: //심볼
  573. case 2: //이미지
  574. //N:일반(모두표출하는것)
  575. //T:소통정보(소통정보가 있는 경우에만 표출하는것)
  576. //F:하단고정(소통정보가 없는 경우에만 표출하는것)
  577. if (pSchUnit->VMS_IFSC_ID == "")
  578. {
  579. //표출할 소통정보가 없는 경우
  580. if (pCDSObj->TRFC_FILL_CD == "T") continue; //
  581. }
  582. else
  583. {
  584. //표출할 소통정보가 있는 경우
  585. if (pCDSObj->TRFC_FILL_CD == "F") continue; //
  586. }
  587. break;
  588. case 11: case 12: case 13: case 14: case 15: case 16: case 17: case 18: case 19:
  589. if (pSchUnit->VMS_IFSC_ID == "") continue; //하단에 표출할 정보제공구간이 없는 경우임
  590. break;
  591. #if 0
  592. case 1://심볼(소통정보 시점 종점 사이 화살표)
  593. #if 1
  594. if (pCDSObj->VMS_DSPL_TXT.Trim() == "->")
  595. if (pSchUnit->VMS_IFSC_ID == "") continue; //하단에 표출할 정보제공구간이 없는 경우임
  596. #else
  597. if (pSchUnit->VMS_IFSC_ID == "") continue; //하단에 표출할 정보제공구간이 없는 경우임
  598. #endif
  599. break;
  600. #endif
  601. default: break;
  602. }
  603. }
  604. pVmsObj = pVmsForm->AddFormObject();
  605. pVmsObj->IFSC_ID = "";
  606. switch(pCDSObj->VMS_FORM_OBJECT_TYPE_CD)
  607. {
  608. case 1: //이미지 심볼
  609. pVmsObj->ObjectKind = graphicID_object_data; //요건 다운로드되어 있는 경우인데 다운로드상관없이 표출되도록하기위함
  610. //pVmsObj->ObjectKind = graphic_object_data;
  611. break;
  612. case 2: //파일이미지
  613. pVmsObj->ObjectKind = graphicID_object_data;
  614. break;
  615. case 3: //소통정보배경이미지
  616. pVmsObj->ObjectKind = graphic_object_data;
  617. break;
  618. case 17: //소통정보이미지1
  619. case 27: //소통정보이미지2
  620. case 37: //소통정보이미지3
  621. case 47: //소통정보이미지4
  622. pVmsObj->ObjectKind = graphicID_object_data;
  623. break;
  624. default:
  625. pVmsObj->ObjectKind = text_object_data;
  626. break;
  627. }
  628. pVmsObj->ObjectType = pCDSObj->VMS_FORM_OBJECT_TYPE_CD; //NUMBER(3) N VMS FORM OBJECT 유형 코드
  629. pVmsObj->TextFontName = pCDSObj->VMS_FONT_TYPE_CD; //NUMBER(3) N VMS 글꼴 유형 코드
  630. //TODO
  631. pVmsObj->StrTextFontName = CodeToFont(pVmsObj->TextFontName);
  632. pVmsObj->TextFontColor = pCDSObj->VMS_FONT_HUE_CD; //NUMBER(9) N VMS 글꼴 색상 코드
  633. pVmsObj->TextFontBold = pCDSObj->VMS_FONT_STYL_CD; //NUMBER(3) Y VMS 글꼴 방식 코드
  634. pVmsObj->TextFontSize = pCDSObj->VMS_FONT_SIZE; //NUMBER(3) Y 0 VMS 글꼴 크기
  635. pVmsObj->TextAlign = pCDSObj->VMS_FONT_ALIGN; //NUMBER(1) Y 0 VMS 표출 문자열정열방식(0:LEFT,1:RIGHT,2:CENTER)
  636. pVmsObj->TextData = pCDSObj->VMS_DSPL_TXT; //VARCHAR2(200) Y VMS 표출 텍스트
  637. pVmsObj->PosX = pCDSObj->VMS_DSPL_XCRDN; //NUMBER(5) Y VMS 표출 X좌표
  638. pVmsObj->PosY = pCDSObj->VMS_DSPL_YCRDN; //NUMBER(5) Y VMS 표출 Y좌표
  639. pVmsObj->Width = pCDSObj->VMS_DSPL_WIDTH; //NUMBER(5) Y 0 VMS 표출 넓이
  640. pVmsObj->Height = pCDSObj->VMS_DSPL_HEIGHT; //NUMBER(5) Y 0 VMS 표출 높이
  641. pVmsObj->IsBlinking = pCDSObj->VMS_DSPL_BLINKING; //NUMBER(1) Y 0 VMS 표출 점멸 여부(0:지속, 1:점멸)
  642. pVmsObj->BkColor = pCDSObj->VMS_DSPL_BKCOLOR; //NUMBER(1) Y 0 VMS 표출 배경색상코드
  643. pVmsObj->ObjectSize = pCDSObj->VMS_DSPL_SIZE; //NUMBER(7) Y 0 VMS 표출 크기(문자:문자길이,이미지:이미지전체크기)
  644. pVmsObj->ImageId = pCDSObj->SYMBLIB_NMBR+"0"; //NUMBER(4) N 0 심벌라이브러리 번호
  645. pVmsObj->ImageType = "0"; //Bitmap
  646. if (pVmsObj->ObjectKind != text_object_data)
  647. {
  648. if (pVmsObj->NewImage() != NULL)
  649. {
  650. try
  651. {
  652. pVmsObj->pImageData->Picture->Bitmap->Canvas->Lock();
  653. try
  654. {
  655. pVmsObj->pImageData->Picture->Assign(pCDSObj->pImage->Picture);
  656. }
  657. catch(Exception &e)
  658. {
  659. LERROR("SaveMemoryStream1: %s[%s] - %s", pVmsForm->FormId.c_str(), pVmsObj->ImageId.c_str(), AnsiString(e.Message).c_str());
  660. }
  661. }
  662. __finally
  663. {
  664. pVmsObj->pImageData->Picture->Bitmap->Canvas->Unlock();
  665. pVmsObj->pImageStream->Clear();
  666. pVmsObj->pImageStream->Position = 0;
  667. pVmsObj->pImageData->Picture->Graphic->SaveToStream((Classes::TStream*)pVmsObj->pImageStream);
  668. }
  669. }
  670. }
  671. //폼객체 유형별 Fill In
  672. if (pVmsObj->ObjectType == 0) //고정문자열
  673. {
  674. #if 0
  675. if (pObj->FBmpDownload == false && pObj->FIsOldProtocol == false)
  676. {
  677. //신규VMS인 경우 첫자리가 0 인경우 해당 문자를 표출하지 못함
  678. if (pVmsObj->TextData != "")
  679. {
  680. if (pVmsObj->TextData.SubString(1,1) == "0")
  681. {
  682. pVmsObj->TextData = " " + pVmsObj->TextData;
  683. pVmsObj->PosX = pVmsObj->PosX - 5;
  684. }
  685. }
  686. }
  687. #endif
  688. ChangePosition(pVmsObj);
  689. }
  690. else
  691. if (pVmsObj->ObjectType == 1 || //심볼
  692. pVmsObj->ObjectType == 2 ) //파일이미지
  693. {
  694. ; //처리없음
  695. }
  696. else
  697. if (pVmsObj->ObjectType == 17 || //소통정보이미지1
  698. pVmsObj->ObjectType == 27 || //소통정보이미지2
  699. pVmsObj->ObjectType == 37 || //소통정보이미지3
  700. pVmsObj->ObjectType == 47 ) //소통정보이미지4
  701. {
  702. if (!pVmsObj->pImageData) continue;
  703. TCDSImage *pSymbol = ImageManager->FLists.Find(pVmsObj->ImageId);
  704. if (!pSymbol) continue;
  705. try
  706. {
  707. int X, Y;
  708. switch(pVmsObj->ObjectType)
  709. {
  710. case 17: pVmsObj->IFSC_ID = pSchUnit->FRST_IMG_IFSC_ID; break;
  711. case 27: pVmsObj->IFSC_ID = pSchUnit->SECD_IMG_IFSC_ID; break;
  712. case 37: pVmsObj->IFSC_ID = pSchUnit->THIR_IMG_IFSC_ID; break;
  713. case 47: pVmsObj->IFSC_ID = pSchUnit->FOUR_IMG_IFSC_ID; break;
  714. }
  715. FOR_STL(TCDSImageCell*, pCell, pSymbol->FLists)
  716. {
  717. TCDSIfsc *pTmpIfsc = IfscManager->FLists.Find(pVmsObj->IFSC_ID);
  718. if (pTmpIfsc)
  719. {
  720. X = pCell->POSX;
  721. Y = pCell->POSY;
  722. pVmsObj->ImageId = pCDSObj->SYMBLIB_NMBR + pTmpIfsc->CMTR_GRAD_CD;
  723. try
  724. {
  725. pVmsObj->pImageData->Picture->Bitmap->Canvas->Lock();
  726. pVmsObj->pImageData->Picture->Bitmap->Canvas->Brush->Color = GradeToFillColor(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  727. TColor clColor = pVmsObj->pImageData->Picture->Bitmap->Canvas->Pixels[X][Y];
  728. pVmsObj->pImageData->Picture->Bitmap->Canvas->FloodFill(X, Y, clColor, fsSurface);
  729. }
  730. __finally
  731. {
  732. pVmsObj->pImageData->Picture->Bitmap->Canvas->Unlock();
  733. }
  734. }
  735. }
  736. pVmsObj->pImageStream->Clear();
  737. pVmsObj->pImageStream->Position = 0;
  738. pVmsObj->pImageData->Picture->Graphic->SaveToStream((Classes::TStream*)pVmsObj->pImageStream);
  739. }
  740. catch(Exception &e)
  741. {
  742. LERROR("SaveMemoryStreamX: %s[%s] - %s", pVmsForm->FormId.c_str(), pVmsObj->ImageId.c_str(), AnsiString(e.Message).c_str());
  743. }
  744. }
  745. else
  746. if (pVmsObj->ObjectType == 3) //소통정보 배경이미지
  747. {
  748. if (!pVmsObj->pImageData) continue;
  749. TCDSImage *pSymbol = ImageManager->FLists.Find(pVmsObj->ImageId);
  750. if (!pSymbol) continue;
  751. try
  752. {
  753. int X, Y;
  754. FOR_STL(TCDSImageCell*, pCell, pSymbol->FLists)
  755. {
  756. TCDSIfsc *pTmpIfsc = IfscManager->FLists.Find(pCell->VMS_IFSC_ID);
  757. if (pTmpIfsc)
  758. {
  759. X = pCell->POSX;
  760. Y = pCell->POSY;
  761. try
  762. {
  763. pVmsObj->pImageData->Picture->Bitmap->Canvas->Lock();
  764. pVmsObj->pImageData->Picture->Bitmap->Canvas->Brush->Color = GradeToFillColor(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  765. TColor clColor = pVmsObj->pImageData->Picture->Bitmap->Canvas->Pixels[X][Y];
  766. pVmsObj->pImageData->Picture->Bitmap->Canvas->FloodFill(X, Y, clColor, fsSurface);
  767. }
  768. __finally
  769. {
  770. pVmsObj->pImageData->Picture->Bitmap->Canvas->Unlock();
  771. }
  772. }
  773. }
  774. pVmsObj->pImageStream->Clear();
  775. pVmsObj->pImageStream->Position = 0;
  776. pVmsObj->pImageData->Picture->Graphic->SaveToStream((Classes::TStream*)pVmsObj->pImageStream);
  777. }
  778. catch(Exception &e)
  779. {
  780. LERROR("SaveMemoryStream2: %s[%s] - %s", pVmsForm->FormId.c_str(), pVmsObj->ImageId.c_str(), AnsiString(e.Message).c_str());
  781. }
  782. }
  783. else
  784. if (pVmsObj->ObjectType == 61 || //구간명
  785. pVmsObj->ObjectType == 62 || //시점명
  786. pVmsObj->ObjectType == 63 || //종점명
  787. pVmsObj->ObjectType == 64 || //돌발종류
  788. pVmsObj->ObjectType == 65 ) //대응문구
  789. {
  790. //돌발문안인 경우임
  791. pVmsObj->TextData = " ";
  792. VMS_EVENT_DETL *pEvt = pSchUnit->EVENT;
  793. if (pEvt)
  794. {
  795. switch(pVmsObj->ObjectType)
  796. {
  797. case 61: pVmsObj->TextData = pEvt->VMS_IFSC_NM; break; //구간명(사용안함)
  798. case 62: pVmsObj->TextData = pEvt->STRT_LCTN_NM; break; //VMS돌발시점명
  799. case 63: pVmsObj->TextData = pEvt->END_LCTN_NM; break; //VMS돌발종점명
  800. case 64: pVmsObj->TextData = pEvt->VMS_INCD_DETL_NM; break; //VMS돌발세부유형명
  801. case 65: pVmsObj->TextData = pEvt->OCRR_LCTN_NM; break; //대응문구(사용안함-발생장소로 일단넣음)
  802. }
  803. }
  804. if (pVmsObj->TextData == "") pVmsObj->TextData = " ";
  805. ChangePosition(pVmsObj);
  806. //TB_VMS_FORM_OBJECT_TYPE 테이블에 유형추가하고
  807. //돌발화면에서 필요한 항목 추가, TB_INCD_OCRR_VMS 테이블에 컬럼추가해야함
  808. }
  809. else
  810. if (pVmsObj->ObjectType == 71 || //발생장소
  811. pVmsObj->ObjectType == 72 || //해당도로
  812. pVmsObj->ObjectType == 73 || //통제시점명
  813. pVmsObj->ObjectType == 74 || //통제종점명
  814. pVmsObj->ObjectType == 75 || //00차로 차단
  815. pVmsObj->ObjectType == 76 || //00월00일 ~ 00월00일
  816. pVmsObj->ObjectType == 77 ) //대응문구
  817. {
  818. //공사/행사문안 임
  819. pVmsObj->TextData = " ";
  820. VMS_EVENT_DETL *pEvt = pSchUnit->EVENT;
  821. if (pEvt)
  822. {
  823. switch(pVmsObj->ObjectType)
  824. {
  825. case 71: pVmsObj->TextData = pEvt->OCRR_LCTN_NM; break; //발생장소
  826. case 72: pVmsObj->TextData = pEvt->VMS_IFSC_NM; break; //해당도로
  827. case 73: pVmsObj->TextData = pEvt->STRT_LCTN_NM; break; //통제시점명
  828. case 74: pVmsObj->TextData = pEvt->END_LCTN_NM; break; //통제종점명
  829. case 75:
  830. {
  831. int nLane = pEvt->INCD_CLSR_LANE.ToIntDef(0);
  832. #ifdef LANG_ENG
  833. if (nLane == 111111)
  834. pVmsObj->TextData = "차로 차단";
  835. else
  836. if (nLane > 0)
  837. pVmsObj->TextData = "일부 차단";
  838. else
  839. pVmsObj->TextData = " ";
  840. #else
  841. if (nLane == 111111)
  842. pVmsObj->TextData = "차로 차단";
  843. else
  844. if (nLane > 0)
  845. pVmsObj->TextData = "일부 차단";
  846. else
  847. pVmsObj->TextData = " ";
  848. #endif
  849. }
  850. break; //00차로 차단
  851. case 76: //00월00일 ~ 00월00일
  852. {
  853. #ifdef LANG_ENG
  854. String sFrom = pEvt->INCD_STRT_DT.SubString(5,2) + "월" + pEvt->INCD_STRT_DT.SubString(7,2) + "일";
  855. String sTo = pEvt->INCD_END_PRAR_DT.SubString(5,2) + "월" + pEvt->INCD_END_PRAR_DT.SubString(7,2) + "일";
  856. #else
  857. String sFrom = pEvt->INCD_STRT_DT.SubString(5,2) + "월" + pEvt->INCD_STRT_DT.SubString(7,2) + "일";
  858. String sTo = pEvt->INCD_END_PRAR_DT.SubString(5,2) + "월" + pEvt->INCD_END_PRAR_DT.SubString(7,2) + "일";
  859. #endif
  860. //문자열 맨 앞이 '0'으로 시작하는 경우 VMS에서 표출되지 않음
  861. //if (g_AppCfg.DownloadBitmap == false)
  862. if (pObj->FBmpDownload == false)
  863. {
  864. if (sFrom.SubString(1,1) == "0")
  865. {
  866. sFrom = " " + sFrom;
  867. pVmsObj->PosX = pVmsObj->PosX - 5;
  868. }
  869. }
  870. pVmsObj->TextData = sFrom + " ~ " + sTo;
  871. }
  872. break;
  873. case 77: pVmsObj->TextData = pEvt->OCRR_LCTN_NM; break; //대응문구(사용안함-발생장소로 일단넣음)
  874. }
  875. }
  876. if (pVmsObj->TextData == "") pVmsObj->TextData = " ";
  877. ChangePosition(pVmsObj);
  878. }
  879. else
  880. if (pVmsObj->ObjectType == 81 || //돌발종류
  881. pVmsObj->ObjectType == 82 || //해당도로
  882. pVmsObj->ObjectType == 83 || //우회도로
  883. pVmsObj->ObjectType == 84 ) //발생장소
  884. {
  885. pVmsObj->TextData = " ";
  886. VMS_EVENT_DETL *pEvt = pSchUnit->EVENT;
  887. if (pEvt)
  888. {
  889. switch(pVmsObj->ObjectType)
  890. {
  891. case 81: pVmsObj->TextData = pEvt->VMS_INCD_DETL_NM; break; //돌발종류
  892. case 82: pVmsObj->TextData = pEvt->VMS_IFSC_NM; break; //해당도로
  893. case 83: pVmsObj->TextData = pEvt->VMS_IFSC_NM; break; //우회도로
  894. case 84: pVmsObj->TextData = pEvt->OCRR_LCTN_NM; break; //발생장소
  895. }
  896. }
  897. if (pVmsObj->TextData == "") pVmsObj->TextData = " ";
  898. ChangePosition(pVmsObj);
  899. }
  900. else
  901. {
  902. //객체가 가변(소통정보 표출) 인 경우 가변문자를 설정하자....
  903. AnsiString VMS_IFSC_ID = "";
  904. switch(pVmsObj->ObjectType)
  905. {
  906. case 11: case 12: case 13: case 14: case 15: case 16: case 18: case 19:
  907. VMS_IFSC_ID = pSchUnit->FRST_VMS_IFSC_ID;
  908. if (pVmsForm->FormKind == enFormKindTrfImg)
  909. {
  910. VMS_IFSC_ID = pSchUnit->VMS_IFSC_ID;
  911. }
  912. else
  913. if (pVmsForm->FormKind == enFormKindCongest && pVmsObj->ObjectType == 18)
  914. {
  915. VMS_IFSC_ID = pSchUnit->VMS_IFSC_ID;
  916. }
  917. break;
  918. case 21: case 22: case 23: case 24: case 25: case 26: case 28:
  919. VMS_IFSC_ID = pSchUnit->SECD_VMS_IFSC_ID;
  920. break;
  921. case 31: case 32: case 33: case 34: case 35: case 36: case 38:
  922. VMS_IFSC_ID = pSchUnit->THIR_VMS_IFSC_ID;
  923. break;
  924. case 41: case 42: case 43: case 44: case 45: case 46: case 48:
  925. VMS_IFSC_ID = pSchUnit->FOUR_VMS_IFSC_ID;
  926. break;
  927. case 91: case 92:
  928. VMS_IFSC_ID = pCDSObj->VMS_IFSC_ID; //축통행시간/축소통상황(고정)
  929. break;
  930. case 93: case 94: case 95: case 96:
  931. VMS_IFSC_ID = pSchUnit->VMS_IFSC_ID;
  932. break;
  933. default: continue;
  934. }
  935. pVmsObj->TextData = " ";
  936. TCDSIfsc *pTmpIfsc = IfscManager->FLists.Find(VMS_IFSC_ID);
  937. if (pTmpIfsc)
  938. {
  939. switch(pVmsObj->ObjectType)
  940. {
  941. case 11: case 21: case 31: case 41: //구간명
  942. pVmsObj->TextData = pTmpIfsc->VMS_IFSC_NM;
  943. break;
  944. case 12: case 22: case 32: case 42: case 93://시점명
  945. pVmsObj->TextData = pTmpIfsc->DSPL_STRT_NODE_NM;
  946. break;
  947. case 13: case 23: case 33: case 43: case 94://종점명
  948. pVmsObj->TextData = pTmpIfsc->DSPL_END_NODE_NM;
  949. break;
  950. case 14: case 24: case 34: case 44: case 92: case 95://소통상황
  951. #if 0
  952. pVmsObj->TextData = GradeToString(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0), pVmsForm->FormKind);
  953. #else
  954. if (pObj->VmsType == "VUTP") //도형식인 경우
  955. pVmsObj->TextData = GradeToString(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0), enFormKindTrfImg);
  956. else
  957. pVmsObj->TextData = GradeToString(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0), pVmsForm->FormKind);
  958. #endif
  959. pVmsObj->TextFontColor = GradeToColorCode(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  960. break;
  961. case 19: //소통상황(가변)
  962. {
  963. AnsiString sGradText = GradeToString(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0), pVmsForm->FormKind);
  964. if (pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0) == grade_smoothness)
  965. {
  966. #ifdef LANG_ENG
  967. sGradText.printf("소통원활 약 %d 분", pTmpIfsc->TRVL_HH);
  968. #else
  969. sGradText.printf("소통원활 약 %d 분", pTmpIfsc->TRVL_HH);
  970. #endif
  971. }
  972. pVmsObj->TextData = sGradText;
  973. pVmsObj->TextFontColor = GradeToColorCode(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  974. }
  975. break;
  976. case 15: case 25: case 35: case 45: case 91: case 96://통행시간
  977. #if 0
  978. pVmsObj->TextData = AnsiString(pTmpIfsc->TRVL_HH);
  979. #else
  980. {
  981. AnsiString sFmt = pCDSObj->VMS_DSPL_TXT;
  982. if (sFmt.Pos("0"))
  983. {
  984. sFmt = StringReplace(sFmt, "0000", "%4d", TReplaceFlags() << rfReplaceAll);
  985. sFmt = StringReplace(sFmt, "000", "%3d", TReplaceFlags() << rfReplaceAll);
  986. sFmt = StringReplace(sFmt, "00", "%2d", TReplaceFlags() << rfReplaceAll);
  987. sFmt = StringReplace(sFmt, "0", "%d", TReplaceFlags() << rfReplaceAll);
  988. pVmsObj->TextData.printf(sFmt.c_str(), pTmpIfsc->TRVL_HH);
  989. }
  990. else
  991. {
  992. pVmsObj->TextData = AnsiString(pTmpIfsc->TRVL_HH);
  993. }
  994. }
  995. #endif
  996. pVmsObj->TextFontColor = GradeToColorCode(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  997. break;
  998. case 16: case 26: case 36: case 46://통행속도
  999. pVmsObj->TextData = AnsiString(pTmpIfsc->SPED);
  1000. pVmsObj->TextFontColor = GradeToColorCode(pTmpIfsc->CMTR_GRAD_CD.ToIntDef(0));
  1001. break;
  1002. case 17: case 27: case 37: case 47: //방향이미지...???
  1003. break;
  1004. case 18: case 28: case 38: case 48:
  1005. pVmsObj->TextData = pTmpIfsc->SPOT_NM;
  1006. break;
  1007. }
  1008. ChangePosition(pVmsObj);
  1009. }
  1010. }
  1011. } //FOR_STL(폼객체생성)
  1012. pVmsForm->UnLock();
  1013. } //for(최대 제공 메시지 갯수만큼 생성)
  1014. }
  1015. __finally
  1016. {
  1017. pObj->pForms->UnLock();
  1018. }
  1019. } //iterator(VMS전체루프)
  1020. LINFO("MakeVmsDownloadForm: End. (VMS: %d EA, Forms %d EA)", nSaveVmsCnt, nSaveFormCnt);
  1021. LINFO("MakeVmsDatabaseForm: Start");
  1022. nSaveVmsCnt = 0;
  1023. nSaveFormCnt= 0;
  1024. //데이터베이스에 저장할 폼을 생성한다.
  1025. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  1026. {
  1027. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  1028. if (pObj->Server.UseFlag != bit_enable) continue;
  1029. if (!pObj->FProvide) continue;
  1030. nSaveFormCnt += MakeVmsDatabaseForm(pObj);
  1031. nSaveVmsCnt++;
  1032. }
  1033. LINFO("MakeVmsDatabaseForm: End. (VMS: %d EA, Forms %d EA)", nSaveVmsCnt, nSaveFormCnt);
  1034. return VERR_NONE;
  1035. }
  1036. //---------------------------------------------------------------------------
  1037. int __fastcall TFrmMain::MakeVmsDatabaseForm(TVmsCtlr *AObj)
  1038. {
  1039. int nResult = VERR_OTHER;
  1040. int nSelCnt = 0;
  1041. if (!AObj) return VERR_MEMORY_ALLOC;
  1042. int nFormCnt = AObj->pForms->Count();
  1043. if (nFormCnt == 0) return VERR_NONE;
  1044. try
  1045. {
  1046. try
  1047. {
  1048. AObj->pForms->Lock();
  1049. for (int ii = 0; ii < nFormCnt; ii++)
  1050. {
  1051. TVmsForm *pForm = AObj->pForms->GetItem(ii);
  1052. int nObjCnt;
  1053. try
  1054. {
  1055. pForm->pBitmap->Canvas->Lock();
  1056. pForm->FormClear(CodeToColor(pForm->BkColor));
  1057. nObjCnt = pForm->Count();
  1058. for (int jj = 0; jj < nObjCnt; jj++)
  1059. {
  1060. TVmsFormObj *pFormObj = pForm->GetItem(jj);
  1061. switch(pFormObj->ObjectType)
  1062. {
  1063. case 1: //심볼
  1064. case 2: //이미지
  1065. case 17: //소통정보이미지1
  1066. case 27: //소통정보이미지2
  1067. case 37: //소통정보이미지3
  1068. case 47: //소통정보이미지4
  1069. case 3: //소통정보배경이미지
  1070. pForm->pBitmap->Canvas->Draw(pFormObj->PosX, pFormObj->PosY, pFormObj->pImageData->Picture->Graphic);
  1071. break;
  1072. default://기타 문자열
  1073. pForm->pBitmap->Canvas->Brush->Color = CodeToColor(pFormObj->BkColor);
  1074. pForm->pBitmap->Canvas->Font->Color = CodeToColor(pFormObj->TextFontColor);
  1075. pForm->pBitmap->Canvas->Font->Name = CodeToFont(pFormObj->TextFontName);
  1076. pForm->pBitmap->Canvas->Font->Size = pFormObj->TextFontSize;
  1077. if (pFormObj->TextFontBold)
  1078. pForm->pBitmap->Canvas->Font->Style = TFontStyles() << fsBold;
  1079. else
  1080. pForm->pBitmap->Canvas->Font->Style = TFontStyles();
  1081. pForm->pBitmap->Canvas->TextOutA(pFormObj->PosX, pFormObj->PosY, pFormObj->TextData);
  1082. break;
  1083. }
  1084. }
  1085. try
  1086. {
  1087. pForm->pStream->Clear();
  1088. pForm->pStream->Position = 0;
  1089. pForm->pBitmap->SaveToStream(pForm->pStream);
  1090. }
  1091. catch(Exception &e)
  1092. {
  1093. LERROR("SaveMemoryStream3: %s", AnsiString(e.Message).c_str());
  1094. }
  1095. try
  1096. {
  1097. if (g_AppCfg.SaveFormImage)
  1098. {
  1099. String sFormImage;
  1100. String sFormDir = g_sFormDir + AObj->VmsId + "\\";
  1101. //ForceDirectories(sFormDir.c_str());
  1102. sFormImage.printf(L"%s%s_%02d.bmp", sFormDir.c_str(), String(AObj->VmsId).c_str(), ii);
  1103. pForm->pBitmap->SaveToFile(sFormImage);
  1104. }
  1105. }
  1106. catch(Exception &e)
  1107. {
  1108. LERROR("SaveMemoryStream-SaveToFile: %s", AnsiString(e.Message).c_str());
  1109. }
  1110. #if 0
  1111. try
  1112. {
  1113. //pForm->pBitmap->SaveToFile(g_sFormDir + AObj->VmsId + "\\" + AObj->VmsId + "_" + PHASE);
  1114. //FTP다운로드 하는 경우 폼을 FTP디렉토리에 저장해야함
  1115. if (AObj->FIsFtpDownload)
  1116. {
  1117. String DefForm, RunForm;
  1118. DefForm.printf(L"%s9%d.bmp", String(AObj->VmsDownId).c_str(), ii);
  1119. RunForm.printf(L"%s%02d.bmp", String(AObj->VmsDownId).c_str(), ii);
  1120. if (AObj->CTLMODE->Control == 'B')
  1121. {
  1122. //pForm->pBitmap->SaveToFile(g_sFtpDir + DefForm);
  1123. }
  1124. pForm->pBitmap->SaveToFile(g_sFtpDir + RunForm);
  1125. }
  1126. }
  1127. catch(Exception &e)
  1128. {
  1129. LERROR("SaveMemoryStream-SaveToFile: %s", AnsiString(e.Message).c_str());
  1130. }
  1131. #endif
  1132. nSelCnt++;
  1133. }
  1134. __finally
  1135. {
  1136. pForm->pBitmap->Canvas->Unlock();
  1137. }
  1138. }
  1139. nResult = VERR_NONE;
  1140. }
  1141. catch(Exception &e)
  1142. {
  1143. LERROR("SaveMemoryStream4: %s", AnsiString(e.Message).c_str());
  1144. }
  1145. }
  1146. __finally
  1147. {
  1148. AObj->pForms->UnLock();
  1149. }
  1150. return nSelCnt;
  1151. }
  1152. //---------------------------------------------------------------------------
  1153. void __fastcall TFrmMain::OnWMUserMessage(TMessage &Msg)
  1154. {
  1155. ReplyMessage(0);
  1156. if ((int)Msg.WParam == WM_MAKE_DOWNLOAD_FORM)
  1157. {
  1158. int nResult = MakeVmsDownloadForm();
  1159. SendDbThreadMessage(WM_SAVE_DOWNLOAD_FORM, NULL, NULL);
  1160. return;
  1161. }
  1162. if ((int)Msg.WParam == WM_WINDOW_RESTORE)
  1163. {
  1164. Application->Restore();
  1165. Application->BringToFront();
  1166. }
  1167. if ((int)Msg.WParam == WM_DATABASE_CLOSE)
  1168. {
  1169. m_bDB = state_error;
  1170. }
  1171. if ((int)Msg.WParam == WM_DATABASE_OPEN)
  1172. {
  1173. m_bDB = state_normal;
  1174. }
  1175. if ((int)Msg.WParam == WM_THREAD_TERMINATE)
  1176. {
  1177. Sleep(500);
  1178. AutoClose();
  1179. }
  1180. }
  1181. //---------------------------------------------------------------------------
  1182. void __fastcall TFrmMain::OnVmsThreadMessage(TMessage &Msg)
  1183. {
  1184. TVmsCtlr *pObj = (TVmsCtlr*)Msg.LParam;
  1185. switch(Msg.WParam)
  1186. {
  1187. case WM_VMS_SERVER_STTS:
  1188. FrmVmsInfo->UpdateServerState((int)pObj);
  1189. SendDbThreadMessage(WM_EQUIP_STATE, Msg.LParam, 1);
  1190. break;
  1191. case WM_VMS_CLIENT_STTS:
  1192. FrmVmsInfo->UpdateClientState((int)pObj);
  1193. break;
  1194. case WM_VMS_STATE_STTS:
  1195. FrmVmsInfo->UpdateClientState((int)pObj);
  1196. SendDbThreadMessage(WM_EQUIP_STATE, Msg.LParam, 0);
  1197. break;
  1198. }
  1199. }
  1200. //---------------------------------------------------------------------------
  1201. void __fastcall TFrmMain::OnUdpDataRecvMessage(TMessage &Msg)
  1202. {
  1203. int nResult;
  1204. IPCUDPMESSAGESTRUCT *RcvData = (IPCUDPMESSAGESTRUCT*)Msg.LParam;
  1205. INT_SENDER *Sender = &RcvData->Sender;
  1206. INT_PACKET *Pkt = &RcvData->Pkt;
  1207. INT_HEAD *head = &Pkt->head;
  1208. INT_DATA *data = &Pkt->data;
  1209. char *pData = &data->Data[2];
  1210. BYTE OpCode = (BYTE)data->Data[0];
  1211. LINFO("OPR Client Req: %s.%d, %02X[%02X]", VComm_ulong2ip(Sender->IP), Sender->Port, head->OPCode, OpCode);
  1212. if (head->OPCode == INT_OP_COMM_COMMON)
  1213. {
  1214. switch(OpCode)
  1215. {
  1216. case INT_OP_VMS_POWER_CTL:
  1217. {
  1218. INT_VMS_POWER_CTL_REQ *pReq = (INT_VMS_POWER_CTL_REQ*)pData;
  1219. LINFO("VmsPowerCtlReq: %.*s, %s, %s, %d", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId, pReq->Command);
  1220. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1221. {
  1222. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1223. }
  1224. }
  1225. break;
  1226. case INT_OP_VMS_LUMINANCE_CTL:
  1227. {
  1228. INT_VMS_LUMINANCE_REQ *pReq = (INT_VMS_LUMINANCE_REQ*)pData;
  1229. LINFO("VmsLuminanceReq: %.*s, %s, %s, %d", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId, pReq->Luminance);
  1230. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1231. {
  1232. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1233. }
  1234. }
  1235. break;
  1236. case INT_OP_VMS_RESET:
  1237. {
  1238. INT_VMS_RESET_REQ *pReq = (INT_VMS_RESET_REQ*)pData;
  1239. LINFO("VmsResetReq: %.*s, %s, %s", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId);
  1240. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1241. {
  1242. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1243. }
  1244. }
  1245. break;
  1246. case INT_OP_VMS_PARA_SET:
  1247. {
  1248. INT_VMS_PARA_SET_REQ *pReq = (INT_VMS_PARA_SET_REQ*)pData;
  1249. LINFO("VmsParaSetReq: %.*s, %s, %s", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId);
  1250. LINFO("VmsParaSetReq: %d.%d,%d,%d,%d,%d,%d",
  1251. pReq->SchMsgTime,
  1252. pReq->ModuleTemp,
  1253. pReq->FanTemp,
  1254. pReq->HeaterTemp,
  1255. pReq->ModuleFail,
  1256. pReq->RetryCount,
  1257. pReq->TimeOut);
  1258. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1259. {
  1260. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1261. }
  1262. }
  1263. break;
  1264. case INT_OP_VMS_PARA_SET2:
  1265. {
  1266. INT_VMS_PARA_SET_REQ2 *pReq = (INT_VMS_PARA_SET_REQ2*)pData;
  1267. LINFO("VmsParaSetReq: %.*s, %s, %s", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId);
  1268. LINFO("VmsParaSetReq: %d.%d,%d,%d,%d,%d,%d,%d,%d,%d,%d,%d",
  1269. pReq->DefCommErr, // 통신장애 기본값, 제어기가 Host로부터 Poll 또는 명령을 받지 않고 경과할 수 있는 최대시간 (default ; 60초)
  1270. pReq->SlotCommErr, // 통신장애 slot번호, 통신 fail 시 표시할 메시지 번호(default 0번)
  1271. pReq->SlotPowerErr, // 전원장애 slot번호, 전원장애 시 표시할 메시지 번호(default 0번)
  1272. pReq->NightLuminance, // 야간 휘도 값, 0x30 ~ 0x3F
  1273. pReq->DayLuminance, // 주간 휘도 값, 0x40 ~ 0x4F
  1274. pReq->PhaseCycleTime, // phase시간주기, 장애시 phase주기 (default : 3초, 범위 : 0 ~ 10초)
  1275. pReq->ModuleFailRate, // 모듈장애율, 한개의 module을 장애로 처리하기 위한 장애 pixel백분율 (default 10%)
  1276. pReq->ModuleCheckTime, // 모듈감시 주기, 0 ~ 255 (단위:초)
  1277. pReq->BoardOnHour, // 전광판 On time(시), 0시 ~ 23시
  1278. pReq->BoardOnMin, // 전광판 On time(분), 0시 ~ 23시
  1279. pReq->BoardOffHour, // 전광판 Off time(시), 0시 ~ 23시
  1280. pReq->BoardOffMin); // 전광판 Off time(분), 0시 ~ 23시
  1281. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1282. {
  1283. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1284. }
  1285. }
  1286. break;
  1287. case INT_OP_VMS_COMMON:
  1288. {
  1289. INT_VMS_COMMON_REQ *pReq = (INT_VMS_COMMON_REQ*)pData;
  1290. LINFO("VmsCommonReq: %.*s, %s, %s : 0x%02x", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId, pReq->Command);
  1291. if (pReq->Command == 0x01)
  1292. {
  1293. //메시지 바로 다운로드함
  1294. ProvideEvent(provide_event, NULL, NULL);
  1295. }
  1296. }
  1297. break;
  1298. case INT_OP_VMS_DIRECT:
  1299. {
  1300. INT_VMS_DIRECT_CTL_REQ *pReq = (INT_VMS_DIRECT_CTL_REQ*)pData;
  1301. LINFO("VmsDirectReq: %.*s, %s, %s : 0x%02x", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId, pReq->Command);
  1302. if ((nResult = SendVmsThreadMessage(pReq->VmsId, RcvData, OpCode, (char*)pReq)) != VERR_NONE)
  1303. {
  1304. //ClientResponse(SEND_NACK, &Req, result, NULL);
  1305. }
  1306. }
  1307. break;
  1308. case INT_OP_VMS_MODE:
  1309. {
  1310. INT_VMS_MODE_REQ *pReq = (INT_VMS_MODE_REQ*)pData;
  1311. #if 0
  1312. LINFO("VmsModeSetReq: %.*s, %s, %s, %c", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->VmsId, pReq->OperId, pReq->Mode);
  1313. #else
  1314. LINFO("VmsModeSetReq: %.*s, %s, %s, %d EA", INT_VMS_MAX_DATETIME, pReq->CmdTime, pReq->OperId, pReq->Count);
  1315. #endif
  1316. //ProvideEvent(provide_mode, pReq->VmsId, pReq->Mode);
  1317. ProvideEvent(provide_mode, (BYTE*)pReq, NULL);
  1318. }
  1319. break;
  1320. case INT_OP_VMS_STATE_REQ:
  1321. LINFO("VmsStateReq");
  1322. DMCOMM->SendEquipStateAllProc();
  1323. break;
  1324. case INT_OP_VMS_IMAGE_SYMBOL:
  1325. LINFO("VmsImageSymbolUpdate");
  1326. SendDbThreadMessage(WM_MASTER_IMAGE_SYMBOL, NULL, NULL);
  1327. break;
  1328. case INT_OP_VMS_IMAGE_TRAFFIC:
  1329. LINFO("VmsImageTrafficUpdate");
  1330. SendDbThreadMessage(WM_MASTER_IMAGE_TRAFFIC, NULL, NULL);
  1331. break;
  1332. case INT_OP_VMS_FORM_UPDATE:
  1333. LINFO("VmsFormUpdate");
  1334. SendDbThreadMessage(WM_MASTER_FORM, NULL, NULL);
  1335. break;
  1336. case INT_OP_VMS_IFSC_UPDATE:
  1337. LINFO("VmsIfscUpdate");
  1338. SendDbThreadMessage(WM_MASTER_VMS_IFSC, NULL, NULL);
  1339. break;
  1340. default:
  1341. LERROR("Unknown Client Request: %02X", OpCode);
  1342. break;
  1343. }
  1344. }
  1345. }
  1346. //---------------------------------------------------------------------------
  1347. void __fastcall TFrmMain::TerminateApplication(void)
  1348. {
  1349. LERROR("Program terminated start");
  1350. /* 연결 소켓 종료 */
  1351. DMCOMM->TerminateVms();
  1352. Sleep(500);
  1353. DMCOMM->TerminateVms();
  1354. DMCOMM->TerminateVmsClient();
  1355. SendTerminal();
  1356. if (m_CommThreadID != NULL)
  1357. {
  1358. g_SysInfo->State.hFinishEvent = CreateEvent(NULL, FALSE, FALSE, "");
  1359. if (g_SysInfo->State.hFinishEvent == NULL)
  1360. {
  1361. LERROR("Create thread finish event fail");
  1362. }
  1363. if (!PostThreadMessage(m_CommThreadID, WM_QUIT, NULL, NULL))
  1364. {
  1365. LDEBUG("PostThreadMessage fail:%d", GetLastError());
  1366. }
  1367. m_CommThreadID = NULL;
  1368. if (g_SysInfo->State.hFinishEvent != NULL)
  1369. {
  1370. DWORD dwWaitResult;
  1371. dwWaitResult = WaitForSingleObject(g_SysInfo->State.hFinishEvent, 5000);
  1372. if (dwWaitResult != WAIT_OBJECT_0)
  1373. {
  1374. LERROR("Wait finish event fail");
  1375. }
  1376. CloseHandle(g_SysInfo->State.hFinishEvent);
  1377. }
  1378. }
  1379. m_bAction = state_error;
  1380. m_bComm = state_error;
  1381. m_bDB = state_error;
  1382. SendProcessState();
  1383. Sleep(500);
  1384. VComm_Close();
  1385. LERROR("Program terminated end");
  1386. }
  1387. //---------------------------------------------------------------------------
  1388. void __fastcall TFrmMain::UpdateProcessStatePanel()
  1389. {
  1390. TColor clState;
  1391. clState = clGreen;
  1392. if (m_bAction != vms_normal) clState = clRed;
  1393. if (plStateAction->Color != clState) plStateAction->Color = clState;
  1394. if (m_bComm == state_normal) clState = clGreen;
  1395. else
  1396. if (m_bComm == state_unknown) clState = clGray;
  1397. else clState = clRed;
  1398. if (plStateComm->Color != clState) plStateComm->Color = clState;
  1399. if (m_bDB == state_normal) clState = clGreen;
  1400. else
  1401. if (m_bDB == state_unknown) clState = clGray;
  1402. else clState = clRed;
  1403. if (plStateDb->Color != clState) plStateDb->Color = clState;
  1404. }
  1405. //---------------------------------------------------------------------------
  1406. int __fastcall TFrmMain::SendDbThreadMessage(UINT Msg, int wParam, int lParam)
  1407. {
  1408. int result = VERR_OTHER;
  1409. if (m_CommThreadID != NULL)
  1410. {
  1411. if (PostThreadMessage(m_CommThreadID, Msg, (WPARAM)wParam, (LPARAM)lParam))
  1412. {
  1413. result = VERR_NONE;
  1414. }
  1415. else
  1416. {
  1417. result = VERR_INTERNAL;
  1418. }
  1419. }
  1420. return result;
  1421. }
  1422. //---------------------------------------------------------------------------
  1423. int __fastcall TFrmMain::SendDbThreadDataMessage(UINT Msg, void *pData, int iLen)
  1424. {
  1425. int result = VERR_OTHER;
  1426. char *p;
  1427. if (m_CommThreadID != NULL)
  1428. {
  1429. p = new char[iLen];
  1430. if (p != NULL)
  1431. {
  1432. try
  1433. {
  1434. memcpy(p, pData, iLen);
  1435. if (PostThreadMessage(m_CommThreadID, Msg, (WPARAM)p, NULL))
  1436. {
  1437. result = VERR_NONE;
  1438. Sleep(50);
  1439. }
  1440. else
  1441. {
  1442. result = VERR_INTERNAL;
  1443. }
  1444. }
  1445. __finally
  1446. {
  1447. if (result != VERR_NONE) delete []p;
  1448. }
  1449. }
  1450. else
  1451. {
  1452. result = VERR_MEMORY_ALLOC;
  1453. }
  1454. }
  1455. return result;
  1456. }
  1457. //---------------------------------------------------------------------------
  1458. void __fastcall TFrmMain::ClientResponse(int Flag, CLIENT_COMMAND *pReq, int error, void *pData)
  1459. {
  1460. #ifdef CENTERCOMM
  1461. BYTE ErrCode;
  1462. int sResult;
  1463. switch(error)
  1464. {
  1465. case SYS_ERR_NONE: break;
  1466. case SYS_ERR_OTHER: ErrCode = INT_ERROR_OTHER; break;
  1467. case SYS_ERR_INTERNAL: ErrCode = INT_ERROR_SYSTEM; break;
  1468. case SYS_ERR_MEMORY: ErrCode = INT_ERROR_SYSTEM; break;
  1469. case SYS_ERR_DATABASE: ErrCode = INT_ERROR_SYSTEM; break;
  1470. case SYS_ERR_RESET: ErrCode = INT_ERROR_SYSTEM; break;
  1471. case SYS_ERR_START: ErrCode = INT_ERROR_SYSTEM; break;
  1472. case SYS_ERR_OFFLINE: ErrCode = INT_ERROR_OFFLINE; break;
  1473. case SYS_ERR_NO_RES: ErrCode = INT_ERROR_NO_RESPONSE; break;
  1474. case SYS_ERR_ACCESS: ErrCode = INT_ERROR_PROCESS; break;
  1475. case SYS_ERR_INVALID: ErrCode = INT_ERROR_OTHER; break;
  1476. case SYS_ERR_UNKNOWN: ErrCode = INT_ERROR_UNKNOWN_CODE; break;
  1477. case SYS_ERR_WRITE_LENGTH: ErrCode = INT_ERROR_OTHER; break;
  1478. case SYS_ERR_PACKET_SIZE_LARGE: ErrCode = INT_ERROR_OTHER; break;
  1479. case SYS_ERR_INVALID_TAG: ErrCode = INT_ERROR_OTHER; break;
  1480. case SYS_ERR_CRC: ErrCode = INT_ERROR_OTHER; break;
  1481. case SYS_ERR_LENGTH: ErrCode = INT_ERROR_LENGTH; break;
  1482. case SYS_ERR_ADDRESS: ErrCode = INT_ERROR_ADDRESS; break;
  1483. case SYS_ERR_HEADER_OPTIONS: ErrCode = INT_ERROR_HEADER; break;
  1484. case SYS_ERR_UNKNOWN_COMMAND: ErrCode = INT_ERROR_UNKNOWN_OPCODE; break;
  1485. case SYS_ERR_RECEIVE_TIMEOUT: ErrCode = INT_ERROR_OTHER; break;
  1486. case SYS_ERR_DATA_SIZE: ErrCode = INT_ERROR_DISCORD; break;
  1487. case SYS_ERR_MISMATCH: ErrCode = INT_ERROR_OTHER; break;
  1488. case SYS_ERR_INVALID_PARA: ErrCode = INT_ERROR_INVALID_DATA; break;
  1489. case SYS_ERR_MOVEMENT: ErrCode = INT_ERROR_MOVEMENT; break;
  1490. case SYS_ERR_UNAUTHORIZED: ErrCode = INT_ERROR_UNAUTHORIZED; break;
  1491. default: ErrCode = INT_ERROR_OTHER; break;
  1492. }
  1493. if (Flag == SEND_ACK)
  1494. {
  1495. INT_ACK_RES Ack;
  1496. memset(&Ack, 0x00, sizeof(Ack));
  1497. Ack.OPCode.Type = INT_TYPE(pReq->OpCode);
  1498. Ack.OPCode.Kind = INT_KIND(pReq->OpCode);
  1499. Ack.MsgSeq = pReq->MsgSeq;
  1500. if ((sResult = AckRes(&Ack, pReq->ProcessID)) != UDP_ERR_NONE)
  1501. {
  1502. LERROR("AckRes fail %d", sResult);
  1503. }
  1504. }
  1505. else
  1506. if (Flag == SEND_NACK)
  1507. {
  1508. INT_NACK_RES Nack;
  1509. memset(&Nack, 0x00, sizeof(Nack));
  1510. Nack.OPCode.Type = INT_TYPE(pReq->OpCode);
  1511. Nack.OPCode.Kind = INT_KIND(pReq->OpCode);
  1512. Nack.MsgSeq = pReq->MsgSeq;
  1513. Nack.ErrCode = ErrCode;
  1514. if ((sResult = NackRes(&Nack, pReq->ProcessID)) != UDP_ERR_NONE)
  1515. {
  1516. LERROR("NackRes fail %d", sResult);
  1517. }
  1518. }
  1519. #endif
  1520. }
  1521. //---------------------------------------------------------------------------
  1522. bool __fastcall TFrmMain::CheckBasisTime(char *p, int Cycle, int Basis)
  1523. {
  1524. char cTime[15];
  1525. CommUtil_MakeBasisTime(cTime, Cycle, Basis);
  1526. if (memcmp(p, cTime, 14) != 0)
  1527. {
  1528. memcpy(p, cTime, 14);
  1529. return true;
  1530. }
  1531. return false;
  1532. }
  1533. //---------------------------------------------------------------------------
  1534. void __fastcall TFrmMain::ProvideEvent(int Type, BYTE *pVmsId, BYTE Mode)
  1535. {
  1536. int result;
  1537. PROVIDE_STRUCT Pro;
  1538. memset(&Pro, 0x00, sizeof(Pro));
  1539. Pro.Type = Type;
  1540. if (pVmsId)
  1541. {
  1542. INT_VMS_MODE_REQ *pReq = (INT_VMS_MODE_REQ*)pVmsId;
  1543. Pro.Count = pReq->Count;
  1544. memcpy(Pro.Unit, pReq->Unit, sizeof(Pro.Unit));
  1545. }
  1546. #if 0
  1547. switch(Type)
  1548. {
  1549. case provide_event:
  1550. Pro.Type = Type;
  1551. break;
  1552. case provide_mode:
  1553. Pro.Type = Type;
  1554. //memcpy(Pro.VmsId, pVmsId, VMS_ID_SIZE);
  1555. //Pro.Mode = Mode;
  1556. INT_VMS_MODE_REQ *pReq
  1557. break;
  1558. default:
  1559. return;
  1560. }
  1561. #endif
  1562. if ((result = SendDbThreadDataMessage(WM_PROVIDE_PROC, &Pro, sizeof(Pro))) != SYS_ERR_NONE)
  1563. {
  1564. LERROR("SendDbThreadDataMessage Error %d", result);
  1565. }
  1566. }
  1567. //---------------------------------------------------------------------------
  1568. void __fastcall TFrmMain::CheckProvideSave()
  1569. {
  1570. SAVE_STRUCT ProvideSave;
  1571. SAVE_STRUCT DownLoadSave;
  1572. memset(&ProvideSave, 0x00, sizeof(ProvideSave));
  1573. memset(&DownLoadSave, 0x00, sizeof(DownLoadSave));
  1574. ProvideSave.Type = save_provide;
  1575. ProvideSave.Count = 0;
  1576. DownLoadSave.Type = save_download;
  1577. DownLoadSave.Count = 0;
  1578. VmsIterator it;
  1579. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  1580. {
  1581. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  1582. if (pObj->Server.UseFlag != bit_enable) continue;
  1583. if ((pObj->DOWNLOAD->SaveFlag == false) &&
  1584. (CommUtil_TimeDiff(pObj->DOWNLOAD->dTimer) > VMS_DOWNLOAD_TIMEOUT))
  1585. {
  1586. DownLoadSave.pObj[DownLoadSave.Count++] = (void *)pObj;
  1587. pObj->DOWNLOAD->SaveFlag = true;
  1588. }
  1589. if ((pObj->CTLMODE->SaveFlag == false) &&
  1590. (CommUtil_TimeDiff(pObj->CTLMODE->pTimer) > VMS_PROVIDE_TIMEOUT))
  1591. {
  1592. ProvideSave.pObj[ProvideSave.Count++] = (void *)pObj;
  1593. pObj->CTLMODE->SaveFlag = true;
  1594. }
  1595. }
  1596. if (ProvideSave.Count != 0)
  1597. {
  1598. SendDbThreadDataMessage(WM_PROVIDE_SAVE, &ProvideSave, sizeof(ProvideSave));
  1599. }
  1600. if (DownLoadSave.Count != 0)
  1601. {
  1602. SendDbThreadDataMessage(WM_PROVIDE_SAVE, &DownLoadSave, sizeof(DownLoadSave));
  1603. }
  1604. }
  1605. //---------------------------------------------------------------------------
  1606. bool __fastcall TFrmMain::CheckResource(size_t MaxMemory, DWORD MaxHandle, DWORD MaxThread, DWORD MaxGdi)
  1607. {
  1608. bool result;
  1609. HANDLE hProcess;
  1610. PROCESS_MEMORY_COUNTERS pmc;
  1611. size_t uSize;
  1612. DWORD HandleCount, ThreadCount, GdiCount;
  1613. HANDLE hProcessSnap;
  1614. PROCESSENTRY32 pe32;
  1615. DWORD ProcessId;
  1616. result = false;
  1617. uSize = 0;
  1618. HandleCount = 0;
  1619. ThreadCount = 0;
  1620. GdiCount = 0;
  1621. hProcess = GetCurrentProcess();
  1622. if (hProcess != NULL)
  1623. {
  1624. if ( GetProcessMemoryInfo( hProcess, &pmc, sizeof(pmc)) )
  1625. {
  1626. uSize = pmc.WorkingSetSize/1024;
  1627. if ((MaxMemory != 0) && (uSize > MaxMemory))
  1628. {
  1629. LERROR("Memory usage exceeds standards!!!...[%d][%d]", MaxMemory, uSize);
  1630. result = true;
  1631. }
  1632. }
  1633. if ( GetProcessHandleCount( hProcess, &HandleCount) )
  1634. {
  1635. if ((MaxHandle != 0) && (HandleCount > MaxHandle))
  1636. {
  1637. LERROR("Window handle exceed standards!!!...[%d][%d]", MaxHandle, HandleCount);
  1638. result = true;
  1639. }
  1640. }
  1641. ProcessId = GetCurrentProcessId();
  1642. if ((hProcessSnap = CreateToolhelp32Snapshot( TH32CS_SNAPPROCESS, 0 )) != INVALID_HANDLE_VALUE)
  1643. {
  1644. pe32.dwSize = sizeof( PROCESSENTRY32 );
  1645. if ( Process32First( hProcessSnap, &pe32 ) )
  1646. {
  1647. do
  1648. {
  1649. if (pe32.th32ProcessID == ProcessId)
  1650. {
  1651. ThreadCount = pe32.cntThreads;
  1652. if ((MaxThread != 0) && (ThreadCount > MaxThread))
  1653. {
  1654. LERROR("Criteria exceeded thread!!!...[%d][%d]", MaxThread, ThreadCount);
  1655. result = true;
  1656. }
  1657. break;
  1658. }
  1659. } while( Process32Next( hProcessSnap, &pe32 ) );
  1660. }
  1661. CloseHandle( hProcessSnap );
  1662. }
  1663. GdiCount = GetGuiResources( hProcess, GR_GDIOBJECTS);
  1664. if ((MaxGdi != 0) && (GdiCount > MaxGdi))
  1665. {
  1666. LERROR("GDI Objects exceeding standards!!!...[%d][%d]", MaxGdi, GdiCount);
  1667. result = true;
  1668. }
  1669. CloseHandle( hProcess );
  1670. }
  1671. try
  1672. {
  1673. FMemSize = uSize;
  1674. plMemory->Caption = FormatFloat("##,##0", uSize) ;// + " KB";
  1675. plHandle->Caption = FormatFloat("##,##0", HandleCount);// + " EA";
  1676. plThread->Caption = FormatFloat("##,##0", ThreadCount);// + " EA";
  1677. plGdi->Caption = FormatFloat("##,##0", GdiCount) ;// + " EA";
  1678. } catch (Exception &e) {}
  1679. return result;
  1680. }
  1681. //---------------------------------------------------------------------------
  1682. int TFrmMain::LogWrite(int ALogKind, char *AFmt, ...)
  1683. {
  1684. va_list ap;
  1685. int cnt = 0;
  1686. char szFmtData[MAX_LOG_BUFFER];
  1687. AnsiString sLogKind;
  1688. bool bLog = false;
  1689. switch(ALogKind)
  1690. {
  1691. case eLOG_INFO : bLog = g_LogCfg.Info; sLogKind = " [INF] "; break;
  1692. case eLOG_DATA : bLog = g_LogCfg.Data; sLogKind = " [DAT] "; break;
  1693. case eLOG_ERROR : bLog = g_LogCfg.Error; sLogKind = " [ERR] "; break;
  1694. case eLOG_WARNING: bLog = g_LogCfg.Warning; sLogKind = " [WAN] "; break;
  1695. case eLOG_DEBUG : bLog = g_LogCfg.Debug; sLogKind = " [DBG] "; break;
  1696. case eLOG_DETAIL : bLog = g_LogCfg.Detail; sLogKind = " [DET] "; break;
  1697. }
  1698. if (!bLog) return -1;
  1699. try
  1700. {
  1701. va_start(ap, AFmt);
  1702. cnt = vsprintf(szFmtData, AFmt, ap);
  1703. va_end(ap);
  1704. ITSLog->LogWrite(NULL, ALogKind, szFmtData);
  1705. IPC_LOG_MESSAGE *pLog = &FLogMsg;//new IPC_LOG_MESSAGE;
  1706. if (pLog)
  1707. {
  1708. pLog->Kind = ALogKind;
  1709. pLog->Flag = 0;
  1710. pLog->Len = strlen(szFmtData);
  1711. pLog->Tm = Now();
  1712. memset(pLog->Msg, 0x00, sizeof(pLog->Msg));
  1713. sprintf(pLog->Msg, "%sMAIN %s", sLogKind.c_str(), szFmtData);
  1714. DWORD dwResult = 0;
  1715. LRESULT lResult = SEND_LOGMSG(FrmSysLog->Handle, WM_LOG_DISPLAY, pLog, NULL, SMTO_NORMAL, 2000, dwResult);
  1716. if (lResult == 0)
  1717. {
  1718. dwResult = GetLastError();
  1719. if (dwResult == ERROR_TIMEOUT)
  1720. {
  1721. }
  1722. //SAFE_DELETE(pLog);
  1723. }
  1724. }
  1725. }
  1726. catch(Exception &e)
  1727. {
  1728. }
  1729. return cnt;
  1730. }
  1731. //---------------------------------------------------------------------------
  1732. void __fastcall TFrmMain::Panel16DblClick(TObject *Sender)
  1733. {
  1734. CheckResource((g_AppCfg.MaxMemory * 1024), g_AppCfg.MaxHandle, g_AppCfg.MaxThread, g_AppCfg.MaxGdi);
  1735. }
  1736. //---------------------------------------------------------------------------
  1737. void __fastcall TFrmMain::plStateDbDblClick(TObject *Sender)
  1738. {
  1739. SendDbThreadMessage(WM_MASTER_IMAGE_SYMBOL, NULL, NULL);
  1740. Sleep(500);
  1741. SendDbThreadMessage(WM_MASTER_FORM, NULL, NULL);
  1742. Sleep(500);
  1743. SendDbThreadMessage(WM_MASTER_VMS_IFSC, NULL, NULL);
  1744. }
  1745. //---------------------------------------------------------------------------
  1746. void __fastcall TFrmMain::plStateActionDblClick(TObject *Sender)
  1747. {
  1748. ProvideEvent(provide_event, NULL, NULL);
  1749. }
  1750. //---------------------------------------------------------------------------
  1751. void __fastcall TFrmMain::LoadOldVmsInfo()
  1752. {
  1753. //LINFO("Old Protocol Version VMS Information Loading...");
  1754. TStringList *slFile = NULL;
  1755. String sCfgFile = g_sCfgDir + "OldVMS.inf";
  1756. try
  1757. {
  1758. slFile = new TStringList;
  1759. slFile->Clear();
  1760. slFile->LoadFromFile(sCfgFile);
  1761. int ii;
  1762. unsigned int hn, ln;
  1763. BYTE chn, cln, val;
  1764. char szData[2048];
  1765. BYTE RxBuff[VMS_MAX_PACKET_SIZE];
  1766. int RxLen;
  1767. RxLen = 0;
  1768. memset(RxBuff, 0x00, sizeof(RxBuff));
  1769. for (ii = 0; ii < slFile->Count; ii++)
  1770. {
  1771. AnsiString sVmsId = slFile->Strings[ii].Trim();
  1772. if (sVmsId == "") continue;
  1773. if (sVmsId == "\r\n") continue;
  1774. TVmsCtlr *pObj = FindVms(sVmsId);
  1775. if (pObj)
  1776. {
  1777. pObj->FIsOldProtocol = true;
  1778. //LINFO("%s : 이전 버전 프로토콜 사용", sVmsId.c_str());
  1779. }
  1780. else
  1781. {
  1782. //LINFO("%s : 이전 버전 프로토콜 사용(찾을수 없음)", sVmsId.c_str());
  1783. }
  1784. }
  1785. }
  1786. catch(Exception &e)
  1787. {
  1788. LERROR("LoadOldVmsInfo Exception: %s", AnsiString(e.Message).c_str());
  1789. }
  1790. delete slFile;
  1791. }
  1792. //---------------------------------------------------------------------------
  1793. void __fastcall TFrmMain::LoadFtpVmsInfo()
  1794. {
  1795. //LINFO("FTP Download VMS Information Loading...");
  1796. TStringList *slFile = NULL;
  1797. String sCfgFile = g_sCfgDir + "FtpVMS.inf";
  1798. try
  1799. {
  1800. slFile = new TStringList;
  1801. slFile->Clear();
  1802. slFile->LoadFromFile(sCfgFile);
  1803. int ii;
  1804. unsigned int hn, ln;
  1805. BYTE chn, cln, val;
  1806. char szData[2048];
  1807. BYTE RxBuff[VMS_MAX_PACKET_SIZE];
  1808. int RxLen;
  1809. RxLen = 0;
  1810. memset(RxBuff, 0x00, sizeof(RxBuff));
  1811. for (ii = 0; ii < slFile->Count; ii++)
  1812. {
  1813. AnsiString sVmsId = slFile->Strings[ii].Trim();
  1814. if (sVmsId == "") continue;
  1815. if (sVmsId == "\r\n") continue;
  1816. TVmsCtlr *pObj = FindVms(sVmsId);
  1817. if (pObj)
  1818. {
  1819. pObj->FIsFtpDownload = true;
  1820. pObj->FBmpDownload = true; //FTP로 다운로드 하는 경우 이미지로 전송되어야함
  1821. //LINFO("%s : FTP Downloaod 사용", sVmsId.c_str());
  1822. }
  1823. else
  1824. {
  1825. //LINFO("%s : FTP Downloaod 사용(찾을수 없음)", sVmsId.c_str());
  1826. }
  1827. }
  1828. }
  1829. catch(Exception &e)
  1830. {
  1831. LERROR("LoadFtpVmsInfo Exception: %s", AnsiString(e.Message).c_str());
  1832. }
  1833. delete slFile;
  1834. }
  1835. //---------------------------------------------------------------------------
  1836. void __fastcall TFrmMain::LoadFontVmsInfo()
  1837. {
  1838. //LINFO("Protocol Font Name VMS Information Loading...");
  1839. TStringList *slFile = NULL;
  1840. String sCfgFile = g_sCfgDir + "FontNameVMS.inf";
  1841. try
  1842. {
  1843. slFile = new TStringList;
  1844. slFile->Clear();
  1845. slFile->LoadFromFile(sCfgFile);
  1846. int ii;
  1847. unsigned int hn, ln;
  1848. BYTE chn, cln, val;
  1849. char szData[2048];
  1850. BYTE RxBuff[VMS_MAX_PACKET_SIZE];
  1851. int RxLen;
  1852. RxLen = 0;
  1853. memset(RxBuff, 0x00, sizeof(RxBuff));
  1854. for (ii = 0; ii < slFile->Count; ii++)
  1855. {
  1856. AnsiString sVmsId = slFile->Strings[ii].Trim();
  1857. if (sVmsId == "") continue;
  1858. if (sVmsId == "\r\n") continue;
  1859. TVmsCtlr *pObj = FindVms(sVmsId);
  1860. if (pObj)
  1861. {
  1862. pObj->FIsProtolFontName = true;
  1863. //LINFO("%s : Font Name Protocol 사용", sVmsId.c_str());
  1864. }
  1865. else
  1866. {
  1867. //LINFO("%s : Font Name Protocol 사용(찾을수 없음)", sVmsId.c_str());
  1868. }
  1869. }
  1870. }
  1871. catch(Exception &e)
  1872. {
  1873. LERROR("LoadFontVmsInfo Exception: %s", AnsiString(e.Message).c_str());
  1874. }
  1875. delete slFile;
  1876. }
  1877. //---------------------------------------------------------------------------
  1878. void __fastcall TFrmMain::LoadBitmapVmsInfo()
  1879. {
  1880. //LINFO("Bitmap Form VMS Information Loading...");
  1881. TStringList *slFile = NULL;
  1882. String sCfgFile = g_sCfgDir + "BitmapVMS.inf";
  1883. try
  1884. {
  1885. slFile = new TStringList;
  1886. slFile->Clear();
  1887. slFile->LoadFromFile(sCfgFile);
  1888. int ii;
  1889. unsigned int hn, ln;
  1890. BYTE chn, cln, val;
  1891. char szData[2048];
  1892. BYTE RxBuff[VMS_MAX_PACKET_SIZE];
  1893. int RxLen;
  1894. RxLen = 0;
  1895. memset(RxBuff, 0x00, sizeof(RxBuff));
  1896. for (ii = 0; ii < slFile->Count; ii++)
  1897. {
  1898. AnsiString sVmsId = slFile->Strings[ii].Trim();
  1899. if (sVmsId == "") continue;
  1900. if (sVmsId == "\r\n") continue;
  1901. TVmsCtlr *pObj = FindVms(sVmsId);
  1902. if (pObj)
  1903. {
  1904. pObj->FBmpDownload = true;
  1905. //LINFO("%s : Bitmap Form 사용", sVmsId.c_str());
  1906. }
  1907. else
  1908. {
  1909. //LINFO("%s : Bitmap Form 사용(찾을수 없음)", sVmsId.c_str());
  1910. }
  1911. }
  1912. }
  1913. catch(Exception &e)
  1914. {
  1915. LERROR("LoadBitmapVmsInfo Exception: %s", AnsiString(e.Message).c_str());
  1916. }
  1917. delete slFile;
  1918. }
  1919. //---------------------------------------------------------------------------
  1920. TVmsCtlr* __fastcall TFrmMain::FindVms(AnsiString AVmsId)
  1921. {
  1922. VmsIterator it;
  1923. for(it=VmsManager->FLists.FMapObject.begin(); it != VmsManager->FLists.FMapObject.end(); ++it)
  1924. {
  1925. TVmsCtlr *pObj = (TVmsCtlr*)it->second;
  1926. if (pObj->VmsId.AnsiCompare(AVmsId) == 0)
  1927. {
  1928. return pObj;
  1929. }
  1930. }
  1931. return NULL;
  1932. }
  1933. //---------------------------------------------------------------------------