From c3c0d2742db73d8a91cdc28218a58e4863086095 Mon Sep 17 00:00:00 2001
From: admin <zzjincn@163.com>
Date: 星期五, 25 四月 2025 15:11:20 +0800
Subject: [PATCH] rtmp推理处理

---
 PreProcessFn.cpp |  546 ++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 364 insertions(+), 182 deletions(-)

diff --git a/PreProcessFn.cpp b/PreProcessFn.cpp
index 04e3fb7..b089513 100644
--- a/PreProcessFn.cpp
+++ b/PreProcessFn.cpp
@@ -332,6 +332,14 @@
     return size * nmemb;
 }
 
+string join(const vector<string>& sequence, const string& separator)
+{
+	std::string result;
+	for (size_t i = 0; i < sequence.size(); ++i)
+		result += sequence[i] + ((i != sequence.size() - 1) ? separator : "");
+	return result;
+}
+
 /// @brief 瑙嗛娴佹媺鍙栧鐞�
 /// @param _rtspUrl 瑙嗛娴佹簮鍦板潃
 /// @param queJC 鏈鐞嗙殑瑙嗛娴佸抚闃熷垪
@@ -342,7 +350,7 @@
 
 	int count = 0;
 	long currentFrame = 1;
-	long skip_frame_num = deley;//璺冲抚闂撮殧璁剧疆锛堟瘡1甯э級
+	long skip_frame_num = skipN;//璺冲抚闂撮殧璁剧疆锛堟瘡1甯э級
 
 	while (!asyncStop)
 	{
@@ -455,6 +463,27 @@
 	rtspStream.release();	
 }
 
+std::string jsontostr(Json::Value& json)
+{
+	string return_str;
+	if(!json.isNull()&&!json.empty())
+	{
+		for (int i = 0; i < json.size(); i++)
+		{
+			return_str += json[i].asString()+",";
+		}
+		if (!return_str.empty() && return_str.back() == ',') {
+       		return_str.pop_back();
+    	}
+    
+	}
+	else
+	{
+		return_str = "";
+	}
+	return return_str;
+}
+
 /// @brief 瑙嗛甯у鐞嗗嚱鏁�
 /// @param ipcsNode 鎽勫儚鏈鸿妭鐐�
 /// @param modelArray 妯″瀷鍒楄〃
