CDSCrossF.cpp 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSCrossF.h"
  4. //---------------------------------------------------------------------------
  5. #pragma package(smart_init)
  6. //---------------------------------------------------------------------------
  7. void TCrossCam::Copy(TCrossCam *AObj)
  8. {
  9. if (AObj)
  10. {
  11. AObj->CROSS_ID = CROSS_ID;
  12. AObj->CAM_ID = CAM_ID;
  13. AObj->CAM_NM = CAM_NM;
  14. AObj->DIRECTION = DIRECTION;
  15. AObj->ANGLE = ANGLE;
  16. AObj->IP = IP;
  17. AObj->ID = ID;
  18. AObj->PWD = PWD;
  19. AObj->RTSP_URL = RTSP_URL;
  20. AObj->RTSP_PORT = RTSP_PORT;
  21. AObj->HTTP_PORT = HTTP_PORT;
  22. }
  23. }
  24. //---------------------------------------------------------------------------
  25. //---------------------------------------------------------------------------
  26. TCross::TCross()
  27. {
  28. }
  29. //---------------------------------------------------------------------------
  30. TCross::~TCross()
  31. {
  32. }
  33. //---------------------------------------------------------------------------
  34. //---------------------------------------------------------------------------
  35. TCrossManager *CrossManager = NULL;
  36. //---------------------------------------------------------------------------
  37. TCrossManager::TCrossManager()
  38. {
  39. }
  40. //---------------------------------------------------------------------------
  41. TCrossManager::~TCrossManager()
  42. {
  43. FLists.RemoveAll();
  44. FCamLists.RemoveAll();
  45. }
  46. //---------------------------------------------------------------------------
  47. bool TCrossManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  48. {
  49. String sQry;
  50. TADOQuery *pADO = NULL;
  51. sQry = "SELECT A.* \r\n"
  52. " FROM MST_CROSS A \r\n"
  53. " WHERE DEL_YN = 'N' \r\n";
  54. FLists.Lock();
  55. try
  56. {
  57. FLists.RemoveAll();
  58. try
  59. {
  60. pADO = new TADOQuery(NULL);
  61. pADO->Close();
  62. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  63. pADO->SQL->Clear();
  64. pADO->SQL->Text = sQry;
  65. pADO->Prepared = true;
  66. pADO->Open();
  67. for( ; !pADO->Eof; pADO->Next())
  68. {
  69. TCross *pObj = new TCross();
  70. pObj->CROSS_ID = pADO->FieldByName("CROSS_ID")->AsString;
  71. pObj->CROSS_NM = pADO->FieldByName("NAME")->AsString.Trim();
  72. pObj->CROSS_TYPE = pADO->FieldByName("CROSS_TYPE")->AsString.Trim();
  73. FLists.Push(pObj->CROSS_ID, pObj);
  74. }
  75. }
  76. catch(EDatabaseError &E)
  77. {
  78. throw Exception(String(E.ClassName()) + E.Message);
  79. }
  80. catch(Exception &e)
  81. {
  82. throw Exception(String(e.ClassName()) + e.Message);
  83. }
  84. }
  85. __finally
  86. {
  87. if (pADO)
  88. {
  89. pADO->Close();
  90. delete pADO;
  91. }
  92. FLists.UnLock();
  93. }
  94. return LoadCrossCam(ADbConn);
  95. }
  96. //---------------------------------------------------------------------------
  97. bool TCrossManager::LoadCrossCam(TADOConnection *ADbConn/*=NULL*/)
  98. {
  99. String sQry;
  100. TADOQuery *pADO = NULL;
  101. FLists.Lock();
  102. try
  103. {
  104. FOR_STL(TCross*, pObj, FLists)
  105. {
  106. pObj->FLists.RemoveAll();
  107. }
  108. }
  109. __finally
  110. {
  111. FLists.UnLock();
  112. }
  113. sQry = "SELECT A.CROSS_ID, B.CAM_ID, B.NAME, B.DEL_YN, C.DIRECTION, C.X, C.Y, C.ANGLE, \r\n"
  114. " B.IP, B.ID, B.PW, B.RTSP_URL, B.RTSP_PORT, B.HTTP_PORT, B.RIGHT_USE \r\n"
  115. " FROM MST_CROSS A, MST_CCAM B, MST_CCAM_ACCESS C \r\n"
  116. " WHERE A.CROSS_ID = B.CROSS_ID \r\n"
  117. " AND B.CAM_ID = C.CAM_ID \r\n"
  118. " AND A.DEL_YN = 'N' \r\n"
  119. " AND B.DEL_YN = 'N' \r\n"
  120. " ORDER BY A.CROSS_ID, B.CAM_ID \r\n";
  121. try
  122. {
  123. String WCAM_CTLR_NMBR;
  124. FLists.Lock();
  125. FCamLists.Lock();
  126. FCamLists.RemoveAll();
  127. try
  128. {
  129. pADO = new TADOQuery(NULL);
  130. pADO->Close();
  131. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  132. pADO->SQL->Clear();
  133. pADO->SQL->Text = sQry;
  134. pADO->Prepared = true;
  135. pADO->Open();
  136. for( ; !pADO->Eof; pADO->Next())
  137. {
  138. String CROSS_ID = pADO->FieldByName("CROSS_ID")->AsString;
  139. TCross *pCross = FLists.Find(String(CROSS_ID));
  140. if (!pCross) continue;
  141. TCrossCam *pObj = new TCrossCam();
  142. if (pObj)
  143. {
  144. pObj->CROSS_ID = CROSS_ID;
  145. pObj->CAM_ID = pADO->FieldByName("CAM_ID")->AsString;
  146. pObj->CAM_NM = pADO->FieldByName("NAME")->AsString;
  147. pObj->DIRECTION = pADO->FieldByName("DIRECTION")->AsString.Trim();
  148. pObj->ANGLE = pADO->FieldByName("ANGLE")->AsInteger;
  149. pObj->IP = pADO->FieldByName("IP")->AsString.Trim();
  150. pObj->ID = pADO->FieldByName("ID")->AsString.Trim();
  151. pObj->PWD = pADO->FieldByName("PW")->AsString.Trim();
  152. pObj->RTSP_URL = pADO->FieldByName("RTSP_URL")->AsString.Trim();
  153. pObj->RTSP_PORT = pADO->FieldByName("RTSP_PORT")->AsInteger;
  154. pObj->HTTP_PORT = pADO->FieldByName("HTTP_PORT")->AsInteger;
  155. pCross->FLists.Push(pObj->CAM_ID, pObj);
  156. TCrossCam *pObj2 = new TCrossCam();
  157. pObj->Copy(pObj2);
  158. FCamLists.Push(pObj2->CAM_ID, pObj2);
  159. }
  160. }
  161. }
  162. catch(EDatabaseError &E)
  163. {
  164. throw Exception(String(E.ClassName()) + E.Message);
  165. }
  166. catch(Exception &e)
  167. {
  168. throw Exception(String(e.ClassName()) + e.Message);
  169. }
  170. }
  171. __finally
  172. {
  173. if (pADO)
  174. {
  175. pADO->Close();
  176. delete pADO;
  177. }
  178. FLists.UnLock();
  179. FCamLists.UnLock();
  180. }
  181. return true;
  182. }
  183. //---------------------------------------------------------------------------