From a26c680f12915788cc6126661d51a7672bb6ba8f Mon Sep 17 00:00:00 2001
From: pansen <pansen626@sina.com>
Date: 星期三, 03 四月 2019 14:24:21 +0800
Subject: [PATCH] 修改VideoToImageMulth和VideoAnalysFrimHC的删除摄像机和编辑摄像机的nsq消息回调函数.
---
QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.h | 8 +
QiaoJiaSystem/DataManagerServer/http_configserver.cpp | 42 +++++
QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.cpp | 141 +++++++++++++------
QiaoJiaSystem/VideoAnalysFromHC/CMakeLists.txt | 12 +
QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.h | 8
QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.cpp | 205 ++++++++++++-----------------
6 files changed, 242 insertions(+), 174 deletions(-)
diff --git a/QiaoJiaSystem/DataManagerServer/http_configserver.cpp b/QiaoJiaSystem/DataManagerServer/http_configserver.cpp
index f1d76be..3f32428 100644
--- a/QiaoJiaSystem/DataManagerServer/http_configserver.cpp
+++ b/QiaoJiaSystem/DataManagerServer/http_configserver.cpp
@@ -1119,6 +1119,17 @@
if (DEV_NO_TYPE == dev_type) {//add new camera
db_c.updateConfigTableByDevType(DEV_CAMERA);
+ {
+ //#todo
+// std::string topic = "VideoToImageMulth";
+// std::string topic1 = "VideoAnalysFromHC";
+// Json::Value json_cfg;
+// json_cfg["cam_edit"] = content;
+// std::string msg = json_cfg.toStyledString();
+// DBG("msg:" << msg);
+// nsqMsgProducer->Publish(topic, (void *) (&msg));
+// nsqMsgProducer->Publish(topic1, (void *) (&msg));
+ }
runAllApp();
}
//edit camera's sdks
@@ -1126,9 +1137,20 @@
(rec_sdk_old.str_det_thr != rec_sdk.str_det_thr) ||
(rec_sdk_old.str_cmp_thr != rec_sdk.str_cmp_thr)) */
{
- killVideoAnalysFromHCApp();
- sleep(1);
- runAllApp();
+ //#todo sendMessage To haikang&VideoToImage
+ {
+ std::string topic = "VideoToImageMulth";
+ std::string topic1 = "VideoAnalysFromHC";
+ Json::Value json_cfg;
+ json_cfg["cam_edit"] = content;
+ std::string msg = json_cfg.toStyledString();
+ DBG("msg:" << msg);
+ nsqMsgProducer->Publish(topic, (void *) (&msg));
+ nsqMsgProducer->Publish(topic1, (void *) (&msg));
+ }
+// killVideoAnalysFromHCApp();
+// sleep(1);
+// runAllApp();
}
Json::Value value_out;
@@ -1408,12 +1430,22 @@
QString cam_id = QString::fromStdString(value_reader["str_cam_dev_id"].asString());
int ret = db_c.deleteCamDevandSdkByCamID(cam_id);
if (ret) {
- killVideoAnalysFromHCApp();
+// killVideoAnalysFromHCApp();
int dev_record = db_c.searchCamDevNumber();
if (dev_record == 0) {
db_c.updateConfigTableByDevType(DEV_NO_TYPE);
} else {
- runAllApp();
+// runAllApp();
+ }
+ {
+ std::string topic = "VideoToImageMulth";
+ std::string topic1 = "VideoAnalysFromHC";
+ Json::Value json_cfg;
+ json_cfg["cam_del"] = content;
+ std::string msg = json_cfg.toStyledString();
+ DBG("msg:" << msg);
+ nsqMsgProducer->Publish(topic, (void *) (&msg));
+ nsqMsgProducer->Publish(topic1, (void *) (&msg));
}
return "{\"ret_status\": \"ok_ack\"}";
} else {
diff --git a/QiaoJiaSystem/VideoAnalysFromHC/CMakeLists.txt b/QiaoJiaSystem/VideoAnalysFromHC/CMakeLists.txt
index 1afbdbf..838998b 100644
--- a/QiaoJiaSystem/VideoAnalysFromHC/CMakeLists.txt
+++ b/QiaoJiaSystem/VideoAnalysFromHC/CMakeLists.txt
@@ -162,11 +162,15 @@
# cudart
# cublas
opencv_world
-# jsoncpp
+ # jsoncpp
curl
uuid
pthread
hiredis
+ #mq
+ event
+ evnsq
+ evpp_concurrentqueue
)
include_directories(
@@ -211,6 +215,9 @@
/usr/include/x86_64-linux-gnu/qt5/QtSql/
../../BasicPlatForm/libs/hiredis-master/include
+ #nsq
+ ../../../BasicPlatForm/libs/EvnsqTool/include
+ ../../../BasicPlatForm/libs/libevent/include
)
link_directories(
@@ -228,6 +235,9 @@
../../../BasicPlatForm/libs/hcTool/HCNetSDK64/lib/HCNetSDKCom/
../../../BasicPlatForm/libs/libboost/lib
../../../BasicPlatForm/libs/hiredis-master/lib/
+ #nsq
+ ../../../BasicPlatForm/libs/EvnsqTool/lib
+ ../../../BasicPlatForm/libs/libevent/lib
)
add_executable(${PROJECT_NAME}
diff --git a/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.cpp b/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.cpp
index e354f4e..b1bc13a 100644
--- a/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.cpp
+++ b/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.cpp
@@ -29,6 +29,17 @@
resetFdfs();
init();
{
+ IMPORT_APP_ARGS;
+ //nsq set callback func
+ DBG("NsqMsgConsumer Init");
+ string pName(argv[0]);
+ nsqMsgConsumer = new BasicMsg::Nsq::NsqMsgConsumer("127.0.0.1", "4150", pName,
+ to_string(appPref.getIntData("RpcVTIMPort")));
+ nsqMsgConsumer->setMessageCallback(std::bind(&OnMsgFunc, std::placeholders::_1, this));
+ nsqMsgConsumer->init();
+ DBG("NsqMsgConsumer Init END!!");
+ }
+ {
// std::thread httpServer([&]() {
// //#todo port
// HttpSrvRetRecieve httpSrvRetRecieve("0.0.0.0", 12306, 1);
@@ -67,6 +78,58 @@
return rtsp_url;
}
+
+void RtspAnalysElement::OnMsgFunc(void *msgPtr, void *pThisPtr) {
+
+ evnsq::Message *msg = (evnsq::Message *) msgPtr;
+ DBG("Received a message, id=" << msg->id << " message=[" << msg->body.ToString() << "]");
+ RtspAnalysElement *pthis = (RtspAnalysElement *) pThisPtr;
+ Json::Reader reader;
+ Json::Value value;
+ if (reader.parse(msg->body.ToString(), value)) {
+ auto itor_json_end = value.end();
+ Json::Value cfg_val;
+ for (auto itor_json = value.begin(); itor_json != itor_json_end; ++itor_json) {
+ //#todo 浣跨敤绛栫暐妯″紡?鍙戦�佺澶氫釜鎸囦护绱Н鍚庡彂閫�?
+ if (itor_json->isString() && reader.parse(itor_json->asString(), cfg_val)) {
+ if (itor_json.name() == "cam_edit") {
+ string cam_idx = cfg_val["str_cam_dev_id"].asString();
+ if (pthis->controllers.find(cam_idx) != pthis->controllers.end()) {
+ if (pthis->m_GB28181_Enable) {
+ auto lst = pthis->m_lDBTool->searchCamDevTableByType(1);
+ for (auto &item : lst) {
+ if (item.str_cam_dev_id.toStdString() != cam_idx)continue;
+ string rtsp_url = "GB28181";
+ pthis->addCamWithSearchRuleMap(item, rtsp_url);
+ break;
+ }
+ } else {
+ auto lst = pthis->m_lDBTool->searchCamDevTableByType(0);
+ for (auto &item : lst) {
+ if (item.str_cam_dev_id.toStdString() != cam_idx)continue;
+ std::string rtsp_url = rtspAddrBuild(item.str_ip.toStdString(), 554,
+ item.str_username.toStdString(),
+ item.str_password.toStdString(),
+ item.str_brand.toStdString());
+ pthis->addCamWithSearchRuleMap(item, rtsp_url);
+ break;
+ }
+ }
+ }
+ } else if (itor_json.name() == "cam_del") {
+ string cam_idx = cfg_val["str_cam_dev_id"].asString();
+ pthis->removeCamera(cam_idx);
+ }
+ } else {
+ DBG("itor value is not string ");
+ continue;
+ }
+ }
+ } else {
+ ERR("Error Message!!");
+ }
+}
+
void RtspAnalysElement::init() {
m_GB28181_Enable = appPref.getIntData("GB28181_Enable");
@@ -80,7 +143,6 @@
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) {
- Json::Value json;
int startCamNO = appPref.getIntData("CamStartNO");
int CamCount = appPref.getIntData("CamEndNO") - appPref.getIntData("CamStartNO") + 1;
auto itor = lst.begin();
@@ -89,7 +151,6 @@
ERR("startCamNO > lst.size()");
return;
}
-
for (int i = 0; i < startCamNO; i++) {
itor++;
}
@@ -99,29 +160,11 @@
ERR("itor == lst.end()");
return;
}
- std::string t_camIdex = itor->str_cam_dev_id.toStdString();
- std::string rtsp_url = "GB28181";
+ auto &item = *itor;
- SdkRuleMap ruleMap = m_lDBTool->searchSdkRuleByCamId(itor->str_cam_dev_id);
- for (auto &rule:ruleMap) {
+ string rtsp_url = "GB28181";
+ addCamWithSearchRuleMap(item, rtsp_url);
- rule.second.strAddr = itor->str_addr;
- rule.second.weekRuleVec = m_lDBTool->searchCameraWeekRuleByCamId(itor->str_cam_dev_id, rule.first);
-
- if (rule.second.nSdkType == PerStaticSdk) {
- float temp = 1 - (float) (rule.second.nThreshold) / 100;
- rule.second.fSensitivity = (75 + 25 * temp) / 100;
-
- } else if (rule.second.nSdkType != FaceSdk) {
- float temp = 1 - (float) (rule.second.nThreshold) / 100;
- rule.second.fSensitivity = (5 + 90 * temp) / 100;
- }
- DBG("fSensitivity" << rule.second.fSensitivity);
- }
- appPref.setStringData(t_camIdex + "rtsp", rtsp_url);
-
- INFO("cam add is " << itor->str_addr.toStdString());
- addCamera(t_camIdex, ruleMap);
itor++;
}
@@ -160,7 +203,6 @@
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) {
- Json::Value json;
int startCamNO = appPref.getIntData("CamStartNO");
int CamCount = appPref.getIntData("CamEndNO") - appPref.getIntData("CamStartNO") + 1;
auto itor = lst.begin();
@@ -179,30 +221,12 @@
ERR("itor == lst.end()");
return;
}
- 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());
- SdkRuleMap ruleMap = m_lDBTool->searchSdkRuleByCamId(itor->str_cam_dev_id);
- for (auto &rule:ruleMap) {
+ auto &item = *itor;
+ std::string rtsp_url = rtspAddrBuild(item.str_ip.toStdString(), 554, item.str_username.toStdString(),
+ item.str_password.toStdString(), item.str_brand.toStdString());
- rule.second.strAddr = itor->str_addr;
- rule.second.weekRuleVec = m_lDBTool->searchCameraWeekRuleByCamId(itor->str_cam_dev_id, rule.first);
+ addCamWithSearchRuleMap(item, rtsp_url);
- if (rule.second.nSdkType == PerStaticSdk) {
- float temp = 1 - (float) (rule.second.nThreshold) / 100;
- rule.second.fSensitivity = (75 + 25 * temp) / 100;
-
- } else if (rule.second.nSdkType != FaceSdk) {
- float temp = 1 - (float) (rule.second.nThreshold) / 100;
- rule.second.fSensitivity = (5 + 90 * temp) / 100;
- }
- DBG("fSensitivity" << rule.second.fSensitivity);
- }
- appPref.setStringData(t_camIdex + "rtsp", rtsp_url);
- json["rtsp"] = rtsp_url;
-
- INFO("cam add is " << itor->str_addr.toStdString());
- addCamera(t_camIdex, ruleMap);
itor++;
}
} else {
@@ -212,6 +236,31 @@
}
}
+void RtspAnalysElement::addCamWithSearchRuleMap(const Record_Cam_Dev &item, string rtsp_url) {
+ string t_camIdex = item.str_cam_dev_id.toStdString();
+
+ SdkRuleMap ruleMap = m_lDBTool->searchSdkRuleByCamId(item.str_cam_dev_id);
+ for (auto &rule:ruleMap) {
+
+ rule.second.strAddr = item.str_addr;
+ rule.second.weekRuleVec = m_lDBTool->searchCameraWeekRuleByCamId(item.str_cam_dev_id, rule.first);
+
+ if (rule.second.nSdkType == PerStaticSdk) {
+ float temp = 1 - (float) (rule.second.nThreshold) / 100;
+ rule.second.fSensitivity = (75 + 25 * temp) / 100;
+
+ } else if (rule.second.nSdkType != FaceSdk) {
+ float temp = 1 - (float) (rule.second.nThreshold) / 100;
+ rule.second.fSensitivity = (5 + 90 * temp) / 100;
+ }
+ DBG("fSensitivity" << rule.second.fSensitivity);
+ }
+ appPref.setStringData(t_camIdex + "rtsp", rtsp_url);
+
+ INFO("cam add is " << item.str_addr.toStdString());
+ addCamera(t_camIdex, ruleMap);
+}
+
RtspAnalysElement::~RtspAnalysElement() {
for (auto controller: controllers) {
diff --git a/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.h b/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.h
index da7757a..084f8c2 100644
--- a/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.h
+++ b/QiaoJiaSystem/VideoAnalysFromHC/RtspAnalysElement.h
@@ -11,6 +11,7 @@
#include <VideoServer/QiaoJia/DB/LDBTool.h>
#include <basic/util/app/AppPreference.hpp>
+#include "NsqMsgTool.hpp"
class RtspAnalysElement {
@@ -36,6 +37,8 @@
private:
void init();
+ static void OnMsgFunc(void *msgPtr, void *pThisPtr);
+
std::string resetFdfs(std::string ip = "", unsigned int port = 0, std::string content = "");
static std::vector<int> chnString2Vec(std::string str_list);
@@ -43,6 +46,9 @@
// void setDataByType(Json::Value& json,const SdkRule& rule);
private:
+ //nsq
+ BasicMsg::Nsq::NsqMsgConsumer *nsqMsgConsumer;
+
LDBTool *m_lDBTool;
int m_GB28181_Enable;
std::map<std::string, AppPipeController *> controllers;
@@ -51,6 +57,8 @@
FastFdsWithLock fdfsClient;
std::map<int, SdkRule> sdkRuleMap;
+
+ void addCamWithSearchRuleMap(const Record_Cam_Dev &item, string rtsp_url);
};
diff --git a/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.cpp b/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.cpp
index afec100..e00b34e 100644
--- a/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.cpp
+++ b/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.cpp
@@ -9,126 +9,6 @@
using std::string;
void *gRtspAnalysManagerCamera = nullptr;
-RtspAnalysManager::RtspAnalysManager(LDBTool *_dbTool) : m_lDBTool(nullptr), m_maxCount(50), m_currentCount(0) {
-// INFO("MYH DEBUG HERE");
- m_lDBTool = _dbTool;
- init();
-
- //nsq set callback func
- DBG("NsqMsgConsumer Init");
- nsqMsgConsumer = new BasicMsg::Nsq::NsqMsgConsumer("127.0.0.1", "4150", "cut_dura_edit",
- to_string(appPref.getIntData("RpcVTIMPort")));
- nsqMsgConsumer->setMessageCallback(std::bind(&OnMsgFunc, std::placeholders::_1, this));
- nsqMsgConsumer->init();
- DBG("NsqMsgConsumer Init END!!");
-
-}
-
-void RtspAnalysManager::OnMsgFunc(void *msgPtr, void *pThisPtr) {
- evnsq::Message *msg = (evnsq::Message *) msgPtr;
- DBG("Received a message, id=" << msg->id << " message=[" << msg->body.ToString() << "]");
- RtspAnalysManager *pthis = (RtspAnalysManager *) pThisPtr;
- Json::Reader reader;
- Json::Value value;
- if (reader.parse(msg->body.ToString(), value)) {
- auto itor_json_end = value.end();
- Json::Value cfg_val;
- for (auto itor_json = value.begin(); itor_json != itor_json_end; ++itor_json) {
- if (itor_json->isString() && reader.parse(itor_json->asString(), cfg_val)) {
- if (itor_json.name() == "cut_dura_edit") {
- int cut_max_duration = cfg_val["cut_max_duration"].asInt();
- int cut_min_duration = cfg_val["cut_min_duration"].asInt();
- DBG("cut_max_duration: " << cut_max_duration << " cut_min_duration: " << cut_min_duration);
- appPref.setIntData("n_cut_max_duration", cut_max_duration);
- appPref.setIntData("n_cut_min_duration", cut_min_duration);
-
- DBG("cut_max_duration: " << cut_max_duration << " cut_min_duration: " << cut_min_duration);
-// m_GB28181_Enable = appPref.getIntData("GB28181_Enable");
-//*****************************#todo extract to func ************************************
- //#todo GB28181
- if (pthis->m_GB28181_Enable) {
- DBG("searchCamDevTableByType before");
- auto lst = pthis->m_lDBTool->searchCamDevTableByType(1);
- DBG("searchCamDevTableByType size:" << lst.size());
- if (lst.size() > 0) {
- int startCamNO = appPref.getIntData("CamStartNO");
- int CamCount = appPref.getIntData("CamEndNO") - appPref.getIntData("CamStartNO") + 1;
- INFO("StartCamNO: " << startCamNO << " CamCount: " << CamCount);
- auto itor = lst.begin();
-
- if (startCamNO >= lst.size()) {
- ERR("startCamNO > lst.size()");
- return;
- }
-
- for (int i = 0; i < startCamNO; i++) {
- itor++;
- }
- for (int i = 0; i < CamCount; i++) {
- if (itor == lst.end()) {
- ERR("itor == lst.end()");
- return;
- }
- std::string t_camIdex = itor->str_cam_dev_id.toStdString();
- DBG("-----camID:" << t_camIdex << "min:" << cut_min_duration << "max:"
- << cut_max_duration);
- pthis->m_controllers_videoCapElem[t_camIdex]->SetVideoMinMaxSeconds(cut_min_duration,
- cut_max_duration);
- itor++;
- }
- } else {
- ERR("searchCamDevTableByType size is 0");
- }
- } else {
- auto lst = pthis->m_lDBTool->searchCamDevTableByType(0);
- if (lst.size() > 0) {
- int startCamNO = appPref.getIntData("CamStartNO");
- int CamCount = appPref.getIntData("CamEndNO") - appPref.getIntData("CamStartNO") + 1;
- INFO("StartCamNO: " << startCamNO << " CamCount: " << CamCount);
- auto itor = lst.begin();
-
- if (startCamNO >= lst.size()) {
- ERR("startCamNO > lst.size()");
- return;
- }
-
- for (int i = 0; i < startCamNO; i++) {
- itor++;
- }
-
- for (int i = 0; i < CamCount; i++) {
- if (itor == lst.end()) {
- ERR("itor == lst.end()");
- return;
- }
- std::string t_camIdex = itor->str_cam_dev_id.toStdString();
- DBG("-----camID:" << t_camIdex << "min:" << cut_min_duration << "max:"
- << cut_max_duration);
- pthis->m_controllers[t_camIdex]->SetVideoMinMaxSeconds(cut_min_duration,
- cut_max_duration);
- itor++;
- }
-
- } else {
- ERR("searchCamDevTableByType size is 0");
- }
- }
-//***************************************************************************************
- }
-
- } else {
-
- DBG("itor value is not string ");
- continue;
- }
- }
-
-
- } else {
- ERR("Error Message!!");
- }
-}
-
static std::string rtspAddrBuild(std::string ip, const int port, std::string username,
std::string passwd, std::string brand) {
std::string rtsp_url;
@@ -150,6 +30,91 @@
return rtsp_url;
}
+RtspAnalysManager::RtspAnalysManager(LDBTool *_dbTool) : m_lDBTool(nullptr), m_maxCount(50), m_currentCount(0) {
+// INFO("MYH DEBUG HERE");
+ m_lDBTool = _dbTool;
+ init();
+
+ IMPORT_APP_ARGS;
+ //nsq set callback func
+ DBG("NsqMsgConsumer Init");
+ string pName(argv[0]);
+ nsqMsgConsumer = new BasicMsg::Nsq::NsqMsgConsumer("127.0.0.1", "4150", pName,
+ to_string(appPref.getIntData("RpcVTIMPort")));
+ nsqMsgConsumer->setMessageCallback(std::bind(&OnMsgFunc, std::placeholders::_1, this));
+ nsqMsgConsumer->init();
+ DBG("NsqMsgConsumer Init END!!");
+
+}
+
+void RtspAnalysManager::OnMsgFunc(void *msgPtr, void *pThisPtr) {
+ evnsq::Message *msg = (evnsq::Message *) msgPtr;
+ DBG("Received a message, id=" << msg->id << " message=[" << msg->body.ToString() << "]");
+ RtspAnalysManager *pthis = (RtspAnalysManager *) pThisPtr;
+ Json::Reader reader;
+ Json::Value value;
+ if (reader.parse(msg->body.ToString(), value)) {
+ auto itor_json_end = value.end();
+ Json::Value cfg_val;
+ for (auto itor_json = value.begin(); itor_json != itor_json_end; ++itor_json) {
+ //#todo 浣跨敤绛栫暐妯″紡?鍙戦�佺澶氫釜鎸囦护绱Н鍚庡彂閫�?
+ if (itor_json->isString() && reader.parse(itor_json->asString(), cfg_val)) {
+ if (itor_json.name() == "cut_dura_edit") {
+ int cut_max_duration = cfg_val["cut_max_duration"].asInt();
+ int cut_min_duration = cfg_val["cut_min_duration"].asInt();
+ DBG("cut_max_duration: " << cut_max_duration << " cut_min_duration: " << cut_min_duration);
+ appPref.setIntData("n_cut_max_duration", cut_max_duration);
+ appPref.setIntData("n_cut_min_duration", cut_min_duration);
+
+ DBG("cut_max_duration: " << cut_max_duration << " cut_min_duration: " << cut_min_duration);
+// m_GB28181_Enable = appPref.getIntData("GB28181_Enable");
+ //#todo GB28181
+ if (pthis->m_GB28181_Enable) {
+ for (auto &item : pthis->m_controllers_videoCapElem) {
+ item.second->SetVideoMinMaxSeconds(cut_min_duration, cut_max_duration);
+ }
+ } else {
+ for (auto &item : pthis->m_controllers) {
+ item.second->SetVideoMinMaxSeconds(cut_min_duration, cut_max_duration);
+ }
+ }
+ } else if (itor_json.name() == "cam_edit") {
+ string cam_idx = cfg_val["str_cam_dev_id"].asString();
+ if (pthis->m_GB28181_Enable) {
+ if (pthis->m_controllers_videoCapElem.find(cam_idx) !=
+ pthis->m_controllers_videoCapElem.end()) {
+ INFO("cam add is " << cfg_val["str_addr"].asString());
+ pthis->addCamera(cam_idx, "GB28181");
+ }
+ } else {
+ if (pthis->m_controllers.find(cam_idx) != pthis->m_controllers.end()) {
+ std::string rtsp_url = rtspAddrBuild(cfg_val["str_ip"].asString(), 554,
+ cfg_val["str_username"].asString(),
+ cfg_val["str_password"].asString(),
+ cfg_val["str_brand"].asString());
+ INFO("cam add is " << cfg_val["str_addr"].asString());
+ pthis->addCamera(cam_idx, rtsp_url);
+ }
+ }
+ } else if (itor_json.name() == "cam_del") {
+ string cam_idx = cfg_val["str_cam_dev_id"].asString();
+ if (pthis->m_GB28181_Enable) {
+ pthis->removeCamera(cam_idx);
+ } else {
+ pthis->removeCamera(cam_idx);
+ }
+ }
+ } else {
+ DBG("itor value is not string ");
+ continue;
+ }
+ }
+ } else {
+ ERR("Error Message!!");
+ }
+}
+
+
//鍒濆鍖栧嚱鏁�
void RtspAnalysManager::init() {
// INFO("MYH DEBUG HERE")
diff --git a/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.h b/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.h
index c17270a..dabe3ed 100644
--- a/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.h
+++ b/QiaoJiaSystem/VideoToImageMulth/RtspAnalysManager.h
@@ -23,6 +23,7 @@
//using BASICGB28181::VideoCaptureElementWithRtp;
//澶栭儴浣跨敤鐨勫叏灞�鎸囬拡
extern void *gRtspAnalysManagerCamera;
+
//鐢ㄦ潵瀹炵幇recordVideo鐨凴PC鐨勬帴鍙g被
class RtspAnalysManager : public ::RtspAnalys::RtspAnalysServer {
@@ -31,10 +32,12 @@
RtspAnalysManager() : m_maxCount(50), m_currentCount(0) {
m_lDBTool = new LDBTool;
init();
-
+ IMPORT_APP_ARGS;
//nsq set callback func
DBG("NsqMsgConsumer Init");
- nsqMsgConsumer = new BasicMsg::Nsq::NsqMsgConsumer("127.0.0.1", "4150", "cut_dura_edit", to_string(appPref.getIntData("RpcVTIMPort")));
+ string pName(argv[0]);
+ nsqMsgConsumer = new BasicMsg::Nsq::NsqMsgConsumer("127.0.0.1", "4150", pName,
+ to_string(appPref.getIntData("RpcVTIMPort")));
nsqMsgConsumer->setMessageCallback(std::bind(&OnMsgFunc, std::placeholders::_1, this));
nsqMsgConsumer->init();
DBG("NsqMsgConsumer Init END!!");
@@ -61,6 +64,7 @@
private:
void init();
+
static void OnMsgFunc(void *msgPtr, void *pThisPtr);
private:
--
Gitblit v1.8.0