| | |
| | | using std::string; |
| | | |
| | | RtspAnalysManager::RtspAnalysManager(LDBTool *_dbTool) : m_lDBTool(nullptr), m_maxCount(50), m_currentCount(0) { |
| | | INFO("MYH DEBUG HERE"); |
| | | m_lDBTool=new LDBTool; |
| | | init(); |
| | | |
| | |
| | | |
| | | //初始化函数 |
| | | void RtspAnalysManager::init() { |
| | | |
| | | INFO("MYH DEBUG HERE") |
| | | auto lst = m_lDBTool->searchCamDevTableAll(); |
| | | Record_Config lst_dev = m_lDBTool->searchConfigTableWithinServerInfo(); |
| | | |
| | |
| | | appPref.setIntData("n_cut_max_duration", lst_dev.n_cut_max_duration); |
| | | appPref.setIntData("n_cut_min_duration", lst_dev.n_cut_min_duration); |
| | | if (lst.size() > 0) { |
| | | |
| | | int startCamNO = appPref.getIntData("CamStart") * appPref.getIntData("CamStep"); |
| | | int CamCount = appPref.getIntData("CamStep"); |
| | | INFO("StartCamNO: "<<startCamNO<<" CamStep: "<<CamCount); |
| | | auto itor = lst.begin(); |
| | | |
| | | if(startCamNO >= lst.size()) |
| | |
| | | } |
| | | |
| | | for(int i=0; i < startCamNO; i++){ |
| | | |
| | | std::string t_camIdex = itor->str_cam_dev_id.toStdString(); |
| | | std::string rtsp_url = rtspAddrBuild(itor->str_ip.toStdString(), 554, itor->str_username.toStdString(), |
| | | itor->str_password.toStdString(), itor->str_brand.toStdString()); |
| | | INFO("JumpCam: "<<t_camIdex<<" URL: "<<rtsp_url); |
| | | itor++; |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | RtspAnalysManager::~RtspAnalysManager() { |
| | | INFO("Program Exit"); |
| | | for (auto controller: m_controllers) { |
| | | INFO("Delete Controller: "<<controller.first); |
| | | delete controller.second; |
| | | } |
| | | m_controllers.clear(); |
| | |
| | | Record_Config lst_dev = m_lDBTool->searchConfigTableWithinServerInfo(); |
| | | |
| | | if (m_controllers.find(index) == m_controllers.end()) { |
| | | INFO("MYH DEBUG HERE"); |
| | | if (m_currentCount >= m_maxCount) { |
| | | ERR("addCamera faild, camera's num is full!") |
| | | return -1; |
| | | } |
| | | DBG("RTSP: "<<rtsp<<" INDEX:"<<index); |
| | | INFO("RTSP: "<<rtsp<<" INDEX:"<<index); |
| | | m_imgRedisControllers[index] = new RtspImageRedisElement(index); |
| | | m_imgRedisControllers[index]->start(); |
| | | |
| | |
| | | |
| | | } else { |
| | | removeCamera(index); |
| | | DBG("removeCamera " << index); |
| | | INFO("removeCamera " << index); |
| | | //DBG("removeCamera " << index); |
| | | return addCamera(index, rtsp); |
| | | } |
| | | } |
| | |
| | | * @return 总是0 |
| | | */ |
| | | int RtspAnalysManager::removeCamera(const std::string &index) { |
| | | INFO("MYH DEBUG HERE"); |
| | | if (m_controllers.find(index) == m_controllers.end())return -1; |
| | | auto controller = m_controllers[index]; |
| | | controller->stop(); |
| | |
| | | imgRedis->wait(); |
| | | delete imgRedis; |
| | | m_imgRedisControllers.erase(index); |
| | | INFO("MYH DEBUG HERE"); |
| | | return 0; |
| | | } |
| | | |
| | |
| | | * @return |
| | | */ |
| | | int RtspAnalysManager::removeAll() { |
| | | INFO("MYH DEBUG HERE"); |
| | | for (auto controller: m_controllers) { |
| | | controller.second->stop(); |
| | | } |
| | |
| | | delete controller.second; |
| | | } |
| | | m_controllers.clear(); |
| | | INFO("MYH DEBUG HERE"); |
| | | |
| | | |
| | | for (auto controller: m_imgRedisControllers) { |
| | |
| | | |
| | | |
| | | m_currentCount = 0; |
| | | INFO("MYH DEBUG HERE"); |
| | | return 0; |
| | | } |
| | | |
| | |
| | | //保存视频到RtspImageRedis的队列,由RtspCaptureElement调用 |
| | | bool RtspAnalysManager::SaveImageToRedis(const std::string& camId,const std::string& imageName,const cv::Mat& img) |
| | | { |
| | | INFO("MYH DEBUG HERE"); |
| | | auto item = m_imgRedisControllers.find(camId); |
| | | if(item!=m_imgRedisControllers.end()) |
| | | { |
| | | INFO("Save Succeed Cam: "<<camId<<" ImageKey: "<<imageName); |
| | | item->second->SaveImage(imageName,img); |
| | | } else { |
| | | ERR("Save Failed Cam: "<<camId<<" ImageKey: "<<imageName); |
| | | } |
| | | INFO("MYH DEBUG HERE"); |
| | | return true; |
| | | } |
| | | |