FrmLangF.cpp 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSDbF.h"
  4. #include "ITSUtilF.h"
  5. #include "CDSFontF.h"
  6. #include "AppGlobalF.h"
  7. #pragma hdrstop
  8. #include "FrmLangF.h"
  9. //---------------------------------------------------------------------------
  10. #pragma package(smart_init)
  11. #pragma link "cxContainer"
  12. #pragma link "cxControls"
  13. #pragma link "cxEdit"
  14. #pragma link "cxGraphics"
  15. #pragma link "cxLabel"
  16. #pragma link "cxLookAndFeelPainters"
  17. #pragma link "cxLookAndFeels"
  18. #pragma link "dxSkinBlack"
  19. #pragma link "dxSkinBlue"
  20. #pragma link "dxSkinsCore"
  21. #pragma link "cxButtons"
  22. #pragma link "dxSkinCaramel"
  23. #pragma link "dxSkinCoffee"
  24. #pragma link "dxSkinDarkRoom"
  25. #pragma link "dxSkinDarkSide"
  26. #pragma link "dxSkinFoggy"
  27. #pragma link "dxSkinGlassOceans"
  28. #pragma link "dxSkiniMaginary"
  29. #pragma link "dxSkinLilian"
  30. #pragma link "dxSkinLiquidSky"
  31. #pragma link "dxSkinLondonLiquidSky"
  32. #pragma link "dxSkinMcSkin"
  33. #pragma link "dxSkinMoneyTwins"
  34. #pragma link "dxSkinOffice2007Black"
  35. #pragma link "dxSkinOffice2007Blue"
  36. #pragma link "dxSkinOffice2007Green"
  37. #pragma link "dxSkinOffice2007Pink"
  38. #pragma link "dxSkinOffice2007Silver"
  39. #pragma link "dxSkinOffice2010Black"
  40. #pragma link "dxSkinOffice2010Blue"
  41. #pragma link "dxSkinOffice2010Silver"
  42. #pragma link "dxSkinSeven"
  43. #pragma link "dxSkinSharp"
  44. #pragma link "dxSkinSilver"
  45. #pragma link "dxSkinStardust"
  46. #pragma link "VmsDesignerF"
  47. #pragma resource "*.dfm"
  48. TFrmLang *FrmLang;
  49. //---------------------------------------------------------------------------
  50. __fastcall TFrmLang::TFrmLang(TComponent* Owner)
  51. : TForm(Owner)
  52. {
  53. FFontInit = false;
  54. //Show();
  55. }
  56. //---------------------------------------------------------------------------
  57. void TFrmLang::ITSSkin_ButtonClick(TcxButton *ASearch, TcxButton *AEdit, TcxButton *AAdd, TcxButton *ADel, TcxButton *AApply)
  58. {
  59. if (!AEdit) return;
  60. if (AEdit->Down)
  61. {
  62. // 편집모드 시작
  63. AEdit->Glyph->Assign(BtnEdit2->Glyph);
  64. AEdit->Hint = lblEditHint1->Caption;//"데이터 편집 종료/취소";
  65. if (ASearch) ASearch->Enabled = false;
  66. if (AAdd) AAdd->Enabled = true;
  67. if (ADel) ADel->Enabled = true;
  68. if (AApply) AApply->Enabled = true;
  69. }
  70. else
  71. {
  72. // 편집모드 종료
  73. AEdit->Glyph->Assign(BtnEdit1->Glyph);
  74. AEdit->Hint = lblEditHint2->Caption;//"데이터 편집";
  75. if (ASearch) ASearch->Enabled = true;
  76. if (AAdd) AAdd->Enabled = false;
  77. if (ADel) ADel->Enabled = false;
  78. if (AApply) AApply->Enabled = false;
  79. }
  80. }
  81. //---------------------------------------------------------------------------
  82. void __fastcall TFrmLang::FormClose(TObject *Sender, TCloseAction &Action)
  83. {
  84. try
  85. {
  86. if (m_pEdtDesigner)
  87. {
  88. delete m_pEdtDesigner;
  89. m_pEdtDesigner = NULL;
  90. }
  91. }
  92. catch(...)
  93. {
  94. }
  95. }
  96. //---------------------------------------------------------------------------
  97. void __fastcall TFrmLang::FormCreate(TObject *Sender)
  98. {
  99. m_pEdtDesigner = new TVmsFormDesigner(PnlEditForm);
  100. m_pEdtDesigner->ApplicationHandle = (long)Handle;
  101. }
  102. //---------------------------------------------------------------------------
  103. int __fastcall TFrmLang::CheckImageUseCount(String ASYMB_LIB_NMBR)
  104. {
  105. String sQry;
  106. TADOQuery *pADO = NULL;
  107. int nResult = 0;
  108. sQry = "SELECT COUNT(1) AS CNT \r\n"
  109. " FROM TB_VMS_FORM_OBJECT \r\n"
  110. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  111. try
  112. {
  113. try
  114. {
  115. pADO = new TADOQuery(NULL);
  116. pADO->Close();
  117. pADO->Connection = ITSDb_GetConnection();
  118. ITSDb_SQLText(pADO, sQry);
  119. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  120. ITSDb_SQLOpen(pADO);
  121. nResult = pADO->FieldByName("CNT")->AsInteger;
  122. }
  123. catch(EDatabaseError &E)
  124. {
  125. DBERRORMSG("CheckImageUseCount", String(E.ClassName()), E.Message, sQry);
  126. throw Exception(String(E.ClassName()) + E.Message);
  127. }
  128. catch(Exception &e)
  129. {
  130. DBERRORMSG("CheckImageUseCount", String(e.ClassName()), e.Message, sQry);
  131. throw Exception(String(e.ClassName()) + e.Message);
  132. }
  133. }
  134. __finally
  135. {
  136. if (pADO)
  137. {
  138. pADO->Close();
  139. delete pADO;
  140. }
  141. }
  142. return nResult;
  143. }
  144. //---------------------------------------------------------------------------
  145. bool __fastcall TFrmLang::DelVmsImage(String ASYMB_LIB_NMBR, bool ADelIfsc)
  146. {
  147. String sQry;
  148. TADOQuery *pADO = NULL;
  149. try
  150. {
  151. try
  152. {
  153. pADO = new TADOQuery(NULL);
  154. pADO->Close();
  155. pADO->Connection = ITSDb_GetConnection();
  156. if (ADelIfsc)
  157. {
  158. sQry = "DELETE TB_VMS_SYMB_IFSC \r\n"
  159. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  160. ITSDb_SQLText(pADO, sQry);
  161. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  162. pADO->ExecSQL();
  163. }
  164. #if 0
  165. sQry = "DELETE TB_VMS_SYMB_LIB \r\n"
  166. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  167. #else
  168. sQry = "UPDATE TB_VMS_SYMB_LIB \r\n"
  169. " SET DEL_YN = 'Y', \r\n"
  170. " UPDT_DT = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') \r\n"
  171. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  172. #endif
  173. ITSDb_SQLText(pADO, sQry);
  174. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  175. pADO->ExecSQL();
  176. return true;
  177. }
  178. catch(EDatabaseError &E)
  179. {
  180. DBERRORMSG("DelVmsImage", String(E.ClassName()), E.Message, sQry);
  181. throw Exception(String(E.ClassName()) + E.Message);
  182. }
  183. catch(Exception &e)
  184. {
  185. DBERRORMSG("DelVmsImage", String(e.ClassName()), e.Message, sQry);
  186. throw Exception(String(e.ClassName()) + e.Message);
  187. }
  188. }
  189. __finally
  190. {
  191. if (pADO)
  192. {
  193. pADO->Close();
  194. delete pADO;
  195. }
  196. }
  197. return true;
  198. }
  199. //---------------------------------------------------------------------------
  200. bool __fastcall TFrmLang::GetNextVmsImgeId(int &ANmbr, int AFromId, int AToId)
  201. {
  202. String sQry;
  203. TADOQuery *pADO = NULL;
  204. sQry = "SELECT NVL(MAX(SYMB_NMBR), :p01)+1 AS NEWID FROM TB_VMS_SYMB_LIB WHERE SYMB_NMBR BETWEEN :p02 AND :p03 \r\n";
  205. try
  206. {
  207. try
  208. {
  209. pADO = new TADOQuery(NULL);
  210. pADO->Close();
  211. pADO->Connection = ITSDb_GetConnection();
  212. ITSDb_SQLText(pADO, sQry);
  213. ITSDb_SQLBind(pADO, "p01", AFromId-1);
  214. ITSDb_SQLBind(pADO, "p02", AFromId);
  215. ITSDb_SQLBind(pADO, "p03", AToId);
  216. ITSDb_SQLOpen(pADO);
  217. pADO->Open();
  218. ANmbr = pADO->FieldByName("NEWID")->AsInteger;
  219. return true;
  220. }
  221. catch(EDatabaseError &E)
  222. {
  223. DBERRORMSG("GetNextVmsImgeId", String(E.ClassName()), E.Message, sQry);
  224. throw Exception(String(E.ClassName()) + E.Message);
  225. }
  226. catch(Exception &e)
  227. {
  228. DBERRORMSG("GetNextVmsImgeId", String(e.ClassName()), e.Message, sQry);
  229. throw Exception(String(e.ClassName()) + e.Message);
  230. }
  231. }
  232. __finally
  233. {
  234. if (pADO)
  235. {
  236. pADO->Close();
  237. delete pADO;
  238. }
  239. }
  240. return false;
  241. }
  242. //---------------------------------------------------------------------------
  243. bool __fastcall TFrmLang::UpdateVmsImage(String ASYMB_LIB_NMBR, String ASYMB_EXPL, TImage *AImage, String ASYMB_TYPE)
  244. {
  245. bool bResult = false;
  246. String sQry;
  247. TADOQuery *pADO = NULL;
  248. sQry = "UPDATE TB_VMS_SYMB_LIB \r\n"
  249. " SET RGST_DT = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS'), \r\n"
  250. " SYMB_EXPL = :p02, \r\n";
  251. if (AImage != NULL)
  252. {
  253. sQry+= " IMAG_DATA = :p03, \r\n";
  254. }
  255. if (ASYMB_TYPE != "")
  256. {
  257. sQry+= " SYMB_TYPE = :p04, \r\n";
  258. }
  259. sQry+= " UPDT_DT = TO_CHAR(SYSDATE, 'YYYYMMDDHH24MISS') \r\n"
  260. " WHERE SYMB_LIB_NMBR = :p01 \r\n";
  261. TMemoryStream *dataStream = NULL;
  262. if (AImage != NULL)
  263. {
  264. dataStream = new TMemoryStream();
  265. AImage->Picture->Bitmap->SaveToStream(dataStream);
  266. }
  267. try
  268. {
  269. try
  270. {
  271. pADO = new TADOQuery(NULL);
  272. pADO->Close();
  273. pADO->Connection = ITSDb_GetConnection();
  274. ITSDb_SQLText(pADO, sQry);
  275. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  276. ITSDb_SQLBind(pADO, "p02", ASYMB_EXPL);
  277. if (AImage != NULL)
  278. {
  279. pADO->Parameters->ParamByName("p03")->LoadFromStream(dataStream, ftBlob);
  280. }
  281. if (ASYMB_TYPE != "")
  282. {
  283. ITSDb_SQLBind(pADO, "p04", ASYMB_TYPE);
  284. }
  285. pADO->ExecSQL();
  286. bResult = true;
  287. }
  288. catch(EDatabaseError &E)
  289. {
  290. DBERRORMSG("UpdateVmsImage", String(E.ClassName()), E.Message, sQry);
  291. throw Exception(String(E.ClassName()) + E.Message);
  292. }
  293. catch(Exception &e)
  294. {
  295. DBERRORMSG("UpdateVmsImage", String(e.ClassName()), e.Message, sQry);
  296. throw Exception(String(e.ClassName()) + e.Message);
  297. }
  298. }
  299. __finally
  300. {
  301. if (pADO)
  302. {
  303. pADO->Close();
  304. delete pADO;
  305. }
  306. if (dataStream) delete dataStream;
  307. dataStream = NULL;
  308. }
  309. return bResult;
  310. }
  311. //---------------------------------------------------------------------------
  312. void __fastcall TFrmLang::UpdateVmsFormImage(String ASYMB_LIB_NMBR, String AOldWidth, String AOldHeight, String ANewWidth, String ANewHeight)
  313. {
  314. String sQry;
  315. TADOQuery *pADO = NULL;
  316. sQry = "SELECT VMS_FORM_ID \r\n"
  317. " FROM TB_VMS_FORM_OBJECT \r\n"
  318. " WHERE SYMB_LIB_NMBR = :p01 \r\n"
  319. " GROUP BY VMS_FORM_ID \r\n";
  320. LstVmsFormId->Items->Clear();
  321. try
  322. {
  323. try
  324. {
  325. pADO = new TADOQuery(NULL);
  326. pADO->Close();
  327. pADO->Connection = ITSDb_GetConnection();
  328. ITSDb_SQLText(pADO, sQry);
  329. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  330. ITSDb_SQLOpen(pADO);
  331. for( ; !pADO->Eof; pADO->Next())
  332. {
  333. String VMS_FORM_ID = pADO->FieldByName("VMS_FORM_ID")->AsString;
  334. LstVmsFormId->Items->Add(VMS_FORM_ID);
  335. }
  336. }
  337. catch(EDatabaseError &E)
  338. {
  339. DBERRORMSG("UpdateVmsFormImage", String(E.ClassName()), E.Message, sQry);
  340. throw Exception(String(E.ClassName()) + E.Message);
  341. }
  342. catch(Exception &e)
  343. {
  344. DBERRORMSG("UpdateVmsFormImage", String(e.ClassName()), e.Message, sQry);
  345. throw Exception(String(e.ClassName()) + e.Message);
  346. }
  347. }
  348. __finally
  349. {
  350. if (pADO)
  351. {
  352. pADO->Close();
  353. delete pADO;
  354. }
  355. }
  356. if (LstVmsFormId->Items->Count == 0) return;
  357. //폼객체 이미지 크기 조정
  358. UpdateVmsFormImageType(ASYMB_LIB_NMBR, AOldWidth, AOldHeight, ANewWidth, ANewHeight);
  359. //폼이미지 BLOB 업데이트
  360. for (int ii = 0; ii < LstVmsFormId->Items->Count; ii++)
  361. {
  362. UpdateVmsFormImageBlob(LstVmsFormId->Items->Strings[ii]);
  363. }
  364. }
  365. //---------------------------------------------------------------------------
  366. void __fastcall TFrmLang::UpdateVmsFormImageType(String ASYMB_LIB_NMBR, String AOldWidth, String AOldHeight, String ANewWidth, String ANewHeight)
  367. {
  368. if (AOldWidth == ANewWidth && AOldHeight == ANewHeight) return;
  369. String sQry;
  370. TADOQuery *pADO = NULL;
  371. #if 0
  372. UPDATE TB_VMS_FORM_OBJECT
  373. SET VMS_DSPL_WIDTH = 320,
  374. VMS_DSPL_HEIGHT = 64
  375. WHERE (VMS_FORM_OBJECT_ID, VMS_FORM_ID)
  376. IN (SELECT VMS_FORM_OBJECT_ID, VMS_FORM_ID
  377. FROM TB_VMS_FORM_OBJECT
  378. WHERE SYMB_LIB_NMBR = 6014
  379. AND (VMS_DSPL_WIDTH <> 320 OR VMS_DSPL_HEIGHT <> 64) )
  380. #endif
  381. //기존에 이미지크기를 그래도 사용하는 폼객체인 경우에만 변경된 크기로 업데이트 해준다.
  382. //이미지 크기가 다르다는 것은 사용자가 이미지를 폼편집에서 수정한 것이라 사용자가 직접
  383. //수정하여야 한다.
  384. sQry = "UPDATE TB_VMS_FORM_OBJECT \r\n"
  385. " SET VMS_DSPL_WIDTH = :p04, \r\n"
  386. " VMS_DSPL_HEIGHT = :p05 \r\n"
  387. " WHERE (VMS_FORM_OBJECT_ID, VMS_FORM_ID) \r\n"
  388. " IN (SELECT VMS_FORM_OBJECT_ID, VMS_FORM_ID \r\n"
  389. " FROM TB_VMS_FORM_OBJECT \r\n"
  390. " WHERE SYMB_LIB_NMBR = :p01 \r\n"
  391. " AND VMS_DSPL_WIDTH = :p02 \r\n"
  392. " AND VMS_DSPL_HEIGHT = :p03) \r\n";
  393. try
  394. {
  395. try
  396. {
  397. pADO = new TADOQuery(NULL);
  398. pADO->Close();
  399. pADO->Connection = ITSDb_GetConnection();
  400. ITSDb_SQLText(pADO, sQry);
  401. ITSDb_SQLBind(pADO, "p01", ASYMB_LIB_NMBR);
  402. ITSDb_SQLBind(pADO, "p02", AOldWidth);
  403. ITSDb_SQLBind(pADO, "p03", AOldHeight);
  404. ITSDb_SQLBind(pADO, "p04", ANewWidth);
  405. ITSDb_SQLBind(pADO, "p05", ANewHeight);
  406. ITSDb_SQLExec(pADO);
  407. }
  408. catch(EDatabaseError &E)
  409. {
  410. DBERRORMSG("UpdateVmsFormImageType", String(E.ClassName()), E.Message, sQry);
  411. throw Exception(String(E.ClassName()) + E.Message);
  412. }
  413. catch(Exception &e)
  414. {
  415. DBERRORMSG("UpdateVmsFormImageType", String(e.ClassName()), e.Message, sQry);
  416. throw Exception(String(e.ClassName()) + e.Message);
  417. }
  418. }
  419. __finally
  420. {
  421. if (pADO)
  422. {
  423. pADO->Close();
  424. delete pADO;
  425. }
  426. }
  427. }
  428. //---------------------------------------------------------------------------
  429. void __fastcall TFrmLang::UpdateVmsFormImageBlob(String AVMS_FORM_ID)
  430. {
  431. if (GetVmsFormImage(ImgForm, AVMS_FORM_ID) == false)
  432. {
  433. return;
  434. }
  435. String sQry;
  436. TADOQuery *pADO = NULL;
  437. sQry = "UPDATE TB_VMS_FORM \r\n"
  438. " SET VMS_FORM_IMAG = :p02 \r\n"
  439. " WHERE VMS_FORM_ID = :p01 \r\n";
  440. TMemoryStream *dataStream = new TMemoryStream();
  441. ImgForm->Picture->Bitmap->SaveToStream(dataStream);
  442. try
  443. {
  444. try
  445. {
  446. pADO = new TADOQuery(NULL);
  447. pADO->Close();
  448. pADO->Connection = ITSDb_GetConnection();
  449. ITSDb_SQLText(pADO, sQry);
  450. ITSDb_SQLBind(pADO, "p01", AVMS_FORM_ID);
  451. pADO->Parameters->ParamByName("p02")->LoadFromStream(dataStream, ftBlob);
  452. pADO->ExecSQL();
  453. }
  454. catch(EDatabaseError &E)
  455. {
  456. DBERRORMSG("UpdateVmsFormImageBlob", String(E.ClassName()), E.Message, sQry);
  457. throw Exception(String(E.ClassName()) + E.Message);
  458. }
  459. catch(Exception &e)
  460. {
  461. DBERRORMSG("UpdateVmsFormImageBlob", String(e.ClassName()), e.Message, sQry);
  462. throw Exception(String(e.ClassName()) + e.Message);
  463. }
  464. }
  465. __finally
  466. {
  467. if (pADO)
  468. {
  469. pADO->Close();
  470. delete pADO;
  471. }
  472. if (dataStream) delete dataStream;
  473. dataStream = NULL;
  474. }
  475. }
  476. //---------------------------------------------------------------------------
  477. bool __fastcall TFrmLang::GetVmsFormImage(TImage *AImage, String AVMS_FORM_ID)
  478. {
  479. if (FFontInit == false)
  480. {
  481. FOR_STL(TCDSFontColor*, pObj, CDSFontManager->FFontColors)
  482. {
  483. m_pEdtDesigner->InitFontColor(pObj->VMS_FONT_COLR_CD, (TColor)pObj->VMS_FONT_COLR_VAL);
  484. }
  485. FFontInit = true;
  486. }
  487. m_pEdtDesigner->Clear();
  488. m_pEdtDesigner->EditMode = false;
  489. m_pEdtDesigner->Hide();
  490. String sQry;
  491. TADOQuery *pADO = NULL;
  492. AImage->Picture->Bitmap->FreeImage();
  493. AImage->Picture->Bitmap = NULL;
  494. sQry = "SELECT A.VMS_MODL_KIND, A.VMS_FORM_COLR_CD, \r\n"
  495. " B.VMS_WDTH, B.VMS_HGHT, \r\n"
  496. " C.*, \r\n"
  497. " E.VMS_FONT_NAME_NM, \r\n"
  498. " D.IMAG_DATA AS SYMB_IMG, \r\n"
  499. " D.SYMB_EXPL AS SYMB_IMG_NM \r\n"
  500. " FROM TB_VMS_FORM A, \r\n"
  501. " TB_VMS_TYPE B, \r\n"
  502. " TB_VMS_FORM_OBJECT C, \r\n"
  503. " TB_VMS_SYMB_LIB D, \r\n"
  504. " TB_VMS_FONT_NAME E \r\n"
  505. " WHERE A.VMS_FORM_ID = :p01 \r\n"
  506. " AND A.VMS_MODL_KIND = B.VMS_MODL_KIND \r\n"
  507. " AND A.VMS_FORM_ID = C.VMS_FORM_ID \r\n"
  508. " AND C.SYMB_LIB_NMBR = D.SYMB_LIB_NMBR(+) \r\n"
  509. " AND C.VMS_FONT_NAME_CD = E.VMS_FONT_NAME_CD(+) \r\n"
  510. " ORDER BY C.VMS_FORM_OBJECT_ID ASC \r\n";
  511. int nRows = 0;
  512. try
  513. {
  514. try
  515. {
  516. pADO = new TADOQuery(NULL);
  517. pADO->Close();
  518. pADO->Connection = ITSDb_GetConnection();
  519. ITSDb_SQLText(pADO, sQry);
  520. ITSDb_SQLBind(pADO, "p01", AVMS_FORM_ID);
  521. ITSDb_SQLOpen(pADO);
  522. int nDrawType;
  523. String sObjKind;
  524. for( ; !pADO->Eof; pADO->Next())
  525. {
  526. if (nRows == 0)
  527. {
  528. m_pEdtDesigner->SizeType = pADO->FieldByName("VMS_MODL_KIND")->AsString;
  529. m_pEdtDesigner->BkColorCode = pADO->FieldByName("VMS_MODL_KIND")->AsString;
  530. int nW = pADO->FieldByName("VMS_WDTH")->AsInteger;
  531. int nH = pADO->FieldByName("VMS_HGHT")->AsInteger;
  532. m_pEdtDesigner->SetSize(nW, nH);
  533. m_pEdtDesigner->SetPos(0, 0);
  534. AImage->Width = nW;
  535. AImage->Height = nH;
  536. AImage->Picture->Bitmap->Width = nW;
  537. AImage->Picture->Bitmap->Height = nH;
  538. }
  539. nRows++;
  540. int nObjId = pADO->FieldByName("VMS_FORM_OBJECT_ID")->AsInteger;
  541. int nObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsInteger;
  542. if (nObjType == 1 || //이미지 심볼
  543. nObjType == 2 || //파일이미지
  544. nObjType == 3 || //소통정보이미지
  545. nObjType == 17 || //소통이미지1
  546. nObjType == 27 || //소통이미지2
  547. nObjType == 37 || //소통이미지3
  548. nObjType == 47 || //소통이미지4
  549. nObjType == 200 || //동영상
  550. nObjType == 300 || //스트리밍영상
  551. nObjType == 406 || //@통합대기등급 이미지
  552. nObjType == 407 || //@미세먼지등급 이미지
  553. nObjType == 408 || //@초미세먼지등급 이미지
  554. nObjType == 413 //@오존등급이미지
  555. )
  556. {
  557. if (nObjType == 3) sObjKind = OBJKIND_IMAGE;
  558. else sObjKind = OBJKIND_IMAGEID;
  559. nDrawType = 1; //이미지그리기
  560. }
  561. else
  562. {
  563. sObjKind = OBJKIND_TEXT; //문자열
  564. nDrawType = 0; //문자열그리기
  565. }
  566. int nBlinking = pADO->FieldByName("VMS_DSPL_BLINKING")->AsInteger;
  567. int nPosX = pADO->FieldByName("VMS_DSPL_XCRDN")->AsInteger;
  568. int nPosY = pADO->FieldByName("VMS_DSPL_YCRDN")->AsInteger;
  569. int nWidth = pADO->FieldByName("VMS_DSPL_WIDTH")->AsInteger;
  570. int nHeight = pADO->FieldByName("VMS_DSPL_HEIGHT")->AsInteger;
  571. TVmsFormObject *pObj = m_pEdtDesigner->AddObject((VmsObjectDrawType)nDrawType);
  572. if (!pObj) continue;
  573. if (nObjType == 200 || nObjType == 300)
  574. {
  575. pObj->EditMode = false;
  576. }
  577. String sIfscId = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  578. String sFillCd = pADO->FieldByName("TRFC_FILL_CD")->AsString;
  579. pObj->ObjSeq = nObjId;
  580. pObj->ObjId = nObjId;
  581. pObj->ObjKind = sObjKind;
  582. pObj->ObjType = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsString;
  583. pObj->ObjSize = pADO->FieldByName("VMS_DSPL_SIZE")->AsInteger;
  584. pObj->BkColorCode = pADO->FieldByName("VMS_DSPL_BKCOLOR")->AsString;
  585. pObj->Blink = nBlinking == 1 ? true : false;
  586. pObj->ImageId = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  587. pObj->Text = pADO->FieldByName("VMS_DSPL_TXT")->AsString;
  588. pObj->RunText = pObj->Text;
  589. pObj->SetPos(nPosX, nPosY);
  590. if (pObj->ObjKind == OBJKIND_TEXT) // 문자열
  591. {
  592. int nFontBold = pADO->FieldByName("VMS_FONT_BOLD")->AsInteger;
  593. pObj->FontName = pADO->FieldByName("VMS_FONT_NAME_NM")->AsString;
  594. pObj->FontNameCode = pADO->FieldByName("VMS_FONT_NAME_CD")->AsString;
  595. pObj->FontColorCode = pADO->FieldByName("VMS_FONT_COLR_CD")->AsString;
  596. pObj->FontSize = pADO->FieldByName("VMS_FONT_SIZE")->AsInteger;
  597. pObj->FontBold = nFontBold == 1 ? true : false;
  598. pObj->TextAlign = pADO->FieldByName("VMS_FONT_ALIGN")->AsInteger;
  599. //pObj->SetPos(nPosX, nPosY);
  600. //pObj->SetSize(pADO->FieldByName("VMS_DSPL_WIDTH")->AsInteger, pADO->FieldByName("VMS_DSPL_HEIGHT")->AsInteger);
  601. }
  602. else //if (sObjKind == "1" || sObjKind == "2") // 이미지(1), 이미지 ID(2)
  603. {
  604. if (pObj->ObjKind == OBJKIND_IMAGEID)
  605. {
  606. if (pObj->Text.Trim() == "")
  607. {
  608. pObj->Text = pObj->ImageId;
  609. }
  610. }
  611. TStream *pStream = NULL;
  612. pStream = pADO->CreateBlobStream(pADO->FieldByName("VMS_DSPL_FIGR"), bmRead);
  613. try
  614. {
  615. if (pStream && pStream->Size > 0)
  616. {
  617. Graphics::TBitmap *Bitmap = pObj->GetBitmap();
  618. pStream->Position = 0;
  619. Bitmap->LoadFromStream(pStream);
  620. #ifdef IMAGE_RESIZE
  621. #if 0
  622. if (nObjType == 1 || nObjType == 2)
  623. {
  624. pObj->GetImage()->AutoSize= false;
  625. pObj->GetImage()->Stretch = true;
  626. pObj->GetImage()->Width = nWidth;
  627. pObj->GetImage()->Height = nHeight;
  628. pObj->SetSize(nWidth, nHeight);
  629. pObj->SetPos(nPosX, nPosY);
  630. }
  631. else
  632. {
  633. pObj->SetSize(Bitmap->Width, Bitmap->Height);
  634. }
  635. #else
  636. switch(nObjType)
  637. {
  638. case 1: //심볼
  639. case 2: //이미지
  640. case 3: //소통정보배경이미지
  641. case 17: //소통정보이미지1
  642. case 27: //소통정보이미지2
  643. case 37: //소통정보이미지3
  644. case 47: //소통정보이미지4
  645. case 167: //@우회소통정보이미지
  646. case 200: //동영상이미지
  647. case 300: //스트리밍영상이미지
  648. case 406: //@통합대기등급 이미지
  649. case 407: //@미세먼지등급 이미지
  650. case 408: //@초미세먼지등급 이미지
  651. case 413: //@오존등급이미지
  652. pObj->GetImage()->AutoSize= false;
  653. pObj->GetImage()->Stretch = true;
  654. pObj->GetImage()->Width = nWidth;
  655. pObj->GetImage()->Height = nHeight;
  656. pObj->SetSize(nWidth, nHeight);
  657. pObj->SetPos(nPosX, nPosY);
  658. break;
  659. default:
  660. pObj->SetSize(Bitmap->Width, Bitmap->Height);
  661. pObj->SetPos(nPosX, nPosY); //TODO
  662. break;
  663. }
  664. #endif
  665. #else
  666. pObj->SetSize(Bitmap->Width, Bitmap->Height);
  667. pObj->SetPos(nPosX, nPosY);
  668. #endif
  669. }
  670. }
  671. __finally
  672. {
  673. SAFE_DELETE(pStream);
  674. }
  675. }
  676. //pObj->SetPos(nPosX, nPosY);
  677. //if (pObj->Left < 0) pObj->Left = 0;
  678. //if (pObj->Top < 0) pObj->Top = 0;
  679. pObj->Show();
  680. pObj->BringToFront();
  681. }
  682. }
  683. catch(EDatabaseError &E)
  684. {
  685. DBERRORMSG("UpdateVmsFormImageBlob", String(E.ClassName()), E.Message, sQry);
  686. return false;
  687. }
  688. catch(Exception &e)
  689. {
  690. DBERRORMSG("UpdateVmsFormImageBlob", String(e.ClassName()), e.Message, sQry);
  691. return false;
  692. }
  693. }
  694. __finally
  695. {
  696. if (pADO)
  697. {
  698. pADO->Close();
  699. delete pADO;
  700. }
  701. }
  702. m_pEdtDesigner->GetVmsFormImage(AImage);
  703. return nRows > 0 ? true : false;
  704. }
  705. //---------------------------------------------------------------------------