From d3b7bbe7102cd089680a828f5d8f6402c8cf6342 Mon Sep 17 00:00:00 2001 From: pansen <pansen626@sina.com> Date: 星期四, 07 三月 2019 14:43:28 +0800 Subject: [PATCH] GB28181集成完成,集成推流模块 --- QiaoJiaSystem/StructureApp/PerimeterElement.cpp | 216 ++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 161 insertions(+), 55 deletions(-) diff --git a/QiaoJiaSystem/StructureApp/PerimeterElement.cpp b/QiaoJiaSystem/StructureApp/PerimeterElement.cpp index 5e480ee..19f3a92 100644 --- a/QiaoJiaSystem/StructureApp/PerimeterElement.cpp +++ b/QiaoJiaSystem/StructureApp/PerimeterElement.cpp @@ -13,14 +13,19 @@ #include <uuid/uuid.h> #include <jsoncpp/json/json.h> +#define ALARM_PERCENT (10) //10% PerimeterElement::PerimeterElement(const SdkRule &rule) : m_sdkRule(rule), PipeElement(true), trackingTrigger(nullptr), mRealNum(0), - m_triggerElement(rule.nTriggerDelay*8,0), + //姣忕鍑犲紶,灏变箻浠ュ嚑 + m_triggerElement(rule.nTriggerDelay*3,0), pManagerEsDB(nullptr), - m_bIsMask(true) + m_bIsMask(true), + m_bSetWH(false), + pointArray(nullptr), + m_rpcClient("RtspAnalysServer", "127.0.0.1",appPref.getIntData("RpcServerPort"),"tcp") { pManagerEsDB = new EsDBTool(appPref.getStringData("ipAdd"), appPref.getIntData("ipPort")); @@ -31,25 +36,31 @@ delete pManagerEsDB; pManagerEsDB = nullptr; } + if(pointArray) + { +// delete[] pointArray[0]; + delete[] pointArray; + } } void PerimeterElement::threadInitial() { - setMask(m_sdkRule.strAreas.toStdString()); +// setMask(m_sdkRule.strAreas.toStdString()); } void PerimeterElement::threadFunc() { - // ClockTimer ct("PerimeterElement::threadFunc"); + //ClockTimer ct("PerimeterElement::threadFunc"); if (!isInWeek(m_sdkRule.weekRuleVec)) return; int num = 0; std::string picDate; + std::string imgKey; bool state = false; m_recVec.clear(); - // DBG("Objs="<<mObjs.size()<<" fSensitivity="<<m_sdkRule.fSensitivity<<" nThreshold"<<m_sdkRule.nThreshold); +// DBG("Objs="<<mObjs.size()<<" fSensitivity="<<m_sdkRule.fSensitivity<<" nThreshold"<<m_sdkRule.nThreshold); for (auto obj:mObjs) { @@ -57,41 +68,77 @@ QRect rect(obj.rect.x, obj.rect.y, obj.rect.width, obj.rect.height); QPoint center = rect.center(); - if (mPolygon.containsPoint(center, Qt::OddEvenFill) || !m_bIsMask) { - m_recVec.push_back(obj.rect); - if (picDate.empty()) { - picDate = obj.properties["time"]; - // DBG("picDate="<<picDate); + if (picDate.empty()) { + picDate = obj.properties["time"]; + // DBG("picDate="<<picDate); + + } + if(imgKey.empty()) + { + imgKey =obj.properties["imgKey"]; + } + if (m_sdkRule.nSdkType == PerimeterSdk) + { + + if(m_bIsMask) + { + std::vector<Point> poly2; + std::vector<Point> interPoly; + poly2.push_back(Point(rect.x(),rect.y())); + poly2.push_back(Point(rect.x()+rect.width(),rect.y())); + poly2.push_back(Point(rect.x()+rect.width(),rect.y()+rect.height())); + poly2.push_back(Point(rect.x(),rect.y()+rect.height())); + IntAreaCalcUtil::PolygonClip(poly1,poly2,interPoly); + float inter = IntAreaCalcUtil::intAreaCalc(interPoly); + float total1 =IntAreaCalcUtil::intAreaCalc(poly1); + float total2 = IntAreaCalcUtil::intAreaCalc(poly2); + int per1 = (int)(inter / total1 * 100); + int per2 = (int)(inter / total2 * 100); + int per=std::max(per1,per2); + + if(ALARM_PERCENT <= per) + { + //DBG("per 1="<<per1<<" per2="<<per2<<" per="<<per); + m_recVec.push_back(obj.rect); + num++; + } } - num++; - } - else + else if (mPolygon.containsPoint(center, Qt::OddEvenFill) || !m_bIsMask) { - // DBG("id="<< obj.properties["id"]<<" no containts x="<<rect.center().x()<<" y="<<rect.center().y()); + m_recVec.push_back(obj.rect); + + + num++; } + } switch (m_sdkRule.nSdkType) { case PerimeterSdk: - state = num > 0 ; - + //state = num > 0 ; + state =( num !=mRealNum); + // DBG("num="<<num<< "time="<< picDate); + INFO("SDK Type: PerimeterSdk"); break; case CrowdSdk: - state = num > m_sdkRule.nAlarmNumLowerLimit ; + state = num > m_sdkRule.nAlarmNumLowerLimit && num !=mRealNum; + INFO("SDK Type: CrowdSdk"); break; case PerHubSdk: - state = num > m_sdkRule.nAlarmNumLowerLimit && num < m_sdkRule.nAlarmNumUpperLimit ; -// if(m_sdkRule.nAlarmNumLowerLimit>0) + state = num > m_sdkRule.nAlarmNumLowerLimit && num < m_sdkRule.nAlarmNumUpperLimit && num !=mRealNum; + INFO("SDK Type: PerHubSdk"); + +// if(m_sdkRule.nAlarmNumLowerLimit>=0) // { -// if( m_sdkRule.nAlarmNumUpperLimit>m_sdkRule.nAlarmNumLowerLimit+1) +// if( m_sdkRule.nAlarmNumUp2019-01-16 09:49:57perLimit>m_sdkRule.nAlarmNumLowerLimit+1) // { // m_triggerElement.setState(num>m_sdkRule.nAlarmNumLowerLimit && num<m_sdkRule.nAlarmNumUpperLimit); @@ -119,36 +166,63 @@ default: break; } - + INFO("State:"<<state<<" Num:"<<num<<" mRealNum:"<<mRealNum<<" LowerLimit :"<<m_sdkRule.nAlarmNumLowerLimit<<" HightLimit: "<<m_sdkRule.nAlarmNumUpperLimit); m_triggerElement.setState(state); m_triggerElement.triggerOnce(); - // DBG("imgUrl="<<imgUrl); - if (m_triggerElement.getTriggerState() && num!=mRealNum) + if (m_triggerElement.getTriggerState()) { - - cv::Mat t_image = image(CutMask()).clone(); - if(t_image.empty()) - { - if(image.empty()) + if(num > 0) { + if(pointArray!=nullptr) { - DBG("image empty"); + const cv::Point2i* ppt[1] = { pointArray }; + + int npt[]={npts}; + + cv::polylines(image, ppt,npt, 1, true,cv::Scalar(255,255,0), 2); } - DBG("t_image empty"); - return; + + for(auto rect:m_recVec) + { + cv::rectangle(image, rect, cv::Scalar(0, 0, 255), 2); + } +// cv::Mat t_image = image(CutMask()).clone(); +// if(t_image.empty()) +// { +// DBG("t_image empty"); +// return; +// } + std::string imgUrl = uploadImgToFdfs(image); + saveInfoToEs(imgUrl, picDate,imgKey); } - std::string imgUrl = uploadImgToFdfs(t_image); - saveInfoToEs(imgUrl, picDate); DBG("num=" << num << " lastnum=" << mRealNum); mRealNum = num; + + //todo 閲嶇疆鎶ヨtrigger + m_triggerElement.setState(false); + m_triggerElement.triggerOnce(); } -// if(state) -//DBG("mRealNum=" << mRealNum <<"m_triggerElement.getTriggerState()="<<m_triggerElement.getTriggerState()); + +// if (m_triggerElement.getTriggerState() && num!=mRealNum) +// { + +// cv::Mat t_image = image(CutMask()).clone(); +// if(t_image.empty()) +// { +// DBG("t_image empty"); +// return; +// } +// std::string imgUrl = uploadImgToFdfs(t_image); +// saveInfoToEs(imgUrl, picDate); +// DBG("num=" << num << " lastnum=" << mRealNum); +// mRealNum = num; +// } - if(!state) - { - mRealNum = num; - } + +// if(!state) +// { +// mRealNum = num; +// } // DBG("m_sdkRule.nSdkType="<<m_sdkRule.nSdkType<<" num="<<num); @@ -193,14 +267,27 @@ } int size = arrayAreas.size(); npts = size; + float sizeW=(float)appPref.getIntData(m_sdkRule.strCamId.toStdString()+"width")/480; + float sizeH=(float)appPref.getIntData(m_sdkRule.strCamId.toStdString()+"height")/270; + pointArray=new cv::Point2i[npts]; for (int i = 0; i < size; ++i) { QJsonValue jsonValue = arrayAreas[i]; QJsonObject obj = jsonValue.toObject(); - int x = obj.value("x").toDouble() * 4; - int y = obj.value("y").toDouble() * 4; + int x = obj.value("x").toDouble() *sizeW; + int y = obj.value("y").toDouble() *sizeH; + pointArray[i]={x,y}; + if(m_sdkRule.nSdkType == PerimeterSdk) + { + poly1.push_back(Point(x,y)); + } + else + { + mPolygon << (QPoint(x, y)); + } + DBG("width="<<sizeW); + DBG("height="<<sizeH); - mPolygon << (QPoint(x, y)); } } @@ -220,6 +307,12 @@ // image = cv::Mat(value.rows, value.cols, CV_8UC3, sharedMemory->data()); // } value.copyTo(image); + if(!m_bSetWH) + { + setMask(m_sdkRule.strAreas.toStdString()); + m_bSetWH=true; + } + } bool PerimeterElement::getTriggerState() const { @@ -243,7 +336,7 @@ return strImgUrl; } -bool PerimeterElement::saveInfoToEs(const std::string &imgUrl, const std::string &time) { +bool PerimeterElement::saveInfoToEs(const std::string &imgUrl, const std::string &time,const std::string& imgKey) { string str_uuid; uuid_t t_uuid; @@ -262,38 +355,54 @@ // DBG("to_string(m_sdkRule.nSdkType)="<<to_string(m_sdkRule.nSdkType)); // t_json["Gender"] = obj.score; - t_json["picName"] = "wait todo";// 鎶撴媿鐓х墖鍚嶇О - t_json["content"] = "wait todo";// 鍐呭鎻忚堪 + t_json["picName"] = "";// 鎶撴媿鐓х墖鍚嶇О + t_json["content"] = "";// 鍐呭鎻忚堪 t_json["personPicUrl"] = "";// 浜哄憳 鍦板簱鍥剧墖 t_json["ChannlId"] = getProperty("ch_id"); // 閫氶亾id t_json["likeDate"] = AppUtil::getTimeSecString(); // 姣斿鏃堕棿 t_json["picAddress"] = m_sdkRule.strAddr.toStdString();// 鎶撴媿鍦板潃 DBG("picAddress="<<m_sdkRule.strAddr.toStdString()); - t_json["picMaxUrl"] = "wait todo"; // 澶у浘璺緞 + t_json["picMaxUrl"] = ""; // 澶у浘璺緞 // t_json["Age"] ="wait todo"; t_json["picDate"] = time; // 鎶撴媿鏃堕棿锛屽繀椤绘湁 DBG("picDate="<<time); - t_json["picLocalUrl"] = "wait todo"; // 鏈湴璺緞 + t_json["picLocalUrl"] = ""; // 鏈湴璺緞 t_json["isDelete"] = "1";//榛樿1 ,0鏃犳晥 1鏈夋晥 - t_json["likePer"] = "0"; // 鐩镐技鍊� + t_json["likePer"] = 1.0; // 鐩镐技鍊� - t_json["BaseName"] = "wait todo";// 鍦板簱鍚嶇О + t_json["BaseName"] = "";// 鍦板簱鍚嶇О t_json["videoNum"] = m_sdkRule.strCamId.toStdString();//Video璁惧缂栧彿 t_json["picSmUrl"] = imgUrl; // 鎶撴媿鍥剧墖 t_json["indeviceid"] = appPref.getStringData("fxDevID");;// 璁惧id - t_json["idcard"] = "wait todo"; - t_json["personId"] = "wait todo"; + t_json["idcard"] = ""; + t_json["personId"] = ""; t_json["indevicename"] = appPref.getStringData("fxDevNAME");// 璁惧鍚嶇О t_json["FaceFeature"] = "base64"; t_json["personIsHub"] = m_triggerElement.getTriggerState() ? "1" : "4"; //1: 鎶ヨ 2: 鍙枒 3: 瀹夊叏 4: 鏈煡 t_json["videoIp"] = m_sdkRule.strAddr.toStdString(); // 璁惧ip t_json["ack_alarm"] = m_triggerElement.getTriggerState() ? "0" : ""; // que ren shi fou bao jing t_json["cluster_id"] = appPref.getStringData("clusterID");; // ji qun id - + t_json["imgKey"] = imgKey; + try { + auto server = m_rpcClient.getServer(); + if (!server) + { + ERR("server is null"); + //return false; + } + INFO("Record Video "<<imgKey); + server->recordVideo(imgKey); + } + catch (std::exception &e) + { + ERR("Record Video Err: "<<imgKey <<" Message: "<<e.what()); + //return false; + } + INFO("SaveImgKeyToES: "<<imgKey); bool retface = false; if (pManagerEsDB) retface = pManagerEsDB->insertData("personaction", "perVideoAction", t_json.toStyledString(), str_uuid); @@ -366,7 +475,4 @@ // DBG("RECT x="<<rect.x<<"y"<<rect.y<<"w"<<rect.width<<"h"<<rect.height); return rect; } -bool PerimeterElement::isAnd() -{ -} -- Gitblit v1.8.0