VMSM410MF.cpp 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "AppGlobalF.h"
  6. #include "ITSLangTransF.h"
  7. #pragma hdrstop
  8. #include "VMSM410MF.h"
  9. //---------------------------------------------------------------------------
  10. #pragma package(smart_init)
  11. #pragma link "cxButtons"
  12. #pragma link "cxCalendar"
  13. #pragma link "cxContainer"
  14. #pragma link "cxControls"
  15. #pragma link "cxDropDownEdit"
  16. #pragma link "cxEdit"
  17. #pragma link "cxGraphics"
  18. #pragma link "cxGroupBox"
  19. #pragma link "cxLabel"
  20. #pragma link "cxLookAndFeelPainters"
  21. #pragma link "cxLookAndFeels"
  22. #pragma link "cxMaskEdit"
  23. #pragma link "cxPC"
  24. #pragma link "cxPCdxBarPopupMenu"
  25. #pragma link "cxSpinEdit"
  26. #pragma link "cxSplitter"
  27. #pragma link "cxTextEdit"
  28. #pragma link "cxTimeEdit"
  29. #pragma link "dxSkinBlack"
  30. #pragma link "dxSkinBlue"
  31. #pragma link "dxSkinCaramel"
  32. #pragma link "dxSkinCoffee"
  33. #pragma link "dxSkinDarkRoom"
  34. #pragma link "dxSkinDarkSide"
  35. #pragma link "dxSkinFoggy"
  36. #pragma link "dxSkinGlassOceans"
  37. #pragma link "dxSkiniMaginary"
  38. #pragma link "dxSkinLilian"
  39. #pragma link "dxSkinLiquidSky"
  40. #pragma link "dxSkinLondonLiquidSky"
  41. #pragma link "dxSkinMcSkin"
  42. #pragma link "dxSkinMoneyTwins"
  43. #pragma link "dxSkinOffice2007Black"
  44. #pragma link "dxSkinOffice2007Blue"
  45. #pragma link "dxSkinOffice2007Green"
  46. #pragma link "dxSkinOffice2007Pink"
  47. #pragma link "dxSkinOffice2007Silver"
  48. #pragma link "dxSkinOffice2010Black"
  49. #pragma link "dxSkinOffice2010Blue"
  50. #pragma link "dxSkinOffice2010Silver"
  51. #pragma link "dxSkinsCore"
  52. #pragma link "dxSkinscxPCPainter"
  53. #pragma link "dxSkinSeven"
  54. #pragma link "dxSkinSharp"
  55. #pragma link "dxSkinSilver"
  56. #pragma link "dxSkinStardust"
  57. #pragma link "cxRadioGroup"
  58. #pragma link "cxClasses"
  59. #pragma link "cxCustomData"
  60. #pragma link "cxData"
  61. #pragma link "cxDataStorage"
  62. #pragma link "cxDBData"
  63. #pragma link "cxFilter"
  64. #pragma link "cxGrid"
  65. #pragma link "cxGridCustomTableView"
  66. #pragma link "cxGridCustomView"
  67. #pragma link "cxGridDBTableView"
  68. #pragma link "cxGridLevel"
  69. #pragma link "cxGridTableView"
  70. #pragma link "cxStyles"
  71. #pragma link "cxCheckBox"
  72. #pragma link "cxImage"
  73. #pragma link "cxButtonEdit"
  74. #pragma link "cxBlobEdit"
  75. #pragma resource "*.dfm"
  76. TVMSM410M *VMSM410M = NULL;
  77. //---------------------------------------------------------------------------
  78. __fastcall TVMSM410M::TVMSM410M(TComponent* Owner)
  79. : TForm(Owner)
  80. {
  81. LangTrans->Translate(this, ITSDb_GetConnection());
  82. ITSSkin_Load(this);
  83. CMM_LoadForm(g_sFormsDir, this);
  84. FUpdate= false;
  85. FTitle = Caption;//"VMS 소통정보 배경이미지관리";
  86. FListSymb = new TList;
  87. EditMode = false;
  88. TvList->OptionsView->DataRowHeight = 0;
  89. TvList->OptionsView->CellAutoHeight = true;
  90. TvList->OptionsView->Indicator = false;
  91. TvList->OptionsCustomize->ColumnMoving = false;
  92. TvList->OptionsCustomize->ColumnSorting = false;
  93. TvList->Columns[0]->Width = 60;
  94. TvList->Columns[0]->Options->HorzSizing = false;
  95. //http://docwiki.embarcadero.com/RADStudio/Rio/en/Colors_in_the_VCL
  96. m_Color[ 0] =clWebDarkOrange;
  97. m_Color[ 1] =clWebRed;
  98. m_Color[ 2] =clWebDarkRed;
  99. m_Color[ 3] =clWebMaroon;
  100. m_Color[ 4] =clWebIndianRed;
  101. m_Color[ 5] =clWebSalmon;
  102. m_Color[ 6] =clWebCoral;
  103. m_Color[ 7] =clWebGold;
  104. m_Color[ 8] =clWebTomato;
  105. m_Color[ 9] =clWebCrimson;
  106. m_Color[10] =clWebBrown;
  107. m_Color[11] =clWebChocolate;
  108. m_Color[12] =clWebSandyBrown;
  109. m_Color[13] =clWebLightSalmon;
  110. m_Color[14] =clWebLightCoral;
  111. m_Color[15] =clWebOrange;
  112. m_Color[16] =clWebOrangeRed;
  113. m_Color[18] =clWebFirebrick;
  114. m_Color[19] =clWebSaddleBrown;
  115. m_Color[20] =clWebSienna;
  116. m_Color[21] =clWebPeru;
  117. m_Color[22] =clWebDarkSalmon;
  118. m_Color[23] =clWebRosyBrown;
  119. }
  120. //---------------------------------------------------------------------------
  121. TColor TVMSM410M::GetDisplayColor(int ASeq)
  122. {
  123. return g_DispColor[ASeq % MAX_DISPCOLOR];
  124. //return m_Color[ASeq % MAX_VMS_COLOR];
  125. }
  126. //---------------------------------------------------------------------------
  127. void __fastcall TVMSM410M::CommClose()
  128. {
  129. try
  130. {
  131. ClearSymbloList();
  132. SAFE_DELETE(FListSymb);
  133. CMM_SaveForm(g_sFormsDir, this);
  134. }
  135. catch(...)
  136. {
  137. }
  138. }
  139. //---------------------------------------------------------------------------
  140. void __fastcall TVMSM410M::FormShow(TObject *Sender)
  141. {
  142. Refresh();
  143. FormInit();
  144. ChangeEditMode(1);
  145. TmrShow->Enabled = true;
  146. }
  147. //---------------------------------------------------------------------------
  148. void __fastcall TVMSM410M::FormInit()
  149. {
  150. EdNmbr->Text = "";
  151. EdExpl->Text = "";
  152. EdImageFileName->Text = "";
  153. ImgPreView->Picture->Bitmap->FreeImage();
  154. ImgPreView->Picture->Bitmap = NULL;
  155. ImgTemp->Picture->Bitmap->FreeImage();
  156. ImgTemp->Picture->Bitmap = NULL;
  157. SePosX->Value = 0;
  158. SePosY->Value = 0;
  159. SeCellId->Value = 1;
  160. CMM_ClearGridTableView(TvImageCell);
  161. FNewDb = false;
  162. }
  163. //---------------------------------------------------------------------------
  164. void __fastcall TVMSM410M::TmrShowTimer(TObject *Sender)
  165. {
  166. TmrShow->Enabled = false;
  167. LoadVmsIfsc();
  168. LoadImageSymbol();
  169. }
  170. //---------------------------------------------------------------------------
  171. void __fastcall TVMSM410M::BtnCloseClick(TObject *Sender)
  172. {
  173. Close();
  174. }
  175. //---------------------------------------------------------------------------
  176. void __fastcall TVMSM410M::FormClose(TObject *Sender, TCloseAction &Action)
  177. {
  178. CommClose();
  179. VMSM410M = NULL;
  180. Action = caFree;
  181. }
  182. //---------------------------------------------------------------------------
  183. void __fastcall TVMSM410M::FormCloseQuery(TObject *Sender, bool &CanClose)
  184. {
  185. if (FUpdate)
  186. {
  187. POST_MSG(Application->MainForm->Handle, WM_DATABASE_REFRESH, WP_MSG_14, 0);
  188. }
  189. }
  190. //---------------------------------------------------------------------------
  191. void __fastcall TVMSM410M::DisplayInfo()
  192. {
  193. FormInit();
  194. int nRow = TvList->DataController->FocusedRecordIndex;
  195. if( nRow <= -1 )
  196. return;
  197. TcxGridDataController *pDc = TvList->DataController;
  198. nRow = pDc->FocusedRecordIndex;
  199. if (nRow < FListSymb->Count)
  200. {
  201. Graphics::TBitmap *bitmap = (Graphics::TBitmap*)FListSymb->Items[nRow];
  202. ImgPreView->Picture->Bitmap->Assign(bitmap);
  203. ImgTemp->Picture->Bitmap->Assign(bitmap);
  204. }
  205. EdNmbr->Text = VarToStr(pDc->Values[nRow][ColLink1->Index]);
  206. EdExpl->Text = VarToStr(pDc->Values[nRow][ColLink3->Index]);
  207. EdVmsCd->Text = VarToStr(pDc->Values[nRow][ColLink4->Index]);
  208. //셀정보 업데이트
  209. LoadImageSymbolCell(EdNmbr->Text);
  210. UpdateCellColor();
  211. ChangeEditMode(3);
  212. }
  213. //---------------------------------------------------------------------------
  214. void __fastcall TVMSM410M::BtnEditClick(TObject *Sender)
  215. {
  216. if (BtnEdit->Caption == FrmLang->lblEdit->Caption)//"편집")
  217. {
  218. ChangeEditMode(0);
  219. FNewDb = false;
  220. }
  221. else
  222. {
  223. String sId = EdNmbr->Text;
  224. ChangeEditMode(1);
  225. if (CMM_FindGridData(TvList->DataController, sId, ColLink1->Index) >= 0)
  226. {
  227. CMM_SetGridRow(CxList, TvList, sId, ColLink1->Index);
  228. DisplayInfo();
  229. }
  230. }
  231. }
  232. //---------------------------------------------------------------------------
  233. void __fastcall TVMSM410M::ChangeEditMode(int AEdit)
  234. {
  235. //LblWarn->Visible = false;
  236. FImageUpdate = false;
  237. bool bEnabled = false;
  238. switch(AEdit)
  239. {
  240. case 0: //편집버튼클릭
  241. {
  242. BtnEdit->Enabled = true;
  243. BtnInsert->Enabled = false;
  244. BtnDelete->Enabled = false;
  245. BtnSave->Enabled = true;
  246. BtnEdit->Caption = FrmLang->lblCancel->Caption;//"취소";
  247. BtnEdit->Hint = FrmLang->lblCancel->Hint;//데이터 편집 취소";
  248. EditMode = true;
  249. //EdImageFileName->Enabled = false;
  250. EdImageFileName->Enabled = true;
  251. //LblWarn->Visible = true;
  252. }
  253. break;
  254. case 1: //편집[취소]버튼클릭
  255. {
  256. FormInit(); //화면을 모두 지운다.
  257. BtnEdit->Enabled = false;
  258. BtnInsert->Enabled = true;
  259. BtnDelete->Enabled = false;
  260. BtnSave->Enabled = false;
  261. BtnEdit->Caption = FrmLang->lblEdit->Caption;//"편집";
  262. BtnEdit->Hint = FrmLang->lblEdit->Hint;//데이터 편집";
  263. //bEnabled = true;
  264. EditMode = false;
  265. EdImageFileName->Enabled = false;
  266. }
  267. break;
  268. case 2: //추가
  269. {
  270. BtnEdit->Enabled = true;
  271. BtnInsert->Enabled = false;
  272. BtnDelete->Enabled = false;
  273. BtnSave->Enabled = true;
  274. BtnEdit->Caption = FrmLang->lblCancel->Caption;//"취소";
  275. BtnEdit->Hint = FrmLang->lblCancel->Hint;//데이터 편집 취소";
  276. EditMode = true;
  277. EdImageFileName->Enabled = true;
  278. }
  279. break;
  280. case 3: //수정모드
  281. {
  282. BtnEdit->Enabled = true;
  283. BtnInsert->Enabled = true;
  284. BtnDelete->Enabled = true;
  285. BtnSave->Enabled = false;
  286. BtnEdit->Caption = FrmLang->lblEdit->Caption;//"편집";
  287. BtnEdit->Hint = FrmLang->lblEdit->Hint;//데이터 편집";
  288. bEnabled = true;
  289. EditMode = false;
  290. //EdImageFileName->Enabled = false;
  291. EdImageFileName->Enabled = true;
  292. }
  293. break;
  294. }
  295. BtnSaveImgFile->Enabled = false;
  296. if (ImgPreView->Picture->Bitmap != NULL)
  297. {
  298. if (ImgPreView->Picture->Bitmap->Height != 0)
  299. {
  300. BtnSaveImgFile->Enabled = true;
  301. }
  302. }
  303. if (AEdit == 0 || AEdit == 2)
  304. {
  305. PnlCmd->Enabled = true;
  306. GrpList->Enabled = false;
  307. }
  308. else
  309. {
  310. PnlCmd->Enabled = false;
  311. GrpList->Enabled = true;
  312. }
  313. //PnlEdit->Enabled = EditMode;
  314. }
  315. //---------------------------------------------------------------------------
  316. bool __fastcall TVMSM410M::UpdateVmsImage(String ANmbr, String AExpl)
  317. {
  318. String sQry;
  319. TADOQuery *pADO = NULL;
  320. sQry = "UPDATE TB_VMS_SYMB_LIB \r\n"
  321. " SET RGST_DT = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS'), \r\n"
  322. " SYMB_EXPL = :p02, \r\n"
  323. " IMAG_DATA = :p03, \r\n"
  324. " UPDT_DT = TO_CHAR(sysdate, 'YYYYMMDDHH24MISS') \r\n"
  325. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  326. TMemoryStream *dataStream = new TMemoryStream();
  327. //ImgPreView->Picture->Bitmap->SaveToStream(dataStream);
  328. ImgTemp->Picture->Bitmap->SaveToStream(dataStream);
  329. try
  330. {
  331. try
  332. {
  333. pADO = new TADOQuery(NULL);
  334. pADO->Close();
  335. pADO->Connection = ITSDb_GetConnection();
  336. ITSDb_SQLText(pADO, sQry);
  337. ITSDb_SQLBind(pADO, "p01", ANmbr);
  338. ITSDb_SQLBind(pADO, "p02", AExpl);
  339. pADO->Parameters->ParamByName("p03")->LoadFromStream(dataStream, ftBlob);
  340. pADO->ExecSQL();
  341. if (FImageUpdate)
  342. {
  343. sQry = "UPDATE TB_VMS_FORM_OBJECT \r\n"
  344. " SET VMS_DSPL_FIGR = :p03 \r\n"
  345. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  346. ITSDb_SQLText(pADO, sQry);
  347. ITSDb_SQLBind(pADO, "p01", ANmbr);
  348. pADO->Parameters->ParamByName("p03")->LoadFromStream(dataStream, ftBlob);
  349. pADO->ExecSQL();
  350. POST_MSG(Application->MainForm->Handle, WM_DATABASE_REFRESH, WP_MSG_14, 0);
  351. CComm_VmsFormUpdate();
  352. }
  353. return true;
  354. }
  355. catch(EDatabaseError &E)
  356. {
  357. DBERRORMSG("VMS image update", String(E.ClassName()), E.Message, sQry);
  358. throw Exception(String(E.ClassName()) + E.Message);
  359. }
  360. catch(Exception &e)
  361. {
  362. DBERRORMSG("VMS image update", String(e.ClassName()), e.Message, sQry);
  363. throw Exception(String(e.ClassName()) + e.Message);
  364. }
  365. }
  366. __finally
  367. {
  368. if (pADO)
  369. {
  370. pADO->Close();
  371. delete pADO;
  372. }
  373. if (dataStream) delete dataStream;
  374. dataStream = NULL;
  375. }
  376. return true;
  377. }
  378. //---------------------------------------------------------------------------
  379. bool __fastcall TVMSM410M::InsertVmsImage(String ANmbr, String AExpl, String AFileName, String ATypeCd)
  380. {
  381. String sQry;
  382. TADOQuery *pADO = NULL;
  383. sQry = "INSERT INTO TB_VMS_SYMB_LIB(SYMB_LIB_NMBR, RGST_DT, SYMB_EXPL, IMAG_DATA, SYMB_FILE_NM, SYMB_TYPE, AVI_DATA, IMAG_SIZE, UPDT_DT, DEL_YN) \r\n"
  384. " VALUES(:p01, :p02, :p03, :p04, NULL, :p05, NULL, :p06, :p07, 'N' ) \r\n";
  385. TMemoryStream *dataStream = new TMemoryStream();
  386. //ImgPreView->Picture->Bitmap->SaveToStream(dataStream);
  387. ImgTemp->Picture->Bitmap->SaveToStream(dataStream);
  388. try
  389. {
  390. try
  391. {
  392. pADO = new TADOQuery(NULL);
  393. pADO->Close();
  394. pADO->Connection = ITSDb_GetConnection();
  395. ITSDb_SQLText(pADO, sQry);
  396. ITSDb_SQLBind(pADO, "p01", ANmbr);
  397. ITSDb_SQLBind(pADO, "p02", Now().FormatString("yyyymmddhhnnss"));
  398. ITSDb_SQLBind(pADO, "p03", AExpl);
  399. pADO->Parameters->ParamByName("p04")->LoadFromStream(dataStream, ftBlob);
  400. ITSDb_SQLBind(pADO, "p05", ATypeCd);
  401. ITSDb_SQLBind(pADO, "p06", FFileSize);
  402. ITSDb_SQLBind(pADO, "p07", Now().FormatString("yyyymmddhhnnss"));
  403. pADO->ExecSQL();
  404. return true;
  405. }
  406. catch(EDatabaseError &E)
  407. {
  408. DBERRORMSG("VMS image update", String(E.ClassName()), E.Message, sQry);
  409. throw Exception(String(E.ClassName()) + E.Message);
  410. }
  411. catch(Exception &e)
  412. {
  413. DBERRORMSG("VMS image update", String(e.ClassName()), e.Message, sQry);
  414. throw Exception(String(e.ClassName()) + e.Message);
  415. }
  416. }
  417. __finally
  418. {
  419. if (pADO)
  420. {
  421. pADO->Close();
  422. delete pADO;
  423. }
  424. if (dataStream) delete dataStream;
  425. dataStream = NULL;
  426. }
  427. return true;
  428. }
  429. //---------------------------------------------------------------------------
  430. void __fastcall TVMSM410M::BtnSaveClick(TObject *Sender)
  431. {
  432. if (EdNmbr->Text.IsEmpty())
  433. {
  434. Application->MessageBox(FrmLang->lblImage1->Caption.c_str(),//L"VMS 이미지정보 저장\r\n이미지 번호를 입력하세요.",
  435. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  436. return;
  437. }
  438. if (EdExpl->Text.Trim().IsEmpty())
  439. {
  440. Application->MessageBox(FrmLang->lblImage2->Caption.c_str(),//L"VMS 이미지정보 저장\r\n이미지 설명을 입력하세요.",
  441. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  442. return;
  443. }
  444. String sNmbr = EdNmbr->Text;
  445. String sExpl = EdExpl->Text.Trim();
  446. if (TvImageCell->DataController->RecordCount == 0)
  447. {
  448. String sMsg;
  449. sMsg = FrmLang->lblImage7->Caption + ": " + sNmbr;//"VMS이미지번호: " + sNmbr;
  450. sMsg+= "\r\n" + lblText1->Caption;//"이미지 셀 정보가 없습니다.\r\n소통정보 배경이미지 정보를 저장하시겠습니까?";
  451. if (Application->MessageBox(sMsg.c_str(), FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  452. }
  453. bool bIfscSet = true;
  454. TcxGridDataController *pGDC = TvImageCell->DataController;
  455. int nRows = pGDC->RecordCount;
  456. for (int ii = 0; ii < nRows; ii++)
  457. {
  458. String sIfscId = VarToStr(pGDC->Values[ii][ColIfscId->Index]);
  459. if (sIfscId == "")
  460. {
  461. bIfscSet = false;
  462. break;
  463. }
  464. }
  465. if (!bIfscSet)
  466. {
  467. String sMsg;
  468. sMsg = FrmLang->lblImage7->Caption + ": " + sNmbr;//"VMS이미지번호: " + sNmbr;
  469. sMsg+= "\r\n" + lblText2->Caption;//"이미지 셀 정보에 VMS 정보제공구간이 설정되어 있지 않습니다.\r\n소통정보 배경이미지 정보를 저장하시겠습니까?";
  470. if (Application->MessageBox(sMsg.c_str(), FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  471. }
  472. bool bResult = false;
  473. if (!FNewDb)
  474. {
  475. bResult = UpdateVmsImage(sNmbr, sExpl);
  476. }
  477. else
  478. {
  479. if (EdImageFileName->Text.Trim().IsEmpty())
  480. {
  481. Application->MessageBox(FrmLang->lblImage3->Caption.c_str(),//L"VMS 이미지정보 저장\r\n이미지를 선택하셔야 합니다.",
  482. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  483. return;
  484. }
  485. bResult = InsertVmsImage(sNmbr, sExpl, "", "SBT1");
  486. }
  487. if (!bResult) return;
  488. String ANmbr = sNmbr;
  489. String sQry;
  490. TADOQuery *pADO = NULL;
  491. try
  492. {
  493. try
  494. {
  495. pADO = new TADOQuery(NULL);
  496. pADO->Close();
  497. pADO->Connection = ITSDb_GetConnection();
  498. sQry = "DELETE TB_VMS_SYMB_IFSC \r\n"
  499. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  500. ITSDb_SQLText(pADO, sQry);
  501. ITSDb_SQLBind(pADO, "p01", ANmbr);
  502. pADO->ExecSQL();
  503. sQry = "INSERT INTO TB_VMS_SYMB_IFSC ( \r\n"
  504. " SYMB_LIB_NMBR, \r\n"
  505. " CELL_ID, \r\n"
  506. " POSX, \r\n"
  507. " POSY, \r\n"
  508. " VMS_IFSC_ID) \r\n"
  509. " VALUES ( \r\n"
  510. " :p01, \r\n"
  511. " :p02, \r\n"
  512. " :p03, \r\n"
  513. " :p04, \r\n"
  514. " :p05 ) \r\n";
  515. ITSDb_SQLText(pADO, sQry);
  516. ITSDb_GetConnection()->BeginTrans();
  517. TcxGridDataController *pGDC = TvImageCell->DataController;
  518. int nRows = pGDC->RecordCount;
  519. for (int ii = 0; ii < nRows; ii++)
  520. {
  521. String sCellId = VarToStr(pGDC->Values[ii][ColCellId->Index]);
  522. String sPosX = VarToStr(pGDC->Values[ii][ColCellPosX->Index]);
  523. String sPosY = VarToStr(pGDC->Values[ii][ColCellPosY->Index]);
  524. String sIfscId = VarToStr(pGDC->Values[ii][ColIfscId->Index]);
  525. ITSDb_SQLBind(pADO, "p01", ANmbr);
  526. ITSDb_SQLBind(pADO, "p02", sCellId);
  527. ITSDb_SQLBind(pADO, "p03", sPosX);
  528. ITSDb_SQLBind(pADO, "p04", sPosY);
  529. ITSDb_SQLBind(pADO, "p05", sIfscId);
  530. ITSDb_SQLExec(pADO);
  531. }
  532. ITSDb_GetConnection()->CommitTrans();
  533. bResult = true;
  534. }
  535. catch(EDatabaseError &E)
  536. {
  537. ITSDb_GetConnection()->RollbackTrans();
  538. DBERRORMSG("VMS image cell save", String(E.ClassName()), E.Message, sQry);
  539. throw Exception(String(E.ClassName()) + E.Message);
  540. }
  541. catch(Exception &e)
  542. {
  543. ITSDb_GetConnection()->RollbackTrans();
  544. DBERRORMSG("VMS image cell save", String(e.ClassName()), e.Message, sQry);
  545. throw Exception(String(e.ClassName()) + e.Message);
  546. }
  547. }
  548. __finally
  549. {
  550. if (pADO)
  551. {
  552. pADO->Close();
  553. delete pADO;
  554. }
  555. }
  556. if (bResult)
  557. {
  558. Application->MessageBox(lblText3->Caption.c_str(),//L"VMS 소통정보 배경이미지정보 저장\r\nVMS 소통정보 배경이미지정보를 저장 하였습니다.",
  559. FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  560. FUpdate = true;
  561. LoadImageSymbol();
  562. CMM_SetGridRow(CxList, TvList, sNmbr, ColLink1->Index);
  563. DisplayInfo();
  564. CComm_VmsImageTrafficUpdate(); // VMS서버로 이미지가 업데이트 되었음을 알린다.
  565. POST_MSG(Application->MainForm->Handle, WM_DATABASE_REFRESH, WP_MSG_14, 0);
  566. }
  567. }
  568. //---------------------------------------------------------------------------
  569. void __fastcall TVMSM410M::BtnInsertClick(TObject *Sender)
  570. {
  571. FormInit();
  572. //신규아이디를 얻어와서 화면을 초기화한다.
  573. int nNmbr;
  574. if (!GetNextVmsImgeId(nNmbr))
  575. {
  576. Application->MessageBox(FrmLang->lblImage4->Caption.c_str(),//L"새로운 VMS 이미지정보를 생성하지 못하였습니다.\r\n프로그램 종료후에 다시 시도해 보세요.",
  577. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  578. return;
  579. }
  580. EdNmbr->Text = String(nNmbr);
  581. ChangeEditMode(2);
  582. FNewDb = true;
  583. EdImageFileNameClick((TObject *)EdImageFileName);
  584. }
  585. //---------------------------------------------------------------------------
  586. bool __fastcall TVMSM410M::GetNextVmsImgeId(int &ANmbr)
  587. {
  588. String sQry;
  589. TADOQuery *pADO = NULL;
  590. sQry = "SELECT NVL(MAX(SYMB_LIB_NMBR), 6999)+1 AS NEWID FROM TB_VMS_SYMB_LIB WHERE SYMB_LIB_NMBR BETWEEN 7000 AND 7999 \r\n";
  591. try
  592. {
  593. try
  594. {
  595. pADO = new TADOQuery(NULL);
  596. pADO->Close();
  597. pADO->Connection = ITSDb_GetConnection();
  598. pADO->SQL->Clear();
  599. pADO->SQL->Text = sQry;
  600. pADO->Open();
  601. ANmbr = pADO->FieldByName("NEWID")->AsInteger;
  602. return true;
  603. }
  604. catch(EDatabaseError &E)
  605. {
  606. DBERRORLOG("VMS image id query", String(E.ClassName()), E.Message, sQry);
  607. throw Exception(String(E.ClassName()) + E.Message);
  608. }
  609. catch(Exception &e)
  610. {
  611. DBERRORLOG("VMS image id query", String(e.ClassName()), e.Message, sQry);
  612. throw Exception(String(e.ClassName()) + e.Message);
  613. }
  614. }
  615. __finally
  616. {
  617. if (pADO)
  618. {
  619. pADO->Close();
  620. delete pADO;
  621. }
  622. }
  623. return false;
  624. }
  625. //---------------------------------------------------------------------------
  626. bool __fastcall TVMSM410M::CheckImageUse(String ANmbr)
  627. {
  628. String sQry;
  629. TADOQuery *pADO = NULL;
  630. sQry = "SELECT COUNT(1) AS CNT \r\n"
  631. " FROM TB_VMS_FORM_OBJECT \r\n"
  632. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  633. try
  634. {
  635. try
  636. {
  637. pADO = new TADOQuery(NULL);
  638. pADO->Close();
  639. pADO->Connection = ITSDb_GetConnection();
  640. ITSDb_SQLText(pADO, sQry);
  641. ITSDb_SQLBind(pADO, "p01", ANmbr);
  642. ITSDb_SQLOpen(pADO);
  643. if (pADO->FieldByName("CNT")->AsInteger > 0)
  644. {
  645. Application->MessageBox(FrmLang->lblImage5->Caption.c_str(),//L"삭제할 이미지가 VMS 폼에서 사용되고 있습니다.\r\n먼저 해당 폼에서 삭제해주시기 바랍니다.",
  646. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  647. return false;
  648. }
  649. }
  650. catch(EDatabaseError &E)
  651. {
  652. DBERRORMSG("VMS image usage query", String(E.ClassName()), E.Message, sQry);
  653. throw Exception(String(E.ClassName()) + E.Message);
  654. }
  655. catch(Exception &e)
  656. {
  657. DBERRORMSG("VMS image usage query", String(e.ClassName()), e.Message, sQry);
  658. throw Exception(String(e.ClassName()) + e.Message);
  659. }
  660. }
  661. __finally
  662. {
  663. if (pADO)
  664. {
  665. pADO->Close();
  666. delete pADO;
  667. }
  668. }
  669. return true;
  670. }
  671. //---------------------------------------------------------------------------
  672. bool __fastcall TVMSM410M::DelVmsImage(String ANmbr)
  673. {
  674. String sQry;
  675. TADOQuery *pADO = NULL;
  676. try
  677. {
  678. try
  679. {
  680. pADO = new TADOQuery(NULL);
  681. pADO->Close();
  682. pADO->Connection = ITSDb_GetConnection();
  683. sQry = "DELETE TB_VMS_SYMB_IFSC \r\n"
  684. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  685. ITSDb_SQLText(pADO, sQry);
  686. ITSDb_SQLBind(pADO, "p01", ANmbr);
  687. pADO->ExecSQL();
  688. #if 0
  689. sQry = "DELETE TB_VMS_SYMB_LIB \r\n"
  690. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  691. #else
  692. sQry = "UPDATE TB_VMS_SYMB_LIB \r\n"
  693. " SET DEL_YN = 'Y', \r\n"
  694. " UPDT_DT = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') \r\n"
  695. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  696. #endif
  697. ITSDb_SQLText(pADO, sQry);
  698. ITSDb_SQLBind(pADO, "p01", ANmbr);
  699. pADO->ExecSQL();
  700. return true;
  701. }
  702. catch(EDatabaseError &E)
  703. {
  704. DBERRORMSG("VMS image delete", String(E.ClassName()), E.Message, sQry);
  705. throw Exception(String(E.ClassName()) + E.Message);
  706. }
  707. catch(Exception &e)
  708. {
  709. DBERRORMSG("VMS image delete", String(e.ClassName()), e.Message, sQry);
  710. throw Exception(String(e.ClassName()) + e.Message);
  711. }
  712. }
  713. __finally
  714. {
  715. if (pADO)
  716. {
  717. pADO->Close();
  718. delete pADO;
  719. }
  720. }
  721. return true;
  722. }
  723. //---------------------------------------------------------------------------
  724. void __fastcall TVMSM410M::BtnDeleteClick(TObject *Sender)
  725. {
  726. int nIdx = TvList->DataController->FocusedRecordIndex;
  727. if (nIdx < 0) return;
  728. String sId = EdNmbr->Text;
  729. if (sId.IsEmpty())
  730. {
  731. Application->MessageBox(FrmLang->lblImage6->Caption.c_str(),//L"삭제할 VMS 이미지를 목록에서 선택하세요.\r\n목록에서 더블클릭하여 선택합니다.",
  732. FTitle.c_str(), MB_OK|MB_ICONERROR|MB_APPLMODAL);
  733. return;
  734. }
  735. if (!CheckImageUse(sId)) return;
  736. String sMsg;
  737. sMsg = FrmLang->lblImage7->Caption + ": " + sId;//"VMS이미지번호: " + sId;
  738. sMsg+= "\r\n" + FrmLang->lblImage8->Caption;//"선택하신 VMS 이미지 정보를 삭제하시겠습니까?";
  739. if (Application->MessageBox(sMsg.c_str(), FTitle.c_str(), MB_YESNO|MB_ICONQUESTION|MB_APPLMODAL) != IDYES) return;
  740. if (DelVmsImage(sId))
  741. {
  742. FUpdate = true;
  743. Application->MessageBox(FrmLang->lblImage9->Caption.c_str(),//L"VMS 이미지정보삭제\r\nVMS 이미지정보를 삭제 하였습니다.",
  744. FTitle.c_str(), MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  745. FormInit();
  746. ChangeEditMode(1);
  747. LoadImageSymbol();
  748. CComm_VmsImageTrafficUpdate(); // VMS서버로 이미지가 업데이트 되었음을 알린다.
  749. POST_MSG(Application->MainForm->Handle, WM_DATABASE_REFRESH, WP_MSG_14, 0);
  750. }
  751. }
  752. //---------------------------------------------------------------------------
  753. void __fastcall TVMSM410M::BtnSaveImgFileClick(TObject *Sender)
  754. {
  755. SaveDialog->Title = FTitle;
  756. SaveDialog->InitialDir = ExtractFilePath(Application->ExeName);
  757. SaveDialog->Filter = "Bitmap image Files (*.bmp)|*.bmp";
  758. SaveDialog->FileName = EdNmbr->Text + ".bmp";
  759. if (SaveDialog->Execute())
  760. {
  761. try {
  762. String sFileName = SaveDialog->FileName;
  763. int iRet = sFileName.Pos(".bmp");
  764. if (iRet == 0)
  765. {
  766. sFileName = SaveDialog->FileName + ".bmp";
  767. }
  768. //ImgPreView->Picture->SaveToFile(sFileName);
  769. ImgTemp->Picture->SaveToFile(sFileName);
  770. }
  771. catch (Exception &exception)
  772. {
  773. Application->ShowException(&exception);
  774. }
  775. }
  776. }
  777. //---------------------------------------------------------------------------
  778. void __fastcall TVMSM410M::EdImageFileNameClick(TObject *Sender)
  779. {
  780. OpenBmp->Title = FTitle;
  781. OpenBmp->FileName = "";
  782. OpenBmp->Execute();
  783. }
  784. //---------------------------------------------------------------------------
  785. void __fastcall TVMSM410M::OpenBmpCanClose(TObject *Sender, bool &CanClose)
  786. {
  787. String sFName = OpenBmp->FileName;
  788. sFName = sFName.UpperCase();
  789. String sMsgTitle, sMsgString;
  790. sMsgTitle = FrmLang->lblImage10->Caption;//"VMS 이미지 선택";
  791. if (sFName.SubString(sFName.Length()-2, 3) != "BMP")
  792. {
  793. sMsgString = FrmLang->lblImage11->Caption;//"BMP 파일만 적용 가능합니다.";
  794. Application->MessageBox(sMsgString.c_str(), sMsgTitle.c_str(), MB_OK|MB_ICONWARNING|MB_APPLMODAL);
  795. return;
  796. }
  797. try
  798. {
  799. FFileSize = ITSUtil_GetFileSize(sFName);
  800. if (FFileSize <= 0)
  801. {
  802. sMsgString = FrmLang->lblImage12->Caption;//"이미지 파일을 읽어 오는데 실패하였습니다.";
  803. Application->MessageBox(sMsgString.c_str(), sMsgTitle.c_str(), MB_OK|MB_ICONWARNING|MB_APPLMODAL);
  804. return;
  805. }
  806. #if 0
  807. if (FFileSize > (1024 * 32)) // Max 32Kbytes
  808. {
  809. sMsgString = FrmLang->lblImage13->Caption;//"이미지 파일의 최대 크기는 32KBytes를 넘을 수 없습니다.\r\n이미지 파일의 용량을 줄여 주세요.";
  810. Application->MessageBox(sMsgString.c_str(), sMsgTitle.c_str(), MB_OK|MB_ICONWARNING|MB_APPLMODAL);
  811. return;
  812. }
  813. #endif
  814. //EdImageSize->Text = String(dwFileSize);//GetFileSize(sFName));
  815. EdImageFileName->Text = sFName;
  816. ImgPreView->Picture->Bitmap->FreeImage();
  817. ImgPreView->Picture->Bitmap = NULL;
  818. ImgPreView->Picture->Bitmap->LoadFromFile(sFName);
  819. ImgTemp->Picture->Bitmap->FreeImage();
  820. ImgTemp->Picture->Bitmap = NULL;
  821. ImgTemp->Picture->Bitmap->LoadFromFile(sFName);
  822. FImageUpdate = true;
  823. }
  824. catch(...)
  825. {
  826. }
  827. }
  828. //---------------------------------------------------------------------------
  829. void __fastcall TVMSM410M::ClearSymbloList()
  830. {
  831. for(int ii = 0; ii < FListSymb->Count; ii++)
  832. {
  833. Graphics::TBitmap *bitmap = (Graphics::TBitmap *)FListSymb->Items[ii];
  834. delete bitmap;
  835. }
  836. FListSymb->Clear();
  837. }
  838. //---------------------------------------------------------------------------
  839. void __fastcall TVMSM410M::LoadImageSymbol()
  840. {
  841. FormInit();
  842. CMM_ClearGridTableView(TvList);
  843. ClearSymbloList();
  844. String sQry;
  845. TADOQuery *pADO = NULL;
  846. sQry = "SELECT SYMB_LIB_NMBR, \r\n"
  847. " IMAG_DATA, \r\n"
  848. " SYMB_EXPL, SYMB_FILE_NM, SYMB_TYPE \r\n"
  849. " FROM TB_VMS_SYMB_LIB \r\n"
  850. " WHERE SYMB_LIB_NMBR BETWEEN 7000 AND 7999 \r\n"
  851. " AND DEL_YN = 'N' \r\n"
  852. " ORDER BY SYMB_LIB_NMBR \r\n";
  853. int nRowHeight = 0;
  854. try
  855. {
  856. int nRow;
  857. TcxDataController *pGDC = TvList->DataController;
  858. TvList->BeginUpdate();
  859. try
  860. {
  861. pADO = new TADOQuery(NULL);
  862. pADO->Close();
  863. pADO->Connection = ITSDb_GetConnection();
  864. ITSDb_SQLText(pADO, sQry);
  865. ITSDb_SQLOpen(pADO);
  866. for( ; !pADO->Eof; pADO->Next())
  867. {
  868. nRow = pGDC->AppendRecord();
  869. pGDC->Values[nRow][ColLink1->Index] = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  870. pGDC->Values[nRow][ColLink2->Index] = pADO->FieldByName("IMAG_DATA")->AsVariant;
  871. pGDC->Values[nRow][ColLink3->Index] = pADO->FieldByName("SYMB_EXPL")->AsString;
  872. pGDC->Values[nRow][ColLink4->Index] = pADO->FieldByName("SYMB_TYPE")->AsString;
  873. Graphics::TBitmap *bitmap = new Graphics::TBitmap;
  874. bitmap->LoadFromStream(pADO->CreateBlobStream(pADO->FieldByName("IMAG_DATA"), bmRead));
  875. FListSymb->Add(bitmap);
  876. if (bitmap->Height+2 > nRowHeight) nRowHeight = bitmap->Height+3;
  877. }
  878. }
  879. catch(EDatabaseError &E)
  880. {
  881. DBERRORMSG("TVMSM410M::LoadImageSymbol", String(E.ClassName()), E.Message, sQry);
  882. throw Exception(String(E.ClassName()) + E.Message);
  883. }
  884. catch(Exception &e)
  885. {
  886. DBERRORMSG("TVMSM410M::LoadImageSymbol", String(e.ClassName()), e.Message, sQry);
  887. throw Exception(String(e.ClassName()) + e.Message);
  888. }
  889. }
  890. __finally
  891. {
  892. if (pADO)
  893. {
  894. pADO->Close();
  895. delete pADO;
  896. }
  897. TvList->OptionsView->DataRowHeight = nRowHeight;
  898. TvList->EndUpdate();
  899. }
  900. }
  901. //---------------------------------------------------------------------------
  902. void __fastcall TVMSM410M::LoadVmsIfsc()
  903. {
  904. CMM_ClearGridTableView(TvAxis);
  905. String sQry;
  906. TADOQuery *pADO = NULL;
  907. sQry = "SELECT C.VMS_CTLR_NMBR, C.VMS_CTLR_ID, C.VMS_NM, \r\n"
  908. " A.VMS_IFSC_ID, A.VMS_IFSC_NM, \r\n"
  909. " A.DSPL_STRT_NODE_NM, A.DSPL_END_NODE_NM, \r\n"
  910. " A.AXIS_YN \r\n"
  911. " FROM TB_VMS_IFSC A, \r\n"
  912. " TB_VMS_RLTN_IFSC B, \r\n"
  913. " (SELECT VMS_CTLR_NMBR, \r\n"
  914. " VMS_CTLR_ID, \r\n"
  915. " VMS_NM \r\n"
  916. " FROM TB_VMS_CTLR ) C \r\n"
  917. " WHERE A.USE_YN = 'Y' \r\n"
  918. " AND A.VMS_IFSC_ID = B.VMS_IFSC_ID \r\n"
  919. " AND B.VMS_CTLR_NMBR = C.VMS_CTLR_NMBR \r\n";
  920. try
  921. {
  922. int nRow;
  923. TcxDataController *pGDC = TvAxis->DataController;
  924. TvAxis->BeginUpdate();
  925. try
  926. {
  927. pADO = new TADOQuery(NULL);
  928. pADO->Close();
  929. pADO->Connection = ITSDb_GetConnection();
  930. ITSDb_SQLText(pADO, sQry);
  931. ITSDb_SQLOpen(pADO);
  932. for( ; !pADO->Eof; pADO->Next())
  933. {
  934. nRow = pGDC->AppendRecord();
  935. pGDC->Values[nRow][Col00->Index] = pADO->FieldByName("VMS_CTLR_ID")->AsString;
  936. pGDC->Values[nRow][Col01->Index] = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  937. pGDC->Values[nRow][Col02->Index] = pADO->FieldByName("VMS_IFSC_NM")->AsString;
  938. pGDC->Values[nRow][Col03->Index] = pADO->FieldByName("DSPL_STRT_NODE_NM")->AsString;
  939. pGDC->Values[nRow][Col04->Index] = pADO->FieldByName("DSPL_END_NODE_NM")->AsString;
  940. pGDC->Values[nRow][Col05->Index] = pADO->FieldByName("AXIS_YN")->AsString;
  941. }
  942. }
  943. catch(EDatabaseError &E)
  944. {
  945. DBERRORMSG("TVMSM410M::LoadVmsIfsc", String(E.ClassName()), E.Message, sQry);
  946. throw Exception(String(E.ClassName()) + E.Message);
  947. }
  948. catch(Exception &e)
  949. {
  950. DBERRORMSG("TVMSM410M::LoadVmsIfsc", String(e.ClassName()), e.Message, sQry);
  951. throw Exception(String(e.ClassName()) + e.Message);
  952. }
  953. }
  954. __finally
  955. {
  956. if (pADO)
  957. {
  958. pADO->Close();
  959. delete pADO;
  960. }
  961. TvAxis->EndUpdate();
  962. CMM_ExpandCollapseChk(TvAxis, ChkExpand->Checked);
  963. }
  964. }
  965. //---------------------------------------------------------------------------
  966. void __fastcall TVMSM410M::LoadImageSymbolCell(String ANmbr)
  967. {
  968. CMM_ClearGridTableView(TvImageCell);
  969. String sQry;
  970. TADOQuery *pADO = NULL;
  971. sQry = "SELECT A.SYMB_LIB_NMBR, \r\n"
  972. " A.CELL_ID, \r\n"
  973. " A.POSX, POSY, \r\n"
  974. " A.VMS_IFSC_ID, \r\n"
  975. " B.VMS_IFSC_NM, \r\n"
  976. " B.DSPL_STRT_NODE_NM, \r\n"
  977. " B.DSPL_END_NODE_NM \r\n"
  978. " FROM TB_VMS_SYMB_IFSC A, \r\n"
  979. " TB_VMS_IFSC B \r\n"
  980. " WHERE A.SYMB_LIB_NMBR = :p01 \r\n"
  981. " AND A.VMS_IFSC_ID = B.VMS_IFSC_ID(+) \r\n"
  982. " ORDER BY CELL_ID \r\n";
  983. try
  984. {
  985. int nRow;
  986. TcxDataController *pGDC = TvImageCell->DataController;
  987. TvImageCell->BeginUpdate();
  988. try
  989. {
  990. pADO = new TADOQuery(NULL);
  991. pADO->Close();
  992. pADO->Connection = ITSDb_GetConnection();
  993. ITSDb_SQLText(pADO, sQry);
  994. ITSDb_SQLBind(pADO, "p01", ANmbr);
  995. ITSDb_SQLOpen(pADO);
  996. for( ; !pADO->Eof; pADO->Next())
  997. {
  998. nRow = pGDC->AppendRecord();
  999. pGDC->Values[nRow][ColCellId->Index] = pADO->FieldByName("CELL_ID")->AsString;
  1000. pGDC->Values[nRow][ColCellPosX->Index] = pADO->FieldByName("POSX")->AsString;
  1001. pGDC->Values[nRow][ColCellPosY->Index] = pADO->FieldByName("POSY")->AsString;
  1002. pGDC->Values[nRow][ColIfscId->Index] = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  1003. pGDC->Values[nRow][ColIfscNm->Index] = pADO->FieldByName("VMS_IFSC_NM")->AsString;
  1004. pGDC->Values[nRow][ColStrNm->Index] = pADO->FieldByName("DSPL_STRT_NODE_NM")->AsString;
  1005. pGDC->Values[nRow][ColEndNm->Index] = pADO->FieldByName("DSPL_END_NODE_NM")->AsString;
  1006. }
  1007. }
  1008. catch(EDatabaseError &E)
  1009. {
  1010. DBERRORMSG("VMS image query", String(E.ClassName()), E.Message, sQry);
  1011. throw Exception(String(E.ClassName()) + E.Message);
  1012. }
  1013. catch(Exception &e)
  1014. {
  1015. DBERRORMSG("VMS image query", String(e.ClassName()), e.Message, sQry);
  1016. throw Exception(String(e.ClassName()) + e.Message);
  1017. }
  1018. }
  1019. __finally
  1020. {
  1021. if (pADO)
  1022. {
  1023. pADO->Close();
  1024. delete pADO;
  1025. }
  1026. TvImageCell->EndUpdate();
  1027. }
  1028. }
  1029. //---------------------------------------------------------------------------
  1030. void __fastcall TVMSM410M::TvListCellDblClick(TcxCustomGridTableView *Sender, TcxGridTableDataCellViewInfo *ACellViewInfo,
  1031. TMouseButton AButton, TShiftState AShift,
  1032. bool &AHandled)
  1033. {
  1034. if (!ACellViewInfo) return;
  1035. DisplayInfo();
  1036. }
  1037. //---------------------------------------------------------------------------
  1038. void __fastcall TVMSM410M::ColLink2CustomDrawCell(TcxCustomGridTableView *Sender,
  1039. TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  1040. bool &ADone)
  1041. {
  1042. #if 0
  1043. int nRow = AViewInfo->GridRecord->RecordIndex;
  1044. if (nRow < 0) return;
  1045. if (nRow >= FListSymb->Count)
  1046. {
  1047. return;
  1048. }
  1049. try
  1050. {
  1051. Graphics::TBitmap *pBmp = (Graphics::TBitmap*)FListSymb->Items[nRow];
  1052. TRect rc;
  1053. TRect rcOrg = AViewInfo->Bounds;
  1054. int nH = ( (rcOrg.Bottom - rcOrg.Top) - pBmp->Height ) / 2;
  1055. rc.Top = rcOrg.Top + nH+1;
  1056. rc.Bottom = rcOrg.Bottom - nH+1;
  1057. rc.Left = rcOrg.Left + 1;
  1058. rc.Right = rc.Left + pBmp->Width;
  1059. ACanvas->Canvas->StretchDraw(rc, pBmp);
  1060. ADone = true;
  1061. }
  1062. catch(Exception &e)
  1063. {
  1064. }
  1065. #endif
  1066. }
  1067. //---------------------------------------------------------------------------
  1068. void __fastcall TVMSM410M::BtnCellDeleteClick(TObject *Sender)
  1069. {
  1070. TcxGridDataController *pGDC = TvImageCell->DataController;
  1071. int nSelIdx = pGDC->FocusedRecordIndex;
  1072. if (nSelIdx < 0) return;
  1073. pGDC->BeginUpdate();
  1074. pGDC->DeleteRecord(nSelIdx);
  1075. pGDC->EndUpdate();
  1076. UpdateCellColor();
  1077. }
  1078. //---------------------------------------------------------------------------
  1079. void __fastcall TVMSM410M::BtnCellApplyClick(TObject *Sender)
  1080. {
  1081. TcxGridDataController *pGDC = TvImageCell->DataController;
  1082. String sCellId;
  1083. String sPosX;
  1084. String sPosY;
  1085. int nCellId = SeCellId->Value;
  1086. int nPosX = SePosX->Value;
  1087. int nPosY = SePosY->Value;
  1088. int nMaxCellId = 0;
  1089. bool bFound = false;
  1090. sCellId = String(nCellId);
  1091. sPosX = String(nPosX);
  1092. sPosY = String(nPosY);
  1093. int nFocusedIndex = 0;
  1094. try
  1095. {
  1096. int nRows = pGDC->RecordCount;
  1097. TvImageCell->BeginUpdate();
  1098. pGDC->BeginUpdate();
  1099. for (int ii = 0; ii < nRows; ii++)
  1100. {
  1101. String sTmpId = pGDC->Values[ii][ColCellId->Index];
  1102. if (sTmpId == sCellId)
  1103. {
  1104. nFocusedIndex = ii;
  1105. bFound = true;
  1106. }
  1107. }
  1108. if (!bFound)
  1109. {
  1110. nFocusedIndex = pGDC->AppendRecord();
  1111. //SeCellId->Value = nRows+1;
  1112. pGDC->Values[nFocusedIndex][ColCellId->Index] = String(nRows+1);
  1113. }
  1114. pGDC->Values[nFocusedIndex][ColCellPosX->Index] = sPosX;
  1115. pGDC->Values[nFocusedIndex][ColCellPosY->Index] = sPosY;
  1116. }
  1117. __finally
  1118. {
  1119. pGDC->EndUpdate();
  1120. TvImageCell->EndUpdate();
  1121. //if (pGDC->RecordCount > 0) pGDC->FocusedRecordIndex = nFocusedIndex;
  1122. SeCellId->Value = pGDC->RecordCount+1;
  1123. }
  1124. UpdateCellColor();
  1125. }
  1126. //---------------------------------------------------------------------------
  1127. void __fastcall TVMSM410M::ImgPreViewMouseDown(TObject *Sender, TMouseButton Button,
  1128. TShiftState Shift, int X, int Y)
  1129. {
  1130. try {
  1131. SePosX->Value = X;
  1132. SePosY->Value = Y;
  1133. UpdateCellColor();
  1134. TColor FOldColor = ImgPreView->Picture->Bitmap->Canvas->Pixels[SePosX->Value][SePosY->Value];
  1135. ImgPreView->Picture->Bitmap->Canvas->Brush->Style = bsSolid;
  1136. ImgPreView->Picture->Bitmap->Canvas->Brush->Color = clWhite;
  1137. ImgPreView->Picture->Bitmap->Canvas->FloodFill(SePosX->Value, SePosY->Value, FOldColor, fsSurface);
  1138. } catch(...) {}
  1139. }
  1140. //---------------------------------------------------------------------------
  1141. void __fastcall TVMSM410M::ColAreaCustomDrawCell(TcxCustomGridTableView *Sender,
  1142. TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  1143. bool &ADone)
  1144. {
  1145. int nIdx = AViewInfo->GridRecord->RecordIndex;
  1146. if (nIdx < 0)
  1147. return;
  1148. try
  1149. {
  1150. String sCellId = VarToStr(TvImageCell->DataController->Values[nIdx][ColCellId->Index]);
  1151. nIdx = sCellId.ToIntDef(0);
  1152. ACanvas->Brush->Color = GetDisplayColor(nIdx-1);
  1153. ACanvas->Font->Color = ACanvas->Brush->Color;
  1154. }
  1155. catch(...)
  1156. {
  1157. }
  1158. }
  1159. //---------------------------------------------------------------------------
  1160. void __fastcall TVMSM410M::TvImageCellFocusedRecordChanged(TcxCustomGridTableView *Sender,
  1161. TcxCustomGridRecord *APrevFocusedRecord, TcxCustomGridRecord *AFocusedRecord,
  1162. bool ANewItemRecordFocusingChanged)
  1163. {
  1164. TcxGridDataController *pGDC = TvImageCell->DataController;
  1165. int nSelIdx = pGDC->FocusedRecordIndex;
  1166. if (nSelIdx < 0) return;
  1167. String sCellId = VarToStr(pGDC->Values[nSelIdx][ColCellId->Index]);
  1168. String sPosX = VarToStr(pGDC->Values[nSelIdx][ColCellPosX->Index]);
  1169. String sPosY = VarToStr(pGDC->Values[nSelIdx][ColCellPosY->Index]);
  1170. SeCellId->Value = sCellId.ToIntDef(0);
  1171. SePosX->Value = sPosX.ToIntDef(0);
  1172. SePosY->Value = sPosY.ToIntDef(0);
  1173. UpdateCellColor();
  1174. #if 1
  1175. try {
  1176. TColor FOldColor = ImgPreView->Picture->Bitmap->Canvas->Pixels[SePosX->Value][SePosY->Value];
  1177. if (FOldColor == clYellow) return;
  1178. ImgPreView->Picture->Bitmap->Canvas->Brush->Color = clYellow;
  1179. ImgPreView->Picture->Bitmap->Canvas->FloodFill(SePosX->Value, SePosY->Value, FOldColor, fsSurface);
  1180. } catch(...) {}
  1181. #endif
  1182. }
  1183. //---------------------------------------------------------------------------
  1184. void __fastcall TVMSM410M::UpdateCellColor()
  1185. {
  1186. ImgPreView->Picture->Bitmap->FreeImage();
  1187. ImgPreView->Picture->Bitmap = NULL;
  1188. ImgPreView->Picture->Bitmap->Assign(ImgTemp->Picture->Bitmap);
  1189. ImgPreView->Width = ImgPreView->Picture->Bitmap->Width;
  1190. ImgPreView->Height = ImgPreView->Picture->Bitmap->Height;
  1191. TcxGridDataController *pGDC = TvImageCell->DataController;
  1192. int nRows = pGDC->RecordCount;
  1193. try
  1194. {
  1195. TvImageCell->BeginUpdate();
  1196. pGDC->BeginUpdate();
  1197. for (int ii = 0; ii < nRows; ii++)
  1198. {
  1199. String sCellId = VarToStr(pGDC->Values[ii][ColCellId->Index]);
  1200. String sPosX = VarToStr(pGDC->Values[ii][ColCellPosX->Index]);
  1201. String sPosY = VarToStr(pGDC->Values[ii][ColCellPosY->Index]);
  1202. int X = sPosX.ToIntDef(0);
  1203. int Y = sPosY.ToIntDef(0);
  1204. TColor FOldColor = ImgPreView->Picture->Bitmap->Canvas->Pixels[X][Y];
  1205. int nIdx = sCellId.ToIntDef(0);
  1206. ImgPreView->Picture->Bitmap->Canvas->Brush->Style = bsSolid;
  1207. ImgPreView->Picture->Bitmap->Canvas->Brush->Color = GetDisplayColor(nIdx-1);
  1208. ImgPreView->Picture->Bitmap->Canvas->FloodFill(X, Y, FOldColor, fsSurface);
  1209. }
  1210. }
  1211. __finally
  1212. {
  1213. pGDC->EndUpdate();
  1214. TvImageCell->EndUpdate();
  1215. }
  1216. }
  1217. //---------------------------------------------------------------------------
  1218. void __fastcall TVMSM410M::SeCellIdPropertiesChange(TObject *Sender)
  1219. {
  1220. if (((TcxSpinEdit*)Sender)->Value < ((TcxSpinEdit*)Sender)->Properties->MinValue)
  1221. ((TcxSpinEdit*)Sender)->Value = ((TcxSpinEdit*)Sender)->Properties->MinValue;
  1222. else if(((TcxSpinEdit*)Sender)->Value > ((TcxSpinEdit*)Sender)->Properties->MaxValue &&
  1223. ((TcxSpinEdit*)Sender)->Properties->MaxValue)
  1224. ((TcxSpinEdit*)Sender)->Value = ((TcxSpinEdit*)Sender)->Properties->MaxValue;
  1225. }
  1226. //---------------------------------------------------------------------------
  1227. void __fastcall TVMSM410M::TvListFocusedRecordChanged(TcxCustomGridTableView *Sender,
  1228. TcxCustomGridRecord *APrevFocusedRecord, TcxCustomGridRecord *AFocusedRecord,
  1229. bool ANewItemRecordFocusingChanged)
  1230. {
  1231. if (!AFocusedRecord) return;
  1232. DisplayInfo();
  1233. }
  1234. //---------------------------------------------------------------------------
  1235. void __fastcall TVMSM410M::BtnListAddClick(TObject *Sender)
  1236. {
  1237. int nCellIdx = CMM_GetRecordIndex(TvImageCell);
  1238. if (nCellIdx < 0) return;
  1239. int nIfscIdx = CMM_GetRecordIndex(TvAxis);
  1240. if (nIfscIdx < 0) return;
  1241. TcxGridDataController *pDcCell = TvImageCell->DataController;
  1242. TcxGridDataController *pDcIfsc = TvAxis->DataController;
  1243. pDcCell->Values[nCellIdx][ColIfscId->Index] = pDcIfsc->Values[nIfscIdx][Col01->Index];
  1244. pDcCell->Values[nCellIdx][ColIfscNm->Index] = pDcIfsc->Values[nIfscIdx][Col02->Index];
  1245. pDcCell->Values[nCellIdx][ColStrNm->Index] = pDcIfsc->Values[nIfscIdx][Col03->Index];
  1246. pDcCell->Values[nCellIdx][ColEndNm->Index] = pDcIfsc->Values[nIfscIdx][Col04->Index];
  1247. }
  1248. //---------------------------------------------------------------------------
  1249. void __fastcall TVMSM410M::BtnListDeleteClick(TObject *Sender)
  1250. {
  1251. int nCellIdx = CMM_GetRecordIndex(TvImageCell);
  1252. if (nCellIdx < 0) return;
  1253. TcxGridDataController *pDcCell = TvImageCell->DataController;
  1254. pDcCell->Values[nCellIdx][ColIfscId->Index] = "";
  1255. pDcCell->Values[nCellIdx][ColIfscNm->Index] = "";
  1256. pDcCell->Values[nCellIdx][ColStrNm->Index] = "";
  1257. pDcCell->Values[nCellIdx][ColEndNm->Index] = "";
  1258. }
  1259. //---------------------------------------------------------------------------
  1260. void __fastcall TVMSM410M::ChkExpandClick(TObject *Sender)
  1261. {
  1262. CMM_ExpandCollapseChk(TvAxis, ChkExpand->Checked);
  1263. }
  1264. //---------------------------------------------------------------------------
  1265. void __fastcall TVMSM410M::Col05CustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  1266. bool &ADone)
  1267. {
  1268. int nRecordIdx = AViewInfo->GridRecord->RecordIndex;
  1269. if (nRecordIdx < 0)
  1270. {
  1271. return;
  1272. }
  1273. try
  1274. {
  1275. int nItemIdx = AViewInfo->Item->Index;
  1276. if (VarIsNull(AViewInfo->GridRecord->DisplayTexts[nItemIdx])) return;
  1277. String sData = AViewInfo->GridRecord->DisplayTexts[nItemIdx];
  1278. if (sData == "Y")
  1279. {
  1280. ACanvas->Canvas->Brush->Color = clLime;
  1281. }
  1282. }
  1283. catch(Exception &e)
  1284. {
  1285. }
  1286. }
  1287. //---------------------------------------------------------------------------