CDSFormF.cpp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSFormF.h"
  4. #include "VmsUtilsF.h"
  5. #include "VMSCommLibF.h"
  6. //---------------------------------------------------------------------------
  7. #pragma package(smart_init)
  8. //---------------------------------------------------------------------------
  9. TCDSFormObj::TCDSFormObj()
  10. {
  11. pImage = NULL;
  12. pImage = new TImage(NULL);
  13. }
  14. //---------------------------------------------------------------------------
  15. TCDSFormObj::~TCDSFormObj()
  16. {
  17. Clear();
  18. if (pImage)
  19. {
  20. delete pImage;
  21. pImage = NULL;
  22. }
  23. }
  24. //---------------------------------------------------------------------------
  25. void TCDSFormObj::Clear()
  26. {
  27. if (pImage)
  28. {
  29. pImage->Picture->Bitmap->FreeImage();
  30. pImage->Picture->Assign(NULL);
  31. }
  32. }
  33. //---------------------------------------------------------------------------
  34. //---------------------------------------------------------------------------
  35. TCDSForm::TCDSForm()
  36. {
  37. TrfIfsc = false;
  38. TrfAxis = false;
  39. TrfFixed = false;
  40. IsNewForm = true;
  41. TrfBakImgId = "";
  42. }
  43. //---------------------------------------------------------------------------
  44. TCDSForm::~TCDSForm()
  45. {
  46. Clear();
  47. FLists.RemoveAll();
  48. }
  49. //---------------------------------------------------------------------------
  50. void TCDSForm::Clear()
  51. {
  52. }
  53. //---------------------------------------------------------------------------
  54. //---------------------------------------------------------------------------
  55. TCDSFormManager *CDSFormManager = NULL;
  56. //---------------------------------------------------------------------------
  57. TCDSFormManager::TCDSFormManager()
  58. {
  59. }
  60. //---------------------------------------------------------------------------
  61. TCDSFormManager::~TCDSFormManager()
  62. {
  63. FLists.RemoveAll();
  64. }
  65. //---------------------------------------------------------------------------
  66. int TCDSFormManager::LoadVmsFormInfo(TADOConnection *ADbConn)
  67. {
  68. String sQry;
  69. TADOQuery *pADO = NULL;
  70. TStream *pStream = NULL;
  71. int nSelCnt = 0;
  72. DDBSTART;
  73. sQry = "SELECT A.VMS_FORM_ID, \r\n"
  74. " A.VMS_TYPE_CD, \r\n"
  75. " A.VMS_FORM_TYPE_CD, \r\n"
  76. " A.VMS_FORM_COLR_CD, \r\n"
  77. " A.VMS_FORM_DSPL_DRCT_CD, \r\n"
  78. " A.VMS_FORM_DSPL_MTHD_CD, \r\n"
  79. " A.SYMB_LIB_NMBR, \r\n"
  80. " A.UPDT_DT \r\n"
  81. " FROM TB_VMS_FORM A \r\n";
  82. try
  83. {
  84. TCDSForm *pCDSForm;
  85. try
  86. {
  87. pADO = new TADOQuery(NULL);
  88. pADO->Connection = ADbConn;
  89. SQLText(pADO, sQry, true);
  90. SQLOpen(pADO);
  91. for( ; !pADO->Eof; pADO->Next())
  92. {
  93. AnsiString VMS_FORM_ID = pADO->FieldByName("VMS_FORM_ID")->AsString.Trim();
  94. pCDSForm = FLists.Find(VMS_FORM_ID);
  95. if (!pCDSForm)
  96. {
  97. pCDSForm = new TCDSForm();
  98. pCDSForm->VMS_FORM_ID = VMS_FORM_ID;
  99. CDSFormManager->FLists.Push(pCDSForm->VMS_FORM_ID, pCDSForm);
  100. }
  101. pCDSForm->FLists.RemoveAll();
  102. pCDSForm->TrfBakImgId = ""; //소통정보 배경 이미지 ID
  103. pCDSForm->VMS_TYPE_CD = pADO->FieldByName("VMS_TYPE_CD")->AsString;
  104. pCDSForm->VMS_FORM_TYPE_CD = pADO->FieldByName("VMS_FORM_TYPE_CD")->AsInteger;
  105. pCDSForm->VMS_FORM_COLR_CD = pADO->FieldByName("VMS_FORM_COLR_CD")->AsInteger;
  106. pCDSForm->VMS_FORM_DSPL_DRCT_CD = pADO->FieldByName("VMS_FORM_DSPL_DRCT_CD")->AsInteger;
  107. pCDSForm->VMS_FORM_DSPL_MTHD_CD = pADO->FieldByName("VMS_FORM_DSPL_MTHD_CD")->AsInteger;
  108. pCDSForm->TrfIfsc = false;
  109. pCDSForm->TrfAxis = false;
  110. pCDSForm->TrfFixed = false;
  111. AnsiString UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString;
  112. // 정적폼(홍보) 같은 경우 최초 또는 변경되었을 때에만 사용할수 있도록(제어기로 한번만 다운로드 할수 있도록)
  113. // 체크 플래그를 두어 확인할수 있도록 한다.
  114. pCDSForm->IsNewForm = false;
  115. if (pCDSForm->VMS_FORM_TYPE_CD == eFormTp_hongbo && pCDSForm->UPDT_DT != UPDT_DT)
  116. {
  117. pCDSForm->IsNewForm = true;
  118. }
  119. #if 0
  120. if (pCDSForm->VMS_FORM_TYPE_CD == eFormTp_hongbo)
  121. {
  122. //정적인 폼인 경우 폼의 이미지를 파일로 저장해 둔다
  123. pCDSForm->LocalFileName = g_sFtpStaticDir + pCDSForm->VMS_FORM_ID + ".bmp";
  124. pCDSForm->FtpFileName = AnsiString(FTP_STATIC) + "\\" + pCDSForm->VMS_FORM_ID + ".bmp";
  125. // 파일이 존재하지 않거나 업데이트 시각이 다르면 새로 홍보폼 이미지를 생성한다.
  126. if (pCDSForm->UPDT_DT != UPDT_DT || !FileExists(pCDSForm->LocalFileName))
  127. {
  128. AnsiString BackupFileName = pCDSForm->LocalFileName+".bak";
  129. if (FileExists(pCDSForm->LocalFileName))
  130. {
  131. try {
  132. //DeleteFile(pCDSForm->LocalFileName);
  133. MoveFile(pCDSForm->LocalFileName.c_str(), BackupFileName.c_str());
  134. } catch(Exception &) {}
  135. }
  136. try
  137. {
  138. TMemoryStream *Stream1 = (TMemoryStream *)pADO->CreateBlobStream(pADO->FieldByName("VMS_FORM_IMAG"), bmRead);
  139. Stream1->SaveToFile(pCDSForm->LocalFileName);
  140. SAFE_DELETE(Stream1);
  141. }
  142. catch(Exception &e)
  143. {
  144. if (FileExists(BackupFileName))
  145. {
  146. MoveFile(BackupFileName.c_str(), pCDSForm->LocalFileName.c_str());
  147. }
  148. pCDSForm->LocalFileName = "";
  149. pCDSForm->FtpFileName = "";
  150. }
  151. }
  152. }
  153. #endif
  154. pCDSForm->UPDT_DT = UPDT_DT;
  155. nSelCnt++;
  156. }
  157. }
  158. catch(EDatabaseError &E)
  159. {
  160. DBERROR(String(E.ClassName()), E.Message, sQry);
  161. return -1;
  162. }
  163. catch(Exception &e)
  164. {
  165. DBERROR(String(e.ClassName()), e.Message, sQry);
  166. return -1;
  167. }
  168. }
  169. __finally
  170. {
  171. SQLFree(pADO);
  172. }
  173. if (LoadVmsFormObjectInfo(ADbConn) < 0)
  174. {
  175. return -1;
  176. }
  177. IDBSTOP(nSelCnt);
  178. return nSelCnt;
  179. }
  180. //---------------------------------------------------------------------------
  181. int TCDSFormManager::LoadVmsFormObjectInfo(TADOConnection *ADbConn)
  182. {
  183. String sQry;
  184. TADOQuery *pADO = NULL;
  185. TStream *pStream = NULL;
  186. int nSelCnt = 0;
  187. DDBSTART;
  188. sQry = "SELECT B.VMS_FORM_ID, \r\n"
  189. " B.VMS_FORM_OBJECT_ID, \r\n"
  190. " B.VMS_FORM_DSPL_ROW, \r\n"
  191. " B.VMS_FORM_DSPL_CLMN, \r\n"
  192. " B.VMS_FORM_OBJECT_TYPE_CD, \r\n"
  193. " B.VMS_FONT_NAME_CD, \r\n"
  194. " B.VMS_FONT_COLR_CD, \r\n"
  195. " B.VMS_FONT_BOLD, \r\n"
  196. " B.VMS_FONT_SIZE, \r\n"
  197. " B.VMS_FONT_ALIGN, \r\n"
  198. " B.VMS_DSPL_TXT, \r\n"
  199. " B.VMS_DSPL_XCRDN, \r\n"
  200. " B.VMS_DSPL_YCRDN, \r\n"
  201. " B.VMS_DSPL_WIDTH, \r\n"
  202. " B.VMS_DSPL_HEIGHT, \r\n"
  203. " B.VMS_DSPL_BLINKING, \r\n"
  204. " B.VMS_DSPL_BKCOLOR, \r\n"
  205. " B.VMS_DSPL_SIZE, \r\n"
  206. " B.TRFC_FILL_CD, \r\n"
  207. " B.SYMB_LIB_NMBR, \r\n"
  208. " B.VMS_IFSC_ID \r\n"
  209. " FROM TB_VMS_FORM A, \r\n"
  210. " TB_VMS_FORM_OBJECT B, \r\n"
  211. " TB_VMS_SYMB_LIB C \r\n"
  212. " WHERE A.VMS_FORM_ID = B.VMS_FORM_ID \r\n"
  213. " AND B.SYMB_LIB_NMBR = C.SYMB_LIB_NMBR(+) \r\n"
  214. " ORDER BY B.VMS_FORM_ID, B.VMS_FORM_OBJECT_ID \r\n";
  215. try
  216. {
  217. TCDSForm *pCDSForm;
  218. TCDSFormObj *pCDSFormObj;
  219. try
  220. {
  221. pADO = new TADOQuery(NULL);
  222. pADO->Connection = ADbConn;
  223. SQLText(pADO, sQry, true);
  224. SQLOpen(pADO);
  225. for( ; !pADO->Eof; pADO->Next())
  226. {
  227. AnsiString sFormId = pADO->FieldByName("VMS_FORM_ID")->AsString.Trim();
  228. pCDSForm = FLists.Find(sFormId);
  229. if (!pCDSForm)
  230. {
  231. MDEBUG("DCOM Not Found Form Object by FormId: %d", sFormId.c_str());
  232. continue;
  233. }
  234. nSelCnt++;
  235. pCDSFormObj = new TCDSFormObj();
  236. pCDSFormObj->VMS_FORM_OBJECT_ID = pADO->FieldByName("VMS_FORM_OBJECT_ID")->AsInteger;
  237. pCDSFormObj->VMS_FORM_ID = pADO->FieldByName("VMS_FORM_ID")->AsString;
  238. pCDSFormObj->VMS_FORM_DSPL_ROW = pADO->FieldByName("VMS_FORM_DSPL_ROW")->AsInteger;
  239. pCDSFormObj->VMS_FORM_DSPL_CLMN = pADO->FieldByName("VMS_FORM_DSPL_CLMN")->AsInteger;
  240. pCDSFormObj->VMS_FORM_OBJECT_TYPE_CD = pADO->FieldByName("VMS_FORM_OBJECT_TYPE_CD")->AsInteger;
  241. pCDSFormObj->VMS_FONT_NAME_CD = pADO->FieldByName("VMS_FONT_NAME_CD")->AsInteger;
  242. pCDSFormObj->VMS_FONT_COLR_CD = pADO->FieldByName("VMS_FONT_COLR_CD")->AsInteger;
  243. pCDSFormObj->VMS_FONT_BOLD = pADO->FieldByName("VMS_FONT_BOLD")->AsInteger;
  244. pCDSFormObj->VMS_FONT_SIZE = pADO->FieldByName("VMS_FONT_SIZE")->AsInteger;
  245. pCDSFormObj->VMS_FONT_ALIGN = pADO->FieldByName("VMS_FONT_ALIGN")->AsInteger;
  246. pCDSFormObj->VMS_DSPL_TXT = pADO->FieldByName("VMS_DSPL_TXT")->AsString;
  247. pCDSFormObj->VMS_DSPL_XCRDN = pADO->FieldByName("VMS_DSPL_XCRDN")->AsInteger;
  248. pCDSFormObj->VMS_DSPL_YCRDN = pADO->FieldByName("VMS_DSPL_YCRDN")->AsInteger;
  249. pCDSFormObj->VMS_DSPL_WIDTH = pADO->FieldByName("VMS_DSPL_WIDTH")->AsInteger;
  250. pCDSFormObj->VMS_DSPL_HEIGHT = pADO->FieldByName("VMS_DSPL_HEIGHT")->AsInteger;
  251. pCDSFormObj->VMS_DSPL_BLINKING = pADO->FieldByName("VMS_DSPL_BLINKING")->AsInteger;
  252. pCDSFormObj->VMS_DSPL_BKCOLOR = pADO->FieldByName("VMS_DSPL_BKCOLOR")->AsInteger;
  253. pCDSFormObj->VMS_DSPL_SIZE = pADO->FieldByName("VMS_DSPL_SIZE")->AsInteger;
  254. pCDSFormObj->TRFC_FILL_CD = pADO->FieldByName("TRFC_FILL_CD")->AsString;
  255. pCDSFormObj->SYMB_LIB_NMBR = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  256. pCDSFormObj->VMS_IFSC_ID = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  257. pCDSForm->FLists.Push(pCDSFormObj->VMS_FORM_OBJECT_ID, pCDSFormObj);
  258. int nObjType = pCDSFormObj->VMS_FORM_OBJECT_TYPE_CD;
  259. if (pCDSForm->VMS_FORM_TYPE_CD == eFormtp_figure)
  260. {
  261. //도형식 소통정보 폼인데 구간 소통정보를 하단에 표출하는 경우
  262. //하나의 폼이 여러개의 소통정보를 표출되도록 하기 위함
  263. switch(nObjType)
  264. {
  265. //////////////////////// 20200515 추가함(S)
  266. case 0://, , @문자열
  267. case 1://, , @심볼
  268. case 2://, , @이미지
  269. if (pCDSFormObj->TRFC_FILL_CD == "F")
  270. {
  271. //하단고정일 경우 도형식하단에 표출할 소통정보가 없을 경우 표출하는 정보임
  272. pCDSForm->TrfFixed = true;
  273. }
  274. break;
  275. //////////////////////// 20200515 추가함(E)
  276. case 11://, ' @구간명
  277. case 12://, ' @시점명
  278. case 13://, ' @종점명
  279. case 14://, ' @소통상황
  280. case 15://, ' @통행시간
  281. case 16://, ' @통행속도
  282. case 17://, ' @소통정보이미지
  283. case 18://, ' @지점명
  284. pCDSForm->TrfIfsc = true;
  285. break;
  286. case 93://, ' @축시점명(순환)
  287. case 94://, ' @축종점명(순환)
  288. case 95://, ' @축소통상황(순환)
  289. case 96://, ' @축통행시간(순환)
  290. pCDSForm->TrfAxis = true;
  291. break;
  292. }
  293. }
  294. if (nObjType == 3)
  295. {
  296. pCDSForm->TrfBakImgId = pCDSFormObj->SYMB_LIB_NMBR + "0";
  297. }
  298. if (nObjType == 1 || //심볼
  299. nObjType == 2 || //이미지(파일에서 직접입력한것임)
  300. nObjType == 3 || //소통정보배경이미지
  301. nObjType == 17 || //소통정보이미지1
  302. nObjType == 27 || //소통정보이미지2
  303. nObjType == 37 || //소통정보이미지3
  304. nObjType == 47 || //소통정보이미지4
  305. nObjType == 200 || //동영상이미지
  306. nObjType == 300 ) //스트리밍영상이미지
  307. {
  308. pCDSFormObj->Clear();
  309. //pCDSFormObj->pImage->Picture->Bitmap->PixelFormat = pf4bit;
  310. //심볼에서 읽지 않고 폼오브젝트에 있는 이미지를 사용함
  311. #if 1
  312. try
  313. {
  314. TCDSImage *pVmsImg = CDSImageManager->FLists.Find(pCDSFormObj->SYMB_LIB_NMBR+"0");
  315. if (pVmsImg && pVmsImg->IMAG_DATA)
  316. {
  317. pCDSFormObj->pImage->Picture->Bitmap->Assign(pVmsImg->IMAG_DATA->Picture->Bitmap);
  318. }
  319. else
  320. {
  321. MERROR("MAIN LoadVmsFormObjectInfo Symbol Not Found: %s", pCDSFormObj->SYMB_LIB_NMBR.c_str());
  322. }
  323. }
  324. catch(Exception &e)
  325. {
  326. MERROR("MAIN LoadVmsFormObjectInfo Symbol Find Failed: %s, %s, %s", pCDSFormObj->SYMB_LIB_NMBR.c_str(), AnsiString(e.ClassName()).c_str(), AnsiString(e.Message).c_str());
  327. }
  328. #else
  329. TStream *pStream = pADO->CreateBlobStream(pADO->FieldByName("IMAG_DATA"), bmRead);
  330. try
  331. {
  332. if (pStream && pStream->Size > 0)
  333. {
  334. pStream->Position = 0;
  335. AssignBmp(pCDSFormObj->pImage, pStream);
  336. }
  337. }
  338. __finally
  339. {
  340. SAFE_DELETE(pStream);
  341. }
  342. #endif
  343. }
  344. }
  345. }
  346. catch(EDatabaseError &E)
  347. {
  348. DBERROR(String(E.ClassName()), E.Message, sQry);
  349. return -1;
  350. }
  351. catch(Exception &e)
  352. {
  353. DBERROR(String(e.ClassName()), e.Message, sQry);
  354. return -1;
  355. }
  356. }
  357. __finally
  358. {
  359. SQLFree(pADO);
  360. }
  361. #if 0
  362. if (0)//g_LogCfg.Debug)
  363. {
  364. FOR_STL(TCDSForm*, pTmp, FormManager->FLists)
  365. {
  366. MDEBUG("DCOM Vms Form: %s, Objects: %d", pTmp->VMS_FORM_ID.c_str(), pTmp->FLists.Size());
  367. }
  368. }
  369. #endif
  370. IDBSTOP(nSelCnt);
  371. return nSelCnt;
  372. }
  373. //---------------------------------------------------------------------------