123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881 |
- /****************************************************************************
- * @source : FrmVmsOprMainF.cpp
- * @description : 어플리케이션 메인폼
- ****************************************************************************
- * DATE AUTHOR DESCRIPTION
- * --------------------------------------------------------------------------
- * 2011/11/22 정승호 최초작성
- *
- ****************************************************************************/
- //---------------------------------------------------------------------------
- #include <vcl.h>
- #include "ITSSkinF.h"
- #include "ITSUtilF.h"
- #pragma hdrstop
- #include "FrmVmsOprMainF.h"
- #include "TThreadPollingF.h"
- #include "FrmInitializeF.h" // 프로그램 초기화화면
- //#include "CDSVmsTrafficF.h"
- //---------------------------------------------------------------------------
- #include "VMS0500MF.h"
- #include "VMS0100MF.h"
- #include "VMS0200MF.h"
- #include "VMS0300MF.h"
- //#include "VMS0400MF.h"
- #include "VMS0600MF.h"
- //#include "VMS0000MF.h"
- #include "VMSM100MF.h"
- //#include "VMSM200MF.h"
- //#include "VMSM210MF.h"
- #include "VMSM400MF.h"
- #include "VMSM410MF.h"
- #include "VMSM420MF.h"
- #include "VMSM500MF.h"
- #include "VMSM600MF.h"
- #include "VMSM700MF.h"
- #include "VMSM800MF.h"
- #include "VMSM900MF.h"
- //---------------------------------------------------------------------------
- #ifndef ULONG_PTR
- #define ULONG_PTR unsigned long *
- #endif
- #include <stdio.h>
- #include <string.h>
- #include <list>
- #include <map>
- #define STRICT
- #include <windows.h>
- #include <algorithm>
- using std::min;
- using std::max;
- #include "gdiplus.h"
- #include "GdiplusBase.h" //항상 넣어 둔다.
- class CGdiPlusStarter
- {
- private:
- ULONG_PTR m_gpToken;
- public:
- bool m_bSuccess;
- CGdiPlusStarter()
- {
- ::CoInitialize(NULL);
- Gdiplus::GdiplusStartupInput gpsi;
- m_bSuccess = (Gdiplus::GdiplusStartup(&m_gpToken, &gpsi, NULL) == Gdiplus::Ok);
- }
- ~CGdiPlusStarter()
- {
- Gdiplus::GdiplusShutdown(m_gpToken);
- ::CoUninitialize();
- }
- };
- CGdiPlusStarter g_gps;
- //---------------------------------------------------------------------------
- #pragma package(smart_init)
- #pragma link "cxClasses"
- #pragma link "cxContainer"
- #pragma link "cxControls"
- #pragma link "cxEdit"
- #pragma link "cxGraphics"
- #pragma link "cxHint"
- #pragma link "cxLabel"
- #pragma link "cxLookAndFeelPainters"
- #pragma link "cxLookAndFeels"
- #pragma link "cxMaskEdit"
- #pragma link "cxPC"
- #pragma link "cxPCdxBarPopupMenu"
- #pragma link "cxSpinEdit"
- #pragma link "cxTextEdit"
- #pragma link "dxBar"
- #pragma link "dxCustomHint"
- #pragma link "dxRibbon"
- #pragma link "dxRibbonGallery"
- #pragma link "dxRibbonSkins"
- #pragma link "dxRibbonStatusBar"
- #pragma link "dxScreenTip"
- #pragma link "dxSkinBlack"
- #pragma link "dxSkinBlue"
- #pragma link "dxSkinCaramel"
- #pragma link "dxSkinChooserGallery"
- #pragma link "dxSkinCoffee"
- #pragma link "dxSkinDarkRoom"
- #pragma link "dxSkinDarkSide"
- #pragma link "dxSkinFoggy"
- #pragma link "dxSkinGlassOceans"
- #pragma link "dxSkiniMaginary"
- #pragma link "dxSkinLilian"
- #pragma link "dxSkinLiquidSky"
- #pragma link "dxSkinLondonLiquidSky"
- #pragma link "dxSkinMcSkin"
- #pragma link "dxSkinMoneyTwins"
- #pragma link "dxSkinOffice2007Black"
- #pragma link "dxSkinOffice2007Blue"
- #pragma link "dxSkinOffice2007Green"
- #pragma link "dxSkinOffice2007Pink"
- #pragma link "dxSkinOffice2007Silver"
- #pragma link "dxSkinOffice2010Black"
- #pragma link "dxSkinOffice2010Blue"
- #pragma link "dxSkinOffice2010Silver"
- #pragma link "dxSkinsCore"
- #pragma link "dxSkinscxPCPainter"
- #pragma link "dxSkinsdxBarPainter"
- #pragma link "dxSkinsdxRibbonPainter"
- #pragma link "dxSkinSeven"
- #pragma link "dxSkinsForm"
- #pragma link "dxSkinSharp"
- #pragma link "dxSkinSilver"
- #pragma link "dxSkinStardust"
- #pragma link "dxStatusBar"
- #pragma link "dxTabbedMDI"
- #pragma link "IdAntiFreeze"
- #pragma link "IdAntiFreezeBase"
- #pragma link "IdBaseComponent"
- #pragma resource "*.dfm"
- TFrmVmsOprMain *FrmVmsOprMain = NULL;
- #define MAX_EXEPROGRAM 5
- ST_RUNPROGRAM g_RunProgram[MAX_EXEPROGRAM+1] = {
- {"TFrmVmsLogStts", "VmsLogStts.exe", "VMS상태이력조회"},
- {"TFrmVmsLogMsg", "VmsLogMsg.exe", "VMS제공이력조회"},
- {"TFrmVmsLogCtl", "VmsLogCtl.exe", "VMS제어이력조회"},
- {"TFrmVmsLogDnld", "VmsLogDnld.exe", "VMS다운로드이력조회"},
- {"TFrmVmsCmraViewer", "VmsCamViewer.exe", "VMS영상모니터링"},
- {"", "", ""},
- };
- //---------------------------------------------------------------------------
- __fastcall TFrmVmsOprMain::TFrmVmsOprMain(TComponent* Owner)
- : TdxCustomRibbonForm(Owner)//TdxCustomRibbonForm(Owner)//TForm(Owner)
- {
- FLogoutTick = 0;
- DoubleBuffered = true;
- g_AppCfg.lMainWinHandle = (long)Handle;
- StartJobThread();
- while(!PostJobMessage(WM_THREAD, WP_PING)) ;
- Application->OnException = OnAppException;
- ::CoInitialize(NULL);
- //Caption = g_AppCfg.sTitle;
- ITSSkin_Initialize(Application, "EN");
- ITSSkin_Menu(this);
- String sCaption = "";
- ReadConfigInfo(g_AppCfg.sConfigFile, "APPLICATION", "CAPTION", sCaption);
- ITSSkin_Caption(sCaption == "1" ? true : false);
- if (BarVmsSys1->Visible) BarVmsSys1->Visible = false;
- if (BarVmsMngr2->Visible) BarVmsMngr2->Visible = false;
- if (BarVmsSchMngr4->Visible) BarVmsSchMngr4->Visible = false;
- RVMSH400M->Visible = ivNever;
- TabVmsConfig->Visible = false;
- NVMSM300M->Visible = ivNever; //VMS정보제공축관리
- NVMSM310M->Visible = ivNever; //VMS정보제공축설정
- NVMSM410M->Visible = ivNever;
- NVMSM420M->Visible = ivNever;
- RVMSH400M->Visible = ivNever;
- NVMSM800M->Visible = ivNever;
- BarVmsSchMngr3->Visible = false;
- BarVmsSys1->Visible = false;
- Ribbon->ShowTabGroups = true; // 메뉴탭 show/hide
- Ribbon->QuickAccessToolbar->Visible = false;
- //Ribbon->ApplicationButton->Visible = false;
- Ribbon->SupportNonClientDrawing = true;
- Ribbon->EnableTabAero = true;
- TabVmsSystem->Active = true;
- SetColorScheme(g_AppCfg.sSkinName);
- //SetColorScheme("Blue");
- CMM_SetFormPosition(g_AppCfg.bSaveForm);
- CMM_LoadForm(g_sFormsDir, this);
- FVmsServerState = vms_normal;
- TmrOnShow->Enabled = false;
- TmrAppState->Enabled = false;
- }
- //---------------------------------------------------------------------------
- LONG __stdcall HelperExceptionFilter(struct _EXCEPTION_POINTERS * pContext)
- {
- LONG lRet = EXCEPTION_EXECUTE_HANDLER;
- DWORD dwRet = ERROR_SUCCESS;
- __try
- {
- Application->NormalizeTopMosts();
- Application->MessageBox(MSG005, MSG006, MB_OK|MB_ICONERROR|MB_APPLMODAL);
- Application->RestoreTopMosts();
- //TerminateProcess(GetCurrentProcess(), 0);
- }
- __finally
- {
- if(ERROR_SUCCESS != dwRet)
- {
- lRet = EXCEPTION_CONTINUE_SEARCH;
- }
- exit(0);
- }
- return lRet;
- }
- //---------------------------------------------------------------------------
- /*
- * Form이 메모리에서 생성될때 호출되는 생성자 이벤트 핸들러
- * arguments
- * Sender : event handler 객체
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::FormCreate(TObject *Sender)
- {
- //SetUnhandledExceptionFilter(HelperExceptionFilter);
- Application->ShowMainForm = false;
- try {
- Application->Icon->LoadFromResourceName(((unsigned int)HInstance), "MAINICON");
- } catch(...) { ShowMessage("LoadFromResourceName failed"); }
- //DeleteLogFiles((PTCHAR)g_sLogDir.c_str(), 30, (PTCHAR)"*.*");
- //WindowState = wsMaximized;
- // 종료조건이 있는경우..
- //Application->Terminate();
- //return;
- Application->ShowMainForm = true;
- Application->OnHint = OnAppHint;
- ImgAlarm->Visible = false;
- ImgAlarmNormal->Visible = true;
- }
- //---------------------------------------------------------------------------
- /*
- * Form을 보여줄때 호출되는 event 메서드이다.
- * arguments
- * Sender : event handler 객체
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::FormShow(TObject *Sender)
- {
- Application->ProcessMessages();
- g_AppCfg.lMainWinHandle = (long)Handle;
- /*
- * 프로그램 초기화 작업
- */
- InitStatusBar();
- if (g_pLOGIN)
- {
- GetUserMenuRight(g_pLOGIN->sUserId, g_pLOGIN->sUserRightId);
- }
- TmrOnShow->Enabled = true;
- }
- //---------------------------------------------------------------------------
- /*
- * 프로그램 기동후 최초에 수행된다.
- * arguments
- *
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::TmrOnShowTimer(TObject *Sender)
- {
- TmrOnShow->Enabled = false;
- Application->ProcessMessages();
- //폴링작업 객체 초기화
- FPollTraffic.Cycle = (60*1000*2)+11; // 정보제공구간소통정보
- FPollVmsMsg.Cycle = (60*1000*2)+15; // VMS Message
- FPollVmsState.Cycle = (60*1000*2)+ 1; // 시설물상태정보
- FPollPrcsState.Cycle = (60*1000*2)+ 3; // 프로세스상태정보
- FPollIncident.Cycle = (60*1000*2)+ 5; // 돌발정보
- FPollTraffic.IsPolling = true;
- FPollVmsMsg.IsPolling = true;
- FPollVmsState.IsPolling = true;
- FPollPrcsState.IsPolling = true;
- FPollIncident.IsPolling = true;
- TFrmInitialize *FrmInitialize = new TFrmInitialize(this);
- FrmInitialize->FThreadId = g_AppCfg.thr.dwThreadId;
- FrmInitialize->ShowModal();
- UpdateVmsCommStatus(true);
- int nPort = 4602;
- TItsProcess *pPrcs = ItsProcessManager->FLists.Find(g_AppCfg.sProcessId);
- if (pPrcs)
- {
- nPort = pPrcs->PRGM_PORT.ToIntDef(4602);
- }
- nPort += 1; //VMS운영단말은 DB에 저장되어 있지 않기 때문에 포트번호를 1 증가시켜 통신한다.
- int nResult = VComm_Initialize((long)Handle, g_AppCfg.sProcessId, "UOT", nPort, g_AppCfg.sLogDay);
- if (VERR_NONE != nResult)
- {
- Application->MessageBox(MSG007, MSG008, MB_OK|MB_ICONERROR|MB_APPLMODAL);
- g_AppCfg.bAppClose = true;
- Close();
- return;
- }
- FOR_STL(TItsProcess*, pObj, ItsProcessManager->FLists)
- {
- if (pObj->DEL_YN == "Y") continue;
- AnsiString sProcessId = AnsiString(pObj->SYST_ID);
- AnsiString sSystemTp = AnsiString(pObj->SYST_TYPE);
- AnsiString sIpAddress = AnsiString(pObj->SYST_IP_1);
- AnsiString sUdpPort = AnsiString(pObj->PRGM_PORT);
- if (VComm_AddProcess(sProcessId, sSystemTp, sIpAddress, sUdpPort) >= 0)
- {
- if ("UOT" == sSystemTp)
- {
- nPort = sUdpPort.ToIntDef(0);
- VComm_AddProcess(sProcessId, sSystemTp, sIpAddress, AnsiString(nPort+1));
- }
- }
- }
- if (VERR_NONE != VComm_Open())
- {
- Application->MessageBox(MSG007, MSG008, MB_OK|MB_ICONERROR|MB_APPLMODAL);
- g_AppCfg.bAppClose = true;
- Close();
- return;
- }
- UpdateInterCommStatus(true);
- Application->ProcessMessages();
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex = ITSDb_IsOpen() ? 8 : 7;
- //TODO NITS0000MClick((TObject *)NITS0000M); //메인화면을 프로그램 기동과 동시에 호출하는 경우
- #if 0
- if (g_AppCfg.AutoLogout.LogoutExit)
- {
- Application->MessageBox(L"이전 프로그램은 자동로그아웃으로 종료되었습니다.\r\n프로그램을 실행합니다.",
- L"프로그램 실행정보", MB_OK|MB_ICONQUESTION|MB_APPLMODAL);
- }
- #endif
- g_AppCfg.AutoLogout.LogoutExit = false;
- TmrAppState->Enabled = true;
- TmrPolling->Enabled = true;
- TmrCommTimeout->Enabled = true;
- INT_VMS_STATE_REQ Req;
- memset((char*)&Req, 0x00, sizeof(Req));
- Req.Count = 0;
- Req.Type = vms_state_all;
- VComm_VmsStateReq(&Req);
- }
- //---------------------------------------------------------------------------
- /*
- * 작업스레드 생성
- * arguments
- *
- * return
- * void
- */
- bool __fastcall TFrmVmsOprMain::StartJobThread()
- {
- TThreadPolling *pPollingThread = new TThreadPolling(false);
- if (pPollingThread)
- {
- pPollingThread->OnTerminate = OnPollingThreadDone;
- g_AppCfg.thr.pThread = (TThread *)pPollingThread;
- g_AppCfg.thr.dwThreadId = pPollingThread->ThreadID;
- g_AppCfg.thr.nHandle = pPollingThread->Handle;
- //pPollingThread->Resume();
- return true;
- }
- return false;
- }
- //---------------------------------------------------------------------------
- /*
- * 작업스레드 종료
- * arguments
- *
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::TerminateJobThread()
- {
- if (g_AppCfg.thr.bRunning)
- {
- PostJobMessage(WM_THREAD, WM_QUIT);
- }
-
- Sleep(500);
- try
- {
- if (g_AppCfg.thr.bRunning)
- {
- TThreadPolling *pThread = (TThreadPolling *)g_AppCfg.thr.pThread;
- pThread->Terminate();
- //pThread->WaitFor();
- }
- g_AppCfg.thr.pThread = NULL;
- g_AppCfg.thr.dwThreadId = 0;
- g_AppCfg.thr.nHandle = 0;
- g_AppCfg.thr.bRunning = false;
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- /*
- * Form이 닫히기 전에 프로그램의 종료여부를 확인한다.
- * arguments
- *
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::FormCloseQuery(TObject *Sender, bool &CanClose)
- {
- // 폼이 닫히기 전에 수행해야 할 모뮬 기술
- // 프로그램 종료를 사용자가 확인할 수 있도록...
- if (!g_AppCfg.bAppClose)
- {
- #if 0
- String strMsg;
- strMsg = "";
- strMsg = "[ " + g_AppCfg.sTitle + " ]\r\n\n";
- strMsg+= MSG009;
- if (Application->MessageBox(strMsg.c_str(), String(MSG010).c_str(), MB_YESNO|MB_ICONQUESTION) == IDYES)
- {
- /*
- * 화면관련 작업을 못하도록 여기에 코드를 적자...
- */
- ITSDb_ApplicationTerm();
- g_AppCfg.bAppClose = true;
- }
- #else
- ITSDb_ApplicationTerm();
- g_AppCfg.bAppClose = true;
- #endif
- CanClose = false;
- }
- }
- //---------------------------------------------------------------------------
- /*
- * Form을 닫을때 호출되는 event 메서드
- * arguments
- * Sender : event handler 객체
- * Action : TCloseAction 객체
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::FormClose(TObject *Sender, TCloseAction &Action)
- {
- CommClose();
- Action = caFree;
- }
- //---------------------------------------------------------------------------
- /*
- * 닫기버튼 이나 x버튼 클릭시 공통으로 처리하는 로직이들어간다..
- * Form과 DataModule class를 delete시킨다.
- * arguments
- *
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::CommClose()
- {
- try
- {
- VComm_Close();
- CloseAllWindow();
- ITSSkin_Term();
- CMM_SaveForm(g_sFormsDir, this);
- WriteConfigInfo(g_AppCfg.sConfigFile, "APPLICATION", "LOGDAY", Now().FormatString("dd"));
- ::CoUninitialize();
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- /*
- * 열려있는 모든 Form Window들을 닫는다.
- * parameter
- * Sender : Event를 보낸 객체
- * return
- * None
- */
- void __fastcall TFrmVmsOprMain::CloseAllWindow()
- {
- int ii;
- if (g_AppCfg.bTermChildProg)
- {
- // 실행시킨 프로그램을 종료시킨다.
- for (ii = 0; ii < MAX_EXEPROGRAM; ii++)
- {
- if (g_RunProgram[ii].AClassName == "")
- continue;
- TermItsProgram(g_RunProgram[ii].AClassName, "");
- }
- }
- //실행중인 화면을 종료 시킨다.
- try {
- for (ii = 0; ii < Screen->FormCount; ii++)
- {
- if (Screen->Forms[ii] != this)
- {
- if (::IsWindow(Screen->Forms[ii]->Handle))
- {
- String sFormName = Screen->Forms[ii]->Name;
- if (sFormName == "ITSSkin") continue;
- if (sFormName == "FrmSkin") continue;
- if (Screen->Forms[ii]->Owner == this ||
- Screen->Forms[ii]->Owner == Application)
- {
- Screen->Forms[ii]->Close();
- WaitForSingleObject(Screen->Forms[ii]->Handle, 500);
- }
- }
- }
- }
- } catch(...) {}
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::CloseChildWindow()
- {
- int ii;
- //실행중인 화면을 종료 시킨다.
- try {
- for (ii = 0; ii < Screen->FormCount; ii++)
- {
- if (Screen->Forms[ii] != this)
- {
- if (::IsWindow(Screen->Forms[ii]->Handle))
- {
- String sFormName = Screen->Forms[ii]->Name;
- if (sFormName == "ITSSkin") continue;
- if (sFormName == "FrmSkin") continue;
- if (Screen->Forms[ii]->Owner == this ||
- Screen->Forms[ii]->Owner == Application ||
- Screen->Forms[ii]->FormStyle == fsMDIChild)
- {
- Screen->Forms[ii]->Close();
- WaitForSingleObject(Screen->Forms[ii]->Handle, 500);
- }
- }
- }
- }
- } catch(...) {}
- }
- //---------------------------------------------------------------------------
- /*
- * 매1초 마다 주기적으로 실행되는 타이머
- * arguments
- * Sender : event handler 객체
- * return
- * void
- */
- void __fastcall TFrmVmsOprMain::TmrAppStateTimer(TObject *Sender)
- {
- /*
- * 타이머가 1초간격으로 응용프로그램의 상태를 체크하고
- * 응용프로그램의 상태를 주기적으로 체크하여 필요한 조치를 수행한다.
- */
- if (g_AppCfg.bAppClose)
- {
- TmrAppState->Enabled = false;
- TmrPolling->Enabled = false;
- UserLogout(); // 로그아웃
- TerminateJobThread();
- ITSDb_Close();
- Close(); // 응용프로그램 종료
- }
- else
- {
- TmrAppState->Enabled = false;
- UpdateStatusBar();
- if (g_AppCfg.AutoLogout.Enabled)
- {
- FLogoutTick++;
- if (FLogoutTick > (g_AppCfg.AutoLogout.IntervalMin*60))
- {
- //자동로그아웃처리
- g_AppCfg.bAppClose = true;
- g_AppCfg.AutoLogout.LogoutExit = true;
- }
- }
- TmrAppState->Enabled = true;
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::UpdateInterCommStatus(bool AOk)
- {
- int nImgIdx = 8;
- if (AOk == false) nImgIdx = 7;
- if (((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbComm]->PanelStyle)->ImageIndex != nImgIdx)
- {
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbComm]->PanelStyle)->ImageIndex = nImgIdx;
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::UpdateVmsCommStatus(bool ADb)
- {
- if (ADb)
- {
- FOR_STL(TItsProcess*, pPrcs, ItsProcessManager->FLists)
- {
- if (pPrcs->SYST_TYPE == "VMS")
- {
- if (pPrcs->FCommStatus == "1")
- {
- FVmsServerState = vms_normal;
- }
- else
- {
- FVmsServerState = vms_error;
- }
- break;
- }
- }
- }
- int nImgIdx = 8;
- if (FVmsServerState == vms_error) nImgIdx = 7;
- if (((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbVmsComm]->PanelStyle)->ImageIndex != nImgIdx)
- {
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbVmsComm]->PanelStyle)->ImageIndex = nImgIdx;
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::UpdateStatusBar()
- {
- try
- {
- dxStatusBar->Panels->Items[isbTime]->Text = Now().FormatString(STR_DATETIME);
- #if 0
- if (ITSDb_IsOpen())
- {
- if (((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex != 8)
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex = 8;
- }
- else
- {
- if (((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex != 7)
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex = 7;
- }
- #endif
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::DebugMsg(String AMsg)
- {
- dxStatusBar->Panels->Items[isbMsg]->Text = " " + AMsg;
- dxStatusBar->Panels->Items[isbMsg]->StatusBarControl->Refresh();
- TmrDebugHide->Enabled = false;
- TmrDebugHide->Enabled = true;
- //if (g_AppCfg.bDebug) ITSUtil_Trace(AnsiString("VMS_OP: " + AMsg).c_str());
- LOGINFO(AnsiString(AMsg).c_str());
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::TmrDebugHideTimer(TObject *Sender)
- {
- dxStatusBar->Panels->Items[isbMsg]->Text = "";
- dxStatusBar->Panels->Items[isbMsg]->StatusBarControl->Refresh();
- TmrDebugHide->Enabled = false;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::InitStatusBar()
- {
- try
- {
- dxStatusBar->Panels->Items[isbGisPos]->Text = "";
- dxStatusBar->Panels->Items[isbTime]->Text = Now().FormatString(STR_DATETIME);//CFUtil_CurrentDateTime().FormatString(STR_DATETIME);
- if (g_pLOGIN)
- {
- dxStatusBar->Panels->Items[isbUser]->Text = g_pLOGIN->sUserId;
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbUser]->PanelStyle)->ImageIndex = 9;
- }
- dxStatusBar->Panels->Items[isbHint]->Text = "";
- dxStatusBar->Panels->Items[isbMsg]->Text = "";
-
- UpdateStatusBar();
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- bool __fastcall TFrmVmsOprMain::GetUserMenuRight(String AUserId, String AUserRight)
- {
- String sQry;
- TADOQuery *pADO = NULL;
- try
- {
- sQry = "SELECT OPERSYST_MENU_ID \r\n"
- " FROM TB_GROP_MENU_ATHR \r\n"
- " WHERE ATHR_YN = 'N' \r\n"
- " AND GROP_ID = (SELECT GROP_ID \r\n"
- " FROM TB_USER_INFR \r\n"
- " WHERE USER_ID = :p01) \r\n";
- try
- {
- pADO = new TADOQuery(NULL);
- pADO->Close();
- pADO->Connection = ITSDb_GetConnection();
- ITSDb_SQLText(pADO, sQry);
- ITSDb_SQLBind(pADO, "p01", AUserId);
- ITSDb_SQLOpen(pADO);
- for( ; !pADO->Eof; pADO->Next())
- {
- String sMenuId = pADO->FieldByName("OPERSYST_MENU_ID")->AsString;
- try
- {
- int nCompnentCnt = this->ComponentCount;
- for (int ii = 0; ii < nCompnentCnt; ii++)
- {
- String sClassName = this->Components[ii]->ClassName();
- if(sClassName == "TdxBarLargeButton")
- {
- TdxBarLargeButton *pMenu = (TdxBarLargeButton *)this->Components[ii];
- if (pMenu->Name == sMenuId)
- {
- pMenu->Enabled = false;
- break;
- }
- }
- }
- }
- catch(...)
- {
- }
- }
- }
- catch (Exception &exception)
- {
- throw Exception(String(exception.ClassName()) + exception.Message);
- }
- catch (...)
- {
- //ITSDb_GetConnection()->RollbackTrans();
- throw Exception(MSG011);
- }
- }
- __finally
- {
- if (pADO)
- {
- pADO->Close();
- delete pADO;
- }
- }
- return true;
- }
- //---------------------------------------------------------------------------
- HWND __fastcall TFrmVmsOprMain::FindChildWindow(String sFormName)
- {
- int nFormCnt = Screen->FormCount;
- for (int ii = 0; ii < nFormCnt; ii++)
- {
- TForm *pForm = Screen->Forms[ii];
- String sTmpFormName = pForm->Name.SubString(1, sFormName.Length());
- if (sTmpFormName == sFormName)
- {
- return pForm->Handle;
- }
- }
- return NULL;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnSkinClick(TObject *Sender)
- {
- TdxBarButton *pMenu = (TdxBarButton*)Sender;
- try {
- dxSkinController1->SkinName = pMenu->Caption;
- dxSkinController1->Refresh();
- //ITSSkin_SetName(dxSkinController1->SkinName);
- } catch(...) {}
-
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::TmrPollingTimer(TObject *Sender)
- {
- TmrPolling->Enabled = false;
- DWORD dwTick = GetTickCount();
- UpdateThreadStatus(true); //작업스레드 실행 확인
- // 프로세스상태정보
- if (FPollPrcsState.IsPolling && FPollPrcsState.IsPollingTime(dwTick))
- {
- FPollPrcsState.Polling = dwTick;
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_00);
- DebugMsg(">>> Process Status Request");
- //LOGINFO("xxx Process Status Request");
- }
- // VMS상태정보
- if (FPollVmsState.IsPolling && FPollVmsState.IsPollingTime(dwTick))
- {
- FPollVmsState.Polling = dwTick;
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_01);
- DebugMsg(">>> VMS Status Request");
- //LOGINFO("xxx VMS Status Request");
- }
- // VMS Message
- if (FPollVmsMsg.IsPolling && FPollVmsMsg.IsPollingTime(dwTick))
- {
- FPollVmsMsg.Polling = dwTick;
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_02);
- DebugMsg(">>> VMS Display Message Request");
- //LOGINFO("xxx VMS Display Message Request");
- }
- #if 0
- // 소통정보
- if (FPollTraffic.IsPolling && FPollTraffic.IsPollingTime(dwTick))
- {
- FPollTraffic.Polling = dwTick;
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_03);
- DebugMsg(">>> Traffic Request");
- //LOGINFO("xxx Traffic Request");
- }
- // 돌발정보
- if (FPollIncident.IsPolling && FPollIncident.IsPollingTime(dwTick))
- {
- FPollIncident.Polling = dwTick;
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_05);
- DebugMsg(">>> Incident Request");
- //LOGINFO("xxx Incident Request");
- }
- #endif
- if (!g_AppCfg.bAppClose) TmrPolling->Enabled = true;
- }
- //---------------------------------------------------------------------------
- /*
- * 작업스레드로 작업 메시지를 전송한다.
- * arguments
- *
- * return
- * void
- */
- bool __fastcall TFrmVmsOprMain::PostJobMessage(UINT nMsg, int WParam/*=0*/, int LParam/*=0*/)
- {
- int nRes;
-
- //if (g_AppCfg.bDebug) ITSUtil_Trace("PostJobMessage: Msg: %02X, WParam: %02X, LParam: %02X", nMsg, WParam, LParam);
- if (g_AppCfg.thr.dwThreadId)
- {
- for (int ii = 0; ii < 3; ii++)
- {
- if (PostThreadMessageW(g_AppCfg.thr.dwThreadId, nMsg, WParam, LParam))
- {
- nRes = 0;
- return true;
- }
- else
- {
- nRes = GetLastError();
- if (ERROR_INVALID_THREAD_ID == nRes)
- {
- Sleep(500);
- continue;
- }
- }
- }
- }
- return false;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::dxSkinChooserGalleryItem1SkinChanged(TObject *Sender, const UnicodeString ASkinName)
- {
- g_AppCfg.sSkinName = ASkinName;
- WriteConfigInfo(g_AppCfg.sConfigFile, "APPLICATION", "SKINNAME", g_AppCfg.sSkinName);
- SetColorScheme(ASkinName);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::SetColorScheme(String ASkinName)
- {
- Ribbon->ColorSchemeName = ASkinName;
- dxSkinController1->SkinName = ASkinName;
- dxSkinController1->Refresh();
- dxTabbedMDIManager1->LookAndFeel->SkinName = ASkinName;
- dxStatusBar->Invalidate();
- //Panel1->Color = Ribbon->ColorScheme->GetPartColor(rfspRibbonForm);
- //Ribbon.ColorSchemeName := AName;
- //SkinChooserSelectSkinName(AName);
- //Panel1.Color := Ribbon.ColorScheme.GetPartColor(rfspRibbonForm);
- //dxStatusBar.Invalidate;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::ExecuteItsProgram(String AClassName, String AExeName, String AOption)
- {
- HWND hExeForm = FindWindow(AClassName.c_str(), NULL);
- if (hExeForm)
- {
- SetWindowPos(hExeForm, HWND_TOP, 0, 0, 0, 0, SWP_SHOWWINDOW | SWP_NOSIZE | SWP_NOMOVE);
- }
- else
- {
- String sExeName = "";
- String sExeParam= "";
- //if (!ReadConfigInfo(g_AppCfg.sConfigFile, "PROGRAM", AOption, sExeName))
- {
- sExeName = AExeName;
- sExeParam= g_pLOGIN->sUserId;
- }
- ShellExecute(Handle, NULL, sExeName.c_str(), sExeParam.c_str(), NULL, SW_SHOWNORMAL);
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::TermItsProgram(String AClassName, String AExeName)
- {
- HWND hExeForm = FindWindow(AClassName.c_str(), NULL);
- if (hExeForm)
- {
- POST_MSG(hExeForm, WM_CLOSE, 0, 0);
- }
- }
- //---------------------------------------------------------------------------
- /*
- * EXE 프로그램 실행시킴
- */
- void __fastcall TFrmVmsOprMain::OnRunProgramClick(TObject *Sender)
- {
- TdxBarLargeButton *pButton = (TdxBarLargeButton*)Sender;
- int nIdx = pButton->Tag;
- if (nIdx < 0 || nIdx >= MAX_EXEPROGRAM) return;
- if (g_RunProgram[nIdx].AClassName == "") return;
- ExecuteItsProgram(g_RunProgram[nIdx].AClassName, g_RunProgram[nIdx].AExeName, g_RunProgram[nIdx].AOption);
- }
- //---------------------------------------------------------------------------
- /*
- * Application Hint Display Event Handler
- * arguments
- *
- * return
- *
- */
- void __fastcall TFrmVmsOprMain::OnAppHint(TObject *Sender)
- {
- dxStatusBar->Panels->Items[isbHint]->Text = " " + Application->Hint;
- dxStatusBar->Panels->Items[isbHint]->StatusBarControl->Refresh();
- }
- //---------------------------------------------------------------------------
- /*
- * Application Exception Event Handler
- * arguments
- *
- * return
- *
- */
- void __fastcall TFrmVmsOprMain::OnAppException(TObject *Sender, Exception *exception)
- {
- //if (g_AppCfg.bDebug) ITSUtil_Trace("OnAppException");
- String sClassName = (NULL != Sender) ? Sender->ClassName() : String("Unknown_Class");
- String sErrMsg = (NULL != exception) ? exception->Message : String("Unknown_Error");
- String sError = sClassName + " : " + sErrMsg;
- //Application->ShowException(&exception);
- Application->NormalizeTopMosts();
- Application->MessageBox(sError.c_str(), MSG006, MB_OK|MB_ICONERROR|MB_APPLMODAL);
- Application->RestoreTopMosts();
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::UpdateThreadStatus(bool ARequest, bool APing/*=true*/)
- {
- return;
- try
- {
- if (APing) if (ARequest) PostJobMessage(WM_THREAD, WP_PING);
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbStatus]->PanelStyle)->ImageIndex = ARequest ? 7 : 8;
- dxStatusBar->Panels->Items[isbDb]->StatusBarControl->Refresh();
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::UpdateDbStatus(bool ASelect)
- {
- try
- {
- ((TdxStatusBarTextPanelStyle*)dxStatusBar->Panels->Items[isbDb]->PanelStyle)->ImageIndex = ASelect ? 7 : 8;
- dxStatusBar->Panels->Items[isbDb]->StatusBarControl->Refresh();
- }
- catch(...)
- {
- }
- }
- //---------------------------------------------------------------------------
- /*
- * Application Event Message Handler
- * arguments
- *
- * return
- *
- */
- void __fastcall TFrmVmsOprMain::ApplicationEvents1Message(tagMSG &Msg, bool &Handled)
- {
- switch(Msg.message)
- {
- case WM_THREAD:
- switch(Msg.wParam)
- {
- case WP_PING:
- UpdateThreadStatus(false); //스레드 핑 확인
- break;
- case WP_PARAM_TRAFFIC:
- break;
- case WP_DB_SELECT_START:
- UpdateDbStatus(true);
- break;
- case WP_DB_SELECT_OK:
- case WP_DB_SELECT_ERROR:
- case WP_DB_SELECT_CANCEL:
- UpdateDbStatus(false);
- if (Msg.wParam == WP_DB_SELECT_OK)
- {
- OnRefreshMessage(Msg.wParam, Msg.lParam);
- }
- break;
- }
- break;
- #if 0
- case WM_VCOMMDATA_RECV:
- OnUdpDataRecvMessage(Msg);
- UpdateInterCommStatus(true);
- break;
- #endif
- case WM_DATABASE_REFRESH:
- OnDatabaseMessage(Msg.wParam, Msg.lParam);
- break;
- case WM_PLUGINFORM:
- OnRefreshMessage(Msg.wParam, Msg.lParam);
- break;
- case WM_MOUSEMOVE:
- case WM_KEYDOWN:
- case WM_KEYUP:
- FLogoutTick = 0;
- break;
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnRefreshMessage(WPARAM AWParam, LPARAM ALParam)
- {
- HWND hWnd;
- if (AWParam == WP_DB_SELECT_OK)
- {
- DWORD dwTick = GetTickCount();
- switch(ALParam)
- {
- case LP_MSG_00: DebugMsg("<<< Process Status Request Completed."); FPollPrcsState.Polling = dwTick; break;
- case LP_MSG_01: DebugMsg("<<< VMS Status Request Completed."); FPollVmsState.Polling = dwTick; break;
- case LP_MSG_02: DebugMsg("<<< VMS Display Message Request Completed."); FPollVmsMsg.Polling = dwTick; break;
- case LP_MSG_03: DebugMsg("<<< Traffic Request Completed."); FPollTraffic.Polling = dwTick; break;
- case LP_MSG_05: DebugMsg("<<< Incident Request Completed."); FPollIncident.Polling = dwTick; break;
- }
- if (ALParam == LP_MSG_00)
- {
- UpdateVmsCommStatus(true);
- }
- else
- if (ALParam == LP_MSG_02)
- {
- RefreshVmsMessage(WM_VMS_FORM_REFRESH);
- }
- else
- if (ALParam == LP_MSG_05)
- {
- RefreshVmsMessage(WM_VMS_INCIDENT_REFRESH);
- }
- else
- {
- RefreshVmsMessage(WM_VMS_STATE_REFRESH);
- }
- #if 0
- if (NVMS0000M->Enabled)
- {
- hWnd = FindChildWindow("VMS0000M");
- if (hWnd) POST_MSG(hWnd, WM_MAINFORM, AWParam, ALParam);
- }
- #endif
- #if 0
- if (ALParam == LP_MSG_11)
- {
- //시설물 상태정보 업데이트
- ShowFacilityStatus();
- }
- #endif
- }
- else
- {
- LOGERROR("DB Thread failed: %02X[%02X]", ALParam, AWParam);
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnDatabaseMessage(WPARAM AWParam, LPARAM ALParam)
- {
- #if 0
- HWND hWnd;
- switch(AWParam)
- {
- case WP_MSG_01: //소통등급변경
- case WP_MSG_02: //돌발정보변경(오보/등록/해제)
- if (NITS0000M->Enabled)
- {
- hWnd = FindChildWindow("ITS0000M");
- if (hWnd) POST_MSG(hWnd, WM_MAINFORM, AWParam, ALParam);
- }
- break;
- case WP_MSG_03: //시설물 정보 변경
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_14);
- //hWnd = FindChildWindow("ITS0000M");
- //if (hWnd) POST_MSG(hWnd, WM_MAINFORM, AWParam, ALParam);
- break;
- case WP_MSG_04: // IDB0070M-휴일정보
- case WP_MSG_05: // FrmLinkGradeSet-구간등급변경
- case WP_MSG_06: // IDB0060M - 소통등급
- case WP_MSG_07: // IDB0050M -교통파라미터
- //NodeLinkChangeReq(AnsiString("UTP01")); //통합교통정보가공시스템으로 정보변경 내용을 전송
- break;
- case WP_MSG_09: // IDB0100M
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_09); //작업스레드에서 읽어 처리하도록 한다.
- break;
- case WP_MSG_14: // DSRM010M -DSRC-RSE 관리
- PostJobMessage(WM_THREAD, WP_PARAM_TRAFFIC, LP_MSG_14); //작업스레드에서 읽어 처리하도록 한다.
- break;
- default:
- LOGERROR("Unknown Database Msg: %02X[%02X]", ALParam, AWParam);
- break;
- }
- #endif
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnUdpDataRecvMessage(TMessage &Msg)
- {
- int nResult;
- IPCUDPMESSAGESTRUCT *RcvData = (IPCUDPMESSAGESTRUCT*)Msg.LParam;
- INT_SENDER *Sender = &RcvData->Sender;
- INT_PACKET *Pkt = &RcvData->Pkt;
- INT_HEAD *head = &Pkt->head;
- INT_DATA *data = &Pkt->data;
- char *pData = &data->Data[2];
- BYTE OpCode = (BYTE)data->Data[0];
- LOGINFO("*** OPR Client Req: %s.%d", VComm_ulong2ip(Sender->IP), Sender->Port);
- String sMsg = "";
- String sVmsNmbr = "";
- TmrCommTimeout->Enabled = false;
- //FVmsServerState = vms_normal;
- UpdateVmsCommStatus(false);
- UpdateInterCommStatus(true);
- if (head->OPCode == INT_OP_COMM_COMMON)
- {
- switch(OpCode)
- {
- case INT_OP_PG_STATE_RES:
- {
- DebugMsg("*** VMS Process Stauts Recvieved");
- INT_PG_STATE_RES *ARes = (INT_PG_STATE_RES*)pData;
- for (int ii = 0; ii < ARes->Count && ii < INT_MAX_PG_STATE; ii++)
- {
- if (ARes->Unit[ii].Type == INT_ID_VMS_SERVER)
- {
- FVmsServerState = ARes->Unit[ii].Action;
- UpdateVmsCommStatus(false);
- FPollPrcsState.Polling = GetTickCount(); //프로세스상태정보 조회 타이머 리셋
- break;
- }
- }
- }
- break;
- case INT_OP_VMS_STATE_RES:
- {
- char szVmsNmbr[INT_VMS_MAX_ID+1];
- INT_VMS_STATE_RES *ARes = (INT_VMS_STATE_RES*)pData;
- sMsg = "";
- sMsg.printf(L"*** VMS Controller Status Received: %d EA", ARes->Count);
- DebugMsg(sMsg);
- for (int ii = 0; ii < ARes->Count && ii < INT_MAX_VMS_STATE; ii++)
- {
- sMsg = "";
- String sVmsNmbr;
- INT_VMS_STATE *pVms = &ARes->Unit[ii];
- sprintf(szVmsNmbr, "%.*s", INT_VMS_MAX_ID, (char*)pVms->VmsId);
- sVmsNmbr = String(szVmsNmbr);
- TVmsCtlr *pObj = VmsManager->FLists.Find(sVmsNmbr);
- if (pObj)
- {
- VmsStatusCopy(&pObj->WSTATE, pVms);
- if (pObj->WSTATE.OprMode == 'A') pObj->OPER_MODE = "A";
- else if (pObj->WSTATE.OprMode == 'B') pObj->OPER_MODE = "B";
- else pObj->OPER_MODE = "F";
- //pObj->VMS_PHSE_CHNG_CYCL = pObj->WSTATE.ScheduledMessageOperatingTime;
- pObj->VMS_CMNC_ERR_BASS_VAL = pObj->WSTATE.ModuleOperatingTemperature;
- pObj->FAN_MTNS_TMPR = pObj->WSTATE.FanOperatingTemperature;
- pObj->HETR_MTNS_TMPR = pObj->WSTATE.HeaterOperatingTemperature;
- pObj->VMS_MODL_ERR_RATE = pObj->WSTATE.ModuleBasicFailureRate;
- pObj->CheckRunState();
- if (pObj->WSTATE.Comm != vms_normal)
- {
- pObj->VmsMsg->OFFER_YN = false;
- }
- }
- else
- {
- sMsg.printf(L"INT_OP_VMS_STATE_RES VMS not found: %s", sVmsNmbr.c_str());
- DebugMsg(sMsg);
- }
- }
- RefreshVmsMessage(WM_VMS_STATE_REFRESH);
- FPollVmsState.Polling = GetTickCount();
- }
- break;
- case INT_OP_VMS_FORM_SAVE:
- {
- FPollVmsMsg.Reset(); //VMS메시지 조회 타이머 리셋
- char szDateTime[INT_VMS_MAX_DATETIME+1];
- INT_VMS_FORM_SAVE_REQ *AReq = (INT_VMS_FORM_SAVE_REQ*)pData;
- sprintf(szDateTime, "%.*s", INT_VMS_MAX_DATETIME, (char*)AReq->Date);
- String sDateTime = String(szDateTime);
- sMsg = "";
- sMsg.printf(L"*** VMS Form Create Message Received: %s", sDateTime.c_str());
- DebugMsg(sMsg);
- RefreshVmsMessage(WM_VMS_STATE_REFRESH);
- RefreshVmsMessage(WM_VMS_FORM_REFRESH);
- }
- break;
- case INT_OP_VMS_FORM_DOWNLOAD:
- {
- char szDateTime[INT_VMS_MAX_DATETIME+1];
- char szVmsNmbr[INT_VMS_MAX_ID+1];
- INT_VMS_FORM_DOWNLOAD_REQ *AReq = (INT_VMS_FORM_DOWNLOAD_REQ*)pData;
- sMsg.printf(L"*** VMS Form Download Recieved: %d EA", AReq->Count);
- DebugMsg(sMsg);
- for (int ii = 0; ii < AReq->Count && ii < INT_MAX_VMS_FORM_DOWNLOAD; ii++)
- {
- sMsg = "";
- INT_VMS_FORM_DOWNLOAD *pVms = &AReq->Unit[ii];
- sprintf(szVmsNmbr, "%.*s", INT_VMS_MAX_ID, (char*)pVms->VmsId);
- sprintf(szDateTime, "%.*s", INT_VMS_MAX_DATETIME, (char*)pVms->Date);
- sVmsNmbr = String(szVmsNmbr);
- String sDateTime = String(szDateTime);
- TVmsCtlr *pObj = VmsManager->FLists.Find(sVmsNmbr);
- if (pObj)
- {
- bool bDnLd = (pVms->Result == vms_download_succ) ? true : false;
- String sResult = bDnLd ? "Succ" : "Fail";
- pObj->VmsMsg->OFFER_DT = sDateTime;
- pObj->VmsMsg->OFFER_YN = bDnLd;
- for (int kk = 0; kk < pObj->VmsMsg->Total && kk < INT_MAX_VMS_FORM; kk++)
- {
- pObj->VmsMsg->PHASE[kk].DNLD_YN = bDnLd ? "Y" : "N";
- }
- //sMsg.printf(L"*** ===> VMS Msg download: %s, %s", pObj->VMS_CTLR_ID.c_str(), sResult.c_str());
- //DebugMsg(sMsg);
- }
- else
- {
- sMsg.printf(L"*** INT_OP_VMS_FORM_DOWNLOAD VMS not found: %s", sVmsNmbr.c_str());
- DebugMsg(sMsg);
- }
- }
- RefreshVmsMessage(WM_VMS_STATE_REFRESH);
- RefreshVmsMessage(WM_VMS_FORM_REFRESH);
- }
- break;
- }
- }
- TmrCommTimeout->Enabled = true;
- }
- //---------------------------------------------------------------------------
- // Not Used
- void __fastcall TFrmVmsOprMain::OnUdpDataRecvMessage(tagMSG &Msg)
- {
- IPCUDPMESSAGESTRUCT *RcvData = (IPCUDPMESSAGESTRUCT*)Msg.lParam;
- INT_SENDER *Sender = &RcvData->Sender;
- INT_PACKET *Pkt = &RcvData->Pkt;
- INT_HEAD *head = &Pkt->head;
- INT_DATA *data = &Pkt->data;
- char *pData = &data->Data[2];
- BYTE OpCode = (BYTE)data->Data[0];
- LOGINFO("*** OPR Client Req: %s.%d", VComm_ulong2ip(Sender->IP), Sender->Port);
- String sMsg = "";
- String sVmsNmbr = "";
- TmrCommTimeout->Enabled = false;
- //FVmsServerState = vms_normal;
- UpdateVmsCommStatus(false);
- if (head->OPCode == INT_OP_COMM_COMMON)
- {
- switch(OpCode)
- {
- case INT_OP_PG_STATE_RES:
- {
- DebugMsg("*** VMS Process Status Received.");
- INT_PG_STATE_RES *ARes = (INT_PG_STATE_RES*)pData;
- for (int ii = 0; ii < ARes->Count && ii < INT_MAX_PG_STATE; ii++)
- {
- if (ARes->Unit[ii].Type == INT_ID_VMS_SERVER)
- {
- FVmsServerState = ARes->Unit[ii].Action;
- UpdateVmsCommStatus(false);
- FPollPrcsState.Polling = GetTickCount(); //프로세스상태정보 조회 타이머 리셋
- break;
- }
- }
- }
- break;
- case INT_OP_VMS_STATE_RES:
- {
- char szVmsNmbr[INT_VMS_MAX_ID+1];
- INT_VMS_STATE_RES *ARes = (INT_VMS_STATE_RES*)pData;
- sMsg = "";
- sMsg.printf(L"*** VMS Controller Status Received: %d EA", ARes->Count);
- DebugMsg(sMsg);
- for (int ii = 0; ii < ARes->Count && ii < INT_MAX_VMS_STATE; ii++)
- {
- sMsg = "";
- String sVmsNmbr;
- INT_VMS_STATE *pVms = &ARes->Unit[ii];
- sprintf(szVmsNmbr, "%.*s", INT_VMS_MAX_ID, (char*)pVms->VmsId);
- sVmsNmbr = String(szVmsNmbr);
- TVmsCtlr *pObj = VmsManager->FLists.Find(sVmsNmbr);
- if (pObj)
- {
- VmsStatusCopy(&pObj->WSTATE, pVms);
- if (pObj->WSTATE.OprMode == 'A') pObj->OPER_MODE = "A";
- else if (pObj->WSTATE.OprMode == 'B') pObj->OPER_MODE = "B";
- else pObj->OPER_MODE = "F";
- //pObj->VMS_PHSE_CHNG_CYCL = pObj->WSTATE.ScheduledMessageOperatingTime;
- pObj->VMS_CMNC_ERR_BASS_VAL = pObj->WSTATE.ModuleOperatingTemperature;
- pObj->FAN_MTNS_TMPR = pObj->WSTATE.FanOperatingTemperature;
- pObj->HETR_MTNS_TMPR = pObj->WSTATE.HeaterOperatingTemperature;
- pObj->VMS_MODL_ERR_RATE = pObj->WSTATE.ModuleBasicFailureRate;
- }
- else
- {
- sMsg.printf(L"INT_OP_VMS_STATE_RES VMS not found: %s", sVmsNmbr.c_str());
- DebugMsg(sMsg);
- }
- }
- RefreshVmsMessage(WM_VMS_STATE_REFRESH);
- FPollVmsState.Polling = GetTickCount();
- }
- break;
- case INT_OP_VMS_FORM_SAVE:
- {
- FPollVmsMsg.Reset(); //VMS메시지 조회 타이머 리셋
- char szDateTime[INT_VMS_MAX_DATETIME+1];
- INT_VMS_FORM_SAVE_REQ *AReq = (INT_VMS_FORM_SAVE_REQ*)pData;
- sprintf(szDateTime, "%.*s", INT_VMS_MAX_DATETIME, (char*)AReq->Date);
- String sDateTime = String(szDateTime);
- sMsg = "";
- sMsg.printf(L"*** VMS Form Create Received: %s", sDateTime.c_str());
- DebugMsg(sMsg);
- }
- break;
- case INT_OP_VMS_FORM_DOWNLOAD:
- {
- char szDateTime[INT_VMS_MAX_DATETIME+1];
- char szVmsNmbr[INT_VMS_MAX_ID+1];
- INT_VMS_FORM_DOWNLOAD_REQ *AReq = (INT_VMS_FORM_DOWNLOAD_REQ*)pData;
- sMsg.printf(L"*** VMS Form Download Received: %d EA", AReq->Count);
- DebugMsg(sMsg);
- for (int ii = 0; ii < AReq->Count && ii < INT_MAX_VMS_FORM_DOWNLOAD; ii++)
- {
- sMsg = "";
- INT_VMS_FORM_DOWNLOAD *pVms = &AReq->Unit[ii];
- sprintf(szVmsNmbr, "%.*s", INT_VMS_MAX_ID, (char*)pVms->VmsId);
- sprintf(szDateTime, "%.*s", INT_VMS_MAX_DATETIME, (char*)pVms->Date);
- sVmsNmbr = String(szVmsNmbr);
- String sDateTime = String(szDateTime);
- TVmsCtlr *pObj = VmsManager->FLists.Find(sVmsNmbr);
- if (pObj)
- {
- bool bDnLd = (pVms->Result == vms_download_succ) ? true : false;
- String sResult = bDnLd ? "Succ" : "Fail";
- pObj->VmsMsg->OFFER_DT = sDateTime;
- pObj->VmsMsg->OFFER_YN = bDnLd;
- for (int kk = 0; kk < pObj->VmsMsg->Total && kk < INT_MAX_VMS_FORM; kk++)
- {
- pObj->VmsMsg->PHASE[kk].DNLD_YN = bDnLd ? "Y" : "N";
- }
- sMsg.printf(L"*** ===> VMS Msg download: %s, %s", pObj->VMS_CTLR_ID.c_str(), sResult.c_str());
- }
- else
- {
- sMsg.printf(L"*** INT_OP_VMS_FORM_DOWNLOAD VMS not found: %s", sVmsNmbr.c_str());
- }
- DebugMsg(sMsg);
- }
- }
- break;
- }
- }
- TmrCommTimeout->Enabled = true;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::RefreshVmsMessage(int AMsg, WPARAM AWParam/*=0*/, LPARAM ALParam/*=0*/)
- {
- HWND hWnd;
- if (NVMS0000M->Enabled)
- {
- hWnd = FindChildWindow("VMS0000M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- if (NVMS0100M->Enabled)
- {
- hWnd = FindChildWindow("VMS0100M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- if (NVMS0200M->Enabled)
- {
- hWnd = FindChildWindow("VMS0200M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- if (NVMS0300M->Enabled)
- {
- hWnd = FindChildWindow("VMS0300M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- #if 0
- if (NVMS0400M->Enabled)
- {
- hWnd = FindChildWindow("VMS0400M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- #endif
- if (NVMS0500M->Enabled)
- {
- hWnd = FindChildWindow("VMS0500M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- if (NVMS0600M->Enabled)
- {
- hWnd = FindChildWindow("VMS0600M");
- if (hWnd) POST_MSG(hWnd, AMsg, AWParam, ALParam);
- }
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnPollingThreadDone(TObject *Sender)
- {
- LOGINFO("*** Polling thead terminated ***");
- g_AppCfg.thr.bRunning = false;
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::ShowFacilityStatus()
- {
- // HWND hWnd = FindChildWindow("ITS0000M");
- // if (hWnd) POST_MSG(hWnd, WM_MAINFORM, AWParam, ALParam);
- return;
- #if 0
- bool bShow = false;
- try
- {
- try
- {
- ItsFacilityManager->FLists.Lock();
- FOR_STL(TItsFacility*, pFacility, ItsFacilityManager->FLists)
- {
- if (pFacility->DEL_YN == "Y") continue;
- if (pFacility->FCLT_TYPE == "DSRC")
- {
- if (pFacility->FCollCntBase > pFacility->FCollCntCurr)
- {
- bShow = true;
- break;
- }
- }
- if (pFacility->FComm != "1")
- {
- bShow = true;
- break;
- }
- else
- {
- try
- {
- String sValue = pFacility->FCBoxTmpr;
- int nValue = 0;
- if (TryStrToInt(sValue, nValue))
- {
- if (nValue > g_AppCfg.Temp.AlarmValue)
- {
- bShow = true;
- break;
- }
- }
- } catch(...) {}
- }
- }
- }
- __finally
- {
- ItsFacilityManager->FLists.UnLock();
- }
- }
- catch(...)
- {
- }
- if (!bShow)
- {
- LblAlarm->Style->Font->Color = clBlack;
- LblAlarm->Caption = "Alarm Information";
- ImgAlarm->Visible = false;
- ImgAlarmNormal->Visible = true;
- try {
- if (ImgAlarm->Picture->Graphic->ClassName() == "TGIFImage")
- ((TGIFImage *)ImgAlarm->Picture->Graphic)->Animate = false;
- } catch(...) {}
- return;
- }
- ImgAlarmNormal->Visible = false;
- ImgAlarm->Visible = true;
- try {
- if (ImgAlarm->Picture->Graphic->ClassName() == "TGIFImage")
- ((TGIFImage *)ImgAlarm->Picture->Graphic)->Animate = true;
- } catch(...) {}
- LblAlarm->Caption = "Alarm Occured";
- LblAlarm->Style->Font->Color = clRed;
- if (!g_AppCfg.Alarm.Enabled) return;
- if (!g_AppCfg.Alarm.Window) return;
- #endif
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NTST0000MClick(TObject *Sender)
- {
- VmsManager->LoadVmsMsg();
- #if 0
- String sExeName = "Project1.exe";
- String sParam = "\"" + g_pLOGIN->sUserId + "\" \"" + g_pLOGIN->sUserId + "\"";
- //ShellExecute(NULL,"open", "C:\\myprocess.exe", "\"my argument 1 containing spaces\" \"my argument 2\"","C:\\",SW_SHOWNORMAL);
- ShellExecute(Handle, NULL, sExeName.c_str(), sParam.c_str(), NULL, SW_SHOWNORMAL);
- #endif
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM100MClick(TObject *Sender)
- {
- FORMSHOW(VMSM100M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM200MClick(TObject *Sender)
- {
- // FORMSHOW(VMSM200M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM210MClick(TObject *Sender)
- {
- //FORMSHOW(VMSM210M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM400MClick(TObject *Sender)
- {
- FORMSHOW(VMSM400M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM410MClick(TObject *Sender)
- {
- FORMSHOW(VMSM410M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM420MClick(TObject *Sender)
- {
- FORMSHOW(VMSM420M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM500MClick(TObject *Sender)
- {
- FORMSHOW(VMSM500M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM600MClick(TObject *Sender)
- {
- FORMSHOW(VMSM600M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM700MClick(TObject *Sender)
- {
- FORMSHOW(VMSM700M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM800MClick(TObject *Sender)
- {
- FORMSHOW(VMSM800M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMSM900MClick(TObject *Sender)
- {
- FORMSHOW(VMSM900M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0000MClick(TObject *Sender)
- {
- // FORMSHOW(VMS0000M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0100MClick(TObject *Sender)
- {
- if (g_AppCfg.bOnlyOneScreen) CloseChildWindow();
- FORMSHOW(VMS0100M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0200MClick(TObject *Sender)
- {
- if (g_AppCfg.bOnlyOneScreen) CloseChildWindow();
- FORMSHOW(VMS0200M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0300MClick(TObject *Sender)
- {
- if (g_AppCfg.bOnlyOneScreen) CloseChildWindow();
- FORMSHOW(VMS0300M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0500MClick(TObject *Sender)
- {
- if (g_AppCfg.bOnlyOneScreen) CloseChildWindow();
- FORMSHOW(VMS0500M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::NVMS0600MClick(TObject *Sender)
- {
- if (g_AppCfg.bOnlyOneScreen) CloseChildWindow();
- FORMSHOW(VMS0600M);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::TmrCommTimeoutTimer(TObject *Sender)
- {
- //통신타임아웃
- TmrCommTimeout->Enabled = false;
- UpdateInterCommStatus(false);
- FVmsServerState = vms_error;
- UpdateVmsCommStatus(false);
- LOGINFO("xxx VMS Communication Time out xxx");
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::ApplicationEvents1Restore(TObject *Sender)
- {
- //화면 재생
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::ApplicationEvents1Minimize(TObject *Sender)
- {
- //화면 정지
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::OnMenuMouseMove(TObject *Sender, TShiftState Shift, int X,
- int Y)
- {
- ::SetCursor(Screen->Cursors[crHandPoint]);
- }
- //---------------------------------------------------------------------------
- void __fastcall TFrmVmsOprMain::ApplicationEvents1SettingChange(TObject *Sender, int Flag,
- const UnicodeString Section, int &Result)
- {
- DateSeparator = '-';
- TimeSeparator = ':';
- ShortDateFormat = "yyyy-MM-dd";
- ShortTimeFormat = "HH:NN:SS";
- LongTimeFormat = "HH:NN:SS";
- cxFormatController()->BeginUpdate();
- cxFormatController()->UseDelphiDateTimeFormats = true;
- cxFormatController()->EndUpdate();
- cxFormatController()->GetFormats();
- cxFormatController()->NotifyListeners();
- }
- //---------------------------------------------------------------------------
|