CDSImageF.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSImageF.h"
  4. #include "CDSCtlrF.h"
  5. #include "VmsUtilsF.h"
  6. #include "VMSCommLibF.h"
  7. //---------------------------------------------------------------------------
  8. #pragma package(smart_init)
  9. //---------------------------------------------------------------------------
  10. TCDSImageCell::TCDSImageCell()
  11. {
  12. IsDup = false;
  13. }
  14. //---------------------------------------------------------------------------
  15. TCDSImageCell::~TCDSImageCell()
  16. {
  17. }
  18. //---------------------------------------------------------------------------
  19. //---------------------------------------------------------------------------
  20. TCDSImage::TCDSImage()
  21. {
  22. IMAG_DATA = NULL;
  23. IMAG_DATA = new TImage(NULL);
  24. UPDT_DT = "-";
  25. }
  26. //---------------------------------------------------------------------------
  27. TCDSImage::~TCDSImage()
  28. {
  29. Clear();
  30. SAFE_DELETE(IMAG_DATA);
  31. FLists.RemoveAll();
  32. }
  33. //---------------------------------------------------------------------------
  34. void TCDSImage::Clear()
  35. {
  36. if (IMAG_DATA)
  37. {
  38. IMAG_DATA->Picture->Bitmap->FreeImage();
  39. IMAG_DATA->Picture->Assign(NULL);
  40. }
  41. }
  42. //---------------------------------------------------------------------------
  43. //---------------------------------------------------------------------------
  44. TCDSImageManager *CDSImageManager = NULL;
  45. //---------------------------------------------------------------------------
  46. TCDSImageManager::TCDSImageManager()
  47. {
  48. }
  49. //---------------------------------------------------------------------------
  50. TCDSImageManager::~TCDSImageManager()
  51. {
  52. FLists.RemoveAll();
  53. }
  54. //---------------------------------------------------------------------------
  55. int TCDSImageManager::LoadVmsSymbolInfo(TADOConnection *ADbConn)
  56. {
  57. String sQry;
  58. TADOQuery *pADO = NULL;
  59. TStream *pStream = NULL;
  60. int nSelCnt = 0;
  61. int ii;
  62. DWORD dwTick = GetTickCount();
  63. SELSTART;
  64. //SYMB_TYPE: 심벌 유형(SBT0:일반심벌이미지,SBT1:소통정보배경,SBT2:소통정보이미지,SBT3:동영상,SBT4:대기환경등급)
  65. sQry = "SELECT A.* \r\n"
  66. " FROM TB_VMS_SYMB_LIB A \r\n";
  67. try
  68. {
  69. TCDSImage *pVmsImg;
  70. try
  71. {
  72. pADO = new TADOQuery(NULL);
  73. pADO->Connection = ADbConn;
  74. SQLText(pADO, sQry, true);
  75. SQLOpen(pADO);
  76. for( ; !pADO->Eof; pADO->Next())
  77. {
  78. AnsiString SYMB_LIB_NMBR = pADO->FieldByName("SYMB_LIB_NMBR")->AsString;
  79. AnsiString UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString.Trim();
  80. AnsiString SYMB_TYPE = pADO->FieldByName("SYMB_TYPE")->AsString.Trim(); //심벌 유형(SBT0:일반심벌이미지,SBT1:소통정보배경,SBT2:소통정보이미지,SBT3:동영상,SBT4:대기환경등급)
  81. AnsiString sSymbolNmbr = SYMB_LIB_NMBR + "0"; //소통정보이미지 때문에 이미지번호에 "0" 을 추가하여 이미지번호로 사용함
  82. pVmsImg = FLists.Find(sSymbolNmbr);
  83. if (!pVmsImg)
  84. {
  85. pVmsImg = new TCDSImage();
  86. pVmsImg->SYMB_LIB_NMBR = sSymbolNmbr;
  87. FLists.Push(pVmsImg->SYMB_LIB_NMBR, pVmsImg);
  88. }
  89. if (SYMB_TYPE == "SBT4") // 대기환경등급 이미지
  90. {
  91. TStringList *sl = new TStringList;
  92. try
  93. {
  94. sl->Delimiter = '^';
  95. sl->StrictDelimiter = true;
  96. sl->DelimitedText = pADO->FieldByName("SYMB_EXPL")->AsString.Trim();
  97. for (ii = 0; ii < sl->Count; ii++)
  98. {
  99. if (ii < MAX_GRADE_SYNB)
  100. {
  101. pVmsImg->GRAD_SYMB_LIB_NMBR[ii] = sl->Strings[ii].Trim() + "0";
  102. }
  103. }
  104. if (sl) delete sl;
  105. sl = NULL;
  106. }
  107. catch(Exception &e)
  108. {
  109. }
  110. }
  111. nSelCnt++;
  112. AnsiString LocalFileName = "";
  113. AnsiString SYMB_FILE_NM = "";
  114. if (SYMB_TYPE == "SBT3")
  115. {
  116. //동영상
  117. SYMB_FILE_NM = pADO->FieldByName("SYMB_FILE_NM")->AsString.Trim();
  118. }
  119. else
  120. {
  121. SYMB_FILE_NM = pVmsImg->SYMB_LIB_NMBR;
  122. switch(pVmsImg->Type)
  123. {
  124. case vms_image_type_bmp: SYMB_FILE_NM += ".bmp"; break;
  125. case vms_image_type_gif: SYMB_FILE_NM += ".gif"; break;
  126. case vms_image_type_jpg: SYMB_FILE_NM += ".jpg"; break;
  127. default: break;
  128. }
  129. }
  130. LocalFileName = g_sFtpImageDir + SYMB_FILE_NM;
  131. if (FileExists(LocalFileName) && pVmsImg->UPDT_DT == UPDT_DT)
  132. {
  133. //심볼 파일이 로컬 경로에 존재하지 않거나
  134. //심볼 업데이트 시각이 다른 경우에만
  135. //심볼울 로컬 디렉토리에 저장한다.
  136. continue;
  137. }
  138. pVmsImg->Type = vms_image_type_bmp;
  139. pVmsImg->UPDT_DT = UPDT_DT;
  140. pVmsImg->SYMB_TYPE = SYMB_TYPE;
  141. pVmsImg->SYMB_FILE_NM = SYMB_FILE_NM; //동영상인 경우 동영상 파일명
  142. pVmsImg->IMAG_SIZE = pADO->FieldByName("IMAG_SIZE")->AsInteger; // N NUMBER(10) Y 0 이미지 사이즈
  143. pVmsImg->PLAY_TM = pADO->FieldByName("PLAY_TM")->AsInteger; // N NUMBER(10) Y 0 동영상 플레이 시간
  144. pVmsImg->LocalFileName = ""; // 이미지저장명 초기화
  145. pVmsImg->FtpFileName = ""; // Ftp 다운로드 명을 초기화
  146. pVmsImg->Clear();
  147. pVmsImg->FLists.RemoveAll();
  148. TStream *pStream = NULL;
  149. try
  150. {
  151. try
  152. {
  153. pStream = pADO->CreateBlobStream(pADO->FieldByName("IMAG_DATA"), bmRead);
  154. if (pStream && pStream->Size > 0)
  155. {
  156. pStream->Position = 0;
  157. bool bRes = true;
  158. switch(pVmsImg->Type)
  159. {
  160. case vms_image_type_bmp: bRes = AssignBmp(pVmsImg->IMAG_DATA, pStream); break;
  161. case vms_image_type_gif: bRes = AssignGif(pVmsImg->IMAG_DATA, pStream); break;
  162. case vms_image_type_jpg: bRes = AssignJpg(pVmsImg->IMAG_DATA, pStream); break;
  163. default: break;
  164. }
  165. pVmsImg->SYMB_FILE_NM = pVmsImg->SYMB_LIB_NMBR;
  166. switch(pVmsImg->Type)
  167. {
  168. case vms_image_type_bmp: pVmsImg->SYMB_FILE_NM += ".bmp"; break;
  169. case vms_image_type_gif: pVmsImg->SYMB_FILE_NM += ".gif"; break;
  170. case vms_image_type_jpg: pVmsImg->SYMB_FILE_NM += ".jpg"; break;
  171. default: break;
  172. }
  173. pVmsImg->LocalFileName = g_sFtpImageDir + pVmsImg->SYMB_FILE_NM;
  174. pVmsImg->FtpFileName = AnsiString(FTP_IMAGE) + "\\" + pVmsImg->SYMB_FILE_NM;
  175. AnsiString BackupFileName = pVmsImg->LocalFileName+".bak";
  176. if (FileExists(pVmsImg->LocalFileName))
  177. {
  178. try {
  179. DeleteFile(pVmsImg->LocalFileName);
  180. //MoveFile(pVmsImg->LocalFileName.c_str(), BackupFileName.c_str());
  181. } catch(Exception &) {}
  182. }
  183. switch(pVmsImg->Type)
  184. {
  185. case vms_image_type_bmp: bRes = SaveToFileBmp(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  186. case vms_image_type_gif: bRes = SaveToFileGif(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  187. case vms_image_type_jpg: bRes = SaveToFileJpg(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  188. default: break;
  189. }
  190. if (!bRes)
  191. {
  192. //if (FileExists(BackupFileName))
  193. //{
  194. // MoveFile(BackupFileName.c_str(), pVmsImg->LocalFileName.c_str());
  195. //}
  196. pVmsImg->LocalFileName = "";
  197. pVmsImg->FtpFileName = "";
  198. }
  199. }
  200. }
  201. catch(Exception &e)
  202. {
  203. pVmsImg->LocalFileName = "";
  204. pVmsImg->FtpFileName = "";
  205. }
  206. }
  207. __finally
  208. {
  209. SAFE_DELETE(pStream);
  210. }
  211. if (pVmsImg->SYMB_TYPE == "SBT3") //심벌 유형(SBT0:일반심벌이미지,SBT1:소통정보배경,SBT2:소통정보이미지,SBT3:동영상)
  212. {
  213. //위에서 이미지저장하기 위해 파일명을 변경하기 때문에 여기서 동영상 파일명을 다시 읽어온다
  214. pVmsImg->SYMB_FILE_NM = pADO->FieldByName("SYMB_FILE_NM")->AsString.Trim(); //동영상인 경우 동영상 파일명
  215. pVmsImg->LocalFileName = g_sFtpVideoDir + pVmsImg->SYMB_FILE_NM;
  216. pVmsImg->FtpFileName = AnsiString(FTP_VIDEO) + "\\" + pVmsImg->SYMB_FILE_NM; // Ftp 다운로드 명을 설정
  217. #if 0
  218. if (FileExists(pVmsImg->LocalFileName))
  219. {
  220. try {
  221. // DeleteFile(pVmsImg->LocalFileName);
  222. } catch(Exception &) {}
  223. }
  224. else
  225. {
  226. TMemoryStream *Stream1 = (TMemoryStream *)pADO->CreateBlobStream(pADO->FieldByName("AVI_DATA"), bmRead);
  227. try
  228. {
  229. try {
  230. Stream1->SaveToFile(pVmsImg->LocalFileName);
  231. } catch(Exception &) {
  232. pVmsImg->FtpFileName = "";
  233. }
  234. }
  235. __finally
  236. {
  237. SAFE_DELETE(pStream);
  238. }
  239. }
  240. #endif
  241. }
  242. else
  243. if (pVmsImg->SYMB_TYPE == "SBT2") //심벌 유형(SBT0:일반심벌이미지,SBT1:소통정보배경,SBT2:소통정보이미지,SBT3:동영상)
  244. {
  245. //소통정보 등급에 따른 이미지를 새롭게 추가한다.
  246. for (int nTrf = 1; nTrf <= 3; nTrf++)
  247. {
  248. sSymbolNmbr = SYMB_LIB_NMBR + AnsiString(nTrf);
  249. //좌표가 바뀌더라도 셀정보에서 업데이트 한다. 이미지내용이 바뀌는 경우는 없다
  250. //여기서는 일단 메모리에만 이미지정보를 생성한후 셀좌표에 따른 색깔을 LoadVmsSymbolCellInfo 함수에서 입힌후
  251. //마지막에 파일로 저장한다.
  252. TCDSImage* pTmpImg = FLists.Find(sSymbolNmbr);
  253. if (pTmpImg) continue; // 있으면 처리하지 않음
  254. pTmpImg = new TCDSImage();
  255. pTmpImg->SYMB_LIB_NMBR = sSymbolNmbr;
  256. FLists.Push(pTmpImg->SYMB_LIB_NMBR, pTmpImg);
  257. pTmpImg->Type = pVmsImg->Type;
  258. //pTmpImg->UPDT_DT = pVmsImg->UPDT_DT; //여기는 셀정보를 업데이트할때 사용하기 위해 설정하지 않는다
  259. pTmpImg->SYMB_TYPE = pVmsImg->SYMB_TYPE;
  260. pTmpImg->SYMB_FILE_NM = pVmsImg->SYMB_FILE_NM; //동영상인 경우 동영상 파일명
  261. pTmpImg->IMAG_SIZE = pVmsImg->IMAG_SIZE; // N NUMBER(10) Y 0 이미지 사이즈
  262. pTmpImg->PLAY_TM = pVmsImg->PLAY_TM; // N NUMBER(10) Y 0 동영상 플레이 시간
  263. pTmpImg->LocalFileName = ""; // 이미지저장명 초기화
  264. pTmpImg->FtpFileName = ""; // Ftp 다운로드 명을 초기화
  265. pTmpImg->Clear();
  266. pTmpImg->FLists.RemoveAll();
  267. TStream *pTrfStream = NULL;
  268. try
  269. {
  270. try
  271. {
  272. pTrfStream = pADO->CreateBlobStream(pADO->FieldByName("IMAG_DATA"), bmRead);
  273. if (pTrfStream && pTrfStream->Size > 0)
  274. {
  275. pTrfStream->Position = 0;
  276. switch(pTmpImg->Type)
  277. {
  278. case vms_image_type_bmp: AssignBmp(pTmpImg->IMAG_DATA, pTrfStream); break;
  279. case vms_image_type_gif: AssignGif(pTmpImg->IMAG_DATA, pTrfStream); break;
  280. case vms_image_type_jpg: AssignJpg(pTmpImg->IMAG_DATA, pTrfStream); break;
  281. default: break;
  282. }
  283. pTmpImg->SYMB_FILE_NM = pTmpImg->SYMB_LIB_NMBR;
  284. switch(pTmpImg->Type)
  285. {
  286. case vms_image_type_bmp: pTmpImg->SYMB_FILE_NM += ".bmp"; break;
  287. case vms_image_type_gif: pTmpImg->SYMB_FILE_NM += ".gif"; break;
  288. case vms_image_type_jpg: pTmpImg->SYMB_FILE_NM += ".jpg"; break;
  289. default: break;
  290. }
  291. pTmpImg->LocalFileName = g_sFtpImageDir + pTmpImg->SYMB_FILE_NM;
  292. pTmpImg->FtpFileName = AnsiString(FTP_IMAGE) + "\\" + pTmpImg->SYMB_FILE_NM;
  293. }
  294. }
  295. catch(Exception &e)
  296. {
  297. pTmpImg->LocalFileName = "";
  298. pTmpImg->FtpFileName = "";
  299. }
  300. }
  301. __finally
  302. {
  303. SAFE_DELETE(pTrfStream);
  304. }
  305. }
  306. }
  307. }
  308. }
  309. catch(EDatabaseError &E)
  310. {
  311. DBERROR(String(E.ClassName()), E.Message, sQry);
  312. return -1;
  313. }
  314. catch(Exception &e)
  315. {
  316. DBERROR(String(e.ClassName()), e.Message, sQry);
  317. return -1;
  318. }
  319. }
  320. __finally
  321. {
  322. SQLFree(pADO);
  323. }
  324. SELEND(nSelCnt, dwTick);
  325. if (LoadVmsSymbolCellInfo(ADbConn) < 0)
  326. {
  327. return -1;
  328. }
  329. #if 0
  330. //FTP로 다운로드 해야 하기 때문에 파일로 저장해야 한다.
  331. //소통정보 이미지 같은 경우 디비에는 하나만 등록하고 읽어서 처리할때 소통등급별 이미지를 만들어서
  332. //소통등급별로 이미지를 만든다.
  333. //모든 이미지는 최초 한번만 로컬에 파일로 저장하도록 하고 소통정보 이미지인 경우에만 셀정보가 바뀔수 있기 때문에
  334. //새롭게 저장하도록 하자
  335. FOR_STL(TCDSImage*, pVmsImg, FLists)
  336. {
  337. MINFO("DCOM IMAGE: %s, %s, %s", pVmsImg->SYMB_LIB_NMBR.c_str(), pVmsImg->LocalFileName.c_str(), pVmsImg->FtpFileName.c_str());
  338. if (pVmsImg->SYMB_TYPE != "SBT2") continue; // 소통정보 이미지가 아닌경우 이미 위에서 저장 했음
  339. if (pVmsImg->SYMB_LIB_NMBR.ToIntDef(0) % 10) // <== 요거는 원본 이미지가 아닌경우, 마지막심벌자리가 0(원본), 1(원활), 2(지체), 3(정체) 로 저장됨
  340. {
  341. //소통정보 원본 이미지는 이미 저장했으니까 소통등급에 따른 이미지만 여기서 저장
  342. bool bFail = false;
  343. try
  344. {
  345. //기존에 있으면 삭제한다.
  346. AnsiString BackupFileName = pVmsImg->LocalFileName+".bak";
  347. if (FileExists(pVmsImg->LocalFileName))
  348. {
  349. try {
  350. //DeleteFile(pVmsImg->LocalFileName);
  351. MoveFile(pVmsImg->LocalFileName.c_str(), BackupFileName.c_str());
  352. } catch(Exception &) {}
  353. }
  354. bool bRes = true;
  355. switch(pVmsImg->Type)
  356. {
  357. case vms_image_type_bmp: bRes = SaveToFileBmp(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  358. case vms_image_type_gif: bRes = SaveToFileGif(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  359. case vms_image_type_jpg: bRes = SaveToFileJpg(pVmsImg->IMAG_DATA, pVmsImg->LocalFileName); break;
  360. default: break;
  361. }
  362. if (!bRes)
  363. {
  364. if (FileExists(BackupFileName))
  365. {
  366. MoveFile(BackupFileName.c_str(), pVmsImg->LocalFileName.c_str());
  367. }
  368. }
  369. }
  370. catch(Exception &e)
  371. {
  372. pVmsImg->LocalFileName = "";
  373. pVmsImg->FtpFileName = "";
  374. bFail = true;
  375. }
  376. if (bFail)
  377. {
  378. if (FileExists(pVmsImg->LocalFileName))
  379. {
  380. try {
  381. DeleteFile(pVmsImg->LocalFileName);
  382. } catch(Exception &) {}
  383. }
  384. }
  385. }
  386. }
  387. #endif
  388. CtlrItr it;
  389. for(it=CDSCtlrManager->FLists.FObjects.begin(); it != CDSCtlrManager->FLists.FObjects.end(); ++it)
  390. {
  391. TCDSCtlr *pObj = (TCDSCtlr*)it->second;
  392. pObj->FSymbolDownload = true;
  393. }
  394. return nSelCnt;
  395. }
  396. //---------------------------------------------------------------------------
  397. int TCDSImageManager::LoadVmsSymbolCellInfo(TADOConnection *ADbConn)
  398. {
  399. String sQry;
  400. TADOQuery *pADO = NULL;
  401. int nSelCnt = 0;
  402. DWORD dwTick = GetTickCount();
  403. SELSTART;
  404. sQry = "SELECT B.*, A.UPDT_DT \r\n"
  405. " FROM TB_VMS_SYMB_LIB A, \r\n"
  406. " TB_VMS_SYMB_IFSC B \r\n"
  407. " WHERE A.SYMB_LIB_NMBR = B.SYMB_LIB_NMBR \r\n"
  408. " ORDER BY B.SYMB_LIB_NMBR, B.CELL_ID \r\n";
  409. try
  410. {
  411. TCDSImage *pVmsImg;
  412. TCDSImageCell *pImgCell;
  413. try
  414. {
  415. pADO = new TADOQuery(NULL);
  416. pADO->Connection = ADbConn;
  417. SQLText(pADO, sQry, true);
  418. SQLOpen(pADO);
  419. for( ; !pADO->Eof; pADO->Next())
  420. {
  421. AnsiString UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString.Trim();
  422. AnsiString SYMB_LIB_NMBR = pADO->FieldByName("SYMB_LIB_NMBR")->AsString.Trim();
  423. AnsiString sSymbolNmbr = SYMB_LIB_NMBR + "0"; //소통정보이미지 때문에 이미지번호에 "0" 을 추가하여 이미지번호로 사용함
  424. pVmsImg = CDSImageManager->FLists.Find(sSymbolNmbr);
  425. if (!pVmsImg)
  426. {
  427. continue;
  428. }
  429. pImgCell = new TCDSImageCell();
  430. pImgCell->SYMB_LIB_NMBR = sSymbolNmbr;
  431. pImgCell->CELL_ID = pADO->FieldByName("CELL_ID")->AsInteger;
  432. pImgCell->POSX = pADO->FieldByName("POSX")->AsInteger;
  433. pImgCell->POSY = pADO->FieldByName("POSY")->AsInteger;
  434. pImgCell->VMS_IFSC_ID = pADO->FieldByName("VMS_IFSC_ID")->AsString;
  435. pImgCell->IsDup = false;
  436. FOR_STL(TCDSImageCell*, pDup, pVmsImg->FLists)
  437. {
  438. if (pDup->VMS_IFSC_ID == pImgCell->VMS_IFSC_ID)
  439. {
  440. pImgCell->IsDup = true;
  441. break;
  442. }
  443. }
  444. pVmsImg->FLists.Push(pImgCell->CELL_ID, pImgCell);
  445. //소통정보 이미지인 경우(원활,지체,정체 이미지 생성)
  446. if (pVmsImg->SYMB_TYPE == "SBT2") //심벌 유형(SBT0:일반심벌이미지,SBT1:소통정보배경,SBT2:소통정보이미지,SBT3:동영상,SBT4:대기환경등급)
  447. {
  448. for (int nTrf = 1; nTrf <= 3; nTrf++)
  449. {
  450. sSymbolNmbr = SYMB_LIB_NMBR + AnsiString(nTrf);
  451. TCDSImage *pTmpImg = CDSImageManager->FLists.Find(sSymbolNmbr);
  452. if (!pTmpImg) continue;
  453. if (FileExists(pTmpImg->LocalFileName) && pTmpImg->UPDT_DT == UPDT_DT)
  454. {
  455. //변경된게 없으므로 저장하지 않는다.
  456. continue;
  457. }
  458. pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->Lock();
  459. try
  460. {
  461. pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->Brush->Color = GradeToFillColor(nTrf);
  462. TColor clColor = pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->Pixels[pImgCell->POSX][pImgCell->POSY];
  463. if (clColor == clWhite)
  464. {
  465. pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->Brush->Color = clWhite;
  466. }
  467. pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->FloodFill(pImgCell->POSX, pImgCell->POSY, clColor, fsSurface);
  468. }
  469. __finally
  470. {
  471. pTmpImg->IMAG_DATA->Picture->Bitmap->Canvas->Unlock();
  472. }
  473. //소통정보 소통등급 이미지를 로컬에 저장한다.
  474. bool bRes = true;
  475. AnsiString BackupFileName = pTmpImg->LocalFileName+".bak";
  476. if (FileExists(pTmpImg->LocalFileName))
  477. {
  478. try {
  479. DeleteFile(pTmpImg->LocalFileName);
  480. //MoveFile(pTmpImg->LocalFileName.c_str(), BackupFileName.c_str());
  481. } catch(Exception &) {}
  482. }
  483. switch(pTmpImg->Type)
  484. {
  485. case vms_image_type_bmp: bRes = SaveToFileBmp(pTmpImg->IMAG_DATA, pTmpImg->LocalFileName); break;
  486. case vms_image_type_gif: bRes = SaveToFileGif(pTmpImg->IMAG_DATA, pTmpImg->LocalFileName); break;
  487. case vms_image_type_jpg: bRes = SaveToFileJpg(pTmpImg->IMAG_DATA, pTmpImg->LocalFileName); break;
  488. default: break;
  489. }
  490. if (bRes)
  491. {
  492. pTmpImg->UPDT_DT = UPDT_DT;
  493. }
  494. else
  495. {
  496. if (FileExists(BackupFileName))
  497. {
  498. MoveFile(BackupFileName.c_str(), pTmpImg->LocalFileName.c_str());
  499. }
  500. pTmpImg->LocalFileName = "";
  501. pTmpImg->FtpFileName = "";
  502. }
  503. }
  504. }
  505. pVmsImg->UPDT_DT = UPDT_DT;
  506. nSelCnt++;
  507. }
  508. }
  509. catch(EDatabaseError &E)
  510. {
  511. DBERROR(String(E.ClassName()), E.Message, sQry);
  512. return -1;
  513. }
  514. catch(Exception &e)
  515. {
  516. DBERROR(String(e.ClassName()), e.Message, sQry);
  517. return -1;
  518. }
  519. }
  520. __finally
  521. {
  522. SQLFree(pADO);
  523. }
  524. SELEND(nSelCnt, dwTick);
  525. return nSelCnt;
  526. }
  527. //---------------------------------------------------------------------------