VMSM800MF.cpp 66 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "AppGlobalF.h"
  6. #include "CDSVmsIfscF.h"
  7. #include "ITSLangTransF.h"
  8. #include "CDSFontF.h"
  9. #include "CDSVmsFormF.h"
  10. #pragma hdrstop
  11. #include "VMSM800MF.h"
  12. #include "VMSM610MF.h"
  13. #include "VMSM620MF.h"
  14. #include "VMSM630MF.h"
  15. #include "VMSSEL0MF.h"
  16. #include "VMSEDT0MF.h"
  17. //---------------------------------------------------------------------------
  18. #pragma package(smart_init)
  19. #pragma link "cxButtons"
  20. #pragma link "cxCalendar"
  21. #pragma link "cxContainer"
  22. #pragma link "cxControls"
  23. #pragma link "cxDropDownEdit"
  24. #pragma link "cxEdit"
  25. #pragma link "cxGraphics"
  26. #pragma link "cxGroupBox"
  27. #pragma link "cxLabel"
  28. #pragma link "cxLookAndFeelPainters"
  29. #pragma link "cxLookAndFeels"
  30. #pragma link "cxMaskEdit"
  31. #pragma link "cxPC"
  32. #pragma link "cxPCdxBarPopupMenu"
  33. #pragma link "cxSpinEdit"
  34. #pragma link "cxSplitter"
  35. #pragma link "cxTextEdit"
  36. #pragma link "cxTimeEdit"
  37. #pragma link "dxSkinBlack"
  38. #pragma link "dxSkinBlue"
  39. #pragma link "dxSkinCaramel"
  40. #pragma link "dxSkinCoffee"
  41. #pragma link "dxSkinDarkRoom"
  42. #pragma link "dxSkinDarkSide"
  43. #pragma link "dxSkinFoggy"
  44. #pragma link "dxSkinGlassOceans"
  45. #pragma link "dxSkiniMaginary"
  46. #pragma link "dxSkinLilian"
  47. #pragma link "dxSkinLiquidSky"
  48. #pragma link "dxSkinLondonLiquidSky"
  49. #pragma link "dxSkinMcSkin"
  50. #pragma link "dxSkinMoneyTwins"
  51. #pragma link "dxSkinOffice2007Black"
  52. #pragma link "dxSkinOffice2007Blue"
  53. #pragma link "dxSkinOffice2007Green"
  54. #pragma link "dxSkinOffice2007Pink"
  55. #pragma link "dxSkinOffice2007Silver"
  56. #pragma link "dxSkinOffice2010Black"
  57. #pragma link "dxSkinOffice2010Blue"
  58. #pragma link "dxSkinOffice2010Silver"
  59. #pragma link "dxSkinsCore"
  60. #pragma link "dxSkinscxPCPainter"
  61. #pragma link "dxSkinSeven"
  62. #pragma link "dxSkinSharp"
  63. #pragma link "dxSkinSilver"
  64. #pragma link "dxSkinStardust"
  65. #pragma link "cxRadioGroup"
  66. #pragma link "cxClasses"
  67. #pragma link "cxCustomData"
  68. #pragma link "cxData"
  69. #pragma link "cxDataStorage"
  70. #pragma link "cxDBData"
  71. #pragma link "cxFilter"
  72. #pragma link "cxGrid"
  73. #pragma link "cxGridCustomTableView"
  74. #pragma link "cxGridCustomView"
  75. #pragma link "cxGridDBTableView"
  76. #pragma link "cxGridLevel"
  77. #pragma link "cxGridTableView"
  78. #pragma link "cxStyles"
  79. #pragma link "cxCheckBox"
  80. #pragma link "cxImage"
  81. #pragma link "cxButtonEdit"
  82. #pragma link "cxBlobEdit"
  83. #pragma link "cxColorComboBox"
  84. #pragma link "cxCalc"
  85. #pragma link "VmsDesignerF"
  86. #pragma link "FRAME_VmsSchListF"
  87. #pragma resource "*.dfm"
  88. TVMSM800M *VMSM800M = NULL;
  89. //---------------------------------------------------------------------------
  90. __fastcall TVMSM800M::TVMSM800M(TComponent* Owner)
  91. : TForm(Owner)
  92. {
  93. LangTrans->Translate(this, ITSDb_GetConnection());
  94. ITSSkin_Load(this);
  95. CMM_LoadForm(g_sFormsDir, this);
  96. FUpdate= false;
  97. FTitle = Caption;//"VMS 자동 스케줄 관리";
  98. FListSymb = new TList;
  99. EditMode = false;
  100. FVMS_SCH_TYPE = "B"; //기본스케쥴
  101. FEN_DSPL_SCH_TYPE = enScheduleBase;
  102. FRAMEVmsSchList1->PnlTop->Visible = false;
  103. FRAMEVmsSchList1->PnlBottom->Visible = false;
  104. FRAMEVmsSchList1->ColAuto->Visible = false;
  105. FRAMEVmsSchList1->ColFix->Visible = false;
  106. FRAMEVmsSchList1->ColBase->Visible = true;
  107. FRAMEVmsSchList1->FEN_DSPL_SCH_TYPE = FEN_DSPL_SCH_TYPE;
  108. FVmsHeight = 64;
  109. for (int ii = 0; ii < eSchTp_max; ii++)
  110. {
  111. FButtonAdd[ii] = (TcxButton*)FindComponent("BtnListAdd"+IntToStr(ii));
  112. FButtonDel[ii] = (TcxButton*)FindComponent("BtnListDelete"+IntToStr(ii));
  113. FTabSheet[ii] = (TcxTabSheet*)FindComponent("TabSheet"+IntToStr(ii));
  114. FListSch[ii] = (TcxGridTableView*)FindComponent("TvGrid"+IntToStr(ii));
  115. FListFrm[ii] = (TcxGridTableView*)FindComponent("TvForm"+IntToStr(ii));
  116. FLabel[ii] = (TcxLabel*)FrmLang->FindComponent("lblSch"+IntToStr(ii));
  117. }
  118. PgVmsSch->Properties->ActivePage = TabSheet3; //홍보
  119. // eSchTp_traffic
  120. if (FTabSheet[eSchTp_traffic])
  121. {
  122. FTabSheet[eSchTp_traffic]->TabVisible = false;
  123. FTabSheet[eSchTp_traffic]->Visible = false;
  124. }
  125. // eSchTp_incident
  126. if (FTabSheet[eSchTp_incident])
  127. {
  128. FTabSheet[eSchTp_incident]->TabVisible = false;
  129. FTabSheet[eSchTp_incident]->Visible = false;
  130. }
  131. // eSchTp_gongsa
  132. if (FTabSheet[eSchTp_gongsa])
  133. {
  134. FTabSheet[eSchTp_gongsa]->TabVisible = false;
  135. FTabSheet[eSchTp_gongsa]->Visible = false;
  136. }
  137. // eSchTp_deture
  138. if (FTabSheet[eSchTp_deture])
  139. {
  140. FTabSheet[eSchTp_deture]->TabVisible = false;
  141. FTabSheet[eSchTp_deture]->Visible = false;
  142. }
  143. // eSchTp_congest
  144. if (FTabSheet[eSchTp_congest])
  145. {
  146. FTabSheet[eSchTp_congest]->TabVisible = false;
  147. FTabSheet[eSchTp_congest]->Visible = false;
  148. }
  149. // eSchTp_safe
  150. if (FTabSheet[eSchTp_safe])
  151. {
  152. FTabSheet[eSchTp_safe]->TabVisible = false;
  153. FTabSheet[eSchTp_safe]->Visible = false;
  154. }
  155. // eSchTp_video
  156. if (FTabSheet[eSchTp_video])
  157. {
  158. FTabSheet[eSchTp_video]->TabVisible = false;
  159. FTabSheet[eSchTp_video]->Visible = false;
  160. }
  161. // eSchTp_stream
  162. if (FTabSheet[eSchTp_stream])
  163. {
  164. FTabSheet[eSchTp_stream]->TabVisible = false;
  165. FTabSheet[eSchTp_stream]->Visible = false;
  166. }
  167. #if 0
  168. // eSchTp_atmp
  169. if (FTabSheet[eSchTp_atmp])
  170. {
  171. FTabSheet[eSchTp_atmp]->TabVisible = false;
  172. FTabSheet[eSchTp_atmp]->Visible = false;
  173. }
  174. #endif
  175. for (int ii = 0; ii < eSchTp_max; ii++)
  176. {
  177. if (FTabSheet[ii] && (FTabSheet[ii]->TabVisible == false))
  178. {
  179. FListSch[ii] = NULL;
  180. FListFrm[ii] = NULL;
  181. }
  182. if (FListSch[ii]) InitTcxList(FListSch[ii]);
  183. if (FListFrm[ii]) InitTcxList(FListFrm[ii]);
  184. }
  185. }
  186. //---------------------------------------------------------------------------
  187. void __fastcall TVMSM800M::InitTcxList(TcxGridTableView *AView)
  188. {
  189. AView->OptionsView->DataRowHeight = 0;
  190. AView->OptionsView->CellAutoHeight = true;
  191. AView->OptionsView->Indicator = false;
  192. AView->OptionsCustomize->ColumnMoving = false;
  193. AView->OptionsCustomize->ColumnSorting = false;
  194. AView->Columns[0]->Width = 40;
  195. AView->Columns[0]->Options->HorzSizing = false;
  196. AView->Columns[1]->Width = 330;
  197. }
  198. //---------------------------------------------------------------------------
  199. void __fastcall TVMSM800M::CommClose()
  200. {
  201. try
  202. {
  203. if (m_pEdtDesigner)
  204. {
  205. delete m_pEdtDesigner;
  206. m_pEdtDesigner = NULL;
  207. }
  208. APP_DelVmsSizeCombo(CbSizeType);
  209. ClearSymbloList();
  210. SAFE_DELETE(FListSymb);
  211. CMM_SaveForm(g_sFormsDir, this);
  212. }
  213. catch(...)
  214. {
  215. }
  216. }
  217. //---------------------------------------------------------------------------
  218. void __fastcall TVMSM800M::FormCreate(TObject *Sender)
  219. {
  220. m_pEdtDesigner = new TVmsFormDesigner(PnlEditForm);
  221. FOR_STL(TCDSFontColor*, pObj, CDSFontManager->FColors)
  222. {
  223. m_pEdtDesigner->InitFontColor(pObj->VMS_FONT_COLR_CD, (TColor)pObj->VMS_FONT_COLR_VAL);
  224. }
  225. }
  226. //---------------------------------------------------------------------------
  227. void __fastcall TVMSM800M::FormShow(TObject *Sender)
  228. {
  229. Refresh();
  230. FormInit();
  231. ChangeEditMode(1);
  232. TmrShow->Enabled = true;
  233. }
  234. //---------------------------------------------------------------------------
  235. void __fastcall TVMSM800M::FormInit()
  236. {
  237. for (int ii = 0; ii < eSchTp_max; ii++)
  238. {
  239. if (FListSch[ii]) FListSch[ii]->OptionsView->NoDataToDisplayInfoText = FrmLang->lblNoSchedule->Caption;//"<등록되어 있는 스케줄 정보가 없습니다>";
  240. if (FListFrm[ii]) FListFrm[ii]->OptionsView->NoDataToDisplayInfoText = FrmLang->lblNoForm->Caption;//"<등록되어 있는 폼 정보가 없습니다>";
  241. }
  242. //VMS사이즈
  243. APP_FillVmsSizeType(CbSizeType, false);
  244. VmsCtlrManager->LoadVmsFormUsage();
  245. FRAMEVmsSchList1->RefreshVmsFormUsage();
  246. FNewDb = false;
  247. }
  248. //---------------------------------------------------------------------------
  249. void __fastcall TVMSM800M::TmrShowTimer(TObject *Sender)
  250. {
  251. TmrShow->Enabled = false;
  252. }
  253. //---------------------------------------------------------------------------
  254. void __fastcall TVMSM800M::BtnCloseClick(TObject *Sender)
  255. {
  256. Close();
  257. }
  258. //---------------------------------------------------------------------------
  259. void __fastcall TVMSM800M::FormClose(TObject *Sender, TCloseAction &Action)
  260. {
  261. CommClose();
  262. VMSM800M = NULL;
  263. Action = caFree;
  264. }
  265. //---------------------------------------------------------------------------
  266. void __fastcall TVMSM800M::FormCloseQuery(TObject *Sender, bool &CanClose)
  267. {
  268. if (FUpdate)
  269. {
  270. POST_MSG(Application->MainForm->Handle, WM_DATABASE_REFRESH, WP_MSG_14, 0);
  271. }
  272. }
  273. //---------------------------------------------------------------------------
  274. void __fastcall TVMSM800M::ChangeEditMode(int AEdit)
  275. {
  276. }
  277. //---------------------------------------------------------------------------
  278. void __fastcall TVMSM800M::ClearSymbloList()
  279. {
  280. for(int ii = 0; ii < FListSymb->Count; ii++)
  281. {
  282. Graphics::TBitmap *bitmap = (Graphics::TBitmap *)FListSymb->Items[ii];
  283. delete bitmap;
  284. }
  285. FListSymb->Clear();
  286. }
  287. //---------------------------------------------------------------------------
  288. void __fastcall TVMSM800M::FRAMEVmsSchList1TvListCellDblClick(TcxCustomGridTableView *Sender,
  289. TcxGridTableDataCellViewInfo *ACellViewInfo, TMouseButton AButton,
  290. TShiftState AShift, bool &AHandled)
  291. {
  292. if (!ACellViewInfo) return;
  293. DisplayInfo();
  294. }
  295. //---------------------------------------------------------------------------
  296. void __fastcall TVMSM800M::FRAMEVmsSchList1TvListFocusedRecordChanged(TcxCustomGridTableView *Sender,
  297. TcxCustomGridRecord *APrevFocusedRecord, TcxCustomGridRecord *AFocusedRecord,
  298. bool ANewItemRecordFocusingChanged)
  299. {
  300. if (!AFocusedRecord) return;
  301. DisplayInfo();
  302. }
  303. //---------------------------------------------------------------------------
  304. void __fastcall TVMSM800M::CbSizeTypePropertiesChange(TObject *Sender)
  305. {
  306. BtnSearchClick(NULL);
  307. }
  308. //---------------------------------------------------------------------------
  309. void __fastcall TVMSM800M::BtnSearchClick(TObject *Sender)
  310. {
  311. RefreshData();
  312. EdFocus->SetFocus();
  313. ChangeEditMode(1);
  314. }
  315. //---------------------------------------------------------------------------
  316. void __fastcall TVMSM800M::RefreshData()
  317. {
  318. FormClear();
  319. TVmsSizeType *pVmsSizeType = APP_GetVmsSizeTypeObject(CbSizeType);
  320. if (pVmsSizeType == NULL) return;
  321. FVmsTypeCd = pVmsSizeType->TypeCd;
  322. FVmsWidth = pVmsSizeType->Width;
  323. FVmsHeight = pVmsSizeType->Height;
  324. PnlEdtBack->Width = FVmsWidth+4;
  325. PnlEdtBack->Height= FVmsHeight+4;
  326. m_pEdtDesigner->Clear();
  327. m_pEdtDesigner->SizeType = FVmsTypeCd;
  328. m_pEdtDesigner->SetSize(FVmsWidth, FVmsHeight);
  329. m_pEdtDesigner->SetPos(0, 0);
  330. m_pEdtDesigner->BkColorCode = "0";
  331. m_pEdtDesigner->EditMode = true;
  332. m_pEdtDesigner->Show();
  333. FRAMEVmsSchList1->UpdateList(FVmsTypeCd);
  334. LoadVmsFormList(FVmsTypeCd);
  335. }
  336. //---------------------------------------------------------------------------
  337. void __fastcall TVMSM800M::FormClear()
  338. {
  339. FSelIdx = -1;
  340. EdVmsNmbr->Clear();
  341. GrpSchedule->Caption = lblTitle->Caption;//"▶ 자동 스케줄 설정";
  342. for (int ii = 0; ii < eSchTp_max; ii++)
  343. {
  344. if (FListSch[ii]) CMM_ClearGridTableView(FListSch[ii]);
  345. if (FTabSheet[ii] && FLabel[ii]) FTabSheet[ii]->Caption = " " + FLabel[ii]->Caption + " ";
  346. }
  347. FNewDb = false;
  348. }
  349. //---------------------------------------------------------------------------
  350. void __fastcall TVMSM800M::DisplayInfo()
  351. {
  352. FormClear();
  353. FSelIdx = CMM_GetRecordIndex(FRAMEVmsSchList1->TvList);
  354. if (FSelIdx < 0) return;
  355. TcxDataController *pGDC = FRAMEVmsSchList1->TvList->DataController;
  356. String sVmsNmbr = VarToStr(pGDC->Values[FSelIdx][FRAMEVmsSchList1->Column01->Index]);
  357. EdVmsNmbr->Text = sVmsNmbr;
  358. GrpSchedule->Caption = lblTitle->Caption + " (" + VarToStr(pGDC->Values[FSelIdx][FRAMEVmsSchList1->Column02->Index]) + ": " + VarToStr(pGDC->Values[FSelIdx][FRAMEVmsSchList1->Column03->Index]) + ")";
  359. LoadVmsScheduleInfo(sVmsNmbr);
  360. //DrawTrafficScenarioForm();
  361. //DrawVideoStreamScenarioForm(eSchTp_video);
  362. //DrawVideoStreamScenarioForm(eSchTp_stream);
  363. TVmsCtlr *pObj = VmsCtlrManager->FLists.Find(sVmsNmbr);
  364. if (pObj)
  365. {
  366. PSCHEDULE_USAGE Use = &pObj->FormCnt[FEN_DSPL_SCH_TYPE];
  367. for (int ii = 0; ii < eSchTp_max; ii++)
  368. {
  369. if (FTabSheet[ii] && FLabel[ii])
  370. {
  371. FTabSheet[ii]->Caption = " " + FLabel[ii]->Caption + " - " + String(Use->Use[ii]) + "/" + String(Use->Total[ii]) + " ";
  372. }
  373. }
  374. }
  375. ChangeEditMode(3);
  376. }
  377. //---------------------------------------------------------------------------
  378. void __fastcall TVMSM800M::TvFormCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  379. TMouseButton AButton, TShiftState AShift,
  380. bool &AHandled)
  381. {
  382. if (!ACellViewInfo) return;
  383. int nRow = Sender->DataController->FocusedRecordIndex;
  384. if( nRow <= -1 )
  385. return;
  386. if (Sender->Tag >= 0 && Sender->Tag < eSchTp_max)
  387. {
  388. if (FButtonAdd[Sender->Tag])
  389. {
  390. BtnListAdd0Click((TObject*)FButtonAdd[Sender->Tag]);
  391. }
  392. }
  393. }
  394. //---------------------------------------------------------------------------
  395. void __fastcall TVMSM800M::BtnListAdd0Click(TObject *Sender)
  396. {
  397. String sUse = "N";
  398. String sTime= "4";
  399. TcxButton *pBtn = (TcxButton*)Sender;
  400. int nTag = pBtn->Tag;
  401. if (nTag < 0 || nTag >= eSchTp_max) return;
  402. int nSelIdx = CMM_GetRecordIndex(FRAMEVmsSchList1->TvList);
  403. if (nSelIdx < 0) return;
  404. if (!FListFrm[nTag] || !FListSch[nTag]) return;
  405. TcxGridDataController *pDcFrm = FListFrm[nTag]->DataController;
  406. TcxGridDataController *pDcSch = FListSch[nTag]->DataController;
  407. int nFormIdx = CMM_GetRecordIndex(FListFrm[nTag]);
  408. if (nFormIdx < 0) return;
  409. if (nTag == eSchTp_traffic || nTag == eSchTp_video || nTag == eSchTp_stream)
  410. {
  411. sUse = "N";
  412. }
  413. if (nTag == eSchTp_video)
  414. {
  415. sTime= "0";
  416. }
  417. String sStrDate = "";
  418. String sEndDate = "";
  419. bool bSelected= false;
  420. TVMSSEL0M *pSelDate = new TVMSSEL0M(this);
  421. pSelDate->FCurrDay = true;
  422. pSelDate->ShowModal();
  423. bSelected = pSelDate->FSelected;
  424. sStrDate = pSelDate->FStrTime;
  425. sEndDate = pSelDate->FEndTime;
  426. delete pSelDate;
  427. pSelDate = NULL;
  428. if (!bSelected) return;
  429. int nRow = pDcSch->AppendRecord();
  430. pDcSch->Values[nRow][ 0] = VarToStr(pDcFrm->Values[nFormIdx][0]);
  431. pDcSch->Values[nRow][ 1] = (pDcFrm->Values[nFormIdx][1]); //이미지데이터임
  432. pDcSch->Values[nRow][ 3] = sTime;
  433. pDcSch->Values[nRow][ 4] = ITSUtil_FormatStr(sStrDate, STR_HHNN);;
  434. pDcSch->Values[nRow][ 5] = ITSUtil_FormatStr(sEndDate, STR_HHNN);;
  435. pDcSch->Values[nRow][ 6] = sUse;
  436. pDcSch->Values[nRow][ 7] = sStrDate;
  437. pDcSch->Values[nRow][ 8] = sEndDate;
  438. pDcSch->Values[nRow][15] = VarToStr(pDcFrm->Values[nFormIdx][2]);
  439. pDcSch->Values[nRow][20] = VarToStr(pDcFrm->Values[nFormIdx][3]);
  440. pDcSch->Values[nRow][21] = VarToStr(pDcFrm->Values[nFormIdx][4]);
  441. }
  442. //---------------------------------------------------------------------------
  443. void __fastcall TVMSM800M::BtnListDelete0Click(TObject *Sender)
  444. {
  445. TcxButton *pBtn = (TcxButton*)Sender;
  446. int nTag = pBtn->Tag;
  447. if (nTag >= eSchTp_max) return;
  448. int nSelIdx = CMM_GetRecordIndex(FRAMEVmsSchList1->TvList);
  449. if (nSelIdx < 0) return;
  450. if (!FListSch[nTag]) return;
  451. TcxGridDataController *pDcSch = FListSch[nTag]->DataController;
  452. nSelIdx = CMM_GetRecordIndex(FListSch[nTag]);
  453. if (nSelIdx < 0) return;
  454. FListSch[nTag]->DataController->DeleteRecord(nSelIdx);
  455. }
  456. //---------------------------------------------------------------------------
  457. void __fastcall TVMSM800M::TvGridCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  458. TMouseButton AButton, TShiftState AShift,
  459. bool &AHandled)
  460. {
  461. if (!ACellViewInfo) return;
  462. int nRow = Sender->DataController->FocusedRecordIndex;
  463. if( nRow <= -1 )
  464. return;
  465. TcxGridDataController *pGDC = (TcxGridDataController*)Sender->DataController;
  466. int nColIdx = ACellViewInfo->Item->Index;
  467. //ShowMessage(String(Sender->Tag) + " " + String(nColIdx));
  468. String sFormId = VarToStr(pGDC->Values[nRow][0]);
  469. String sStrDate = VarToStr(pGDC->Values[nRow][7]);
  470. String sEndDate = VarToStr(pGDC->Values[nRow][8]);
  471. if (nColIdx == 4 || nColIdx == 5)
  472. {
  473. //표출기간설정
  474. TVMSSEL0M *pSelDate = new TVMSSEL0M(this);
  475. pSelDate->FStrTime = sStrDate;
  476. pSelDate->FEndTime = sEndDate;
  477. pSelDate->ShowModal();
  478. bool bSelected = pSelDate->FSelected;
  479. sStrDate = pSelDate->FStrTime;
  480. sEndDate = pSelDate->FEndTime;
  481. delete pSelDate;
  482. pSelDate = NULL;
  483. if (bSelected)
  484. {
  485. pGDC->Values[nRow][4] = ITSUtil_FormatStr(sStrDate, STR_HHNN);;
  486. pGDC->Values[nRow][5] = ITSUtil_FormatStr(sEndDate, STR_HHNN);;
  487. pGDC->Values[nRow][7] = sStrDate;
  488. pGDC->Values[nRow][8] = sEndDate;
  489. }
  490. return;
  491. }
  492. if (Sender->Tag == eSchTp_traffic)
  493. {
  494. if (VarToStr(pGDC->Values[nRow][15]).ToIntDef(0) == 15)
  495. {
  496. //도형식배경 소통정보 폼
  497. Application->MessageBox(FrmLang->lblSchErr1->Caption.c_str(),//L"VMS 교통정보 폼 구간 설정\r\n도형식 배경소통정보 폼은 폼관리 화면에서 설정 가능합니다.",
  498. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  499. return;
  500. }
  501. // 소통정보 폼 정보구간 설정
  502. TVMSM610M *pIfscFrm = new TVMSM610M(this);
  503. pIfscFrm->FVmsNmbr = EdVmsNmbr->Text;
  504. pIfscFrm->FFormId = sFormId;
  505. pIfscFrm->FVmsTypeCd = FVmsTypeCd;
  506. pIfscFrm->FVmsWidth = FVmsWidth;
  507. pIfscFrm->FVmsHeight = FVmsHeight;
  508. pIfscFrm->FIfscId[0] = VarToStr(pGDC->Values[nRow][9]);
  509. pIfscFrm->FIfscId[1] = VarToStr(pGDC->Values[nRow][10]);
  510. pIfscFrm->FIfscId[2] = VarToStr(pGDC->Values[nRow][11]);
  511. pIfscFrm->FIfscId[3] = VarToStr(pGDC->Values[nRow][12]);
  512. pIfscFrm->FIfscId[4] = VarToStr(pGDC->Values[nRow][16]);
  513. pIfscFrm->FIfscId[5] = VarToStr(pGDC->Values[nRow][17]);
  514. pIfscFrm->FIfscId[6] = VarToStr(pGDC->Values[nRow][18]);
  515. pIfscFrm->FIfscId[7] = VarToStr(pGDC->Values[nRow][19]);
  516. //pIfscFrm->FVmsType = VarToStr(pGDC->Values[nRow][13]).ToIntDef(0);
  517. pIfscFrm->FFormColor = VarToStr(pGDC->Values[nRow][14]);
  518. pIfscFrm->FFormType = VarToStr(pGDC->Values[nRow][15]).ToIntDef(0);
  519. pIfscFrm->ShowModal();
  520. if (pIfscFrm->FSelected)
  521. {
  522. TStream *pImgStream = new TMemoryStream();
  523. try
  524. {
  525. void *p;
  526. Variant v;
  527. pIfscFrm->ImgForm->Picture->Bitmap->SaveToStream(pImgStream);
  528. int aBound[]={0, pImgStream->Size - 1};
  529. v = VarArrayCreate(aBound, 1, varByte);
  530. p = VarArrayLock(v);
  531. pImgStream->Position = 0;
  532. pImgStream->Read(p, pImgStream->Size);
  533. VarArrayUnlock(v);
  534. pGDC->Values[nRow][1] = v;
  535. }
  536. __finally
  537. {
  538. SAFE_DELETE(pImgStream);
  539. }
  540. pGDC->Values[nRow][ 9] = pIfscFrm->FIfscId[0];
  541. pGDC->Values[nRow][10] = pIfscFrm->FIfscId[1];
  542. pGDC->Values[nRow][11] = pIfscFrm->FIfscId[2];
  543. pGDC->Values[nRow][12] = pIfscFrm->FIfscId[3];
  544. pGDC->Values[nRow][16] = pIfscFrm->FIfscId[4];
  545. pGDC->Values[nRow][17] = pIfscFrm->FIfscId[5];
  546. pGDC->Values[nRow][18] = pIfscFrm->FIfscId[6];
  547. pGDC->Values[nRow][19] = pIfscFrm->FIfscId[7];
  548. }
  549. delete pIfscFrm;
  550. pIfscFrm = NULL;
  551. }
  552. if (Sender->Tag == eSchTp_video)
  553. {
  554. TVMSM620M *pVideoFrm = new TVMSM620M(this);
  555. pVideoFrm->FVmsNmbr = EdVmsNmbr->Text;
  556. pVideoFrm->FFormId = sFormId;
  557. pVideoFrm->FVmsTypeCd = FVmsTypeCd;
  558. pVideoFrm->FVmsWidth = FVmsWidth;
  559. pVideoFrm->FVmsHeight = FVmsHeight;
  560. pVideoFrm->FSymbLibNmbr = VarToStr(pGDC->Values[nRow][20]);
  561. pVideoFrm->FStreamAddr = VarToStr(pGDC->Values[nRow][21]);
  562. //pVideoFrm->FVmsType = VarToStr(pGDC->Values[nRow][13]).ToIntDef(0);
  563. pVideoFrm->FFormColor = VarToStr(pGDC->Values[nRow][14]);
  564. pVideoFrm->FFormType = VarToStr(pGDC->Values[nRow][15]).ToIntDef(0);
  565. pVideoFrm->ShowModal();
  566. if (pVideoFrm->FSelected)
  567. {
  568. TStream *pImgStream = new TMemoryStream();
  569. try
  570. {
  571. void *p;
  572. Variant v;
  573. pVideoFrm->ImgForm->Picture->Bitmap->SaveToStream(pImgStream);
  574. int aBound[]={0, pImgStream->Size - 1};
  575. v = VarArrayCreate(aBound, 1, varByte);
  576. p = VarArrayLock(v);
  577. pImgStream->Position = 0;
  578. pImgStream->Read(p, pImgStream->Size);
  579. VarArrayUnlock(v);
  580. pGDC->Values[nRow][1] = v;
  581. }
  582. __finally
  583. {
  584. SAFE_DELETE(pImgStream);
  585. }
  586. pGDC->Values[nRow][20] = pVideoFrm->FSymbLibNmbr;
  587. pGDC->Values[nRow][21] = pVideoFrm->FStreamAddr;
  588. }
  589. delete pVideoFrm;
  590. pVideoFrm = NULL;
  591. }
  592. if (Sender->Tag == eSchTp_stream)
  593. {
  594. TVMSM630M *pStreamFrm = new TVMSM630M(this);
  595. pStreamFrm->FVmsNmbr = EdVmsNmbr->Text;
  596. pStreamFrm->FFormId = sFormId;
  597. pStreamFrm->FVmsTypeCd = FVmsTypeCd;
  598. pStreamFrm->FVmsWidth = FVmsWidth;
  599. pStreamFrm->FVmsHeight = FVmsHeight;
  600. pStreamFrm->FSymbLibNmbr = VarToStr(pGDC->Values[nRow][20]);
  601. pStreamFrm->FStreamAddr = VarToStr(pGDC->Values[nRow][21]);
  602. //pStreamFrm->FVmsType = VarToStr(pGDC->Values[nRow][13]).ToIntDef(0);
  603. pStreamFrm->FFormColor = VarToStr(pGDC->Values[nRow][14]);
  604. pStreamFrm->FFormType = VarToStr(pGDC->Values[nRow][15]).ToIntDef(0);
  605. pStreamFrm->ShowModal();
  606. if (pStreamFrm->FSelected)
  607. {
  608. TStream *pImgStream = new TMemoryStream();
  609. try
  610. {
  611. void *p;
  612. Variant v;
  613. pStreamFrm->ImgForm->Picture->Bitmap->SaveToStream(pImgStream);
  614. int aBound[]={0, pImgStream->Size - 1};
  615. v = VarArrayCreate(aBound, 1, varByte);
  616. p = VarArrayLock(v);
  617. pImgStream->Position = 0;
  618. pImgStream->Read(p, pImgStream->Size);
  619. VarArrayUnlock(v);
  620. pGDC->Values[nRow][1] = v;
  621. }
  622. __finally
  623. {
  624. SAFE_DELETE(pImgStream);
  625. }
  626. pGDC->Values[nRow][20] = pStreamFrm->FSymbLibNmbr;
  627. pGDC->Values[nRow][21] = pStreamFrm->FStreamAddr;
  628. }
  629. delete pStreamFrm;
  630. pStreamFrm = NULL;
  631. }
  632. }
  633. //---------------------------------------------------------------------------
  634. void __fastcall TVMSM800M::BtnAllEditClick(TObject *Sender)
  635. {
  636. TcxButton *pBtn = (TcxButton*)Sender;
  637. //등록되어 있는 스케줄 폼을 전체 VMS에 편집하는 기능
  638. int nTag = PgVmsSch->Properties->ActivePage->Tag;
  639. if (nTag < 0 || nTag >= eSchTp_max)
  640. {
  641. Application->MessageBox(FrmLang->lblRegErr1->Caption.c_str(),//L"VMS 스케줄 일괄 관리\r\n알수 없는 스케줄 유형입니다.",
  642. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  643. return;
  644. }
  645. if (!FListSch[nTag]) return;
  646. TcxGridTableView *pTvList = FListSch[nTag];
  647. TcxGridDataController *pGDC;
  648. String sMode = "E";
  649. if (pBtn->Tag == 1)
  650. {
  651. sMode = "A"; //추가
  652. pTvList = FListFrm[nTag];
  653. }
  654. if (!pTvList) return;
  655. pGDC = pTvList->DataController;
  656. int nFormIdx = CMM_GetRecordIndex(pTvList);
  657. if (nFormIdx < 0)
  658. {
  659. Application->MessageBox(FrmLang->lblRegErr1->Caption.c_str(),//L"VMS 스케줄 일괄 관리\r\n등록되어 있는 스케줄 폼을 목록에서 먼저 선택하세요.",
  660. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  661. return;
  662. }
  663. String sSymbLibNmbr;
  664. String sStreamAddr;
  665. if (pBtn->Tag == 1)
  666. {
  667. sSymbLibNmbr = VarToStr(pGDC->Values[nFormIdx][3]);
  668. sStreamAddr = VarToStr(pGDC->Values[nFormIdx][4]);
  669. }
  670. else
  671. {
  672. sSymbLibNmbr = VarToStr(pGDC->Values[nFormIdx][20]);
  673. sStreamAddr = VarToStr(pGDC->Values[nFormIdx][21]);
  674. }
  675. String sFormId = VarToStr(pGDC->Values[nFormIdx][0]);
  676. TVmsSizeType *pVmsSizeType = APP_GetVmsSizeTypeObject(CbSizeType);
  677. if (pVmsSizeType == NULL)
  678. {
  679. Application->MessageBox(FrmLang->lblRegErr3->Caption.c_str(),//L"VMS 스케줄 일괄 관리\r\nVMS 유형을 알수 없습니다. VMS 크기 유형을 먼저 선택하세요.",
  680. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  681. return;
  682. }
  683. String sVmsType = pVmsSizeType->TypeCd;
  684. TVMSEDT0M *pFrmEdt = new TVMSEDT0M(this);
  685. pFrmEdt->FVmsTypeCd = sVmsType;
  686. pFrmEdt->FScheType = FVMS_SCH_TYPE;
  687. pFrmEdt->FScheFormType = String(nTag);
  688. pFrmEdt->FFormId = sFormId;
  689. pFrmEdt->FMode = sMode;
  690. pFrmEdt->FVmsNmbr = "";
  691. pFrmEdt->FSymbLibNmbr = sSymbLibNmbr;
  692. pFrmEdt->FStreamAddr = sStreamAddr;
  693. pFrmEdt->ShowModal();
  694. bool bOk = pFrmEdt->FSelected;
  695. delete pFrmEdt;
  696. pFrmEdt = NULL;
  697. if (bOk)
  698. {
  699. DisplayInfo();
  700. }
  701. VmsCtlrManager->LoadVmsFormUsage();
  702. FRAMEVmsSchList1->RefreshVmsFormUsage();
  703. }
  704. //---------------------------------------------------------------------------
  705. void __fastcall TVMSM800M::BtnSaveClick(TObject *Sender)
  706. {
  707. //작업한 스케줄 정보를 저장한다.
  708. if (EdVmsNmbr->Text.Trim().IsEmpty())
  709. {
  710. Application->MessageBox(lblErr2->Caption.c_str(),//L"VMS 자동 스케줄 관리\r\nVMS 목록에서 VMS를 먼저 선택한 후 작업을 진행하세요.",
  711. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  712. return;
  713. }
  714. bool bUpdate = true;
  715. String sVmsNmbr = EdVmsNmbr->Text.Trim();
  716. if (bUpdate)
  717. {
  718. String sMsg;
  719. sMsg = "VMS: " + sVmsNmbr;
  720. sMsg+= "\r\n" + lblErr3->Caption;//선택한 VMS의 자동 스케줄 정보를 저장하시겠습니까?";
  721. if (Application->MessageBox(sMsg.c_str(), FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  722. }
  723. try
  724. {
  725. ITSDb_GetConnection()->BeginTrans();
  726. DeleteVmsScenario(sVmsNmbr);
  727. for (int ii = 0; ii < eSchTp_max; ii++)
  728. {
  729. if (FListSch[ii])
  730. {
  731. //ShowMessage(String(ii) + " " + String(FListSch[ii]->Tag));
  732. SaveVmsScenario(sVmsNmbr, FListSch[ii]);
  733. }
  734. }
  735. }
  736. __finally
  737. {
  738. ITSDb_GetConnection()->CommitTrans();
  739. }
  740. Application->MessageBox(lblErr4->Caption.c_str(),//L"VMS 자동 스케줄 관리\r\nVMS 자동 스케줄 정보를 저장 하였습니다.",
  741. FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  742. VmsCtlrManager->LoadVmsFormUsage();
  743. FRAMEVmsSchList1->RefreshVmsFormUsage();
  744. CMM_SetGridRow(FRAMEVmsSchList1->CxList, FRAMEVmsSchList1->TvList, sVmsNmbr, FRAMEVmsSchList1->Column01->Index);
  745. DisplayInfo();
  746. }
  747. //---------------------------------------------------------------------------
  748. bool __fastcall TVMSM800M::SaveVmsScenario(String AVmsNmbr, TcxGridTableView *AListSch)
  749. {
  750. bool bResult = false;
  751. String sQry;
  752. TADOQuery *pADO = NULL;
  753. TcxDataController *pGDC = AListSch->DataController;
  754. String sTypeCd = String(AListSch->Tag);
  755. sQry = "INSERT INTO TB_VMS_DSPL_SCH ( \r\n"
  756. " VMS_CTLR_NMBR, \r\n"
  757. " VMS_SCH_TYPE, \r\n"
  758. " VMS_SCH_FORM_TYPE, \r\n"
  759. " PHASE, \r\n"
  760. " VMS_FORM_ID, \r\n"
  761. " DSPL_STRT_HH, \r\n"
  762. " DSPL_END_HH, \r\n"
  763. " DSPL_HH, \r\n"
  764. " FRST_VMS_IFSC_ID, \r\n"
  765. " SECD_VMS_IFSC_ID, \r\n"
  766. " THIR_VMS_IFSC_ID, \r\n"
  767. " FOUR_VMS_IFSC_ID, \r\n"
  768. " FRST_IMG_IFSC_ID, \r\n"
  769. " SECD_IMG_IFSC_ID, \r\n"
  770. " THIR_IMG_IFSC_ID, \r\n"
  771. " FOUR_IMG_IFSC_ID, \r\n"
  772. " SYMB_LIB_NMBR, \r\n"
  773. " STRM_ADDR, \r\n"
  774. " USE_YN \r\n"
  775. " ) \r\n"
  776. " VALUES( \r\n"
  777. " :p01, :p02, :p03, \r\n"
  778. " :p04, :p05, :p06, \r\n"
  779. " :p07, :p08, :p09, \r\n"
  780. " :p10, :p11, :p12, \r\n"
  781. " :p13, :p14, :p15, \r\n"
  782. " :p16, :p17, :p18, \r\n"
  783. " :p19 \r\n"
  784. " ) \r\n";
  785. try
  786. {
  787. AListSch->BeginUpdate();
  788. pGDC->BeginUpdate();
  789. int nRows = pGDC->RecordCount;
  790. try
  791. {
  792. pADO = new TADOQuery(NULL);
  793. pADO->Close();
  794. pADO->Connection = ITSDb_GetConnection();
  795. ITSDb_SQLText(pADO, sQry);
  796. for (int ii = 0; ii < nRows; ii++)
  797. {
  798. String sFormId = VarToStr(pGDC->Values[ii][0]);
  799. String sDispHH = VarToStr(pGDC->Values[ii][3]);
  800. String sUseYn = VarToStr(pGDC->Values[ii][6]);
  801. String sStrTime = VarToStr(pGDC->Values[ii][7]);
  802. String sEndTime = VarToStr(pGDC->Values[ii][8]);
  803. String sIfscId1 = VarToStr(pGDC->Values[ii][ 9]);
  804. String sIfscId2 = VarToStr(pGDC->Values[ii][10]);
  805. String sIfscId3 = VarToStr(pGDC->Values[ii][11]);
  806. String sIfscId4 = VarToStr(pGDC->Values[ii][12]);
  807. String sImgIfscId1 = VarToStr(pGDC->Values[ii][16]);
  808. String sImgIfscId2 = VarToStr(pGDC->Values[ii][17]);
  809. String sImgIfscId3 = VarToStr(pGDC->Values[ii][18]);
  810. String sImgIfscId4 = VarToStr(pGDC->Values[ii][19]);
  811. String sSymbLibNmbr = VarToStr(pGDC->Values[ii][20]);
  812. String sStrmAddr = VarToStr(pGDC->Values[ii][21]);
  813. ITSDb_SQLBind(pADO, "p01", AVmsNmbr);
  814. ITSDb_SQLBind(pADO, "p02", FVMS_SCH_TYPE);
  815. ITSDb_SQLBind(pADO, "p03", sTypeCd);
  816. ITSDb_SQLBind(pADO, "p04", String(ii+1));
  817. ITSDb_SQLBind(pADO, "p05", sFormId);
  818. ITSDb_SQLBind(pADO, "p06", sStrTime);
  819. ITSDb_SQLBind(pADO, "p07", sEndTime);
  820. ITSDb_SQLBind(pADO, "p08", sDispHH);
  821. ITSDb_SQLBind(pADO, "p09", sIfscId1);
  822. ITSDb_SQLBind(pADO, "p10", sIfscId2);
  823. ITSDb_SQLBind(pADO, "p11", sIfscId3);
  824. ITSDb_SQLBind(pADO, "p12", sIfscId4);
  825. ITSDb_SQLBind(pADO, "p13", sImgIfscId1);
  826. ITSDb_SQLBind(pADO, "p14", sImgIfscId2);
  827. ITSDb_SQLBind(pADO, "p15", sImgIfscId3);
  828. ITSDb_SQLBind(pADO, "p16", sImgIfscId4);
  829. ITSDb_SQLBind(pADO, "p17", sSymbLibNmbr);
  830. ITSDb_SQLBind(pADO, "p18", sStrmAddr);
  831. ITSDb_SQLBind(pADO, "p19", sUseYn);
  832. pADO->ExecSQL();
  833. }
  834. bResult = true;
  835. }
  836. catch(EDatabaseError &E)
  837. {
  838. ITSDb_GetConnection()->RollbackTrans();
  839. DBERRORMSG("TVMSM800M::SaveVmsScenario", String(E.ClassName()), E.Message, sQry);
  840. throw Exception(String(E.ClassName()) + E.Message);
  841. }
  842. catch(Exception &e)
  843. {
  844. ITSDb_GetConnection()->RollbackTrans();
  845. DBERRORMSG("TVMSM800M::SaveVmsScenario", String(e.ClassName()), e.Message, sQry);
  846. throw Exception(String(e.ClassName()) + e.Message);
  847. }
  848. }
  849. __finally
  850. {
  851. if (pADO)
  852. {
  853. pADO->Close();
  854. delete pADO;
  855. }
  856. pGDC->EndUpdate();
  857. AListSch->EndUpdate();
  858. }
  859. return bResult;
  860. }
  861. //---------------------------------------------------------------------------
  862. bool __fastcall TVMSM800M::SaveVmsScenarioWeek(String AVmsNmbr, TcxGridTableView *AListSch)
  863. {
  864. bool bResult = false;
  865. #if 0
  866. String sQry;
  867. TADOQuery *pADO = NULL;
  868. TcxDataController *pGDC = AListSch->DataController;
  869. String sTypeCd = String(AListSch->Tag);
  870. sQry = "INSERT INTO TB_VMS_DSPL_SCH_WEEK ( \r\n"
  871. " VMS_CTLR_NMBR, \r\n"
  872. " VMS_SCH_TYPE, \r\n"
  873. " PHASE, \r\n"
  874. " WEEK_CD, \r\n"
  875. " SCH_HH \r\n"
  876. " ) \r\n"
  877. " VALUES( \r\n"
  878. " :p01, :p02, :p03, \r\n"
  879. " :p04, :p05 \r\n"
  880. " ) \r\n";
  881. try
  882. {
  883. AListSch->BeginUpdate();
  884. pGDC->BeginUpdate();
  885. int nRows = pGDC->RecordCount;
  886. try
  887. {
  888. pADO = new TADOQuery(NULL);
  889. pADO->Close();
  890. pADO->Connection = ITSDb_GetConnection();
  891. ITSDb_SQLText(pADO, sQry);
  892. for (int ii = 0; ii < nRows; ii++)
  893. {
  894. for (int jj = 1; jj <= 7; jj++)
  895. {
  896. ITSDb_SQLBind(pADO, "p01", AVmsNmbr);
  897. ITSDb_SQLBind(pADO, "p02", FVMS_SCH_TYPE);
  898. ITSDb_SQLBind(pADO, "p03", String(ii+1));
  899. ITSDb_SQLBind(pADO, "p04", String(jj));
  900. ITSDb_SQLBind(pADO, "p05", "111111111111111111111111");
  901. pADO->ExecSQL();
  902. }
  903. }
  904. bResult = true;
  905. }
  906. catch(EDatabaseError &E)
  907. {
  908. ITSDb_GetConnection()->RollbackTrans();
  909. DBERRORMSG("TVMSM800M::SaveVmsScenarioWeek", String(E.ClassName()), E.Message, sQry);
  910. throw Exception(String(E.ClassName()) + E.Message);
  911. }
  912. catch(Exception &e)
  913. {
  914. ITSDb_GetConnection()->RollbackTrans();
  915. DBERRORMSG("TVMSM800M::SaveVmsScenarioWeek", String(e.ClassName()), e.Message, sQry);
  916. throw Exception(String(e.ClassName()) + e.Message);
  917. }
  918. }
  919. __finally
  920. {
  921. if (pADO)
  922. {
  923. pADO->Close();
  924. delete pADO;
  925. }
  926. pGDC->EndUpdate();
  927. AListSch->EndUpdate();
  928. }
  929. #endif
  930. return bResult;
  931. }
  932. //---------------------------------------------------------------------------
  933. bool __fastcall TVMSM800M::DeleteVmsScenario(String AVmsNmbr)
  934. {
  935. bool bResult = false;
  936. String sQry;
  937. TADOQuery *pADO = NULL;
  938. sQry = "DELETE TB_VMS_DSPL_SCH \r\n"
  939. " WHERE VMS_SCH_TYPE = :p01 \r\n"
  940. " AND VMS_CTLR_NMBR = :p02 \r\n";
  941. try
  942. {
  943. try
  944. {
  945. pADO = new TADOQuery(NULL);
  946. pADO->Close();
  947. pADO->Connection = ITSDb_GetConnection();
  948. ITSDb_SQLText(pADO, sQry);
  949. ITSDb_SQLBind(pADO, "p01", FVMS_SCH_TYPE);
  950. ITSDb_SQLBind(pADO, "p02", AVmsNmbr);
  951. pADO->ExecSQL();
  952. bResult = true;
  953. }
  954. catch(EDatabaseError &E)
  955. {
  956. ITSDb_GetConnection()->RollbackTrans();
  957. DBERRORMSG("TVMSM800M::DeleteVmsScenario", String(E.ClassName()), E.Message, sQry);
  958. throw Exception(String(E.ClassName()) + E.Message);
  959. }
  960. catch(Exception &e)
  961. {
  962. ITSDb_GetConnection()->RollbackTrans();
  963. DBERRORMSG("TVMSM800M::DeleteVmsScenario", String(e.ClassName()), e.Message, sQry);
  964. throw Exception(String(e.ClassName()) + e.Message);
  965. }
  966. }
  967. __finally
  968. {
  969. if (pADO)
  970. {
  971. pADO->Close();
  972. delete pADO;
  973. }
  974. }
  975. return bResult;
  976. }
  977. //---------------------------------------------------------------------------
  978. void __fastcall TVMSM800M::DrawTrafficScenarioForm()
  979. {
  980. TcxGridTableView *pGrid = FListSch[eSchTp_traffic];
  981. if (!pGrid) return;
  982. TcxDataController *pGDC = pGrid->DataController;
  983. try
  984. {
  985. pGrid->BeginUpdate();
  986. pGDC->BeginUpdate();
  987. int nRows = pGDC->RecordCount;
  988. try
  989. {
  990. for (int ii = 0; ii < nRows; ii++)
  991. {
  992. String sFormId = VarToStr(pGDC->Values[ii][0]);
  993. String sFormClr = VarToStr(pGDC->Values[ii][14]);
  994. int nFormType = VarToStr(pGDC->Values[ii][15]).ToIntDef(0);
  995. FIfscId[0] = VarToStr(pGDC->Values[ii][9]);
  996. FIfscId[1] = VarToStr(pGDC->Values[ii][10]);
  997. FIfscId[2] = VarToStr(pGDC->Values[ii][11]);
  998. FIfscId[3] = VarToStr(pGDC->Values[ii][12]);
  999. FIfscId[4] = VarToStr(pGDC->Values[ii][16]);
  1000. FIfscId[5] = VarToStr(pGDC->Values[ii][17]);
  1001. FIfscId[6] = VarToStr(pGDC->Values[ii][18]);
  1002. FIfscId[7] = VarToStr(pGDC->Values[ii][19]);
  1003. switch(nFormType)
  1004. {
  1005. case 11:// ' 소통상황(1단)
  1006. case 12:// ' 소통상황(2단)
  1007. case 13:// ' 소통상황(3단)
  1008. case 14:// ' 소통상황(4단)
  1009. if (LoadTrafficFormObjectInfo(sFormId, sFormClr, m_pEdtDesigner))
  1010. {
  1011. m_pEdtDesigner->GetVmsFormImage(ImgForm);
  1012. TStream *pImgStream = new TMemoryStream();
  1013. try
  1014. {
  1015. void *p;
  1016. Variant v;
  1017. ImgForm->Picture->Bitmap->SaveToStream(pImgStream);
  1018. int aBound[]={0, pImgStream->Size - 1};
  1019. v = VarArrayCreate(aBound, 1, varByte);
  1020. p = VarArrayLock(v);
  1021. pImgStream->Position = 0;
  1022. pImgStream->Read(p, pImgStream->Size);
  1023. VarArrayUnlock(v);
  1024. pGDC->Values[ii][1] = v;
  1025. }
  1026. __finally
  1027. {
  1028. SAFE_DELETE(pImgStream);
  1029. }
  1030. }
  1031. break;
  1032. }
  1033. }
  1034. }
  1035. catch(Exception &e)
  1036. {
  1037. }
  1038. }
  1039. __finally
  1040. {
  1041. pGDC->EndUpdate();
  1042. pGrid->EndUpdate();
  1043. }
  1044. }
  1045. //---------------------------------------------------------------------------
  1046. bool __fastcall TVMSM800M::LoadTrafficFormObjectInfo(String AFormId, String ABkColor, TVmsFormDesigner *ADesigner)
  1047. {
  1048. ADesigner->Clear();
  1049. m_pEdtDesigner->BkColorCode = ABkColor;
  1050. String sQry;
  1051. TADOQuery *pADO = NULL;
  1052. sQry = "SELECT A.*, \r\n"
  1053. " C.VMS_FONT_NAME_NM, \r\n"
  1054. " B.IMAG_DATA AS SYMB_IMG, \r\n"
  1055. " B.SYMB_EXPL AS SYMB_IMG_NM \r\n"
  1056. " FROM TB_VMS_FORM_OBJECT A, \r\n"
  1057. " TB_VMS_SYMB_LIB B, \r\n"
  1058. " TB_VMS_FONT_NAME C, \r\n"
  1059. " TB_VMS_FORM D \r\n"
  1060. " WHERE D.VMS_FORM_ID = :p01 \r\n"
  1061. " AND D.VMS_FORM_ID = A.VMS_FORM_ID \r\n"
  1062. " AND A.SYMB_LIB_NMBR = B.SYMB_LIB_NMBR(+) \r\n"
  1063. " AND A.VMS_FONT_NAME_CD = C.VMS_FONT_NAME_CD(+) \r\n"
  1064. " ORDER BY A.VMS_FORM_OBJECT_ID ASC \r\n";
  1065. try
  1066. {
  1067. try
  1068. {
  1069. pADO = new TADOQuery(NULL);
  1070. pADO->Close();
  1071. pADO->Connection = ITSDb_GetConnection();
  1072. ITSDb_SQLText(pADO, sQry);
  1073. ITSDb_SQLBind(pADO, "p01", AFormId);
  1074. ITSDb_SQLOpen(pADO);
  1075. int nDrawType;
  1076. String sObjKind;
  1077. for( ; !pADO->Eof; pADO->Next())
  1078. {
  1079. int nFormId = pADO->FieldByName("VMS_FORM_ID")->AsInteger;
  1080. int nObjId = pADO->FieldByName("VMS_FORM_OBJECT_ID")->AsInteger;
  1081. int nObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsInteger;
  1082. if (nObjType == 1 || //심볼
  1083. nObjType == 2 || //이미지
  1084. nObjType == 3 || //배경이미지
  1085. nObjType == 17 || //@소통정보이미지 (1열)
  1086. nObjType == 27 || //@소통정보이미지2(2열)
  1087. nObjType == 37 || //@소통정보이미지3(3열)
  1088. nObjType == 47 || //소통이미지4
  1089. nObjType == 200 || //동영상
  1090. nObjType == 300 || //스트리밍영상
  1091. nObjType == 406 || //@통합대기등급 이미지
  1092. nObjType == 407 || //@미세먼지등급 이미지
  1093. nObjType == 408 || //@초미세먼지등급 이미지
  1094. nObjType == 413 //@오존등급이미지
  1095. )
  1096. {
  1097. if (nObjType == 1) sObjKind = OBJKIND_IMAGEID; //Image Id
  1098. else sObjKind = OBJKIND_IMAGE; //Image
  1099. nDrawType = 1; //이미지그리기
  1100. }
  1101. else
  1102. {
  1103. sObjKind = OBJKIND_TEXT; //문자열
  1104. nDrawType = 0; //문자열그리기
  1105. }
  1106. //실재 맵핑된 구간의 정보를 표출하도록 한다.
  1107. int nBlinking = pADO->FieldByName("VMS_DSPL_BLINKING")->AsInteger;
  1108. int nPosX = pADO->FieldByName("VMS_DSPL_XCRDN")->AsInteger;
  1109. int nPosY = pADO->FieldByName("VMS_DSPL_YCRDN")->AsInteger;
  1110. TVmsFormObject *pObj = ADesigner->AddObject((VmsObjectDrawType)nDrawType);
  1111. if (!pObj) continue;
  1112. //11 , ' @구간명
  1113. //12 , ' @시점명
  1114. //13 , ' @종점명
  1115. //14 , ' @소통상황
  1116. //15 , ' @통행시간
  1117. //16 , ' @통행속도
  1118. //17 , ' @소통이미지
  1119. pObj->Text = pADO->FieldByName("VMS_DSPL_TXT")->AsString.Trim();
  1120. pObj->RunText = pObj->Text;
  1121. String sIfscId = "";
  1122. if (nObjType >= 11 && nObjType < 17)
  1123. sIfscId = FIfscId[0];
  1124. else
  1125. if (nObjType >= 21 && nObjType < 27)
  1126. sIfscId = FIfscId[1];
  1127. else
  1128. if (nObjType >= 31 && nObjType < 37)
  1129. sIfscId = FIfscId[2];
  1130. else
  1131. if (nObjType >= 41 && nObjType < 47)
  1132. sIfscId = FIfscId[3];
  1133. switch(nObjType)
  1134. {
  1135. case 17: sIfscId = FIfscId[4]; break;
  1136. case 27: sIfscId = FIfscId[5]; break;
  1137. case 37: sIfscId = FIfscId[6]; break;
  1138. case 47: sIfscId = FIfscId[7]; break;
  1139. }
  1140. if (sIfscId != "")
  1141. {
  1142. TVmsIfsc *pIfscObj;
  1143. pIfscObj = VmsIfscManager->FLists.Find(sIfscId.ToIntDef(0));
  1144. if (pIfscObj)
  1145. {
  1146. switch(nObjType)
  1147. {
  1148. case 11: case 21: case 31: case 41:
  1149. pObj->RunText = pIfscObj->VMS_IFSC_NM;
  1150. break;
  1151. case 12: case 22: case 32: case 42:
  1152. pObj->RunText = pIfscObj->DSPL_STRT_NODE_NM;
  1153. break;
  1154. case 13: case 23: case 33: case 43:
  1155. pObj->RunText = pIfscObj->DSPL_END_NODE_NM;
  1156. break;
  1157. }
  1158. }
  1159. }
  1160. else
  1161. {
  1162. if (nObjType == 201)
  1163. {
  1164. }
  1165. else
  1166. if (nObjType == 301)
  1167. {
  1168. }
  1169. }
  1170. if (nObjType == 200 || nObjType == 300)
  1171. {
  1172. pObj->EditMode = false;
  1173. }
  1174. pObj->ObjSeq = nObjId;
  1175. pObj->ObjId = nObjId;
  1176. pObj->ObjKind = sObjKind;
  1177. pObj->Tag = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  1178. pObj->ObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsString;
  1179. pObj->ObjSize = pADO->FieldByName("VMS_DSPL_SIZE")->AsInteger;
  1180. pObj->BkColorCode = pADO->FieldByName("VMS_DSPL_BKCOLOR")->AsString;
  1181. pObj->Blink = nBlinking == 1 ? true : false;
  1182. pObj->ImageId = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  1183. if (pObj->ObjKind == OBJKIND_TEXT) // 문자열
  1184. {
  1185. int nFontBold = pADO->FieldByName("VMS_FONT_BOLD")->AsInteger;
  1186. pObj->FontName = pADO->FieldByName("VMS_FONT_NAME_NM")->AsString;
  1187. pObj->FontNameCode = pADO->FieldByName("VMS_FONT_NAME_CD")->AsString;
  1188. pObj->FontColorCode = pADO->FieldByName("VMS_FONT_COLR_CD")->AsString;
  1189. pObj->FontSize = pADO->FieldByName("VMS_FONT_SIZE")->AsInteger;
  1190. pObj->FontBold = nFontBold == 1 ? true : false;
  1191. pObj->TextAlign = pADO->FieldByName("VMS_FONT_ALIGN")->AsInteger;
  1192. pObj->SetSize(pADO->FieldByName("VMS_DSPL_WIDTH")->AsInteger, pADO->FieldByName("VMS_DSPL_HEIGHT")->AsInteger);
  1193. pObj->SetRuntimeText(pObj->RunText);
  1194. }
  1195. else //if (sObjKind == "1" || sObjKind == "2") // 이미지(1), 이미지 ID(2)
  1196. {
  1197. if (pObj->ObjKind == OBJKIND_IMAGEID)
  1198. {
  1199. pObj->Text = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  1200. }
  1201. TStream *pStream = NULL;
  1202. pStream = pADO->CreateBlobStream(pADO->FieldByName("VMS_DSPL_FIGR"), bmRead);
  1203. try
  1204. {
  1205. if (pStream && pStream->Size > 0)
  1206. {
  1207. Graphics::TBitmap *Bitmap = pObj->GetBitmap();
  1208. pStream->Position = 0;
  1209. Bitmap->LoadFromStream(pStream);
  1210. pObj->SetSize(Bitmap->Width, Bitmap->Height);
  1211. }
  1212. }
  1213. __finally
  1214. {
  1215. SAFE_DELETE(pStream);
  1216. }
  1217. }
  1218. pObj->SetPos(nPosX, nPosY);
  1219. pObj->Show();
  1220. pObj->BringToFront();
  1221. }
  1222. }
  1223. catch(EDatabaseError &E)
  1224. {
  1225. DBERRORMSG("TVMSM800M::LoadTrafficFormObjectInfo", String(E.ClassName()), E.Message, sQry);
  1226. throw Exception(String(E.ClassName()) + E.Message);
  1227. }
  1228. catch(Exception &exception)
  1229. {
  1230. DBERRORMSG("TVMSM800M::LoadTrafficFormObjectInfo", String(exception.ClassName()), exception.Message, sQry);
  1231. throw Exception(String(exception.ClassName()) + exception.Message);
  1232. }
  1233. }
  1234. __finally
  1235. {
  1236. if (pADO)
  1237. {
  1238. pADO->Close();
  1239. delete pADO;
  1240. }
  1241. }
  1242. return true;
  1243. }
  1244. //---------------------------------------------------------------------------
  1245. void __fastcall TVMSM800M::DrawVideoStreamScenarioForm(int AFormScheType)
  1246. {
  1247. TcxGridTableView *pGrid = FListSch[AFormScheType];
  1248. if (!pGrid) return;
  1249. TcxDataController *pGDC = pGrid->DataController;
  1250. try
  1251. {
  1252. pGrid->BeginUpdate();
  1253. pGDC->BeginUpdate();
  1254. int nRows = pGDC->RecordCount;
  1255. try
  1256. {
  1257. for (int ii = 0; ii < nRows; ii++)
  1258. {
  1259. String sFormId = VarToStr(pGDC->Values[ii][0]);
  1260. String sFormClr = VarToStr(pGDC->Values[ii][14]);
  1261. int nFormType = VarToStr(pGDC->Values[ii][15]).ToIntDef(0);
  1262. String sSymbLibNmbr = VarToStr(pGDC->Values[ii][20]);
  1263. String sStreamAddr = VarToStr(pGDC->Values[ii][21]);
  1264. switch(nFormType)
  1265. {
  1266. case 70:// ' 동영상 Y
  1267. case 80:// ' 스트리밍영상 Y
  1268. if (LoadVideoStreamFormObjectInfo(sFormId, sFormClr, m_pEdtDesigner, sSymbLibNmbr, sStreamAddr))
  1269. {
  1270. m_pEdtDesigner->GetVmsFormImage(ImgForm);
  1271. TStream *pImgStream = new TMemoryStream();
  1272. try
  1273. {
  1274. void *p;
  1275. Variant v;
  1276. ImgForm->Picture->Bitmap->SaveToStream(pImgStream);
  1277. int aBound[]={0, pImgStream->Size - 1};
  1278. v = VarArrayCreate(aBound, 1, varByte);
  1279. p = VarArrayLock(v);
  1280. pImgStream->Position = 0;
  1281. pImgStream->Read(p, pImgStream->Size);
  1282. VarArrayUnlock(v);
  1283. pGDC->Values[ii][1] = v;
  1284. }
  1285. __finally
  1286. {
  1287. SAFE_DELETE(pImgStream);
  1288. }
  1289. }
  1290. break;
  1291. }
  1292. }
  1293. }
  1294. catch(Exception &e)
  1295. {
  1296. }
  1297. }
  1298. __finally
  1299. {
  1300. pGDC->EndUpdate();
  1301. pGrid->EndUpdate();
  1302. }
  1303. }
  1304. //---------------------------------------------------------------------------
  1305. bool __fastcall TVMSM800M::LoadVideoStreamFormObjectInfo(String AFormId, String ABkColor, TVmsFormDesigner *ADesigner, String ASymbLibNmbr, String AStreamAddr)
  1306. {
  1307. ADesigner->Clear();
  1308. m_pEdtDesigner->BkColorCode = ABkColor;
  1309. String sQry;
  1310. TADOQuery *pADO = NULL;
  1311. sQry = "SELECT A.*, \r\n"
  1312. " C.VMS_FONT_NAME_NM, \r\n"
  1313. " B.IMAG_DATA AS SYMB_IMG, \r\n"
  1314. " B.SYMB_EXPL AS SYMB_IMG_NM, \r\n"
  1315. " B.SYMB_FILE_NM AS SYMB_FILE_NM \r\n"
  1316. " FROM TB_VMS_FORM_OBJECT A, \r\n"
  1317. " TB_VMS_SYMB_LIB B, \r\n"
  1318. " TB_VMS_FONT_NAME C, \r\n"
  1319. " TB_VMS_FORM D \r\n"
  1320. " WHERE D.VMS_FORM_ID = :p01 \r\n"
  1321. " AND D.VMS_FORM_ID = A.VMS_FORM_ID \r\n"
  1322. " AND B.SYMB_LIB_NMBR = :p02 \r\n"
  1323. " AND A.VMS_FONT_NAME_CD = C.VMS_FONT_NAME_CD(+) \r\n"
  1324. " ORDER BY A.VMS_FORM_OBJECT_ID ASC \r\n";
  1325. try
  1326. {
  1327. try
  1328. {
  1329. pADO = new TADOQuery(NULL);
  1330. pADO->Close();
  1331. pADO->Connection = ITSDb_GetConnection();
  1332. ITSDb_SQLText(pADO, sQry);
  1333. ITSDb_SQLBind(pADO, "p01", AFormId);
  1334. ITSDb_SQLBind(pADO, "p02", ASymbLibNmbr);
  1335. ITSDb_SQLOpen(pADO);
  1336. int nDrawType;
  1337. String sObjKind;
  1338. for( ; !pADO->Eof; pADO->Next())
  1339. {
  1340. int nFormId = pADO->FieldByName("VMS_FORM_ID")->AsInteger;
  1341. int nObjId = pADO->FieldByName("VMS_FORM_OBJECT_ID")->AsInteger;
  1342. int nObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsInteger;
  1343. if (nObjType == 1 || //심볼
  1344. nObjType == 2 || //이미지
  1345. nObjType == 3 || //배경이미지
  1346. nObjType == 17 || //@소통정보이미지 (1열)
  1347. nObjType == 27 || //@소통정보이미지2(2열)
  1348. nObjType == 37 || //@소통정보이미지3(3열)
  1349. nObjType == 47 || //소통이미지4
  1350. nObjType == 200 || //동영상
  1351. nObjType == 300 || //스트리밍영상
  1352. nObjType == 406 || //@통합대기등급 이미지
  1353. nObjType == 407 || //@미세먼지등급 이미지
  1354. nObjType == 408 || //@초미세먼지등급 이미지
  1355. nObjType == 413 //@오존등급이미지
  1356. )
  1357. {
  1358. sObjKind = OBJKIND_IMAGEID; //Image Id
  1359. nDrawType = 1; //이미지그리기
  1360. }
  1361. else
  1362. {
  1363. sObjKind = OBJKIND_TEXT; //문자열
  1364. nDrawType = 0; //문자열그리기
  1365. }
  1366. int nBlinking = pADO->FieldByName("VMS_DSPL_BLINKING")->AsInteger;
  1367. int nPosX = pADO->FieldByName("VMS_DSPL_XCRDN")->AsInteger;
  1368. int nPosY = pADO->FieldByName("VMS_DSPL_YCRDN")->AsInteger;
  1369. TVmsFormObject *pObj = ADesigner->AddObject((VmsObjectDrawType)nDrawType);
  1370. if (!pObj) continue;
  1371. pObj->Text = pADO->FieldByName("SYMB_IMG_NM")->AsString.Trim();
  1372. if (AStreamAddr == "") pObj->RunText = pObj->Text;
  1373. else pObj->RunText = AStreamAddr; //pObj->Text;
  1374. pObj->EditMode = false;
  1375. pObj->ObjSeq = nObjId;
  1376. pObj->ObjId = nObjId;
  1377. pObj->ObjKind = sObjKind;
  1378. pObj->Tag = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  1379. pObj->ObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsString;
  1380. pObj->ObjSize = pADO->FieldByName("VMS_DSPL_SIZE")->AsInteger;
  1381. pObj->BkColorCode = pADO->FieldByName("VMS_DSPL_BKCOLOR")->AsString;
  1382. pObj->Blink = nBlinking == 1 ? true : false;
  1383. pObj->ImageId = ASymbLibNmbr; //pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  1384. pObj->SetPos(nPosX, nPosY);
  1385. if (pObj->ObjKind == OBJKIND_TEXT) // 문자열
  1386. {
  1387. int nFontBold = pADO->FieldByName("VMS_FONT_BOLD")->AsInteger;
  1388. pObj->FontName = pADO->FieldByName("VMS_FONT_NAME_NM")->AsString;
  1389. pObj->FontNameCode = pADO->FieldByName("VMS_FONT_NAME_CD")->AsString;
  1390. pObj->FontColorCode = pADO->FieldByName("VMS_FONT_COLR_CD")->AsString;
  1391. pObj->FontSize = pADO->FieldByName("VMS_FONT_SIZE")->AsInteger;
  1392. pObj->FontBold = nFontBold == 1 ? true : false;
  1393. pObj->TextAlign = pADO->FieldByName("VMS_FONT_ALIGN")->AsInteger;
  1394. pObj->SetSize(pADO->FieldByName("VMS_DSPL_WIDTH")->AsInteger, pADO->FieldByName("VMS_DSPL_HEIGHT")->AsInteger);
  1395. pObj->SetRuntimeText(pObj->RunText);
  1396. }
  1397. else //if (sObjKind == "1" || sObjKind == "2") // 이미지(1), 이미지 ID(2)
  1398. {
  1399. if (pObj->ObjKind == OBJKIND_IMAGEID)
  1400. {
  1401. pObj->Text = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  1402. }
  1403. TStream *pStream = NULL;
  1404. //pStream = pADO->CreateBlobStream(pADO->FieldByName("VMS_DSPL_FIGR"), bmRead);
  1405. pStream = pADO->CreateBlobStream(pADO->FieldByName("SYMB_IMG"), bmRead);
  1406. try
  1407. {
  1408. if (pStream && pStream->Size > 0)
  1409. {
  1410. Graphics::TBitmap *Bitmap = pObj->GetBitmap();
  1411. pStream->Position = 0;
  1412. Bitmap->LoadFromStream(pStream);
  1413. pObj->SetSize(Bitmap->Width, Bitmap->Height);
  1414. if (ASymbLibNmbr != "200" && ASymbLibNmbr != "300")
  1415. pObj->SetPos(0, 0);
  1416. }
  1417. }
  1418. __finally
  1419. {
  1420. SAFE_DELETE(pStream);
  1421. }
  1422. }
  1423. #if 0
  1424. switch(nObjType)
  1425. {
  1426. case 200: pObj->Text = ASymbLibNmbr; break;
  1427. case 201: pObj->Text = AStreamAddr; break;
  1428. case 300: pObj->Text = ASymbLibNmbr; break;
  1429. case 301: pObj->Text = AStreamAddr; break;
  1430. }
  1431. #endif
  1432. pObj->Show();
  1433. pObj->BringToFront();
  1434. }
  1435. }
  1436. catch(EDatabaseError &E)
  1437. {
  1438. DBERRORMSG("TVMSM800M::LoadTrafficFormObjectInfo", String(E.ClassName()), E.Message, sQry);
  1439. throw Exception(String(E.ClassName()) + E.Message);
  1440. }
  1441. catch(Exception &exception)
  1442. {
  1443. DBERRORMSG("TVMSM800M::LoadTrafficFormObjectInfo", String(exception.ClassName()), exception.Message, sQry);
  1444. throw Exception(String(exception.ClassName()) + exception.Message);
  1445. }
  1446. }
  1447. __finally
  1448. {
  1449. if (pADO)
  1450. {
  1451. pADO->Close();
  1452. delete pADO;
  1453. }
  1454. }
  1455. return true;
  1456. }
  1457. //---------------------------------------------------------------------------
  1458. void __fastcall TVMSM800M::LoadVmsScheduleInfo(String AVmsNmbr)
  1459. {
  1460. int ii;
  1461. String sQry;
  1462. TADOQuery *pADO = NULL;
  1463. for (ii = 0; ii < eSchTp_max; ii++)
  1464. {
  1465. if (FListSch[ii]) CMM_ClearGridTableView(FListSch[ii]);
  1466. }
  1467. sQry = "SELECT A.*, \r\n"
  1468. " B.VMS_FORM_IMAG, \r\n"
  1469. " B.VMS_TYPE_CD, \r\n"
  1470. " B.VMS_FORM_NM, \r\n"
  1471. " B.VMS_FORM_COLR_CD, \r\n"
  1472. " B.VMS_FORM_TYPE_CD \r\n"
  1473. " FROM TB_VMS_DSPL_SCH A, \r\n"
  1474. " TB_VMS_FORM B \r\n"
  1475. " WHERE A.VMS_SCH_TYPE = :p01 \r\n"
  1476. " AND A.VMS_CTLR_NMBR = :p02 \r\n"
  1477. " AND A.VMS_FORM_ID = B.VMS_FORM_ID \r\n"
  1478. // " AND B.VALID_YN = 'Y' \r\n"
  1479. " ORDER BY A.PHASE \r\n";
  1480. try
  1481. {
  1482. for (ii = 0; ii < eSchTp_max; ii++)
  1483. {
  1484. if (FListSch[ii]) FListSch[ii]->BeginUpdate();
  1485. }
  1486. TcxDataController *pDcSch;
  1487. int nRow;
  1488. try
  1489. {
  1490. int nRow;
  1491. pADO = new TADOQuery(NULL);
  1492. pADO->Close();
  1493. pADO->Connection = ITSDb_GetConnection();
  1494. ITSDb_SQLText(pADO, sQry);
  1495. ITSDb_SQLBind(pADO, "p01", FVMS_SCH_TYPE);
  1496. ITSDb_SQLBind(pADO, "p02", AVmsNmbr);
  1497. ITSDb_SQLOpen(pADO);
  1498. int nFormType;
  1499. for( ; !pADO->Eof; pADO->Next())
  1500. {
  1501. nFormType = pADO->FieldByName("VMS_SCH_FORM_TYPE")->AsInteger;
  1502. if (nFormType < eSchTp_traffic && nFormType >= eSchTp_max) continue;
  1503. if (!FListSch[nFormType]) continue;
  1504. pDcSch = FListSch[nFormType]->DataController;
  1505. nRow = pDcSch->AppendRecord();
  1506. String sStrDate = pADO->FieldByName("DSPL_STRT_HH")->AsString;
  1507. String sEndDate = pADO->FieldByName("DSPL_END_HH")->AsString;
  1508. pDcSch->Values[nRow][ 0] = pADO->FieldByName("VMS_FORM_ID")->AsString;
  1509. pDcSch->Values[nRow][ 1] = pADO->FieldByName("VMS_FORM_IMAG")->AsVariant;
  1510. pDcSch->Values[nRow][ 2] = pADO->FieldByName("FRST_VMS_IFSC_ID")->AsString;
  1511. pDcSch->Values[nRow][ 3] = pADO->FieldByName("DSPL_HH")->AsString;
  1512. pDcSch->Values[nRow][ 4] = ITSUtil_FormatStr(sStrDate, STR_HHNN);;
  1513. pDcSch->Values[nRow][ 5] = ITSUtil_FormatStr(sEndDate, STR_HHNN);;
  1514. pDcSch->Values[nRow][ 6] = pADO->FieldByName("USE_YN")->AsString;
  1515. pDcSch->Values[nRow][ 7] = sStrDate;
  1516. pDcSch->Values[nRow][ 8] = sEndDate;
  1517. pDcSch->Values[nRow][ 9] = pADO->FieldByName("FRST_VMS_IFSC_ID")->AsString;
  1518. pDcSch->Values[nRow][10] = pADO->FieldByName("SECD_VMS_IFSC_ID")->AsString;
  1519. pDcSch->Values[nRow][11] = pADO->FieldByName("THIR_VMS_IFSC_ID")->AsString;
  1520. pDcSch->Values[nRow][12] = pADO->FieldByName("FOUR_VMS_IFSC_ID")->AsString;
  1521. pDcSch->Values[nRow][13] = pADO->FieldByName("VMS_TYPE_CD")->AsString;
  1522. pDcSch->Values[nRow][14] = pADO->FieldByName("VMS_FORM_COLR_CD")->AsString;
  1523. pDcSch->Values[nRow][15] = pADO->FieldByName("VMS_FORM_TYPE_CD")->AsString;
  1524. pDcSch->Values[nRow][16] = pADO->FieldByName("FRST_IMG_IFSC_ID")->AsString;
  1525. pDcSch->Values[nRow][17] = pADO->FieldByName("SECD_IMG_IFSC_ID")->AsString;
  1526. pDcSch->Values[nRow][18] = pADO->FieldByName("THIR_IMG_IFSC_ID")->AsString;
  1527. pDcSch->Values[nRow][19] = pADO->FieldByName("FOUR_IMG_IFSC_ID")->AsString;
  1528. pDcSch->Values[nRow][20] = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  1529. pDcSch->Values[nRow][21] = pADO->FieldByName("STRM_ADDR")->AsString;
  1530. }
  1531. }
  1532. catch(EDatabaseError &E)
  1533. {
  1534. DBERRORMSG("TVMSM800M::LoadVmsScheduleInfo", String(E.ClassName()), E.Message, sQry);
  1535. throw Exception(String(E.ClassName()) + E.Message);
  1536. }
  1537. catch(Exception &e)
  1538. {
  1539. DBERRORMSG("TVMSM800M::LoadVmsScheduleInfo", String(e.ClassName()), e.Message, sQry);
  1540. throw Exception(String(e.ClassName()) + e.Message);
  1541. }
  1542. }
  1543. __finally
  1544. {
  1545. if (pADO)
  1546. {
  1547. pADO->Close();
  1548. delete pADO;
  1549. }
  1550. for (ii = 0; ii < eSchTp_max; ii++)
  1551. {
  1552. if (FListSch[ii]) FListSch[ii]->EndUpdate();
  1553. }
  1554. }
  1555. }
  1556. //---------------------------------------------------------------------------
  1557. bool __fastcall TVMSM800M::LoadVmsFormList(String AFormSizeCd)
  1558. {
  1559. int ii;
  1560. for (ii = 0; ii < eSchTp_max; ii++)
  1561. {
  1562. if (FListFrm[ii]) CMM_ClearGridTableView(FListFrm[ii]);
  1563. }
  1564. String sQry;
  1565. TADOQuery *pADO = NULL;
  1566. //스케쥴에 등록할 폼은 유효성이 Y 인 것만 목록에 표출한다.
  1567. sQry = "SELECT A.* \r\n"
  1568. " FROM TB_VMS_FORM A \r\n"
  1569. " WHERE A.VMS_TYPE_CD = :p01 \r\n"
  1570. " AND A.VALID_YN = 'Y' \r\n"
  1571. " ORDER BY A.VMS_FORM_ID \r\n";
  1572. try
  1573. {
  1574. for (ii = 0; ii < eSchTp_max; ii++)
  1575. {
  1576. if (FListFrm[ii]) FListFrm[ii]->BeginUpdate();
  1577. }
  1578. TcxDataController *pGDC;
  1579. int nRow;
  1580. try
  1581. {
  1582. pADO = new TADOQuery(NULL);
  1583. pADO->Close();
  1584. pADO->Connection = ITSDb_GetConnection();
  1585. ITSDb_SQLText(pADO, sQry);
  1586. ITSDb_SQLBind(pADO, "p01", AFormSizeCd);
  1587. ITSDb_SQLOpen(pADO);
  1588. int nFormTypeCd, nFormIdx;
  1589. for( ; !pADO->Eof; pADO->Next())
  1590. {
  1591. nFormTypeCd = pADO->FieldByName("VMS_FORM_TYPE_CD")->AsInteger;
  1592. nFormIdx = VmsGetFormTypeIdx(nFormTypeCd);
  1593. if (nFormIdx < 0) continue;
  1594. if (!FListFrm[nFormIdx]) continue;
  1595. pGDC = FListFrm[nFormIdx]->DataController;
  1596. nRow = pGDC->AppendRecord();
  1597. pGDC->Values[nRow][0] = pADO->FieldByName("VMS_FORM_ID")->AsString;
  1598. pGDC->Values[nRow][1] = pADO->FieldByName("VMS_FORM_IMAG")->AsVariant;
  1599. pGDC->Values[nRow][2] = String(nFormTypeCd);
  1600. pGDC->Values[nRow][9] = pADO->FieldByName("VMS_FORM_NM")->AsString;
  1601. if (nFormTypeCd == 70)
  1602. {
  1603. pGDC->Values[nRow][3] = "200"; //동영상기본이미지번호
  1604. }
  1605. else
  1606. if (nFormTypeCd == 80)
  1607. {
  1608. pGDC->Values[nRow][3] = "300"; //스트리밍기본이미지번호
  1609. }
  1610. else
  1611. {
  1612. pGDC->Values[nRow][3] = "";
  1613. }
  1614. pGDC->Values[nRow][4] = "";
  1615. }
  1616. }
  1617. catch(EDatabaseError &E)
  1618. {
  1619. DBERRORMSG("TVMSM800M::LoadVmsFormList", String(E.ClassName()), E.Message, sQry);
  1620. throw Exception(String(E.ClassName()) + E.Message);
  1621. }
  1622. catch(Exception &e)
  1623. {
  1624. DBERRORMSG("TVMSM800M::LoadVmsFormList", String(e.ClassName()), e.Message, sQry);
  1625. throw Exception(String(e.ClassName()) + e.Message);
  1626. }
  1627. }
  1628. __finally
  1629. {
  1630. if (pADO)
  1631. {
  1632. pADO->Close();
  1633. delete pADO;
  1634. }
  1635. for (ii = 0; ii < eSchTp_max; ii++)
  1636. {
  1637. if (FListFrm[ii]) FListFrm[ii]->EndUpdate();
  1638. }
  1639. }
  1640. return true;
  1641. }
  1642. //---------------------------------------------------------------------------
  1643. void __fastcall TVMSM800M::cxGridColumn172CustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  1644. bool &ADone)
  1645. {
  1646. int nRecordIdx = AViewInfo->GridRecord->RecordIndex;
  1647. if (nRecordIdx < 0)
  1648. {
  1649. return;
  1650. }
  1651. try
  1652. {
  1653. int nItemIdx = AViewInfo->Item->Index;
  1654. if (VarIsNull(AViewInfo->GridRecord->DisplayTexts[nItemIdx])) return;
  1655. String sEndDt = AViewInfo->GridRecord->DisplayTexts[nItemIdx];
  1656. if (sEndDt < Now().FormatString(STR_HHNN))
  1657. {
  1658. ACanvas->Canvas->Brush->Color = clSilver;
  1659. }
  1660. }
  1661. catch(Exception &e)
  1662. {
  1663. }
  1664. }
  1665. //---------------------------------------------------------------------------