@@ -462,10 +491,11 @@
 /// @param queJC2 澶勭悊瀹岀殑瑙嗛娴佸抚闃熷垪
 void PreProcessFn::fnImRecognitionPro(const Json::Value& ipcsNode, Json::Value modelArray, queue<Mat>& queJC, queue<Mat>& queJC2)
 {
-	std::string ipccode = ipcsNode["ipccode"].asString();//鎽勫儚鏈虹紪鐮�
+	std::string ipccode = ipcsNode["code"].asString();//鎽勫儚鏈虹紪鐮�
 	std::string ipcname = ipcsNode["name"].asString();//鎽勫儚鏈哄悕绉�
 	std::string ipcrtsppath = ipcsNode["video"].asString();//瑙嗛rtsp婧�	
-
+	// std::string skipN = ipcsNode["skipN"].asString();//璺冲抚
+	// int skipN = ipcsNode["skipN"].asString();//璺冲抚
 	//mysql杩炴帴鍒濆鍖�
 	MYSQL* mysql = mysql_init(nullptr);
 	if (!mysql_real_connect(mysql, mysqlpath.c_str(), mysqluser.c_str(), mysqlpass.c_str(), mysqldatabase.c_str(), stoi(mysqlport), NULL, 0))
@@ -497,6 +527,14 @@
 	std::vector<Point>  areaDM;//鍫嗙叅妫�娴嬪尯鍩�	
 	std::vector<Point>  areaWear;//绌挎埓妫�娴嬪尯鍩�
 	std::vector<Point>  areaFire;//鐑熺伀妫�娴嬪尯鍩�
+	std::vector<Point> detectarea;//妫�娴嬪尯鍩�
+	std::vector<Point> flowarea;//鐨甫澶栧洿鍖哄煙
+	std::vector<Point> flowrelate;//鐨甫鐩稿鍖哄煙
+	std::vector<Point> leftarea;//宸︿晶鍖哄煙
+	std::vector<Point> rightarea;//鍙充晶鍖哄煙
+	std::vector<Point> beltarea;//涓棿鍖哄煙
+	std::vector<Point> workarea;//宸ヤ綔鍖哄煙
+
 
 	//妯″瀷澶勭悊 ------绗�2姝�
 	RUN rBelt;//鐨甫杩愯妯″瀷
@@ -626,152 +664,201 @@
 	//鎻愬崌鏈哄拰鐨甫鍒ゆ柇鏃讹紝闇�瑕佺疮璁′笁寮犲浘鐗囨墠鑳借繘琛屽垽鏂�
 	std::vector<cv::Mat> imagesTsj;
 	std::vector<cv::Mat> imagesBelt;
-	
+	std::string color_result;
+	std::string lable_title;
 	
 	cout <<modelArray.size()<<endl;
 	//寰幆姣忎釜鎽勫儚澶寸殑妯″瀷锛屽姞杞芥ā鍨�
 	for (int j = 0; j < modelArray.size(); ++j) {
 		Json::Value modelNode = modelArray[j];
-		std::string modelPath = modelNode["modelpath"].asString();
-		std::string modelPath2 = modelNode["modelpath2"].asString();//妯″瀷2璺緞
-		std::string imagePath = modelNode["imagepath"].asString();
+		std::string modelCode = modelNode["code"].asString();//妯″瀷缂栫爜 鍖哄垎鍔犺浇涓嶅悓鐨勬ā鍨�
+		std::string modelPath = modelNode["path"].asString();
+		std::string modelPath2 = modelNode["path2"].asString();//妯″瀷2璺緞
+		std::string imagePath = modelNode["img_path"].asString();
+
 		std::string modelName = modelNode["name"].asString();
-		std::string modelType = modelNode["type"].asString();//妯″瀷鍒嗘瀽绫诲瀷缂栫爜
-		std::string modelAnalysis = modelNode["analysis"].asString();//妯″瀷鍒嗘瀽缁撴灉缂栫爜
-		std::string leftarea = modelNode.get("leftarea", "").asString();//鐨甫宸︿晶鍖哄煙
-		std::string rightarea = modelNode.get("rightarea", "").asString();//鐨甫鍙充晶鍖哄煙
-		std::string area = modelNode.get("area", "").asString();//鍖哄煙涓�
-		std::string area2 = modelNode.get("area2", "").asString();//鍖哄煙浜�
-		std::string modelLimit = modelNode["limit"].asString();
-		std::string modelLimit2 = modelNode.get("limit2", "").asString();//鐨甫绌鸿浇闄愬畾鍊�
-		std::string modelId = modelNode["modelid"].asString();//妯″瀷id锛屽尯鍒嗗姞杞戒笉鍚岀殑妯″瀷
+		Json::Value modelTypeArr = modelNode["type"];////妯″瀷鍒嗘瀽绫诲瀷缂栫爜  
+		std::string modelType = jsontostr(modelTypeArr);
 
+		double threshold = stod(modelNode["threshold"].asString());//闃堝��
+		float modelLimit = stof(modelNode["limit"].asString());//闄愬畾鍊�
+		std::string modelAnalysis ="";
+		color_result = modelNode["color_result"].asString();//棰滆壊鍙嶆鍊�
+
+		// std::string area = modelNode["threshold"].asString();//鍖哄煙涓�
+		// std::string area2 = modelNode.get("area2", "").asString();//鍖哄煙浜�
+		Json::Value rects = modelNode["point_rects"];////妯″瀷鍒嗘瀽绫诲瀷缂栫爜  
+		for (auto k = 0; k < rects.size(); ++k) 
+			{
+				Json::Value pointNode = rects[k];
+				lable_title=pointNode["title"].asString();
+				std::string point_type=pointNode["type"].asString();
+				Json::Value point_Arr= pointNode["points"];
+				for (auto x = 0; x < point_Arr.size(); ++x) 
+				{
+					int croodx = stoi(point_Arr[x]["x"].asString());
+					int croody = stoi(point_Arr[x]["y"].asString());
+					if(point_type=="detectarea")
+					{
+						detectarea.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="flowarea")
+					{
+						flowarea.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="flowrelate")
+					{
+						flowrelate.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="leftroller")
+					{
+						leftarea.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="rightroller")
+					{
+						rightarea.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="beltarea")
+					{
+						beltarea.push_back(cv::Point(croodx, croody));
+					}
+					if (point_type=="workarea")
+					{
+						workarea.push_back(cv::Point(croodx, croody));
+					}
+						
+				}	
+			}
+
+		int* arr = new int[detectarea.size() * 2];
 		//鍔犺浇妯″瀷澶勭悊------
-		switch (stoi(modelId))
+		if(modelCode=="1") //鐨甫鐘舵��
 		{
-		case 1://鐨甫鐘舵��
-			if (!rBelt.initConfig(modelPath.c_str(), stringToIntArray(area)))
-			{
-				printf("鐨甫杩愯妯″瀷鍒濆鍖栧け璐ャ�俓n");
-			}
-			else
-			{
-				printf("鐨甫杩愯妯″瀷鍒濆鍖栨垚鍔熴�俓n");
-				rBelt.isLoad = true;
-			}
-			areaBelt = stringToPoints(area);
-			videoPathBelt = coalCode + ipccode + modelType + modelAnalysis;
-			wfBelt.setCoalCode(coalCode);
-			wfBelt.setCameraCode(ipccode);
-			wfBelt.setCameraName(ipcname);
-			wfBelt.setRtspUrl(ipcrtsppath);
-			wfBelt.setAnalyse(modelType);
-			wfBelt.setAnalyseResult(modelAnalysis);
-			break;
-		
-		case 2://鎻愬崌鏈鸿繍琛屾娴嬫ā鍨�
-			if (!rTSJ.initConfig(modelPath.c_str(), stringToIntArray(area)))
-			{
-				printf("鎻愬崌鏈烘ā鍨嬪垵濮嬪寲澶辫触銆俓n");
-			}
-			else
-			{
-				printf("鎻愬崌鏈烘ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
-				rTSJ.isLoad = true;
-			}
-			areaTSJ = stringToPoints(area);
-			videoPathTSJ = coalCode + ipccode + modelType;
-			wfTSJ.setCoalCode(coalCode);
-			wfTSJ.setCameraCode(ipccode);
-			wfTSJ.setCameraName(ipcname);
-			wfTSJ.setRtspUrl(ipcrtsppath);
-			wfTSJ.setAnalyse(modelType);
-			wfTSJ.setAnalyseResult(modelAnalysis);
-			break;
-
-		case 3://鍖哄煙闂叆妯″瀷	
-
+				if (!rBelt.initConfig(modelPath.c_str(),arr))
+				{
+					printf("鐨甫杩愯妯″瀷鍒濆鍖栧け璐ャ�俓n");
+				}
+				else
+				{
+					printf("鐨甫杩愯妯″瀷鍒濆鍖栨垚鍔熴�俓n");
+					rBelt.isLoad = true;
+				}
+				areaBelt =detectarea;
+				videoPathBelt = coalCode + ipccode + modelType + modelAnalysis;
+				wfBelt.setCoalCode(coalCode);
+				wfBelt.setCameraCode(ipccode);
+				wfBelt.setCameraName(ipcname);
+				wfBelt.setRtspUrl(ipcrtsppath);
+				wfBelt.setAnalyse(modelType);
+				//wfBelt.setAnalyseResult(modelAnalysis);
+		}
+		if(modelCode=="2") //鎻愬崌鏈鸿繍琛屾娴嬫ā鍨�
+		{
+			if (!rTSJ.initConfig(modelPath.c_str(), arr))
+				{
+					printf("鎻愬崌鏈烘ā鍨嬪垵濮嬪寲澶辫触銆俓n");
+				}
+				else
+				{
+					printf("鎻愬崌鏈烘ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
+					rTSJ.isLoad = true;
+				}
+				areaTSJ = detectarea;
+				videoPathTSJ = coalCode + ipccode + modelType;
+				wfTSJ.setCoalCode(coalCode);
+				wfTSJ.setCameraCode(ipccode);
+				wfTSJ.setCameraName(ipcname);
+				wfTSJ.setRtspUrl(ipcrtsppath);
+				wfTSJ.setAnalyse(modelType);
+				wfTSJ.setAnalyseResult(modelAnalysis);
+				break;
+		}
+		if(modelCode=="3") //浜哄憳鍖哄煙闂叆妯″瀷
+		{
 			if (!hatJC.initConfig(modelPath.c_str(), 0.5, 0.5))
-			{
-				printf("鐩爣妫�娴嬫ā鍨嬪垵濮嬪寲澶辫触\n");
-			}
-			else
-			{
-				printf("鐩爣妫�娴嬫ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
-				hatJC.isLoad = true;
-			}
-			areaPerson = stringToPoints(area);//鍗遍櫓鍖哄煙
-			workareaPerson = stringToPoints(area2);//宸ヤ綔鍖哄煙
-			videoPathPerson = coalCode + ipccode + modelType + modelAnalysis;
-			wfPerson.setCoalCode(coalCode);
-			wfPerson.setCameraCode(ipccode);
-			wfPerson.setCameraName(ipcname);
-			wfPerson.setRtspUrl(ipcrtsppath);
-			wfPerson.setAnalyse(modelType);
-			wfPerson.setAnalyseResult(modelAnalysis);
-
-			break;
-		
-		case 4://鎽勫儚澶撮伄鎸$畻娉�		
+				{
+					printf("鐩爣妫�娴嬫ā鍨嬪垵濮嬪寲澶辫触\n");
+				}
+				else
+				{
+					printf("鐩爣妫�娴嬫ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
+					hatJC.isLoad = true;
+				}
+				areaPerson = detectarea;//鍗遍櫓鍖哄煙
+				workareaPerson = workarea;//宸ヤ綔鍖哄煙
+				videoPathPerson = coalCode + ipccode + modelType + modelAnalysis;
+				wfPerson.setCoalCode(coalCode);
+				wfPerson.setCameraCode(ipccode);
+				wfPerson.setCameraName(ipcname);
+				wfPerson.setRtspUrl(ipcrtsppath);
+				wfPerson.setAnalyse(modelType);
+				wfPerson.setAnalyseResult(modelAnalysis);
+		}
+		if(modelCode=="4") //鎽勫儚澶撮伄鎸$畻娉�
+		{
 			if (!cover.initConfig()) {
-				printf("鎽勫儚澶撮伄鎸$畻娉曞垵濮嬪寲澶辫触\n");
-			}
-			else
-			{
-				std::cout << "鎽勫儚澶撮伄鎸$畻娉曞垵濮嬪寲鎴愬姛" << std::endl;
-				cover.isLoad = true;
-			}
-			videoPathCameraCover = coalCode + ipccode + modelType + modelAnalysis;
-			wfCameraCover.setCoalCode(coalCode);
-			wfCameraCover.setCameraCode(ipccode);
-			wfCameraCover.setCameraName(ipcname);
-			wfCameraCover.setRtspUrl(ipcrtsppath);
-			wfCameraCover.setAnalyse(modelType);
-			wfCameraCover.setAnalyseResult(modelAnalysis);
-			break;
-
-		case 5://鎽勫儚澶寸Щ鍔ㄧ畻娉�		
+					printf("鎽勫儚澶撮伄鎸$畻娉曞垵濮嬪寲澶辫触\n");
+				}
+				else
+				{
+					std::cout << "鎽勫儚澶撮伄鎸$畻娉曞垵濮嬪寲鎴愬姛" << std::endl;
+					cover.isLoad = true;
+				}
+				videoPathCameraCover = coalCode + ipccode + modelType + modelAnalysis;
+				wfCameraCover.setCoalCode(coalCode);
+				wfCameraCover.setCameraCode(ipccode);
+				wfCameraCover.setCameraName(ipcname);
+				wfCameraCover.setRtspUrl(ipcrtsppath);
+				wfCameraCover.setAnalyse(modelType);
+				wfCameraCover.setAnalyseResult(modelAnalysis);
+		}
+		if(modelCode=="5") //鎽勫儚澶寸Щ鍔ㄧ畻娉�
+		{
 			if (!camera.initConfig()) {
-				printf("鎽勫儚澶寸Щ鍔ㄧ畻娉曞垵濮嬪寲澶辫触\n");
-			}
-			else
-			{
-				std::cout << "鎽勫儚澶寸Щ鍔ㄧ畻娉曞垵濮嬪寲鎴愬姛" << std::endl;
-				camera.isLoad = true;
-				camera.stdMat = cv::imread(imagePath);
-			}
-			videoPathCameraMove = coalCode + ipccode + modelType + modelAnalysis;
-			wfCameraMove.setCoalCode(coalCode);
-			wfCameraMove.setCameraCode(ipccode);
-			wfCameraMove.setCameraName(ipcname);
-			wfCameraMove.setRtspUrl(ipcrtsppath);
-			wfCameraMove.setAnalyse(modelType);
-			wfCameraMove.setAnalyseResult(modelAnalysis);
-			break;
+					printf("鎽勫儚澶寸Щ鍔ㄧ畻娉曞垵濮嬪寲澶辫触\n");
+				}
+				else
+				{
+					std::cout << "鎽勫儚澶寸Щ鍔ㄧ畻娉曞垵濮嬪寲鎴愬姛" << std::endl;
+					camera.isLoad = true;
+					camera.stdMat = cv::imread(imagePath);
+				}
+				videoPathCameraMove = coalCode + ipccode + modelType + modelAnalysis;
+				wfCameraMove.setCoalCode(coalCode);
+				wfCameraMove.setCameraCode(ipccode);
+				wfCameraMove.setCameraName(ipcname);
+				wfCameraMove.setRtspUrl(ipcrtsppath);
+				wfCameraMove.setAnalyse(modelType);
+				wfCameraMove.setAnalyseResult(modelAnalysis);
+		}
+		if(modelCode=="6") //鍫嗙叅妫�娴嬫ā鍨�
+		{
+			if (!dm.initConfig(modelPath.c_str(), arr)) {
+					printf("鍫嗙叅妯″瀷鍒濆鍖栧け璐n");
+				}
+				else
+				{
+					std::cout << "鍫嗙叅妯″瀷鍒濆鍖栨垚鍔�" << std::endl;
+					dm.isLoad = true;
+				}
+				videoPathDM = coalCode + ipccode + modelType + modelAnalysis;
+				areaDM = detectarea;
+				limitDM = modelLimit;//鍫嗙叅闄愬畾鐓ら噺鍗犳瘮
 
-		case 6://鍫嗙叅妫�娴嬫ā鍨�		
-			if (!dm.initConfig(modelPath.c_str(), stringToIntArray(area))) {
-				printf("鍫嗙叅妯″瀷鍒濆鍖栧け璐n");
-			}
-			else
-			{
-				std::cout << "鍫嗙叅妯″瀷鍒濆鍖栨垚鍔�" << std::endl;
-				dm.isLoad = true;
-			}
-			videoPathDM = coalCode + ipccode + modelType + modelAnalysis;
-			areaDM = stringToPoints(area2);
-			limitDM = modelLimit;//鍫嗙叅闄愬畾鐓ら噺鍗犳瘮
+				wfDM.setCoalCode(coalCode);
+				wfDM.setCameraCode(ipccode);
+				wfDM.setCameraName(ipcname);
+				wfDM.setRtspUrl(ipcrtsppath);
+				wfDM.setAnalyse(modelType);
+				wfDM.setAnalyseResult(modelAnalysis);
+		}
+		if(modelCode=="7") //鐨甫璺戝亸鍜屽紓鐗╂娴�
+		{
+			int* leftarr = new int[leftarea.size() * 2];
+			int* rightarr = new int[rightarea.size() * 2];
+			int* midd_arr = new int[beltarea.size() * 2];
 
-			wfDM.setCoalCode(coalCode);
-			wfDM.setCameraCode(ipccode);
-			wfDM.setCameraName(ipcname);
-			wfDM.setRtspUrl(ipcrtsppath);
-			wfDM.setAnalyse(modelType);
-			wfDM.setAnalyseResult(modelAnalysis);
-			break;
-
-		case 7://鐨甫璺戝亸鍜屽紓鐗╂娴�	
-			if (!beltJC.initConfig(modelPath.c_str(), stringToIntArray(leftarea), stringToIntArray(rightarea), stringToIntArray(area),stof(modelLimit)))
+			if (!beltJC.initConfig(modelPath.c_str(), leftarr, rightarr, midd_arr, modelLimit))
 			{
 				printf("鐨甫璺戝亸鍜屽紓鐗╂娴嬫ā鍨嬪垵濮嬪寲澶辫触\n");
 			}
@@ -780,9 +867,9 @@
 				printf("鐨甫璺戝亸鍜屽紓鐗╂娴嬫ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
 				beltJC.isLoad = true;
 			}
-			leftareaBeltJC = stringToPoints(leftarea);
-			rightareaBeltJC = stringToPoints(rightarea);
-			areaBeltJC = stringToPoints(area);
+			leftareaBeltJC = leftarea;
+			rightareaBeltJC = rightarea;
+			areaBeltJC = beltarea;
 			videoPathBeltJC = coalCode + ipccode + modelType + modelAnalysis;
 			wfBeltJC.setCoalCode(coalCode);
 			wfBeltJC.setCameraCode(ipccode);
@@ -790,8 +877,9 @@
 			wfBeltJC.setRtspUrl(ipcrtsppath);
 			wfBeltJC.setAnalyse(modelType);
 			wfBeltJC.setAnalyseResult(modelAnalysis);
-			break;
-		case 8://鐚磋溅澶х墿浠�	
+		}
+		if(modelCode=="8") //鐚磋溅澶х墿浠�
+		{
 			if (!hatHC.initConfig(modelPath.c_str(), 0.5, 0.5))
 			{
 				printf("涔樼尨杞︽惡甯﹀ぇ浠舵ā鍨嬪垵濮嬪寲澶辫触\n");
@@ -801,7 +889,7 @@
 				printf("涔樼尨杞︽惡甯﹀ぇ浠舵ā鍨嬪垵濮嬪寲鎴愬姛銆俓n");
 				hatHC.isLoad = true;
 			}
-			areaHC = stringToPoints(area);
+			areaHC = detectarea;
 			videoPathHC = coalCode + ipccode + modelType + modelAnalysis;
 			wfHC.setCoalCode(coalCode);
 			wfHC.setCameraCode(ipccode);
@@ -809,9 +897,10 @@
 			wfHC.setRtspUrl(ipcrtsppath);
 			wfHC.setAnalyse(modelType);
 			wfHC.setAnalyseResult(modelAnalysis);
-			break;
+		}
 
-		case 9://鐫″矖鍒ゆ柇	
+		if (modelCode == "9")//鐫″矖鍒ゆ柇
+		{
 			if (!hatSleep.initConfig(modelPath.c_str(), 0.5, 0.5))
 			{
 				printf("鐫″矖妯″瀷鍒濆鍖栧け璐n");
@@ -821,7 +910,7 @@
 				printf("鐫″矖妯″瀷鍒濆鍖栨垚鍔熴�俓n");
 				hatSleep.isLoad = true;
 			}
-			areaSleep = stringToPoints(area);
+			areaSleep = detectarea;
 			videoPathSleep = coalCode + ipccode + modelType + modelAnalysis;
 			wfSleep.setCoalCode(coalCode);
 			wfSleep.setCameraCode(ipccode);
@@ -829,9 +918,9 @@
 			wfSleep.setRtspUrl(ipcrtsppath);
 			wfSleep.setAnalyse(modelType);
 			wfSleep.setAnalyseResult(modelAnalysis);
-			break;
-
-		case 11://绌挎埓妫�娴�,鍒濆鍖栦袱涓ā鍨�	
+		}
+		if (modelCode == "10")//绌挎埓妫�娴�,鍒濆鍖栦袱涓ā鍨�
+		{
 			if (!hatWear.initConfig(modelPath.c_str(), 0.5, 0.5))
 			{
 				printf("绌挎埓妯″瀷1鍒濆鍖栧け璐n");
@@ -849,7 +938,7 @@
 				}
 				hatWear.isLoad = true;
 			}
-			areaWear = stringToPoints(area);
+			areaWear = detectarea;
 			videoPathWear = coalCode + ipccode + modelType + modelAnalysis;
 			wfWear.setCoalCode(coalCode);
 			wfWear.setCameraCode(ipccode);
@@ -857,10 +946,9 @@
 			wfWear.setRtspUrl(ipcrtsppath);
 			wfWear.setAnalyse(modelType);
 			wfWear.setAnalyseResult(modelAnalysis);
-
-			break;
-		case 12://鐑熺伀妯″瀷	
-
+		}
+		if (modelCode == "11")//鐑熺伀妯″瀷
+		{
 			if (!hatFire.initConfig(modelPath.c_str())) {
 				printf("鐑熺伀妯″瀷鍒濆鍖栧け璐n");
 			}
@@ -869,7 +957,7 @@
 				printf("鐑熺伀妯″瀷鍒濆鍖栨垚鍔熴�俓n");
 				hatFire.isLoad = true;
 			}
-			areaFire = stringToPoints(area);
+			areaFire = detectarea;
 			videoPathFire = coalCode + ipccode + modelType + modelAnalysis;
 			wfFire.setCoalCode(coalCode);
 			wfFire.setCameraCode(ipccode);
@@ -877,9 +965,10 @@
 			wfFire.setRtspUrl(ipcrtsppath);
 			wfFire.setAnalyse(modelType);
 			wfFire.setAnalyseResult(modelAnalysis);
-			break;
-		default:
-			break;
+		}
+		if (modelCode == "12")//浜哄憳璺屽��
+		{
+
 		}
 	}	
 
@@ -891,7 +980,7 @@
 	Mat iMatWear;//浜哄憳绌挎埓鐨勭涓�甯�
 
 	long currentFrame = 1;//璁板綍褰撳墠甯ф暟
-	long skip_frame_num = deley;//璺冲抚闂撮殧璁剧疆
+	long skip_frame_num = skipN;//璺冲抚闂撮殧璁剧疆
 	Mat frame;
 	while (!asyncStop) 
 	{		
@@ -930,7 +1019,7 @@
 				//浜哄憳闂叆妯″瀷澶勭悊鍙婂垽鏂� modelId = 3
 				if (hatJC.isLoad)
 				{
-					futurePerson = std::async(std::launch::async, &PreProcessModel::fnImRecProByModelHAT, &ppm, std::ref(frame), std::ref(hatJC), areaPerson,workareaPerson);
+					futurePerson = std::async(std::launch::async, &PreProcessModel::fnImRecProByModelHAT1, &ppm, std::ref(frame), std::ref(hatJC), areaPerson,workareaPerson,c_list,lable_title,color_result);
 				}
 
 				//鎽勫儚澶寸Щ鍔ㄥ拰閬尅涓撶敤
@@ -1659,14 +1748,14 @@
 	Mat frame;
 
 	long currentFrame = 1;
-	long skip_frame_num = deley;//璺冲抚闂撮殧璁剧疆锛堟瘡1甯э級
+	long skip_frame_num = skipN;//璺冲抚闂撮殧璁剧疆锛堟瘡1甯э級
 
 	//鍒涘缓url杩炴帴锛屽畾鏃跺垽鏂湁娌℃湁椤甸潰杩涜鎷夋祦
 	CURL* curl;
     CURLcode res;
     std::string readBuffer;
 	curl = curl_easy_init();
-	bool pushflg = false;//鏄惁鎺ㄦ祦鏍囧織
+	bool pushflg = true;//鏄惁鎺ㄦ祦鏍囧織
  
 	if(curl)
 	{
@@ -1745,17 +1834,7 @@
 				//cv::resize(frame, frame, Size(1280, 720));
 
 				imgStr = Mat2Base64(frame, ".jpg");//杈撳嚭Base64缂栫爜鐨勫瓧绗︿覆				
-				//std::cout << "Base64 size: " << imgStr.size() << std::endl;
-
-				// // 缂栫爜涓篔PEG鏍煎紡鐨勪簩杩涘埗鏁版嵁
-				// std::vector<uchar> encoded;
-				// std::vector<int> params = {cv::IMWRITE_JPEG_QUALITY, 90};
-				// cv::imencode(".jpg", frame, encoded, params);			
-				// imgStr = std::string(reinterpret_cast<const char*>(encoded.data()), encoded.size());
-				// std::cout << "Binary size: " << imgStr.size() << std::endl;
-
-				//cout << getCurrentDateTime("%Y%m%d%H%M%S") << endl;
-							
+				//std::cout << "Base64 size: " << imgStr.size() << std::endl;	
 				objRabbitmq.Publish(imgStr, ipccode, "");
 				
 				//cv::resize(frame, frame, Size(1280, 720));		
@@ -1796,6 +1875,37 @@
 	//瀹氫箟鎺ュ彈甯�
 	Mat frame;
 
+	vector<string> arguments = {
+		"ffmpeg "
+		"-hwaccel","cuvid",
+		"-hwaccel_output_format","cuda",
+		"-y", "-an",			
+		"-f", "rawvideo",
+		"-vcodec", "rawvideo",
+		"-pix_fmt", "bgr24",
+		"-s",  "640x480",
+		"-r", "15",			
+		"-i", "-",	
+		"-pix_fmt", "yuv420p",
+		"-f", "flv",
+		"-max_delay", "1000",
+		"-flvflags", "no_duration_filesize",
+		"-c:v","h264_nvenc",
+		"-b:v", "3M",
+		"-g:v", "15",
+		"-bf", "0",
+		"-bufsize", "50000000",
+		"-rtbufsize", "50000000",	
+		"rtmp://192.168.1.8:1935/live/camera1" };
+
+	string ffmpeg_command = join(arguments, " ");
+
+	// 鎵撳紑FFmpeg杩涚▼
+	FILE* pipe = popen(ffmpeg_command.c_str(), "w");
+	if (!pipe) {
+		std::cerr << "鏃犳硶鍚姩FFmpeg" << std::endl;
+	}
+		
 	while (!asyncStop) {
 		//std::cout << ipccode + "褰撳墠绾跨▼Rabbitmq鏁版嵁鏁伴噺2222:" << queJC2.size() << std::endl;		
 		try
@@ -1814,20 +1924,92 @@
 			queJC2.pop();
 
 			if (frame.empty())//甯т负绌猴紝鍒欒垗寮�
+				continue;	
+
+			
+			// 灏嗗抚鍐欏叆鍒癋Fmpeg绠¢亾涓�
+			fwrite(frame.data, 1, frame.total() * frame.elemSize(), pipe);
+
+			//cv::resize(frame, frame, Size(1280, 720));		
+			//cv::imshow(ipccode, frame);//灞曠ず甯у浘鐗�
+			//waitKey(10);			
+
+			//std::this_thread::sleep_for(std::chrono::milliseconds(10));// 寤惰繜绛夊緟涓�娈垫椂闂�
+
+		}
+		catch (const std::exception& ex)
+		{
+			std::string errorMessage = "淇濆瓨鍒癛abbitMQ澶辫触:-";
+			errorMessage += ex.what();
+			cout << errorMessage << endl;
+			continue;
+		}		
+	}
+
+	frame.release();
+}
+
+
+
+/// @brief 鎺ㄦ祦鍒版祦濯掍綋鏈嶅姟鍣�
+/// @param queJC2 澶勭悊瀹岀殑瑙嗛娴佸抚闃熷垪
+/// @param ipccode 鎽勫儚鏈虹紪鍙�
+void PreProcessFn::fnPushVideoToUrl(queue<Mat>& queJC2,string toRtsp, string fps, string ipccode)
+{	
+	//瀹氫箟鎺ュ彈甯�
+	Mat frame;
+
+	vector<string> arguments = {
+		"ffmpeg "
+		"-hwaccel","cuvid",
+		"-hwaccel_output_format","cuda",
+		"-y", "-an",			
+		"-f", "rawvideo",
+		"-vcodec", "rawvideo",
+		"-pix_fmt", "bgr24",
+		"-s",  "1280x720",
+		"-r", fps,			
+		"-i", "-",	
+		"-pix_fmt", "yuv420p",
+		"-f", "flv",
+		"-max_delay", "1000",
+		"-flvflags", "no_duration_filesize",
+		"-c:v","h264_nvenc",
+		"-b:v", "3M",
+		"-g:v", "15",
+		"-bf", "0",
+		"-bufsize", "50000000",
+		"-rtbufsize", "50000000",	
+		toRtsp };
+
+	string ffmpeg_command = join(arguments, " ");
+
+	// 鎵撳紑FFmpeg杩涚▼
+	FILE* pipe = popen(ffmpeg_command.c_str(), "w");
+	if (!pipe) {
+		std::cerr << "鏃犳硶鍚姩FFmpeg" << std::endl;
+	}
+		
+	while (!asyncStop) {
+		//std::cout << ipccode + "褰撳墠绾跨▼Rabbitmq鏁版嵁鏁伴噺2222:" << queJC2.size() << std::endl;		
+		try
+		{
+			if (queJC2.size() > 500)
+			{
+				cout << "鎺ㄩ�佽棰戞椂锛屽瓨鍦ㄥ唴瀛樻孩鍑洪闄╋紒" << endl;
+			}
+			
+			if (queJC2.empty() || queJC2.size() == 0)
+			{
 				continue;
-
-			// FFmpeg鎺ㄦ祦鍛戒护
-			std::string ffmpeg_command = 
-				"ffmpeg -y -f rawvideo -pixel_format bgr24 -video_size 640x480 "
-        		"-framerate 30 -i - -c:v libx264 -pix_fmt yuv420p -f rtsp "
-       			"rtsp://192.168.1.188:8554/live/stream";
-
-			// 鎵撳紑FFmpeg杩涚▼
-			FILE* pipe = popen(ffmpeg_command.c_str(), "w");
-			if (!pipe) {
-				std::cerr << "鏃犳硶鍚姩FFmpeg" << std::endl;
 			}
 
+			frame = queJC2.front();
+			queJC2.pop();
+
+			if (frame.empty())//甯т负绌猴紝鍒欒垗寮�
+				continue;	
+			
 			// 灏嗗抚鍐欏叆鍒癋Fmpeg绠¢亾涓�
 			fwrite(frame.data, 1, frame.total() * frame.elemSize(), pipe);
 

--
Gitblit v1.8.0