IRP00101F.cpp 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "ITSSkinF.h"
  4. #include "ITSUtilF.h"
  5. #include "ITSDbF.h"
  6. #include "AppGlobalF.h"
  7. #include "WindowMsgF.h"
  8. #include "CDSCodeF.h"
  9. #include "CDSNodeF.h"
  10. #include "CDSLinkF.h"
  11. #include "ITSLangTransF.h"
  12. #pragma hdrstop
  13. #include "IRP00101F.h"
  14. //---------------------------------------------------------------------------
  15. #pragma package(smart_init)
  16. #pragma link "cxButtons"
  17. #pragma link "cxClasses"
  18. #pragma link "cxControls"
  19. #pragma link "cxCustomData"
  20. #pragma link "cxData"
  21. #pragma link "cxDataStorage"
  22. #pragma link "cxEdit"
  23. #pragma link "cxFilter"
  24. #pragma link "cxGraphics"
  25. #pragma link "cxGrid"
  26. #pragma link "cxGridCustomTableView"
  27. #pragma link "cxGridCustomView"
  28. #pragma link "cxGridLevel"
  29. #pragma link "cxGridTableView"
  30. #pragma link "cxLabel"
  31. #pragma link "cxLookAndFeelPainters"
  32. #pragma link "cxLookAndFeels"
  33. #pragma link "cxStyles"
  34. #pragma link "dxSkinBlack"
  35. #pragma link "dxSkinBlue"
  36. #pragma link "dxSkinsCore"
  37. #pragma link "dxSkinscxPCPainter"
  38. #pragma link "dxmdaset"
  39. #pragma link "cxContainer"
  40. #pragma resource "*.dfm"
  41. #define USE_MEMDATA 1
  42. TIRP00101 *IRP00101 = NULL;
  43. //---------------------------------------------------------------------------
  44. __fastcall TIRP00101::TIRP00101(TComponent* Owner, HWND hHandle, int ARptType, String sFrom, String sTo, String ATitle)
  45. : TForm(Owner)
  46. {
  47. LangTrans->Translate(this, ITSDb_GetConnection());
  48. ITSSkin_Load(this);
  49. CMM_LoadForm(g_sFormsDir, this);
  50. FParent = hHandle;
  51. FStDateTime = sFrom;
  52. FEdDateTime = sTo;
  53. FRptType = ARptType;
  54. FTitle = ATitle;
  55. TvList->OptionsView->Header = true;
  56. //Caption = "보고서";
  57. }
  58. //---------------------------------------------------------------------------
  59. __fastcall TIRP00101::~TIRP00101(void)
  60. {
  61. }
  62. //--------------------------------------------------------------------------
  63. /*
  64. * form 초기화
  65. *
  66. * arguments
  67. *
  68. * return
  69. * void
  70. */
  71. void __fastcall TIRP00101::FormInit()
  72. {
  73. ADOQry->Connection = ITSDb_GetConnection();
  74. m_pGDC = TvList->DataController;
  75. TvList->OptionsView->NoDataToDisplayInfoText = FrmLang->lblNoInfo->Caption;//"<보고서 정보>";
  76. LblSearch->Caption = FTitle;
  77. }
  78. //---------------------------------------------------------------------------
  79. /*
  80. * form을 보여줄때 호출되는 event 메서드이다.
  81. * arguments
  82. * Sender : event handler 객체
  83. * return
  84. * void
  85. */
  86. void __fastcall TIRP00101::FormShow(TObject *Sender)
  87. {
  88. FormInit();
  89. Refresh();
  90. TmrShow->Enabled = true;
  91. }
  92. //---------------------------------------------------------------------------
  93. /*
  94. * 닫기버튼 이나 x버튼 클릭시 공통으로 처리하는 로직이들어간다..
  95. * Form과 DataModule class를 delete시킨다.
  96. * arguments
  97. *
  98. * return
  99. * void
  100. */
  101. void __fastcall TIRP00101::CommClose()
  102. {
  103. CMM_SaveForm(g_sFormsDir, this);
  104. //IRP00101 = NULL;
  105. }
  106. //---------------------------------------------------------------------------
  107. /*
  108. * 최초 1회 수행되는 타이머 이벤트
  109. * arguments
  110. * Sender : event handler 객체
  111. * return
  112. * void
  113. */
  114. void __fastcall TIRP00101::TmrShowTimer(TObject *Sender)
  115. {
  116. TmrShow->Enabled = false;
  117. CMM_ClearGridTableView(TvList);
  118. FRows = 0;
  119. Application->ProcessMessages();
  120. #if USE_MEMDATA
  121. try
  122. {
  123. TvList->BeginUpdate(lsimImmediate);
  124. #endif
  125. if (FRptType == 0)
  126. {
  127. SelReportFacility1();
  128. SelReportFacility2();
  129. }
  130. else
  131. {
  132. Column06->Visible = false;
  133. SelReportTraffic1();
  134. SelReportTraffic2();
  135. }
  136. #if USE_MEMDATA
  137. }
  138. __finally
  139. {
  140. TvList->EndUpdate();
  141. }
  142. #endif
  143. CMM_ExpandCollapseChk(TvList, true);
  144. }
  145. //---------------------------------------------------------------------------
  146. /*
  147. * Refresh Data Event Function
  148. * arguments
  149. *
  150. * return
  151. * void
  152. */
  153. void __fastcall TIRP00101::SelReportFacility1()
  154. {
  155. TSqlCursor sqlCrs;
  156. String sQry;
  157. TADOQuery *pADO = ADOQry;
  158. sQry = "SELECT FACSEQ, FACTYPE, NVL(CMS0CNT, 0) CMS0CNT, NVL(CMS1CNT, 0) CMS1CNT \r\n"
  159. " FROM (SELECT 1 as FACSEQ, 'VMS' AS FACTYPE, SUM(CMS0CNT)AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  160. " FROM (SELECT DECODE(CONN_STTS_CD, 'CMS0', 1, 0) AS CMS0CNT, \r\n"
  161. " DECODE(CONN_STTS_CD, 'CMS0', 0, 1) AS CMS1CNT \r\n"
  162. " FROM TB_VMS_STTS_HS \r\n"
  163. " WHERE RGST_DT BETWEEN :p01 AND :p02 \r\n"
  164. " ) \r\n"
  165. " UNION \r\n"
  166. " SELECT 2 as FACSEQ, 'CCTV' AS FACTYPE, SUM(CMS0CNT)AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  167. " FROM (SELECT DECODE(CMNC_STTS_CD, 'CMS0', 1, 0) AS CMS0CNT, \r\n"
  168. " DECODE(CMNC_STTS_CD, 'CMS0', 0, 1) AS CMS1CNT \r\n"
  169. " FROM TB_CCTV_STTS_HS \r\n"
  170. " WHERE CRTN_DT BETWEEN :p03 AND :p04 \r\n"
  171. " ) \r\n"
  172. " UNION \r\n"
  173. " SELECT 4 as FACSEQ, 'VDS' AS FACTYPE, SUM(CMS0CNT) AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  174. " FROM (SELECT DECODE(CMNC_STTS_CD, 'CMS0', 1, 0) AS CMS0CNT, \r\n"
  175. " DECODE(CMNC_STTS_CD, 'CMS0', 0, 1) AS CMS1CNT \r\n"
  176. " FROM TB_VDS_CTLR_STTS_RAW \r\n"
  177. " WHERE OCRR_DT BETWEEN :p07 AND :p08 \r\n"
  178. " ) \r\n"
  179. #ifdef USE_AVI
  180. " UNION \r\n"
  181. " SELECT 5 as FACSEQ, 'AVI' AS FACTYPE, SUM(CMS0CNT) AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  182. " FROM (SELECT DECODE(CMNC_STTS_CD, 'CMS0', 1, 0) AS CMS0CNT, \r\n"
  183. " DECODE(CMNC_STTS_CD, 'CMS0', 0, 1) AS CMS1CNT \r\n"
  184. " FROM TB_AVI_CTLR_STTS_HS \r\n"
  185. " WHERE CRTN_DT BETWEEN :p13 AND :p14 \r\n"
  186. " ) \r\n"
  187. #endif
  188. #ifdef USE_WCAM
  189. " UNION \r\n"
  190. " SELECT 3 as FACSEQ, '웹카메라' AS FACTYPE, SUM(CMS0CNT) AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  191. " FROM (SELECT DECODE(CMNC_STTS_CD, 'CMS0', 1, 0) AS CMS0CNT, \r\n"
  192. " DECODE(CMNC_STTS_CD, 'CMS0', 0, 1) AS CMS1CNT \r\n"
  193. " FROM TB_WEB_CMRA_STTS_HS \r\n"
  194. " WHERE CRTN_DT BETWEEN :p05 AND :p06 \r\n"
  195. " ) \r\n"
  196. #endif
  197. #ifdef USE_DSRC
  198. " UNION \r\n"
  199. " SELECT 6 as FACSEQ, 'DSRC' AS FACTYPE, SUM(CMS0CNT) AS CMS0CNT, SUM(CMS1CNT) AS CMS1CNT \r\n"
  200. " FROM (SELECT DECODE(CMNC_STTS, '0', 1, 0) AS CMS0CNT, \r\n"
  201. " DECODE(CMNC_STTS, '0', 0, 1) AS CMS1CNT \r\n"
  202. " FROM TB_RSE_STTS_HS \r\n"
  203. " WHERE CLCT_DT BETWEEN :p11 AND :p12 \r\n"
  204. " ) \r\n"
  205. #endif
  206. " ) \r\n"
  207. " ORDER BY FACSEQ \r\n";
  208. try
  209. {
  210. ITSDb_SQLText(pADO, sQry);
  211. ITSDb_SQLBind(pADO, "p01", FStDateTime);
  212. ITSDb_SQLBind(pADO, "p02", FEdDateTime);
  213. ITSDb_SQLBind(pADO, "p03", FStDateTime);
  214. ITSDb_SQLBind(pADO, "p04", FEdDateTime);
  215. ITSDb_SQLBind(pADO, "p07", FStDateTime);
  216. ITSDb_SQLBind(pADO, "p08", FEdDateTime);
  217. #ifdef USE_AVI
  218. ITSDb_SQLBind(pADO, "p13", FStDateTime);
  219. ITSDb_SQLBind(pADO, "p14", FEdDateTime);
  220. #endif
  221. #ifdef USE_WCAM
  222. ITSDb_SQLBind(pADO, "p05", FStDateTime);
  223. ITSDb_SQLBind(pADO, "p06", FEdDateTime);
  224. #endif
  225. #ifdef USE_DSRC
  226. ITSDb_SQLBind(pADO, "p11", FStDateTime);
  227. ITSDb_SQLBind(pADO, "p12", FEdDateTime);
  228. #endif
  229. ITSDb_SQLOpen(pADO);
  230. #if USE_MEMDATA
  231. dxMemData1->DisableControls();
  232. dxMemData1->Close();
  233. dxMemData1->CreateFieldsFromDataSet(pADO);
  234. dxMemData1->LoadFromDataSet(pADO);
  235. dxMemData1->Open();
  236. dxMemData1->First();
  237. dxMemData1->EnableControls();
  238. pADO->Close();
  239. DspReportFacility1MemData();
  240. #else
  241. DspReportFacility1();
  242. #endif
  243. }
  244. catch(EDatabaseError &E)
  245. {
  246. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  247. DBERRORMSG(Caption, String(E.ClassName()), E.Message, sQry);
  248. throw Exception(String(E.ClassName()) + E.Message);
  249. }
  250. catch(Exception &exception)
  251. {
  252. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  253. DBERRORMSG(Caption, String(exception.ClassName()), exception.Message, sQry);
  254. throw Exception(String(exception.ClassName()) + exception.Message);
  255. }
  256. }
  257. //---------------------------------------------------------------------------
  258. void __fastcall TIRP00101::DspReportFacility1()
  259. {
  260. TADOQuery *pADO = ADOQry;
  261. try
  262. {
  263. try {
  264. TvList->BeginUpdate();
  265. FRows = m_pGDC->AppendRecord();
  266. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  267. m_pGDC->Values[FRows][Column02->Index] = cxLabel2->Caption;//"시설물 구분";
  268. m_pGDC->Values[FRows][Column03->Index] = cxLabel3->Caption;//"정상";
  269. m_pGDC->Values[FRows][Column04->Index] = cxLabel4->Caption;//"장애";
  270. m_pGDC->Values[FRows][Column90->Index] = "1";
  271. for( ; !pADO->Eof; pADO->Next())
  272. {
  273. FRows = m_pGDC->AppendRecord();
  274. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  275. m_pGDC->Values[FRows][Column02->Index] = pADO->FieldByName("FACTYPE")->AsString;
  276. m_pGDC->Values[FRows][Column03->Index] = pADO->FieldByName("CMS0CNT")->AsString;
  277. m_pGDC->Values[FRows][Column04->Index] = pADO->FieldByName("CMS1CNT")->AsString;
  278. m_pGDC->Values[FRows][Column90->Index] = "0";
  279. }
  280. FRows = m_pGDC->AppendRecord();
  281. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  282. }
  283. __finally
  284. {
  285. if (pADO)
  286. {
  287. pADO->Close();
  288. }
  289. TvList->EndUpdate();
  290. }
  291. }
  292. catch(EDatabaseError &E)
  293. {
  294. throw Exception(String(E.ClassName()) + E.Message);
  295. }
  296. catch(...)
  297. {
  298. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  299. }
  300. }
  301. //---------------------------------------------------------------------------
  302. void __fastcall TIRP00101::DspReportFacility1MemData()
  303. {
  304. try
  305. {
  306. FRows = m_pGDC->AppendRecord();
  307. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  308. m_pGDC->Values[FRows][Column02->Index] = cxLabel2->Caption;//"시설물 구분";
  309. m_pGDC->Values[FRows][Column03->Index] = cxLabel3->Caption;//"정상";
  310. m_pGDC->Values[FRows][Column04->Index] = cxLabel4->Caption;//"장애";
  311. m_pGDC->Values[FRows][Column90->Index] = "1";
  312. while(!dxMemData1->Eof)
  313. {
  314. FRows = m_pGDC->AppendRecord();
  315. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  316. m_pGDC->Values[FRows][Column02->Index] = dxMemData1->Fields->FieldByName("FACTYPE")->AsString;
  317. m_pGDC->Values[FRows][Column03->Index] = dxMemData1->Fields->FieldByName("CMS0CNT")->AsString;
  318. m_pGDC->Values[FRows][Column04->Index] = dxMemData1->Fields->FieldByName("CMS1CNT")->AsString;
  319. m_pGDC->Values[FRows][Column90->Index] = "0";
  320. dxMemData1->Next();
  321. }
  322. FRows = m_pGDC->AppendRecord();
  323. m_pGDC->Values[FRows][Column01->Index] = cxLabel1->Caption;//"시설물 현황";
  324. dxMemData1->Close();
  325. }
  326. catch(EDatabaseError &E)
  327. {
  328. throw Exception(String(E.ClassName()) + E.Message);
  329. }
  330. catch(...)
  331. {
  332. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  333. }
  334. }
  335. //---------------------------------------------------------------------------
  336. void __fastcall TIRP00101::SelReportFacility2()
  337. {
  338. TSqlCursor sqlCrs;
  339. String sQry;
  340. TADOQuery *pADO = ADOQry;
  341. sQry = "SELECT FACSEQ, FCLT_TYPE, FCLT_ID, FCLT_NM, RGST_DT \r\n"
  342. " FROM ( \r\n"
  343. " SELECT 1 as FACSEQ, 'CCTV' FCLT_TYPE, A.CCTV_CTLR_ID AS FCLT_ID, A.ISTL_LCTN_NM AS FCLT_NM, \r\n"
  344. " CRTN_DT AS RGST_DT \r\n"
  345. " FROM TB_CCTV_CTLR A, \r\n"
  346. " (SELECT CCTV_MNGM_NMBR, CRTN_DT \r\n"
  347. " FROM TB_CCTV_STTS_HS \r\n"
  348. " WHERE CRTN_DT BETWEEN :p01 AND :p02 \r\n"
  349. " AND CMNC_STTS_CD = 'CMS1') B \r\n"
  350. " WHERE A.CCTV_MNGM_NMBR = B.CCTV_MNGM_NMBR \r\n"
  351. " UNION \r\n"
  352. " SELECT 2 as FACSEQ, 'VMS' FCLT_TYPE, A.VMS_CTLR_ID AS FCLT_ID, A.VMS_NM AS FCLT_NM, \r\n"
  353. " RGST_DT AS RGST_DT \r\n"
  354. " FROM TB_VMS_CTLR A, \r\n"
  355. " (SELECT VMS_CTLR_NMBR, RGST_DT \r\n"
  356. " FROM TB_VMS_STTS_HS \r\n"
  357. " WHERE RGST_DT BETWEEN :p03 AND :p04 \r\n"
  358. " AND CONN_STTS_CD = 'CMS1') B \r\n"
  359. " WHERE A.VMS_CTLR_NMBR = B.VMS_CTLR_NMBR \r\n"
  360. " UNION \r\n"
  361. " SELECT 4 as FACSEQ, 'VDS' FCLT_TYPE, A.CTLR_MNGM_NMBR AS FCLT_ID, A.LCTN AS FCLT_NM, \r\n"
  362. " OCRR_DT AS RGST_DT \r\n"
  363. " FROM TB_VDS_CTLR A, \r\n"
  364. " (SELECT CTLR_MNGM_NMBR, OCRR_DT \r\n"
  365. " FROM TB_VDS_CTLR_STTS_RAW \r\n"
  366. " WHERE OCRR_DT BETWEEN :p07 AND :p08 \r\n"
  367. " AND CMNC_STTS_CD = 'CMS1') B \r\n"
  368. " WHERE A.CTLR_MNGM_NMBR = B.CTLR_MNGM_NMBR \r\n"
  369. #ifdef USE_AVI
  370. " UNION \r\n"
  371. " SELECT 5 as FACSEQ, 'AVI' FCLT_TYPE, A.AVI_CTLR_MNGM_NMBR AS FCLT_ID, A.AVI_LCTN_NM AS FCLT_NM,\r\n"
  372. " CRTN_DT AS RGST_DT \r\n"
  373. " FROM TB_AVI_CTLR A, \r\n"
  374. " (SELECT AVI_CTLR_MNGM_NMBR, CRTN_DT \r\n"
  375. " FROM TB_AVI_CTLR_STTS_HS \r\n"
  376. " WHERE CRTN_DT BETWEEN :p13 AND :p14 \r\n"
  377. " AND CMNC_STTS_CD = 'CMS1') B \r\n"
  378. " WHERE A.AVI_CTLR_MNGM_NMBR = B.AVI_CTLR_MNGM_NMBR \r\n"
  379. #endif
  380. #ifdef USE_WCAM
  381. " UNION \r\n"
  382. " SELECT 3 as FACSEQ, '웹카메라' FCLT_TYPE, A.WEB_CMRA_ID AS FCLT_ID, A.ISTL_LCTN_NM AS FCLT_NM, \r\n"
  383. " CRTN_DT AS RGST_DT \r\n"
  384. " FROM TB_WEB_CMRA A, \r\n"
  385. " (SELECT WEB_CMRA_NMBR, CRTN_DT \r\n"
  386. " FROM TB_WEB_CMRA_STTS_HS \r\n"
  387. " WHERE CRTN_DT BETWEEN :p05 AND :p06 \r\n"
  388. " AND CMNC_STTS_CD = 'CMS1') B \r\n"
  389. " WHERE A.WEB_CMRA_NMBR = B.WEB_CMRA_NMBR \r\n"
  390. #endif
  391. #ifdef USE_DSRC
  392. " UNION \r\n"
  393. " SELECT 6 as FACSEQ, 'DSRC' FCLT_TYPE, A.ID AS FCLT_ID, A.ISTL_LCTN_NM AS FCLT_NM, \r\n"
  394. " CLCT_DT AS RGST_DT \r\n"
  395. " FROM TB_RSE_MSTR A, \r\n"
  396. " (SELECT ID, CLCT_DT \r\n"
  397. " FROM TB_RSE_STTS_HS \r\n"
  398. " WHERE CLCT_DT BETWEEN :p11 AND :p12 \r\n"
  399. " AND CMNC_STTS = '1') B \r\n"
  400. " WHERE A.ID = B.ID \r\n"
  401. #endif
  402. " ) \r\n"
  403. " ORDER BY FACSEQ, FCLT_ID, RGST_DT \r\n";
  404. try
  405. {
  406. ITSDb_SQLText(pADO, sQry);
  407. ITSDb_SQLBind(pADO, "p01", FStDateTime);
  408. ITSDb_SQLBind(pADO, "p02", FEdDateTime);
  409. ITSDb_SQLBind(pADO, "p03", FStDateTime);
  410. ITSDb_SQLBind(pADO, "p04", FEdDateTime);
  411. ITSDb_SQLBind(pADO, "p07", FStDateTime);
  412. ITSDb_SQLBind(pADO, "p08", FEdDateTime);
  413. #ifdef USE_AVI
  414. ITSDb_SQLBind(pADO, "p13", FStDateTime);
  415. ITSDb_SQLBind(pADO, "p14", FEdDateTime);
  416. #endif
  417. #ifdef USE_WCAM
  418. ITSDb_SQLBind(pADO, "p05", FStDateTime);
  419. ITSDb_SQLBind(pADO, "p06", FEdDateTime);
  420. #endif
  421. #ifdef USE_DSRC
  422. ITSDb_SQLBind(pADO, "p11", FStDateTime);
  423. ITSDb_SQLBind(pADO, "p12", FEdDateTime);
  424. #endif
  425. ITSDb_SQLOpen(pADO);
  426. #if USE_MEMDATA
  427. dxMemData1->DisableControls();
  428. dxMemData1->Close();
  429. dxMemData1->CreateFieldsFromDataSet(pADO);
  430. dxMemData1->LoadFromDataSet(pADO);
  431. dxMemData1->Open();
  432. dxMemData1->First();
  433. dxMemData1->EnableControls();
  434. pADO->Close();
  435. DspReportFacility2MemData();
  436. #else
  437. DspReportFacility2();
  438. #endif
  439. }
  440. catch(EDatabaseError &E)
  441. {
  442. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  443. DBERRORMSG(Caption, String(E.ClassName()), E.Message, sQry);
  444. throw Exception(String(E.ClassName()) + E.Message);
  445. }
  446. catch(Exception &e)
  447. {
  448. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  449. DBERRORMSG(Caption, String(e.ClassName()), e.Message, sQry);
  450. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  451. }
  452. }
  453. //---------------------------------------------------------------------------
  454. void __fastcall TIRP00101::DspReportFacility2()
  455. {
  456. TADOQuery *pADO = ADOQry;
  457. try
  458. {
  459. try {
  460. TvList->BeginUpdate();
  461. FRows = m_pGDC->AppendRecord();
  462. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  463. m_pGDC->Values[FRows][Column02->Index] = cxLabel6->Caption;//"장애일시";
  464. m_pGDC->Values[FRows][Column03->Index] = cxLabel7->Caption;//"장비유형";
  465. m_pGDC->Values[FRows][Column04->Index] = cxLabel8->Caption;//"아이디";
  466. m_pGDC->Values[FRows][Column05->Index] = cxLabel9->Caption;//"명칭";
  467. m_pGDC->Values[FRows][Column06->Index] = cxLabel10->Caption;//"통신장애";
  468. m_pGDC->Values[FRows][Column90->Index] = "1";
  469. for( ; !pADO->Eof; pADO->Next())
  470. {
  471. FRows = m_pGDC->AppendRecord();
  472. String sRgstDt = pADO->FieldByName("RGST_DT")->AsString;
  473. sRgstDt.Insert(":", 13);
  474. sRgstDt.Insert(":", 11);
  475. sRgstDt.Insert(" ", 9);
  476. sRgstDt.Insert("-", 7);
  477. sRgstDt.Insert("-", 5);
  478. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  479. m_pGDC->Values[FRows][Column02->Index] = sRgstDt;
  480. m_pGDC->Values[FRows][Column03->Index] = pADO->FieldByName("FCLT_TYPE")->AsString;
  481. m_pGDC->Values[FRows][Column04->Index] = pADO->FieldByName("FCLT_ID")->AsString;
  482. m_pGDC->Values[FRows][Column05->Index] = pADO->FieldByName("FCLT_NM")->AsString;
  483. m_pGDC->Values[FRows][Column06->Index] = cxLabel11->Caption;//"통신두절";
  484. m_pGDC->Values[FRows][Column90->Index] = "0";
  485. }
  486. FRows = m_pGDC->AppendRecord();
  487. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  488. }
  489. __finally
  490. {
  491. if (pADO)
  492. {
  493. pADO->Close();
  494. }
  495. TvList->EndUpdate();
  496. }
  497. }
  498. catch(EDatabaseError &E)
  499. {
  500. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  501. DBERRORMSG(Caption, String(E.ClassName()), E.Message, pADO->SQL->Text);
  502. throw Exception(String(E.ClassName()) + E.Message);
  503. }
  504. catch(Exception &e)
  505. {
  506. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  507. DBERRORMSG(Caption, String(e.ClassName()), e.Message, pADO->SQL->Text);
  508. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  509. }
  510. }
  511. //---------------------------------------------------------------------------
  512. void __fastcall TIRP00101::DspReportFacility2MemData()
  513. {
  514. try
  515. {
  516. FRows = m_pGDC->AppendRecord();
  517. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  518. m_pGDC->Values[FRows][Column02->Index] = cxLabel6->Caption;//"장애일시";
  519. m_pGDC->Values[FRows][Column03->Index] = cxLabel7->Caption;//"장비유형";
  520. m_pGDC->Values[FRows][Column04->Index] = cxLabel8->Caption;//"아이디";
  521. m_pGDC->Values[FRows][Column05->Index] = cxLabel9->Caption;//"명칭";
  522. m_pGDC->Values[FRows][Column06->Index] = cxLabel10->Caption;//"통신장애";
  523. m_pGDC->Values[FRows][Column90->Index] = "1";
  524. while(!dxMemData1->Eof)
  525. {
  526. FRows = m_pGDC->AppendRecord();
  527. String sRgstDt = dxMemData1->Fields->FieldByName("RGST_DT")->AsString;
  528. sRgstDt.Insert(":", 13);
  529. sRgstDt.Insert(":", 11);
  530. sRgstDt.Insert(" ", 9);
  531. sRgstDt.Insert("-", 7);
  532. sRgstDt.Insert("-", 5);
  533. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  534. m_pGDC->Values[FRows][Column02->Index] = sRgstDt;
  535. m_pGDC->Values[FRows][Column03->Index] = dxMemData1->Fields->FieldByName("FCLT_TYPE")->AsString;
  536. m_pGDC->Values[FRows][Column04->Index] = dxMemData1->Fields->FieldByName("FCLT_ID")->AsString;
  537. m_pGDC->Values[FRows][Column05->Index] = dxMemData1->Fields->FieldByName("FCLT_NM")->AsString;
  538. m_pGDC->Values[FRows][Column06->Index] = cxLabel11->Caption;//"통신두절";
  539. m_pGDC->Values[FRows][Column90->Index] = "0";
  540. dxMemData1->Next();
  541. }
  542. FRows = m_pGDC->AppendRecord();
  543. m_pGDC->Values[FRows][Column01->Index] = cxLabel5->Caption;//"장애 현황";
  544. dxMemData1->Close();
  545. }
  546. catch(EDatabaseError &E)
  547. {
  548. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  549. DBERRORMSG(Caption, String(E.ClassName()), E.Message, "");
  550. throw Exception(String(E.ClassName()) + E.Message);
  551. }
  552. catch(Exception &e)
  553. {
  554. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  555. DBERRORMSG(Caption, String(e.ClassName()), e.Message, "");
  556. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  557. }
  558. }
  559. //---------------------------------------------------------------------------
  560. void __fastcall TIRP00101::SelReportTraffic1()
  561. {
  562. TSqlCursor sqlCrs;
  563. String sQry;
  564. TADOQuery *pADO = ADOQry;
  565. sQry = "SELECT INCD_STRT_DT, B.CMMN_CD_KOR_NM, LINK_ID, INCD_TITL \r\n"
  566. " FROM TB_INCD_OCRR A, \r\n"
  567. " (SELECT CMMN_CD, CMMN_CD_KOR_NM \r\n"
  568. " FROM TB_CMMN_CD \r\n"
  569. " WHERE CMMN_CLSF_CD = 'IDTU' \r\n"
  570. " ) B \r\n"
  571. " WHERE INCD_STRT_DT BETWEEN :p01 AND :p02 \r\n"
  572. " AND INCD_PRGR_STEP_CD = 'ISS2' \r\n"
  573. " AND A.INCD_TYPE_CLSF_CD = B.CMMN_CD \r\n";
  574. try
  575. {
  576. ITSDb_SQLText(pADO, sQry);
  577. ITSDb_SQLBind(pADO, "p01", FStDateTime);
  578. ITSDb_SQLBind(pADO, "p02", FEdDateTime);
  579. ITSDb_SQLOpen(pADO);
  580. #if USE_MEMDATA
  581. dxMemData1->DisableControls();
  582. dxMemData1->Close();
  583. dxMemData1->CreateFieldsFromDataSet(pADO);
  584. dxMemData1->LoadFromDataSet(pADO);
  585. dxMemData1->Open();
  586. dxMemData1->First();
  587. dxMemData1->EnableControls();
  588. pADO->Close();
  589. DspReportTraffic1MemData();
  590. #else
  591. DspReportTraffic1();
  592. #endif
  593. }
  594. catch(EDatabaseError &E)
  595. {
  596. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  597. DBERRORMSG(Caption, String(E.ClassName()), E.Message, pADO->SQL->Text);
  598. throw Exception(String(E.ClassName()) + E.Message);
  599. }
  600. catch(Exception &e)
  601. {
  602. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  603. DBERRORMSG(Caption, String(e.ClassName()), e.Message, pADO->SQL->Text);
  604. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  605. }
  606. }
  607. //---------------------------------------------------------------------------
  608. void __fastcall TIRP00101::DspReportTraffic1()
  609. {
  610. TADOQuery *pADO = ADOQry;
  611. try
  612. {
  613. try {
  614. TvList->BeginUpdate();
  615. FRows = m_pGDC->AppendRecord();
  616. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  617. m_pGDC->Values[FRows][Column02->Index] = cxLabel13->Caption;//"시작일시";
  618. m_pGDC->Values[FRows][Column03->Index] = cxLabel14->Caption;//"돌발유형";
  619. m_pGDC->Values[FRows][Column04->Index] = cxLabel15->Caption;//"도로명";
  620. m_pGDC->Values[FRows][Column05->Index] = cxLabel16->Caption;//"돌발내용";
  621. m_pGDC->Values[FRows][Column90->Index] = "1";
  622. TItsLink *pLink;
  623. for( ; !pADO->Eof; pADO->Next())
  624. {
  625. FRows = m_pGDC->AppendRecord();
  626. String sLinkId = pADO->FieldByName("LINK_ID")->AsString;
  627. pLink = ItsLinkManager->FLists.Find(sLinkId);
  628. if (pLink)
  629. {
  630. sLinkId = pLink->ROAD_NAME;
  631. }
  632. String sStrtDt = pADO->FieldByName("INCD_STRT_DT")->AsString;
  633. sStrtDt.Insert(":", 13);
  634. sStrtDt.Insert(":", 11);
  635. sStrtDt.Insert(" ", 9);
  636. sStrtDt.Insert("-", 7);
  637. sStrtDt.Insert("-", 5);
  638. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  639. m_pGDC->Values[FRows][Column02->Index] = sStrtDt;
  640. m_pGDC->Values[FRows][Column03->Index] = pADO->FieldByName("CMMN_CD_KOR_NM")->AsString;
  641. m_pGDC->Values[FRows][Column04->Index] = sLinkId;
  642. m_pGDC->Values[FRows][Column05->Index] = pADO->FieldByName("INCD_TITL")->AsString;
  643. m_pGDC->Values[FRows][Column90->Index] = "0";
  644. }
  645. FRows = m_pGDC->AppendRecord();
  646. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  647. }
  648. __finally
  649. {
  650. if (pADO)
  651. {
  652. pADO->Close();
  653. }
  654. TvList->EndUpdate();
  655. }
  656. }
  657. catch(EDatabaseError &E)
  658. {
  659. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  660. DBERRORMSG(Caption, String(E.ClassName()), E.Message, pADO->SQL->Text);
  661. throw Exception(String(E.ClassName()) + E.Message);
  662. }
  663. catch(Exception &e)
  664. {
  665. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  666. DBERRORMSG(Caption, String(e.ClassName()), e.Message, pADO->SQL->Text);
  667. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  668. }
  669. }
  670. //---------------------------------------------------------------------------
  671. void __fastcall TIRP00101::DspReportTraffic1MemData()
  672. {
  673. try
  674. {
  675. FRows = m_pGDC->AppendRecord();
  676. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  677. m_pGDC->Values[FRows][Column02->Index] = cxLabel13->Caption;//"시작일시";
  678. m_pGDC->Values[FRows][Column03->Index] = cxLabel14->Caption;//"돌발유형";
  679. m_pGDC->Values[FRows][Column04->Index] = cxLabel15->Caption;//"도로명";
  680. m_pGDC->Values[FRows][Column05->Index] = cxLabel16->Caption;//"돌발내용";
  681. m_pGDC->Values[FRows][Column90->Index] = "1";
  682. TItsLink *pLink;
  683. while(!dxMemData1->Eof)
  684. {
  685. FRows = m_pGDC->AppendRecord();
  686. String sLinkId = dxMemData1->Fields->FieldByName("LINK_ID")->AsString;
  687. pLink = ItsLinkManager->FLists.Find(sLinkId);
  688. if (pLink)
  689. {
  690. sLinkId = pLink->ROAD_NAME;
  691. }
  692. String sStrtDt = dxMemData1->Fields->FieldByName("INCD_STRT_DT")->AsString;
  693. sStrtDt.Insert(":", 13);
  694. sStrtDt.Insert(":", 11);
  695. sStrtDt.Insert(" ", 9);
  696. sStrtDt.Insert("-", 7);
  697. sStrtDt.Insert("-", 5);
  698. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  699. m_pGDC->Values[FRows][Column02->Index] = sStrtDt;
  700. m_pGDC->Values[FRows][Column03->Index] = dxMemData1->Fields->FieldByName("CMMN_CD_KOR_NM")->AsString;
  701. m_pGDC->Values[FRows][Column04->Index] = sLinkId;
  702. m_pGDC->Values[FRows][Column05->Index] = dxMemData1->Fields->FieldByName("INCD_TITL")->AsString;
  703. m_pGDC->Values[FRows][Column90->Index] = "0";
  704. dxMemData1->Next();
  705. }
  706. FRows = m_pGDC->AppendRecord();
  707. m_pGDC->Values[FRows][Column01->Index] = cxLabel12->Caption;//"돌발 현황";
  708. dxMemData1->Close();
  709. }
  710. catch(EDatabaseError &E)
  711. {
  712. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  713. DBERRORMSG(Caption, String(E.ClassName()), E.Message, "");
  714. throw Exception(String(E.ClassName()) + E.Message);
  715. }
  716. catch(Exception &e)
  717. {
  718. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  719. DBERRORMSG(Caption, String(e.ClassName()), e.Message, "");
  720. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  721. }
  722. }
  723. //---------------------------------------------------------------------------
  724. void __fastcall TIRP00101::SelReportTraffic2()
  725. {
  726. TSqlCursor sqlCrs;
  727. String sQry;
  728. TADOQuery *pADO = ADOQry;
  729. sQry = "SELECT A.LINK_ID, B.PRCN_DT, A.CMTR_GRAD_CD, A.SPED \r\n"
  730. " FROM TB_LINK_TRAF_HS A, \r\n"
  731. " (SELECT LINK_ID, MAX(PRCN_DT) PRCN_DT \r\n"
  732. " FROM TB_LINK_TRAF_HS \r\n"
  733. " WHERE PRCN_DT BETWEEN :p01 AND :p02 \r\n"
  734. " AND CMTR_GRAD_CD <> 'LTC1' \r\n"
  735. " GROUP BY LINK_ID \r\n"
  736. " ) B \r\n"
  737. " WHERE A.LINK_ID = B.LINK_ID \r\n"
  738. " AND A.PRCN_DT = B.PRCN_DT \r\n"
  739. " ORDER BY 3 DESC \r\n";
  740. try
  741. {
  742. ITSDb_SQLText(pADO, sQry);
  743. ITSDb_SQLBind(pADO, "p01", FStDateTime);
  744. ITSDb_SQLBind(pADO, "p02", FEdDateTime);
  745. ITSDb_SQLOpen(pADO);
  746. #if USE_MEMDATA
  747. dxMemData1->DisableControls();
  748. dxMemData1->Close();
  749. dxMemData1->CreateFieldsFromDataSet(pADO);
  750. dxMemData1->LoadFromDataSet(pADO);
  751. dxMemData1->Open();
  752. dxMemData1->First();
  753. dxMemData1->EnableControls();
  754. pADO->Close();
  755. DspReportTraffic2MemData();
  756. #else
  757. DspReportTraffic2();
  758. #endif
  759. }
  760. catch(EDatabaseError &E)
  761. {
  762. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  763. DBERRORMSG(Caption, String(E.ClassName()), E.Message, "");
  764. throw Exception(String(E.ClassName()) + E.Message);
  765. }
  766. catch(Exception &e)
  767. {
  768. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  769. DBERRORMSG(Caption, String(e.ClassName()), e.Message, "");
  770. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  771. }
  772. }
  773. //---------------------------------------------------------------------------
  774. void __fastcall TIRP00101::DspReportTraffic2()
  775. {
  776. TADOQuery *pADO = ADOQry;
  777. try
  778. {
  779. try {
  780. TvList->BeginUpdate();
  781. FRows = m_pGDC->AppendRecord();
  782. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  783. m_pGDC->Values[FRows][Column02->Index] = FrmLang->lblPrcsTm->Caption;//"가공시각";
  784. m_pGDC->Values[FRows][Column03->Index] = cxLabel18->Caption;//"속도";
  785. m_pGDC->Values[FRows][Column04->Index] = cxLabel15->Caption;//"도로명";
  786. m_pGDC->Values[FRows][Column05->Index] = cxLabel19->Caption;//"구간명";
  787. m_pGDC->Values[FRows][Column90->Index] = "1";
  788. TItsNode *pNode;
  789. TItsLink *pLink;
  790. for( ; !pADO->Eof; pADO->Next())
  791. {
  792. FRows = m_pGDC->AppendRecord();
  793. String sFNode, sTNode;
  794. sFNode = sTNode = "";
  795. String sLinkId = pADO->FieldByName("LINK_ID")->AsString;
  796. pLink = ItsLinkManager->FLists.Find(sLinkId);
  797. if (pLink)
  798. {
  799. sLinkId = pLink->ROAD_NAME;
  800. sFNode = pLink->F_NODEID;
  801. pNode = ItsNodeManager->FLists.Find(pLink->F_NODEID);
  802. if (pNode) sFNode = pNode->NODE_NAME;
  803. sTNode = pLink->T_NODEID;
  804. pNode = ItsNodeManager->FLists.Find(pLink->T_NODEID);
  805. if (pNode) sTNode = pNode->NODE_NAME;
  806. }
  807. String sPrcnDt = pADO->FieldByName("PRCN_DT")->AsString;
  808. sPrcnDt.Insert(":", 13);
  809. sPrcnDt.Insert(":", 11);
  810. sPrcnDt.Insert(" ", 9);
  811. sPrcnDt.Insert("-", 7);
  812. sPrcnDt.Insert("-", 5);
  813. String sGrade = pADO->FieldByName("CMTR_GRAD_CD")->AsString;
  814. if (sGrade == "LTC2")
  815. sGrade = FrmLang->lblLTC2->Caption + "(" + pADO->FieldByName("SPED")->AsString + ")";
  816. else
  817. sGrade = FrmLang->lblLTC3->Caption + "(" + pADO->FieldByName("SPED")->AsString + ")";
  818. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  819. m_pGDC->Values[FRows][Column02->Index] = sPrcnDt;
  820. m_pGDC->Values[FRows][Column03->Index] = sGrade;
  821. m_pGDC->Values[FRows][Column04->Index] = sLinkId;
  822. m_pGDC->Values[FRows][Column05->Index] = sFNode + "→" + sTNode;
  823. m_pGDC->Values[FRows][Column90->Index] = "0";
  824. }
  825. FRows = m_pGDC->AppendRecord();
  826. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  827. }
  828. __finally
  829. {
  830. if (pADO)
  831. {
  832. pADO->Close();
  833. }
  834. TvList->EndUpdate();
  835. }
  836. }
  837. catch(EDatabaseError &E)
  838. {
  839. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  840. DBERRORMSG(Caption, String(E.ClassName()), E.Message, pADO->SQL->Text);
  841. throw Exception(String(E.ClassName()) + E.Message);
  842. }
  843. catch(Exception &e)
  844. {
  845. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  846. DBERRORMSG(Caption, String(e.ClassName()), e.Message, pADO->SQL->Text);
  847. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  848. }
  849. }
  850. //---------------------------------------------------------------------------
  851. void __fastcall TIRP00101::DspReportTraffic2MemData()
  852. {
  853. try
  854. {
  855. FRows = m_pGDC->AppendRecord();
  856. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  857. m_pGDC->Values[FRows][Column02->Index] = FrmLang->lblPrcsTm->Caption;//"가공시각";
  858. m_pGDC->Values[FRows][Column03->Index] = cxLabel18->Caption;//"속도";
  859. m_pGDC->Values[FRows][Column04->Index] = cxLabel15->Caption;//"도로명";
  860. m_pGDC->Values[FRows][Column05->Index] = cxLabel19->Caption;//"구간명";
  861. m_pGDC->Values[FRows][Column90->Index] = "1";
  862. TItsNode *pNode;
  863. TItsLink *pLink;
  864. while(!dxMemData1->Eof)
  865. {
  866. FRows = m_pGDC->AppendRecord();
  867. String sFNode, sTNode;
  868. sFNode = sTNode = "";
  869. String sLinkId = dxMemData1->Fields->FieldByName("LINK_ID")->AsString;
  870. pLink = ItsLinkManager->FLists.Find(sLinkId);
  871. if (pLink)
  872. {
  873. sLinkId = pLink->ROAD_NAME;
  874. sFNode = pLink->F_NODEID;
  875. pNode = ItsNodeManager->FLists.Find(pLink->F_NODEID);
  876. if (pNode) sFNode = pNode->NODE_NAME;
  877. sTNode = pLink->T_NODEID;
  878. pNode = ItsNodeManager->FLists.Find(pLink->T_NODEID);
  879. if (pNode) sTNode = pNode->NODE_NAME;
  880. }
  881. String sPrcnDt = dxMemData1->Fields->FieldByName("PRCN_DT")->AsString;
  882. sPrcnDt.Insert(":", 13);
  883. sPrcnDt.Insert(":", 11);
  884. sPrcnDt.Insert(" ", 9);
  885. sPrcnDt.Insert("-", 7);
  886. sPrcnDt.Insert("-", 5);
  887. String sGrade = dxMemData1->Fields->FieldByName("CMTR_GRAD_CD")->AsString;
  888. if (sGrade == "LTC2")
  889. sGrade = FrmLang->lblLTC2->Caption + "(" + dxMemData1->Fields->FieldByName("SPED")->AsString + ")";//"지체(" + dxMemData1->Fields->FieldByName("SPED")->AsString + ")";
  890. else
  891. sGrade = FrmLang->lblLTC3->Caption + "(" + dxMemData1->Fields->FieldByName("SPED")->AsString + ")";//"정체(" + dxMemData1->Fields->FieldByName("SPED")->AsString + ")";
  892. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  893. m_pGDC->Values[FRows][Column02->Index] = sPrcnDt;
  894. m_pGDC->Values[FRows][Column03->Index] = sGrade;
  895. m_pGDC->Values[FRows][Column04->Index] = sLinkId;
  896. m_pGDC->Values[FRows][Column05->Index] = sFNode + "→" + sTNode;
  897. m_pGDC->Values[FRows][Column90->Index] = "0";
  898. dxMemData1->Next();
  899. }
  900. FRows = m_pGDC->AppendRecord();
  901. m_pGDC->Values[FRows][Column01->Index] = cxLabel17->Caption;//"지/정체 현황";
  902. dxMemData1->Close();
  903. }
  904. catch(EDatabaseError &E)
  905. {
  906. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  907. DBERRORMSG(Caption, String(E.ClassName()), E.Message, "");
  908. throw Exception(String(E.ClassName()) + E.Message);
  909. }
  910. catch(Exception &e)
  911. {
  912. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  913. DBERRORMSG(Caption, String(e.ClassName()), e.Message, "");
  914. throw Exception(FrmLang->lblDbErr->Caption);//"알수없는 오류가 발생하였습니다.");
  915. }
  916. }
  917. //---------------------------------------------------------------------------
  918. void __fastcall TIRP00101::OnMessage(TMessage &Msg)
  919. {
  920. switch (Msg.Msg)
  921. {
  922. case WM_PARAM_DATABASE:
  923. if (WP_DB_SELECT_OK == Msg.WParam)
  924. {
  925. //ShowMessage("Select Ok");
  926. }
  927. break;
  928. }
  929. }
  930. //---------------------------------------------------------------------------
  931. void __fastcall TIRP00101::BtnExlSaveClick(TObject *Sender)
  932. {
  933. TcxGrid *pGrid = CxList;
  934. TcxGridTableView *pView = TvList;
  935. String sTitle;
  936. if (FRptType == 1)
  937. sTitle = lblType1->Caption;//"교통보고서";
  938. else
  939. sTitle = lblType2->Caption;//"시설물보고서";
  940. CMM_ExportToExcelFile(sTitle, pGrid, pView, this);
  941. }
  942. //---------------------------------------------------------------------------
  943. void __fastcall TIRP00101::FormClose(TObject *Sender, TCloseAction &Action)
  944. {
  945. POST_MSG(FParent, WM_SUBFORM_CLOSE, 0, 0);
  946. CommClose();
  947. //IRP00101 = NULL;
  948. }
  949. //---------------------------------------------------------------------------
  950. void __fastcall TIRP00101::TvListCustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  951. bool &ADone)
  952. {
  953. if (AViewInfo)
  954. {
  955. String sType = AViewInfo->GridRecord->DisplayTexts[Column90->Index];
  956. if (sType == "1")
  957. ACanvas->Brush->Color = clOlive; //컬럼소제목
  958. }
  959. }
  960. //---------------------------------------------------------------------------
  961. void __fastcall TIRP00101::FormDestroy(TObject *Sender)
  962. {
  963. CommClose();
  964. }
  965. //---------------------------------------------------------------------------