| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  | //
 | 
					
						
							|  |  |  |  | // Created by nvidia on 24-10-14.
 | 
					
						
							|  |  |  |  | //
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "SaveDebugImageEngine.h"
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | using namespace ai_matrix; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | SaveDebugImageEngine::SaveDebugImageEngine() {} | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | SaveDebugImageEngine::~SaveDebugImageEngine() {} | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | APP_ERROR SaveDebugImageEngine::Init() | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     strPort0_ = engineName_ + "_" + std::to_string(engineId_) + "_0"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     this->baseConfig_ = Config::getins()->getBaseConfig(); | 
					
						
							|  |  |  |  |     vecCompressionParams_.push_back(cv::IMWRITE_JPEG_QUALITY);  //选择jpeg
 | 
					
						
							|  |  |  |  |     vecCompressionParams_.push_back(this->iPicQuality_);        //图片质量
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     LogInfo << "SaveDebugImageEngine Init ok"; | 
					
						
							|  |  |  |  |     return APP_ERR_OK; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | APP_ERROR SaveDebugImageEngine::DeInit() | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     LogInfo << "SaveDebugImageEngine DeInit ok"; | 
					
						
							|  |  |  |  |     return APP_ERR_OK; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | APP_ERROR SaveDebugImageEngine::Process() | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |     int iRet = APP_ERR_OK; | 
					
						
							|  |  |  |  |     while (!isStop_) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |         std::shared_ptr<void> pvoidd = nullptr; | 
					
						
							|  |  |  |  |         inputQueMap_[strPort0_]->pop(pvoidd); | 
					
						
							|  |  |  |  |         if (nullptr == pvoidd) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             usleep(1000); | 
					
						
							|  |  |  |  |             continue; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         if (!this->baseConfig_.bTestModel) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             usleep(1000); | 
					
						
							|  |  |  |  |             continue; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 02:36:49 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         std::shared_ptr<VStep2OutputData> pVStep2OutputData = std::static_pointer_cast<VStep2OutputData>(pvoidd); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-26 06:40:12 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         std::string strDataDir = this->baseConfig_.strDebugResultPath + "/" | 
					
						
							|  |  |  |  |                                  + pVStep2OutputData->strDetectDate + "/" | 
					
						
							|  |  |  |  |                                  + StringUtil::getins()->replace_all_distinct(pVStep2OutputData->strDetectTime, ":", "-") | 
					
						
							|  |  |  |  |                                  + "/"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         std::string strJsonPath = strDataDir | 
					
						
							|  |  |  |  |                 + std::to_string(pVStep2OutputData->iFrameId) | 
					
						
							|  |  |  |  |                 + "_" | 
					
						
							|  |  |  |  |                 + std::to_string(pVStep2OutputData->iDataSource) + ".json"; | 
					
						
							|  |  |  |  |         std::string strImagePath = strDataDir | 
					
						
							|  |  |  |  |                 + std::to_string(pVStep2OutputData->iFrameId) | 
					
						
							|  |  |  |  |                 + "_" | 
					
						
							|  |  |  |  |                 + std::to_string(pVStep2OutputData->iDataSource) + ".jpg"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         Json::Value jvFrameInfo; | 
					
						
							|  |  |  |  |         if (!FileUtil::getins()->readJsonInfo(jvFrameInfo, strJsonPath)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             continue; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         cv::Mat image = cv::imread(strImagePath); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |         if (image.empty()) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             LogWarn << "图像未找到:" << strImagePath; | 
					
						
							|  |  |  |  |             continue; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         std::stringstream ss; | 
					
						
							|  |  |  |  |         std::vector<std::string> vecTitle; | 
					
						
							|  |  |  |  |         vecTitle.emplace_back("FrameID:" + to_string(pVStep2OutputData->iFrameId)); | 
					
						
							|  |  |  |  |         vecTitle.emplace_back("TimeStamp:" + jvFrameInfo["timeStamp"].asString()); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         int base_line = 0; | 
					
						
							|  |  |  |  |         cv::Point text_org(15, 45); // 文本起始点
 | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |         for (const auto & i : vecTitle) | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |             cv::Size text_size = cv::getTextSize(i, cv::FONT_HERSHEY_SIMPLEX, 1, 2, 0); | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |             cv::Point baseline_loc(text_org); | 
					
						
							|  |  |  |  |             baseline_loc.y += base_line + text_size.height; | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |             cv::putText(image, i, baseline_loc, cv::FONT_HERSHEY_SIMPLEX, 1, cv::Scalar(0, 255, 0, 255), 2); | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |             // 手动调整x位置,为下一个单词留出空间
 | 
					
						
							|  |  |  |  |             text_org.x += text_size.width + 10; | 
					
						
							|  |  |  |  |             text_org.x = text_org.x > IMAGE_WIDTH ? 15 : text_org.x; | 
					
						
							|  |  |  |  |             base_line++; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         cv::Scalar cvScalar = {0, 255, 0, 255}; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         float centerX = pVStep2OutputData->step2ResultData.fLTX + (pVStep2OutputData->step2ResultData.fRBX - pVStep2OutputData->step2ResultData.fLTX)/2; | 
					
						
							|  |  |  |  |         float centerY = pVStep2OutputData->step2ResultData.fLTY + (pVStep2OutputData->step2ResultData.fRBY - pVStep2OutputData->step2ResultData.fLTY)/2; | 
					
						
							| 
									
										
										
										
											2024-11-26 06:40:12 +00:00
										 |  |  |  | //        auto start = std::chrono::system_clock::now();  //计时开始
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         cv::rectangle(image, | 
					
						
							|  |  |  |  |                       cv::Point(pVStep2OutputData->step2ResultData.fLTX, pVStep2OutputData->step2ResultData.fLTY), | 
					
						
							|  |  |  |  |                       cv::Point(pVStep2OutputData->step2ResultData.fRBX, pVStep2OutputData->step2ResultData.fRBY), | 
					
						
							|  |  |  |  |                       cvScalar, 2); | 
					
						
							|  |  |  |  |         cv::line(image, | 
					
						
							|  |  |  |  |                  cv::Point(centerX, pVStep2OutputData->step2ResultData.fLTY-30), cv::Point(centerX, pVStep2OutputData->step2ResultData.fRBY+30), | 
					
						
							|  |  |  |  |                  cvScalar, 1); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |         cv::Size text_size = cv::getTextSize(pVStep2OutputData->step2ResultData.transInfo.strTmpResult, cv::FONT_HERSHEY_SIMPLEX, 1, 2, 0); | 
					
						
							|  |  |  |  |         cv::Point linePoint(pVStep2OutputData->step2ResultData.fLTX, pVStep2OutputData->step2ResultData.fRBY + text_size.height + 5); | 
					
						
							| 
									
										
										
										
											2024-11-25 02:36:49 +00:00
										 |  |  |  |         cv::putText(image, | 
					
						
							|  |  |  |  |                     pVStep2OutputData->step2ResultData.transInfo.strTmpResult, | 
					
						
							|  |  |  |  |                     linePoint, | 
					
						
							|  |  |  |  |                     cv::FONT_HERSHEY_SIMPLEX, 1, cv::Scalar(0, 255, 0, 180), 2); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-26 06:40:12 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  |         for (const auto &step2ResultData : pVStep2OutputData->vecCornerResultData) | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |         { | 
					
						
							| 
									
										
										
										
											2024-11-25 02:36:49 +00:00
										 |  |  |  |             cvScalar = {0, 255, 255, 255}; | 
					
						
							|  |  |  |  |             float centerX_corner = step2ResultData.fLTX + (step2ResultData.fRBX - step2ResultData.fLTX)/2; | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |             cv::rectangle(image, | 
					
						
							|  |  |  |  |                           cv::Point(step2ResultData.fLTX, step2ResultData.fLTY), | 
					
						
							|  |  |  |  |                           cv::Point(step2ResultData.fRBX, step2ResultData.fRBY), | 
					
						
							|  |  |  |  |                           cvScalar, 2); | 
					
						
							|  |  |  |  |             cv::line(image, | 
					
						
							| 
									
										
										
										
											2024-11-25 02:36:49 +00:00
										 |  |  |  |                      cv::Point(centerX_corner, step2ResultData.fLTY-30), cv::Point(centerX_corner, step2ResultData.fRBY+30), | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |                      cvScalar, 1); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-26 06:40:12 +00:00
										 |  |  |  | //        auto end = std::chrono::system_clock::now();
 | 
					
						
							|  |  |  |  | //        LogDebug << "图片存储用时: " << std::chrono::duration_cast<std::chrono::milliseconds>(end - start).count() << "ms  " << strImagePath;
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         if (!cv::imwrite(strImagePath, image, this->vecCompressionParams_)) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |             LogError << "图片存储失败:" << strImagePath; | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-25 11:01:44 +00:00
										 |  |  |  | //        else
 | 
					
						
							|  |  |  |  | //        {
 | 
					
						
							|  |  |  |  | //            LogInfo << "图片存储成功:" << strImagePath;
 | 
					
						
							|  |  |  |  | //        }
 | 
					
						
							| 
									
										
										
										
											2024-11-26 06:40:12 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-24 00:58:06 +00:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |     return APP_ERR_OK; | 
					
						
							|  |  |  |  | } |