From 6151028a8e0e63ed6967faa7c23ff56b076879df Mon Sep 17 00:00:00 2001
From: chenshijun <csj_sky@126.com>
Date: 星期五, 05 四月 2019 11:22:03 +0800
Subject: [PATCH] 解决GB28181推多路流问题

---
 QiaoJiaSystem/GB28181DecoderModel/VideoCaptureElementWithRtp.cpp |   38 ++++++++++++++++++++++++++++----------
 1 files changed, 28 insertions(+), 10 deletions(-)

diff --git a/QiaoJiaSystem/GB28181DecoderModel/VideoCaptureElementWithRtp.cpp b/QiaoJiaSystem/GB28181DecoderModel/VideoCaptureElementWithRtp.cpp
index 2f7010f..46e8089 100644
--- a/QiaoJiaSystem/GB28181DecoderModel/VideoCaptureElementWithRtp.cpp
+++ b/QiaoJiaSystem/GB28181DecoderModel/VideoCaptureElementWithRtp.cpp
@@ -48,28 +48,45 @@
                 DBG("waitSignal(\"DecoderImageOK\") begin");
 #endif
                 //绛夊緟淇″彿瑙﹀彂
+//                DBG("waitSignal before: " << p_this->m_chanPubID);
                 gSignalLock.waitSignal(p_this->m_chanPubID + "DecoderImageOK");
+//                DBG("waitSignal: " << p_this->m_chanPubID);
 #ifdef TestCode
                 DBG("waitSignal(\"DecoderImageOK\") after");
 #endif
-                /****褰曞儚妯″潡浠g爜*****/
-                p_this->m_picCount++;
-                //鍑犲紶閫変竴寮犳斁鍏edis
-                if (p_this->m_picCount % m_nPicsPickOne != 0) {
-                    continue;
-                } else {
-                    p_this->m_picCount.store(0);
-                }
+
 
 //            浠巉fmpeg瑙g爜绫讳腑鑾峰彇鍥剧墖
                 p_this->m_fFmpegDecoderJPG.getImage().copyTo(p_this->m_image);
+                /****debug*****///todo
+                if(p_this->m_image.empty()) {
+                    ERR("camID:" << p_this->m_chanPubID);
+                    continue;
+                }
+//                else {
+//                    static int count =0;
+//                    count ++;
+//                    if(count > 100){
+//                        ERR("camID:" << p_this->m_chanPubID << " cols:" << p_this->m_image.cols <<\
+//        " rows:" << p_this->m_image.rows << " channels:" << p_this->m_image.channels());
+//                        count = 0;
+//                    }
+//                }
+
                 {
+                    /****褰曞儚妯″潡浠g爜*****/
+                    p_this->m_picCount++;
+                    //鍑犲紶閫変竴寮犳斁鍏edis
+                    if (p_this->m_picCount % m_nPicsPickOne != 0) {
+                        continue;
+                    } else {
+                        p_this->m_picCount.store(0);
+                    }
                     cv::Mat copyMat;
                     std::string imageName = p_this->m_fFmpegDecoderJPG.GetImageName();
                     p_this->m_image.copyTo(copyMat);
-                    m_pManager->SaveImageToRedis(p_this->m_chanPubID, imageName, copyMat);
+                    p_this->m_pManager->SaveImageToRedis(p_this->m_chanPubID, imageName, copyMat);
                 }
-                /*********/
 
                 p_this->submit();
             }
@@ -128,6 +145,7 @@
                             p_this->m_running = false;
                             stop();
                             INFO("grabFrame faild, element stopping");
+                            break;
                         } else {
                             //todo 涓氬姟姝婚攣
                             usleep((6 - reopenTime--) * 1000000);

--
Gitblit v1.8.0