FrmCrsTrafVolLogSubF.cpp 78 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341
  1. //---------------------------------------------------------------------------
  2. #include <vcl.h>
  3. #include "AppGlobalF.h"
  4. #include "ITSSkinF.h"
  5. #include "ITSUtilF.h"
  6. #include "ITSDbF.h"
  7. #include "ITSLogF.h"
  8. #include "ITSLangTransF.h"
  9. #include "CDSCrossF.h"
  10. #pragma hdrstop
  11. #include "FrmCrsTrafVolLogSubF.h"
  12. //---------------------------------------------------------------------------
  13. #pragma package(smart_init)
  14. #pragma link "cxButtons"
  15. #pragma link "cxCalc"
  16. #pragma link "cxCheckBox"
  17. #pragma link "cxClasses"
  18. #pragma link "cxContainer"
  19. #pragma link "cxControls"
  20. #pragma link "cxCustomData"
  21. #pragma link "cxData"
  22. #pragma link "cxDataStorage"
  23. #pragma link "cxEdit"
  24. #pragma link "cxFilter"
  25. #pragma link "cxGraphics"
  26. #pragma link "cxGrid"
  27. #pragma link "cxGridCustomTableView"
  28. #pragma link "cxGridCustomView"
  29. #pragma link "cxGridLevel"
  30. #pragma link "cxGridTableView"
  31. #pragma link "cxLookAndFeelPainters"
  32. #pragma link "cxLookAndFeels"
  33. #pragma link "cxSplitter"
  34. #pragma link "cxStyles"
  35. #pragma link "cxTextEdit"
  36. #pragma link "dxSkinBlack"
  37. #pragma link "dxSkinBlue"
  38. #pragma link "dxSkinCaramel"
  39. #pragma link "dxSkinCoffee"
  40. #pragma link "dxSkinDarkRoom"
  41. #pragma link "dxSkinDarkSide"
  42. #pragma link "dxSkinFoggy"
  43. #pragma link "dxSkinGlassOceans"
  44. #pragma link "dxSkiniMaginary"
  45. #pragma link "dxSkinLilian"
  46. #pragma link "dxSkinLiquidSky"
  47. #pragma link "dxSkinLondonLiquidSky"
  48. #pragma link "dxSkinMcSkin"
  49. #pragma link "dxSkinMoneyTwins"
  50. #pragma link "dxSkinOffice2007Black"
  51. #pragma link "dxSkinOffice2007Blue"
  52. #pragma link "dxSkinOffice2007Green"
  53. #pragma link "dxSkinOffice2007Pink"
  54. #pragma link "dxSkinOffice2007Silver"
  55. #pragma link "dxSkinOffice2010Black"
  56. #pragma link "dxSkinOffice2010Blue"
  57. #pragma link "dxSkinOffice2010Silver"
  58. #pragma link "dxSkinsCore"
  59. #pragma link "dxSkinscxPCPainter"
  60. #pragma link "dxSkinSeven"
  61. #pragma link "dxSkinSharp"
  62. #pragma link "dxSkinSilver"
  63. #pragma link "dxSkinStardust"
  64. #pragma link "cxLabel"
  65. #pragma link "cxGridBandedTableView"
  66. #pragma link "cxSpinEdit"
  67. #pragma link "FRAME_ChartF"
  68. #pragma link "cxDropDownEdit"
  69. #pragma link "cxMaskEdit"
  70. #pragma resource "*.dfm"
  71. //TFrmCrsTrafVolLogSub *FrmCrsTrafVolLogSub = NULL;
  72. //---------------------------------------------------------------------------
  73. __fastcall TFrmCrsTrafVolLogSub::TFrmCrsTrafVolLogSub(TComponent* Owner, HWND hHandle, String sFrom, String sTo, String sCrossId, String sCamId, String sDrctCd,
  74. int nStatType, bool isLane, String sCrossNm, String sCamNm, TCross *pObj)
  75. : TForm(Owner)
  76. {
  77. LangTrans->Translate(this, ITSDb_GetConnection());
  78. ITSSkin_Load(this);
  79. //CMM_LoadForm(g_sFormsDir, this);
  80. FParent = hHandle;
  81. FStDateTime = sFrom;
  82. FEdDateTime = sTo;
  83. FCrossId = sCrossId;
  84. FCamId = sCamId;
  85. FDrctCd = sDrctCd;
  86. FStatType = nStatType;
  87. FLane = isLane;
  88. FCrossNm = sCrossNm;
  89. FCamNm = sCamNm;
  90. FCrossObj = pObj;
  91. Col05->Visible = FLane;
  92. FOR_STL(TCrossCam*, pCam, FCrossObj->FLists)
  93. {
  94. TCrossCam *pObj1 = new TCrossCam();
  95. TCrossCam *pObj2 = new TCrossCam();
  96. pCam->Copy(pObj1);
  97. pCam->Copy(pObj2);
  98. FCmraIdLists.Push(pObj1->CMRA_ID, pObj1);
  99. FDrctCdLists.Push(IntToStr(pObj2->DRCT_DVSN_CD), pObj2);
  100. }
  101. if (FStatType > 1) {
  102. // 30분 통계 부터 유턴교통량 데이터가 존재하지 않음.
  103. ColU0->Visible = false;
  104. TvList->Bands->Items[5]->Visible = false;
  105. }
  106. if (FLane)
  107. {
  108. //차선별 이력일 경우 차트를 그리지 않는다
  109. PnlChart->Visible = false;
  110. spltChart->Visible = false;
  111. }
  112. else
  113. {
  114. FRAMEChart1->LblOptionName->Caption = "카메라";
  115. FRAMEChart1->LblOptionName->Visible = true;
  116. FRAMEChart1->CbOption->Visible = true;
  117. }
  118. }
  119. //---------------------------------------------------------------------------
  120. void __fastcall TFrmCrsTrafVolLogSub::FormInit()
  121. {
  122. ADOQry->Connection = ITSDb_GetConnection();
  123. m_pGDC = TvList->DataController;
  124. TvList->OptionsView->NoDataToDisplayInfoText = Caption + ": " + lblText1->Caption;//조회결과가 없습니다.";
  125. FRAMEChart1->FTitle = Caption;//"시설물 통신단절통계";
  126. FRAMEChart1->SetChartLegend("시간", "교통량");
  127. FRAMEChart1->ChartValueDisplay(FRAMEChart1->ChkDisplayVal->Checked);
  128. FRAMEChart1->TvChart->ToolBox->CustomizeButton = true;
  129. FRAMEChart1->TvChart->Legend->Position = cppDefault;
  130. FRAMEChart1->TvChart->DiagramStackedBar->Enabled = true;
  131. FRAMEChart1->TvChart->DiagramStackedColumn->Enabled = true;
  132. FRAMEChart1->TvChart->DiagramStackedColumn->Active = true;
  133. //FRAMEChart1->TvChart->DiagramColumn->Active = true;
  134. if (!FLane) FillChartOptions();
  135. LblSearch->Caption = lblText2->Caption + FStDateTime.SubString(1, 12) + " ~ " + FEdDateTime.SubString(1, 12);
  136. }
  137. //---------------------------------------------------------------------------
  138. void __fastcall TFrmCrsTrafVolLogSub::FillChartOptions()
  139. {
  140. FRAMEChart1->CbOption->Properties->OnChange = NULL;
  141. FRAMEChart1->CbOption->Properties->Items->Clear();
  142. TCross* pCross = FCrossObj;//CrossManager->FLists.Find(FCrossId);
  143. if (pCross)
  144. {
  145. if (FCamNm == "*ALL*")
  146. {
  147. FOR_STL(TCrossCam*, pCam, pCross->FLists)
  148. {
  149. FRAMEChart1->CbOption->Properties->Items->Add("[" + pCam->CMRA_ID + "] " + pCam->CMRA_NM);
  150. }
  151. }
  152. else
  153. {
  154. String sCamId = StringReplace(FCamId, "'", "", TReplaceFlags() << rfReplaceAll);
  155. FRAMEChart1->CbOption->Properties->Items->Add("[" + sCamId + "] " + FCamNm);
  156. }
  157. }
  158. FRAMEChart1->CbOption->ItemIndex = 0;
  159. FRAMEChart1->CbOption->Properties->OnChange = CbOptionPropertiesChange;
  160. }
  161. //---------------------------------------------------------------------------
  162. void __fastcall TFrmCrsTrafVolLogSub::FormShow(TObject *Sender)
  163. {
  164. FormInit();
  165. Refresh();
  166. TmrShow->Enabled = true;
  167. }
  168. //---------------------------------------------------------------------------
  169. void __fastcall TFrmCrsTrafVolLogSub::CommClose()
  170. {
  171. //CMM_SaveForm(g_sFormsDir, this);
  172. //FrmVmsLogSub = NULL;
  173. }
  174. //---------------------------------------------------------------------------
  175. void __fastcall TFrmCrsTrafVolLogSub::TmrShowTimer(TObject *Sender)
  176. {
  177. TmrShow->Enabled = false;
  178. if (FLane)
  179. {
  180. switch(FStatType)
  181. {
  182. case 0: Sel05M_Lane(); break; //5분
  183. case 1: Sel15M_Lane(); break; //15분
  184. case 2: Sel30M_Lane(); break; //30분
  185. case 3: Sel60M_Lane(); break; //1시간
  186. case 4: SelDay_Lane(); break; //일
  187. case 5: SelMonth_Lane(); break; //월
  188. }
  189. }
  190. else
  191. {
  192. switch(FStatType)
  193. {
  194. case 0: Sel05M(); break; //5분
  195. case 1: Sel15M(); break; //15분
  196. case 2: Sel30M(); break; //30분
  197. case 3: Sel60M(); break; //1시간
  198. case 4: SelDay(); break; //일
  199. case 5: SelMonth(); break; //월
  200. }
  201. }
  202. }
  203. //---------------------------------------------------------------------------
  204. void __fastcall TFrmCrsTrafVolLogSub::ChkExpandClick(TObject *Sender)
  205. {
  206. CMM_ExpandCollapseChk(TvList, ChkExpand->Checked);
  207. }
  208. //---------------------------------------------------------------------------
  209. void __fastcall TFrmCrsTrafVolLogSub::Sel05M()
  210. {
  211. TSqlCursor sqlCrs;
  212. String sQry;
  213. TADOQuery *pADO = ADOQry;
  214. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  215. " A.CMRA_ID AS cmraId, \r\n"
  216. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  217. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  218. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  219. " NVL(MIN(A.LANE), 0) AS lane, \r\n"
  220. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  221. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  222. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  223. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  224. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  225. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  226. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  227. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  228. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  229. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  230. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  231. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  232. " NVL(SUM(A.UTURN_TFVL), 0) AS uturnTfvl, \r\n"
  233. " NVL(ROUND(AVG(A.SPEED), 0), 0) AS sped, \r\n"
  234. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  235. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  236. " NVL(SUM(A.BIKE_GO_TFVL), 0) AS bikeGoTfvl, \r\n"
  237. " NVL(SUM(A.BIKE_LEFT_TFVL), 0) AS bikeLeftTfvl, \r\n"
  238. " NVL(SUM(A.BIKE_RGHT_TFVL), 0) AS bikeRghtTfvl, \r\n"
  239. " NVL(SUM(A.ILG_WALK_CNT), 0) AS iglWalkCnt, \r\n"
  240. " 0 AS srvcLvl, \r\n"
  241. " COUNT(1) AS dataCnt \r\n"
  242. " FROM TB_SC_IMGN_DTCT_RAW_CLCT A \r\n"
  243. " WHERE A.IXR_ID = :p01 \r\n"
  244. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  245. " AND A.CMRA_ID IN (" + FCamId + ") \r\n"
  246. " GROUP BY A.IXR_ID, A.CMRA_ID, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  247. " ORDER BY A.IXR_ID, A.CMRA_ID, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  248. try
  249. {
  250. ITSDb_SQLText(pADO, sQry);
  251. ITSDb_SQLBind(pADO, "p01", FCrossId);
  252. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  253. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  254. ITSDb_SQLOpen(pADO);
  255. }
  256. catch(EDatabaseError &E)
  257. {
  258. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel05M", String(E.ClassName()), E.Message, sQry);
  259. throw Exception(String(E.ClassName()) + E.Message);
  260. }
  261. catch(Exception &e)
  262. {
  263. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel05M", String(e.ClassName()), e.Message, sQry);
  264. throw Exception(String(e.ClassName()) + e.Message);
  265. }
  266. DspHistory();
  267. }
  268. //---------------------------------------------------------------------------
  269. void __fastcall TFrmCrsTrafVolLogSub::Sel05M_Lane()
  270. {
  271. TSqlCursor sqlCrs;
  272. String sQry;
  273. TADOQuery *pADO = ADOQry;
  274. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  275. " A.CMRA_ID AS cmraId, \r\n"
  276. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  277. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  278. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  279. " NVL(A.LANE, 0) AS lane, \r\n"
  280. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  281. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  282. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  283. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  284. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  285. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  286. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  287. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  288. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  289. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  290. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  291. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  292. " NVL(A.UTURN_TFVL, 0) AS uturnTfvl, \r\n"
  293. " NVL(A.SPEED, 0) AS sped, \r\n"
  294. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  295. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  296. " NVL(A.BIKE_GO_TFVL, 0) AS bikeGoTfvl, \r\n"
  297. " NVL(A.BIKE_LEFT_TFVL, 0) AS bikeLeftTfvl, \r\n"
  298. " NVL(A.BIKE_RGHT_TFVL, 0) AS bikeRghtTfvl, \r\n"
  299. " NVL(A.ILG_WALK_CNT, 0) AS iglWalkCnt, \r\n"
  300. " 0 AS srvcLvl, \r\n"
  301. " 1 AS dataCnt \r\n"
  302. " FROM TB_SC_IMGN_DTCT_RAW_CLCT A \r\n"
  303. " WHERE A.IXR_ID = :p01 \r\n"
  304. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  305. " AND A.CMRA_ID IN (" + FCamId + ") \r\n"
  306. " ORDER BY A.IXR_ID, A.CMRA_ID, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  307. try
  308. {
  309. ITSDb_SQLText(pADO, sQry);
  310. ITSDb_SQLBind(pADO, "p01", FCrossId);
  311. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  312. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  313. ITSDb_SQLOpen(pADO);
  314. }
  315. catch(EDatabaseError &E)
  316. {
  317. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel05M_Lane", String(E.ClassName()), E.Message, sQry);
  318. throw Exception(String(E.ClassName()) + E.Message);
  319. }
  320. catch(Exception &e)
  321. {
  322. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel05M_Lane", String(e.ClassName()), e.Message, sQry);
  323. throw Exception(String(e.ClassName()) + e.Message);
  324. }
  325. DspHistory();
  326. }
  327. //---------------------------------------------------------------------------
  328. void __fastcall TFrmCrsTrafVolLogSub::Sel15M()
  329. {
  330. TSqlCursor sqlCrs;
  331. String sQry;
  332. TADOQuery *pADO = ADOQry;
  333. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  334. " 'X' AS cmraId, \r\n"
  335. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  336. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  337. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  338. " 0 AS lane, \r\n"
  339. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  340. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  341. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  342. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  343. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  344. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  345. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  346. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  347. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  348. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  349. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  350. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  351. " NVL(SUM(A.UTURN_TFVL), 0) AS uturnTfvl, \r\n"
  352. " 0 AS sped, \r\n"
  353. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  354. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  355. " 0 AS bikeGoTfvl, \r\n"
  356. " 0 AS bikeLeftTfvl, \r\n"
  357. " 0 AS bikeRghtTfvl, \r\n"
  358. " 0 AS iglWalkCnt, \r\n"
  359. " NVL(MIN(A.SRVC_LVL), 0) AS srvcLvl, \r\n"
  360. " COUNT(1) AS dataCnt \r\n"
  361. " FROM TB_SC_ACRD_15MM_STAT A \r\n"
  362. " WHERE A.IXR_ID = :p01 \r\n"
  363. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  364. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  365. " GROUP BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  366. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  367. try
  368. {
  369. ITSDb_SQLText(pADO, sQry);
  370. ITSDb_SQLBind(pADO, "p01", FCrossId);
  371. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  372. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  373. ITSDb_SQLOpen(pADO);
  374. }
  375. catch(EDatabaseError &E)
  376. {
  377. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel15M", String(E.ClassName()), E.Message, sQry);
  378. throw Exception(String(E.ClassName()) + E.Message);
  379. }
  380. catch(Exception &e)
  381. {
  382. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel15M", String(e.ClassName()), e.Message, sQry);
  383. throw Exception(String(e.ClassName()) + e.Message);
  384. }
  385. DspHistory();
  386. }
  387. //---------------------------------------------------------------------------
  388. void __fastcall TFrmCrsTrafVolLogSub::Sel15M_Lane()
  389. {
  390. TSqlCursor sqlCrs;
  391. String sQry;
  392. TADOQuery *pADO = ADOQry;
  393. #if 0
  394. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  395. " 'X' AS cmraId, \r\n"
  396. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  397. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  398. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  399. " NVL(A.LANE, 0) AS lane, \r\n"
  400. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  401. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  402. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  403. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  404. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  405. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  406. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  407. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  408. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  409. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  410. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  411. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  412. " NVL(A.UTURN_TFVL, 0) AS uturnTfvl, \r\n"
  413. " 0 AS sped, \r\n"
  414. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  415. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  416. " 0 AS bikeGoTfvl, \r\n"
  417. " 0 AS bikeLeftTfvl, \r\n"
  418. " 0 AS bikeRghtTfvl, \r\n"
  419. " 0 AS iglWalkCnt, \r\n"
  420. " A.SRVC_LVL AS srvcLvl, \r\n"
  421. " 1 AS dataCnt \r\n"
  422. " FROM TB_SC_ACRD_15MM_STAT A \r\n"
  423. " WHERE A.IXR_ID = :p01 \r\n"
  424. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  425. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  426. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  427. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  428. #else
  429. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  430. " A.CMRA_ID AS cmraId, \r\n"
  431. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  432. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  433. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  434. " NVL(A.LANE, 0) AS lane, \r\n"
  435. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  436. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  437. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  438. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  439. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  440. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  441. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  442. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  443. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  444. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  445. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  446. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  447. " NVL(A.UTURN_TFVL, 0) AS uturnTfvl, \r\n"
  448. " 0 AS sped, \r\n"
  449. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  450. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  451. " 0 AS bikeGoTfvl, \r\n"
  452. " 0 AS bikeLeftTfvl, \r\n"
  453. " 0 AS bikeRghtTfvl, \r\n"
  454. " 0 AS iglWalkCnt, \r\n"
  455. " 0 AS srvcLvl, \r\n"
  456. " 1 AS dataCnt \r\n"
  457. " FROM TB_SC_LANE_15MM_STAT A \r\n"
  458. " WHERE A.IXR_ID = :p01 \r\n"
  459. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  460. " AND A.CMRA_ID IN (" + FCamId + ") \r\n"
  461. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  462. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  463. #endif
  464. try
  465. {
  466. ITSDb_SQLText(pADO, sQry);
  467. ITSDb_SQLBind(pADO, "p01", FCrossId);
  468. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  469. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  470. ITSDb_SQLOpen(pADO);
  471. }
  472. catch(EDatabaseError &E)
  473. {
  474. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel15M_Lane", String(E.ClassName()), E.Message, sQry);
  475. throw Exception(String(E.ClassName()) + E.Message);
  476. }
  477. catch(Exception &e)
  478. {
  479. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel15M_Lane", String(e.ClassName()), e.Message, sQry);
  480. throw Exception(String(e.ClassName()) + e.Message);
  481. }
  482. DspHistory();
  483. }
  484. //---------------------------------------------------------------------------
  485. void __fastcall TFrmCrsTrafVolLogSub::Sel30M()
  486. {
  487. TSqlCursor sqlCrs;
  488. String sQry;
  489. TADOQuery *pADO = ADOQry;
  490. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  491. " 'X' AS cmraId, \r\n"
  492. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  493. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  494. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  495. " 0 AS lane, \r\n"
  496. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  497. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  498. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  499. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  500. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  501. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  502. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  503. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  504. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  505. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  506. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  507. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  508. " 0 AS uturnTfvl, \r\n"
  509. " 0 AS sped, \r\n"
  510. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  511. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  512. " 0 AS bikeGoTfvl, \r\n"
  513. " 0 AS bikeLeftTfvl, \r\n"
  514. " 0 AS bikeRghtTfvl, \r\n"
  515. " 0 AS iglWalkCnt, \r\n"
  516. " NVL(MIN(A.SRVC_LVL), 0) AS srvcLvl, \r\n"
  517. " COUNT(1) AS dataCnt \r\n"
  518. " FROM TB_SC_ACRD_30MM_STAT A \r\n"
  519. " WHERE A.IXR_ID = :p01 \r\n"
  520. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  521. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  522. " GROUP BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  523. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  524. try
  525. {
  526. ITSDb_SQLText(pADO, sQry);
  527. ITSDb_SQLBind(pADO, "p01", FCrossId);
  528. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  529. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  530. ITSDb_SQLOpen(pADO);
  531. }
  532. catch(EDatabaseError &E)
  533. {
  534. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel30M", String(E.ClassName()), E.Message, sQry);
  535. throw Exception(String(E.ClassName()) + E.Message);
  536. }
  537. catch(Exception &e)
  538. {
  539. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel30M", String(e.ClassName()), e.Message, sQry);
  540. throw Exception(String(e.ClassName()) + e.Message);
  541. }
  542. DspHistory();
  543. }
  544. //---------------------------------------------------------------------------
  545. void __fastcall TFrmCrsTrafVolLogSub::Sel30M_Lane()
  546. {
  547. TSqlCursor sqlCrs;
  548. String sQry;
  549. TADOQuery *pADO = ADOQry;
  550. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  551. " 'X' AS cmraId, \r\n"
  552. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  553. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  554. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24:MI') AS dspDt, \r\n"
  555. " NVL(A.LANE, 0) AS lane, \r\n"
  556. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  557. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  558. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  559. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  560. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  561. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  562. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  563. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  564. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  565. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  566. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  567. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  568. " 0 AS uturnTfvl, \r\n"
  569. " 0 AS sped, \r\n"
  570. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  571. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  572. " 0 AS bikeGoTfvl, \r\n"
  573. " 0 AS bikeLeftTfvl, \r\n"
  574. " 0 AS bikeRghtTfvl, \r\n"
  575. " 0 AS iglWalkCnt, \r\n"
  576. " A.SRVC_LVL AS srvcLvl, \r\n"
  577. " 1 AS dataCnt \r\n"
  578. " FROM TB_SC_ACRD_30MM_STAT A \r\n"
  579. " WHERE A.IXR_ID = :p01 \r\n"
  580. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  581. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  582. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  583. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  584. try
  585. {
  586. ITSDb_SQLText(pADO, sQry);
  587. ITSDb_SQLBind(pADO, "p01", FCrossId);
  588. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  589. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  590. ITSDb_SQLOpen(pADO);
  591. }
  592. catch(EDatabaseError &E)
  593. {
  594. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel30M_Lane", String(E.ClassName()), E.Message, sQry);
  595. throw Exception(String(E.ClassName()) + E.Message);
  596. }
  597. catch(Exception &e)
  598. {
  599. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel30M_Lane", String(e.ClassName()), e.Message, sQry);
  600. throw Exception(String(e.ClassName()) + e.Message);
  601. }
  602. DspHistory();
  603. }
  604. //---------------------------------------------------------------------------
  605. void __fastcall TFrmCrsTrafVolLogSub::Sel60M()
  606. {
  607. TSqlCursor sqlCrs;
  608. String sQry;
  609. TADOQuery *pADO = ADOQry;
  610. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  611. " 'X' AS cmraId, \r\n"
  612. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  613. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  614. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24') AS dspDt, \r\n"
  615. " 0 AS lane, \r\n"
  616. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  617. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  618. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  619. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  620. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  621. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  622. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  623. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  624. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  625. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  626. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  627. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  628. " 0 AS uturnTfvl, \r\n"
  629. " 0 AS sped, \r\n"
  630. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  631. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  632. " 0 AS bikeGoTfvl, \r\n"
  633. " 0 AS bikeLeftTfvl, \r\n"
  634. " 0 AS bikeRghtTfvl, \r\n"
  635. " 0 AS iglWalkCnt, \r\n"
  636. " NVL(MIN(A.SRVC_LVL), 0) AS srvcLvl, \r\n"
  637. " COUNT(1) AS dataCnt \r\n"
  638. " FROM TB_SC_ACRD_HH_STAT A \r\n"
  639. " WHERE A.IXR_ID = :p01 \r\n"
  640. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  641. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  642. " GROUP BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  643. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  644. try
  645. {
  646. ITSDb_SQLText(pADO, sQry);
  647. ITSDb_SQLBind(pADO, "p01", FCrossId);
  648. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  649. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  650. ITSDb_SQLOpen(pADO);
  651. }
  652. catch(EDatabaseError &E)
  653. {
  654. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel60M", String(E.ClassName()), E.Message, sQry);
  655. throw Exception(String(E.ClassName()) + E.Message);
  656. }
  657. catch(Exception &e)
  658. {
  659. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel60M", String(e.ClassName()), e.Message, sQry);
  660. throw Exception(String(e.ClassName()) + e.Message);
  661. }
  662. DspHistory();
  663. }
  664. //---------------------------------------------------------------------------
  665. void __fastcall TFrmCrsTrafVolLogSub::Sel60M_Lane()
  666. {
  667. TSqlCursor sqlCrs;
  668. String sQry;
  669. TADOQuery *pADO = ADOQry;
  670. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  671. " 'X' AS cmraId, \r\n"
  672. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  673. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  674. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD HH24') AS dspDt, \r\n"
  675. " NVL(A.LANE, 0) AS lane, \r\n"
  676. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  677. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  678. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  679. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  680. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  681. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  682. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  683. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  684. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  685. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  686. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  687. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  688. " 0 AS uturnTfvl, \r\n"
  689. " 0 AS sped, \r\n"
  690. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  691. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  692. " 0 AS bikeGoTfvl, \r\n"
  693. " 0 AS bikeLeftTfvl, \r\n"
  694. " 0 AS bikeRghtTfvl, \r\n"
  695. " 0 AS iglWalkCnt, \r\n"
  696. " A.SRVC_LVL AS srvcLvl, \r\n"
  697. " 1 AS dataCnt \r\n"
  698. " FROM TB_SC_ACRD_HH_STAT A \r\n"
  699. " WHERE A.IXR_ID = :p01 \r\n"
  700. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  701. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  702. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  703. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  704. try
  705. {
  706. ITSDb_SQLText(pADO, sQry);
  707. ITSDb_SQLBind(pADO, "p01", FCrossId);
  708. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  709. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  710. ITSDb_SQLOpen(pADO);
  711. }
  712. catch(EDatabaseError &E)
  713. {
  714. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel60M_Lane", String(E.ClassName()), E.Message, sQry);
  715. throw Exception(String(E.ClassName()) + E.Message);
  716. }
  717. catch(Exception &e)
  718. {
  719. DBERRORMSG("TFrmCrsTrafVolLogSub::Sel60M_Lane", String(e.ClassName()), e.Message, sQry);
  720. throw Exception(String(e.ClassName()) + e.Message);
  721. }
  722. DspHistory();
  723. }
  724. //---------------------------------------------------------------------------
  725. void __fastcall TFrmCrsTrafVolLogSub::SelDay()
  726. {
  727. TSqlCursor sqlCrs;
  728. String sQry;
  729. TADOQuery *pADO = ADOQry;
  730. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  731. " 'X' AS cmraId, \r\n"
  732. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  733. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  734. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD') AS dspDt, \r\n"
  735. " 0 AS lane, \r\n"
  736. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  737. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  738. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  739. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  740. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  741. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  742. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  743. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  744. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  745. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  746. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  747. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  748. " 0 AS uturnTfvl, \r\n"
  749. " 0 AS sped, \r\n"
  750. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  751. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  752. " 0 AS bikeGoTfvl, \r\n"
  753. " 0 AS bikeLeftTfvl, \r\n"
  754. " 0 AS bikeRghtTfvl, \r\n"
  755. " 0 AS iglWalkCnt, \r\n"
  756. " 0 AS srvcLvl, \r\n"
  757. " COUNT(1) AS dataCnt \r\n"
  758. " FROM TB_SC_ACRD_DD_STAT A \r\n"
  759. " WHERE A.IXR_ID = :p01 \r\n"
  760. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  761. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  762. " GROUP BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  763. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  764. try
  765. {
  766. ITSDb_SQLText(pADO, sQry);
  767. ITSDb_SQLBind(pADO, "p01", FCrossId);
  768. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  769. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  770. ITSDb_SQLOpen(pADO);
  771. }
  772. catch(EDatabaseError &E)
  773. {
  774. DBERRORMSG("TFrmCrsTrafVolLogSub::SelDay", String(E.ClassName()), E.Message, sQry);
  775. throw Exception(String(E.ClassName()) + E.Message);
  776. }
  777. catch(Exception &e)
  778. {
  779. DBERRORMSG("TFrmCrsTrafVolLogSub::SelDay", String(e.ClassName()), e.Message, sQry);
  780. throw Exception(String(e.ClassName()) + e.Message);
  781. }
  782. DspHistory();
  783. }
  784. //---------------------------------------------------------------------------
  785. void __fastcall TFrmCrsTrafVolLogSub::SelDay_Lane()
  786. {
  787. TSqlCursor sqlCrs;
  788. String sQry;
  789. TADOQuery *pADO = ADOQry;
  790. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  791. " 'X' AS cmraId, \r\n"
  792. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  793. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  794. " TO_CHAR(A.CLCT_DT, 'YYYY-MM-DD') AS dspDt, \r\n"
  795. " NVL(A.LANE, 0) AS lane, \r\n"
  796. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  797. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  798. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  799. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  800. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  801. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  802. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  803. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  804. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  805. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  806. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  807. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  808. " 0 AS uturnTfvl, \r\n"
  809. " 0 AS sped, \r\n"
  810. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  811. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  812. " 0 AS bikeGoTfvl, \r\n"
  813. " 0 AS bikeLeftTfvl, \r\n"
  814. " 0 AS bikeRghtTfvl, \r\n"
  815. " 0 AS iglWalkCnt, \r\n"
  816. " 0 AS srvcLvl, \r\n"
  817. " 1 AS dataCnt \r\n"
  818. " FROM TB_SC_ACRD_DD_STAT A \r\n"
  819. " WHERE A.IXR_ID = :p01 \r\n"
  820. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  821. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  822. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  823. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  824. try
  825. {
  826. ITSDb_SQLText(pADO, sQry);
  827. ITSDb_SQLBind(pADO, "p01", FCrossId);
  828. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  829. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  830. ITSDb_SQLOpen(pADO);
  831. }
  832. catch(EDatabaseError &E)
  833. {
  834. DBERRORMSG("TFrmCrsTrafVolLogSub::SelDay_Lane", String(E.ClassName()), E.Message, sQry);
  835. throw Exception(String(E.ClassName()) + E.Message);
  836. }
  837. catch(Exception &e)
  838. {
  839. DBERRORMSG("TFrmCrsTrafVolLogSub::SelDay_Lane", String(e.ClassName()), e.Message, sQry);
  840. throw Exception(String(e.ClassName()) + e.Message);
  841. }
  842. DspHistory();
  843. }
  844. //---------------------------------------------------------------------------
  845. void __fastcall TFrmCrsTrafVolLogSub::SelMonth()
  846. {
  847. TSqlCursor sqlCrs;
  848. String sQry;
  849. TADOQuery *pADO = ADOQry;
  850. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  851. " 'X' AS cmraId, \r\n"
  852. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  853. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  854. " TO_CHAR(A.CLCT_DT, 'YYYY-MM') AS dspDt, \r\n"
  855. " 0 AS lane, \r\n"
  856. " NVL(MIN(A.INTL_ATMP_HEAT_LNGT), 0) AS intlAtmpHeatLngt, \r\n"
  857. " NVL(ROUND(AVG(A.OCPY_RATE), 2), 0) AS ocpyRate, \r\n"
  858. " NVL(SUM(A.WALK_CNT), 0) AS walkCnt, \r\n"
  859. " NVL(SUM(A.LRG_GO_TFVL), 0) AS lrgGoTfvl, \r\n"
  860. " NVL(SUM(A.MDDL_GO_TFVL), 0) AS mddlGoTfvl, \r\n"
  861. " NVL(SUM(A.SMAL_GO_TFVL), 0) AS smalGoTfvl, \r\n"
  862. " NVL(SUM(A.LRG_LEFT_TFVL), 0) AS lrgLeftTfvl, \r\n"
  863. " NVL(SUM(A.MDDL_LEFT_TFVL), 0) AS mddlLeftTfvl, \r\n"
  864. " NVL(SUM(A.SMAL_LEFT_TFVL), 0) AS smalLeftTfvl, \r\n"
  865. " NVL(SUM(A.LRG_RGHT_TFVL), 0) AS lrgRghtTfvl, \r\n"
  866. " NVL(SUM(A.MDDL_RGHT_TFVL), 0) AS mddlRghtTfvl, \r\n"
  867. " NVL(SUM(A.SMAL_RGHT_TFVL), 0) AS smalRghtTfvl, \r\n"
  868. " 0 AS uturnTfvl, \r\n"
  869. " 0 AS sped, \r\n"
  870. " NVL(SUM(A.BUS_DVRS_LANE_GO_TFVL), 0) AS busDvrsLaneGoTfvl, \r\n"
  871. " NVL(SUM(A.BUS_DVRS_LANE_LEFT_TFVL), 0) AS busDvrsLaneLeftTfvl, \r\n"
  872. " 0 AS bikeGoTfvl, \r\n"
  873. " 0 AS bikeLeftTfvl, \r\n"
  874. " 0 AS bikeRghtTfvl, \r\n"
  875. " 0 AS iglWalkCnt, \r\n"
  876. " 0 AS srvcLvl, \r\n"
  877. " COUNT(1) AS dataCnt \r\n"
  878. " FROM TB_SC_ACRD_MN_STAT A \r\n"
  879. " WHERE A.IXR_ID = :p01 \r\n"
  880. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  881. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  882. " GROUP BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n"
  883. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  884. try
  885. {
  886. ITSDb_SQLText(pADO, sQry);
  887. ITSDb_SQLBind(pADO, "p01", FCrossId);
  888. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  889. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  890. ITSDb_SQLOpen(pADO);
  891. }
  892. catch(EDatabaseError &E)
  893. {
  894. DBERRORMSG("TFrmCrsTrafVolLogSub::SelMonth", String(E.ClassName()), E.Message, sQry);
  895. throw Exception(String(E.ClassName()) + E.Message);
  896. }
  897. catch(Exception &e)
  898. {
  899. DBERRORMSG("TFrmCrsTrafVolLogSub::SelMonth", String(e.ClassName()), e.Message, sQry);
  900. throw Exception(String(e.ClassName()) + e.Message);
  901. }
  902. DspHistory();
  903. }
  904. //---------------------------------------------------------------------------
  905. void __fastcall TFrmCrsTrafVolLogSub::SelMonth_Lane()
  906. {
  907. TSqlCursor sqlCrs;
  908. String sQry;
  909. TADOQuery *pADO = ADOQry;
  910. sQry = "SELECT A.IXR_ID AS ixrId, \r\n"
  911. " 'X' AS cmraId, \r\n"
  912. " A.DRCT_DVSN_CD AS drctDvsnCd, \r\n"
  913. " TO_CHAR(A.CLCT_DT, 'YYYYMMDDHH24MISS') AS statDt, \r\n"
  914. " TO_CHAR(A.CLCT_DT, 'YYYY-MM') AS dspDt, \r\n"
  915. " NVL(A.LANE, 0) AS lane, \r\n"
  916. " NVL(A.INTL_ATMP_HEAT_LNGT, 0) AS intlAtmpHeatLngt, \r\n"
  917. " NVL(A.OCPY_RATE, 0) AS ocpyRate, \r\n"
  918. " NVL(A.WALK_CNT, 0) AS walkCnt, \r\n"
  919. " NVL(A.LRG_GO_TFVL, 0) AS lrgGoTfvl, \r\n"
  920. " NVL(A.MDDL_GO_TFVL, 0) AS mddlGoTfvl, \r\n"
  921. " NVL(A.SMAL_GO_TFVL, 0) AS smalGoTfvl, \r\n"
  922. " NVL(A.LRG_LEFT_TFVL, 0) AS lrgLeftTfvl, \r\n"
  923. " NVL(A.MDDL_LEFT_TFVL, 0) AS mddlLeftTfvl, \r\n"
  924. " NVL(A.SMAL_LEFT_TFVL, 0) AS smalLeftTfvl, \r\n"
  925. " NVL(A.LRG_RGHT_TFVL, 0) AS lrgRghtTfvl, \r\n"
  926. " NVL(A.MDDL_RGHT_TFVL, 0) AS mddlRghtTfvl, \r\n"
  927. " NVL(A.SMAL_RGHT_TFVL, 0) AS smalRghtTfvl, \r\n"
  928. " 0 AS uturnTfvl, \r\n"
  929. " 0 AS sped, \r\n"
  930. " NVL(A.BUS_DVRS_LANE_GO_TFVL, 0) AS busDvrsLaneGoTfvl, \r\n"
  931. " NVL(A.BUS_DVRS_LANE_LEFT_TFVL, 0) AS busDvrsLaneLeftTfvl, \r\n"
  932. " 0 AS bikeGoTfvl, \r\n"
  933. " 0 AS bikeLeftTfvl, \r\n"
  934. " 0 AS bikeRghtTfvl, \r\n"
  935. " 0 AS iglWalkCnt, \r\n"
  936. " 0 AS srvcLvl, \r\n"
  937. " 1 AS dataCnt \r\n"
  938. " FROM TB_SC_ACRD_MN_STAT A \r\n"
  939. " WHERE A.IXR_ID = :p01 \r\n"
  940. " AND A.CLCT_DT BETWEEN TO_DATE(:p02, 'YYYYMMDDHH24MISS') AND TO_DATE(:p03, 'YYYYMMDDHH24MISS') \r\n"
  941. " AND A.DRCT_DVSN_CD IN (" + FDrctCd + ") \r\n"
  942. " ORDER BY A.IXR_ID, A.DRCT_DVSN_CD, A.LANE, A.DRCT_DVSN_CD, A.CLCT_DT \r\n";
  943. " ORDER BY B.CROSS_ID, A.DRCT_DVSN_CD, A.STAT_DT, A.LANE \r\n";
  944. try
  945. {
  946. ITSDb_SQLText(pADO, sQry);
  947. ITSDb_SQLBind(pADO, "p01", FCrossId);
  948. ITSDb_SQLBind(pADO, "p02", FStDateTime);
  949. ITSDb_SQLBind(pADO, "p03", FEdDateTime);
  950. ITSDb_SQLOpen(pADO);
  951. }
  952. catch(EDatabaseError &E)
  953. {
  954. DBERRORMSG("TFrmCrsTrafVolLogSub::SelMonth_Lane", String(E.ClassName()), E.Message, sQry);
  955. throw Exception(String(E.ClassName()) + E.Message);
  956. }
  957. catch(Exception &e)
  958. {
  959. DBERRORMSG("TFrmCrsTrafVolLogSub::SelMonth_Lane", String(e.ClassName()), e.Message, sQry);
  960. throw Exception(String(e.ClassName()) + e.Message);
  961. }
  962. DspHistory();
  963. }
  964. //---------------------------------------------------------------------------
  965. void __fastcall TFrmCrsTrafVolLogSub::DspHistory()
  966. {
  967. TADOQuery *pADO = ADOQry;
  968. try
  969. {
  970. CMM_ClearGridTableView(TvList);
  971. int nRow = 0;
  972. int nDataCnt = 0;
  973. try {
  974. TvList->BeginUpdate(lsimImmediate);
  975. nDataCnt = pADO->RecordCount;
  976. m_pGDC->RecordCount = nDataCnt;
  977. for( ; !pADO->Eof; pADO->Next(), nRow++)
  978. {
  979. String CMRA_NM = "";
  980. String CMRA_ID = pADO->FieldByName("cmraId")->AsString;
  981. if (CMRA_ID == "X") {
  982. int DRCT_DVSN_CD = pADO->FieldByName("drctDvsnCd")->AsInteger;
  983. TCrossCam *pCam = FDrctCdLists.Find(IntToStr(DRCT_DVSN_CD));
  984. if (pCam) {
  985. CMRA_ID = pCam->CMRA_ID;
  986. }
  987. }
  988. TCrossCam *pCam = FCmraIdLists.Find(CMRA_ID);
  989. if (pCam) {
  990. CMRA_NM = pCam->CMRA_NM;
  991. }
  992. m_pGDC->Values[nRow][Col01->Index] = nRow+1;
  993. m_pGDC->Values[nRow][Col02->Index] = "["+FCrossObj->IXR_ID+"] " + FCrossObj->IXR_NM;
  994. m_pGDC->Values[nRow][Col03->Index] = CMRA_NM;
  995. m_pGDC->Values[nRow][Col04->Index] = pADO->FieldByName("dspDt")->AsString;
  996. m_pGDC->Values[nRow][Col05->Index] = pADO->FieldByName("lane")->AsInteger;
  997. int G1 = pADO->FieldByName("lrgGoTfvl")->AsInteger;
  998. int G2 = pADO->FieldByName("mddlGoTfvl")->AsInteger;
  999. int G3 = pADO->FieldByName("smalGoTfvl")->AsInteger;
  1000. int G4 = pADO->FieldByName("busDvrsLaneGoTfvl")->AsInteger;
  1001. int G0 = G1+G2+G3+G4;
  1002. int L1 = pADO->FieldByName("lrgLeftTfvl")->AsInteger;
  1003. int L2 = pADO->FieldByName("mddlLeftTfvl")->AsInteger;
  1004. int L3 = pADO->FieldByName("smalLeftTfvl")->AsInteger;
  1005. int L4 = pADO->FieldByName("busDvrsLaneLeftTfvl")->AsInteger;
  1006. int L0 = L1+L2+L3;
  1007. int R1 = pADO->FieldByName("lrgRghtTfvl")->AsInteger;
  1008. int R2 = pADO->FieldByName("mddlRghtTfvl")->AsInteger;
  1009. int R3 = pADO->FieldByName("smalRghtTfvl")->AsInteger;
  1010. int R0 = R1+R2+R3;
  1011. int U1 = pADO->FieldByName("uturnTfvl")->AsInteger;
  1012. int U0 = U1;
  1013. m_pGDC->Values[nRow][Col06->Index] = pADO->FieldByName("ocpyRate")->AsFloat;
  1014. m_pGDC->Values[nRow][Col08->Index] = pADO->FieldByName("sped")->AsInteger;
  1015. m_pGDC->Values[nRow][Col07->Index] = G0+L0+R0+U0;
  1016. m_pGDC->Values[nRow][ColG1->Index] = G1;
  1017. m_pGDC->Values[nRow][ColG2->Index] = G2;
  1018. m_pGDC->Values[nRow][ColG3->Index] = G3;
  1019. m_pGDC->Values[nRow][ColG4->Index] = G4;
  1020. m_pGDC->Values[nRow][ColG0->Index] = G0;
  1021. m_pGDC->Values[nRow][ColL1->Index] = L1;
  1022. m_pGDC->Values[nRow][ColL2->Index] = L2;
  1023. m_pGDC->Values[nRow][ColL3->Index] = L3;
  1024. m_pGDC->Values[nRow][ColL4->Index] = L4;
  1025. m_pGDC->Values[nRow][ColL0->Index] = L0;
  1026. m_pGDC->Values[nRow][ColR1->Index] = R1;
  1027. m_pGDC->Values[nRow][ColR2->Index] = R2;
  1028. m_pGDC->Values[nRow][ColR3->Index] = R3;
  1029. m_pGDC->Values[nRow][ColR0->Index] = R0;
  1030. m_pGDC->Values[nRow][ColU1->Index] = U1;
  1031. m_pGDC->Values[nRow][ColU0->Index] = U0;
  1032. m_pGDC->Values[nRow][ColCrossId->Index] = pADO->FieldByName("ixrId")->AsString;
  1033. m_pGDC->Values[nRow][ColCamId->Index] = CMRA_ID;
  1034. }
  1035. }
  1036. __finally
  1037. {
  1038. if (pADO)
  1039. {
  1040. pADO->Close();
  1041. }
  1042. TvList->EndUpdate();
  1043. if (!FLane)
  1044. {
  1045. DspChart();
  1046. }
  1047. LblRecords->Caption = FormatFloat("##,##0", m_pGDC->RecordCount) + lblCnt->Caption;//" 건";
  1048. String sEnd = "데이터 " + LblRecords->Caption + " 이 조회 되었습니다.";
  1049. Application->MessageBox(sEnd.c_str(), L"데이터 조회 완료", MB_OK|MB_ICONINFORMATION|MB_APPLMODAL);
  1050. }
  1051. }
  1052. catch(EDatabaseError &E)
  1053. {
  1054. DBERRORMSG("History Results", String(E.ClassName()), E.Message, pADO->SQL->Text);
  1055. throw Exception(String(E.ClassName()) + E.Message);
  1056. }
  1057. catch(Exception &e)
  1058. {
  1059. DBERRORMSG("History Results", String(e.ClassName()), e.Message, pADO->SQL->Text);
  1060. throw Exception(String(e.ClassName()) + e.Message);
  1061. }
  1062. }
  1063. //---------------------------------------------------------------------------
  1064. void __fastcall TFrmCrsTrafVolLogSub::DspChart()
  1065. {
  1066. FRAMEChart1->ChartValueDisplay(FRAMEChart1->ChkDisplayVal->Checked);
  1067. TcxGridChartView *TvChart = FRAMEChart1->TvChart;
  1068. try
  1069. {
  1070. TvChart->ClearSeries();
  1071. TvChart->DataController->RecordCount = 0;
  1072. String sSelCamId = APP_GetCode(FRAMEChart1->CbOption);
  1073. if (sSelCamId == "") return;
  1074. TcxGridChartSeries *pChart1 = NULL;
  1075. TcxGridChartSeries *pChart2 = NULL;
  1076. TcxGridChartSeries *pChart3 = NULL;
  1077. TcxGridChartSeries *pChart4 = NULL;
  1078. int nRow = 0;
  1079. int nDataCnt = 0;
  1080. try {
  1081. TvList->BeginUpdate(lsimImmediate);
  1082. TvChart->BeginUpdate();
  1083. pChart1 = TvChart->CreateSeries();
  1084. pChart1->DataBinding->ValueType = "Integer";
  1085. pChart1->DisplayText = "직진";
  1086. pChart2 = TvChart->CreateSeries();
  1087. pChart2->DataBinding->ValueType = "Integer";
  1088. pChart2->DisplayText = "좌회전";
  1089. pChart3 = TvChart->CreateSeries();
  1090. pChart3->DataBinding->ValueType = "Integer";
  1091. pChart3->DisplayText = "우회전";
  1092. if (TvList->Bands->Items[5]->Visible) {
  1093. pChart4 = TvChart->CreateSeries();
  1094. pChart4->DataBinding->ValueType = "Integer";
  1095. pChart4->DisplayText = "유턴";
  1096. }
  1097. #if 0
  1098. int nRowCnt = TvList->ViewData->RecordCount;
  1099. for (int ii = 0; ii < nRowCnt; ii++)
  1100. {
  1101. TcxCustomGridRow* ARow = TvList->ViewData->Rows[ii];
  1102. String sCrossId = ARow->Values[ColCrossId->Index];
  1103. if (FCrossId != sCrossId) continue;
  1104. String sCamId = ARow->Values[ColCamId->Index];
  1105. if (sSelCamId != sCamId) continue;
  1106. nRow = TvChart->DataController->AppendRecord();
  1107. pChart1->Values[nRow] = ARow->Values[ColG0->Index];
  1108. pChart2->Values[nRow] = ARow->Values[ColL0->Index];
  1109. pChart3->Values[nRow] = ARow->Values[ColR0->Index];
  1110. if (TvList->Bands->Items[5]->Visible) {
  1111. pChart4->Values[nRow] = ARow->Values[ColU0->Index];
  1112. }
  1113. String sCltTm = ARow->Values[Col04->Index];
  1114. TvChart->Categories->Values[nRow] = sCltTm.SubString(12, 5);
  1115. }
  1116. #else
  1117. int nRowCnt = TvList->DataController->RecordCount;
  1118. for (int ii = 0; ii < nRowCnt; ii++)
  1119. {
  1120. String sCrossId = TvList->DataController->Values[ii][ColCrossId->Index];
  1121. if (FCrossId != sCrossId) continue;
  1122. String sCamId = TvList->DataController->Values[ii][ColCamId->Index];
  1123. if (sSelCamId != sCamId) continue;
  1124. nRow = TvChart->DataController->AppendRecord();
  1125. pChart1->Values[nRow] = TvList->DataController->Values[ii][ColG0->Index];
  1126. pChart2->Values[nRow] = TvList->DataController->Values[ii][ColL0->Index];
  1127. pChart3->Values[nRow] = TvList->DataController->Values[ii][ColR0->Index];
  1128. if (TvList->Bands->Items[5]->Visible) {
  1129. pChart4->Values[nRow] = TvList->DataController->Values[ii][ColU0->Index];
  1130. }
  1131. String sCltTm = TvList->DataController->Values[ii][Col04->Index];
  1132. TvChart->Categories->Values[nRow] = sCltTm;//sCltTm.SubString(12, 5);
  1133. }
  1134. #endif
  1135. }
  1136. __finally
  1137. {
  1138. TvChart->EndUpdate();
  1139. TvList->EndUpdate();
  1140. }
  1141. }
  1142. catch(EDatabaseError &E)
  1143. {
  1144. throw Exception(String(E.ClassName()) + E.Message);
  1145. }
  1146. catch(Exception &e)
  1147. {
  1148. throw Exception(String(e.ClassName()) + e.Message);
  1149. }
  1150. }
  1151. //---------------------------------------------------------------------------
  1152. void __fastcall TFrmCrsTrafVolLogSub::BtnExlSaveClick(TObject *Sender)
  1153. {
  1154. TcxGrid *pGrid = CxList;
  1155. TcxGridTableView *pView = TvList;
  1156. String sTitle= Caption;
  1157. CMM_ExportToExcelFile(sTitle, pGrid, pView, this);
  1158. //CMM_ExportToExcelFile(String pTitle, TcxGrid *pGrid, TcxGridTableView *pView, TForm *pOwner, bool bExpand=true, bool bSaveAll=true, bool bUseNativeFormat=true);
  1159. }
  1160. //---------------------------------------------------------------------------
  1161. void __fastcall TFrmCrsTrafVolLogSub::FormClose(TObject *Sender, TCloseAction &Action)
  1162. {
  1163. POST_MSG(FParent, WM_SUBFORM_CLOSE, 0, 0);
  1164. CommClose();
  1165. }
  1166. //---------------------------------------------------------------------------
  1167. void __fastcall TFrmCrsTrafVolLogSub::FormDestroy(TObject *Sender)
  1168. {
  1169. //
  1170. }
  1171. //---------------------------------------------------------------------------
  1172. void __fastcall TFrmCrsTrafVolLogSub::CbOptionPropertiesChange(TObject *Sender)
  1173. {
  1174. //TcxComboBox *pCombo = (TcxComboBox*)Sender;
  1175. DspChart();
  1176. FRAMEChart1->EdFocus->SetFocus();
  1177. }
  1178. //---------------------------------------------------------------------------
  1179. void __fastcall TFrmCrsTrafVolLogSub::Col07CustomDrawCell(TcxCustomGridTableView *Sender, TcxCanvas *ACanvas, TcxGridTableDataCellViewInfo *AViewInfo,
  1180. bool &ADone)
  1181. {
  1182. TColor tColor = ACanvas->Brush->Color;
  1183. TColor tFont = clBlack;
  1184. try
  1185. {
  1186. if (!VarIsNull(AViewInfo->Value))
  1187. {
  1188. int value = AViewInfo->Value;
  1189. if (value == 0)
  1190. {
  1191. tColor = clSilver;
  1192. }
  1193. else
  1194. {
  1195. tColor = clLime;
  1196. }
  1197. }
  1198. else
  1199. {
  1200. tColor = clSilver;
  1201. }
  1202. //if (tColor == clSilver) tFont = tColor;
  1203. ACanvas->Font->Color = tFont;
  1204. ACanvas->SetBrushColor(tColor);
  1205. }
  1206. catch(...)
  1207. {
  1208. }
  1209. }
  1210. //---------------------------------------------------------------------------
  1211. void __fastcall TFrmCrsTrafVolLogSub::BtnBestFitClick(TObject *Sender)
  1212. {
  1213. try
  1214. {
  1215. TvList->BeginUpdate();
  1216. TvList->ApplyBestFit(NULL, false, false);
  1217. }
  1218. __finally
  1219. {
  1220. TvList->EndUpdate();
  1221. }
  1222. }
  1223. //---------------------------------------------------------------------------