From 217b286ad5eb04084ab82e870d90a5d1809b3a28 Mon Sep 17 00:00:00 2001
From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期三, 02 八月 2017 11:17:46 +0800
Subject: [PATCH] split client server

---
 VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapperClient.cpp |  126 ++++++++++++++++++++++++++---------------
 1 files changed, 80 insertions(+), 46 deletions(-)

diff --git a/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.cpp b/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapperClient.cpp
similarity index 80%
copy from VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.cpp
copy to VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapperClient.cpp
index 030841c..c5bb607 100644
--- a/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.cpp
+++ b/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapperClient.cpp
@@ -1,4 +1,4 @@
-#include "CameraWrapper.h"
+#include "CameraWrapperClient.h"
 #include <logger.h>
 #include <Logger/src/logger.hpp>
 #include <MaterialBuffer.h>
@@ -8,10 +8,11 @@
 #include <PL_V4L2Source.h>
 #include <PL_BlockGrouping.h>
 #include <PL_ColorConv.h>
+#include <PL_AndroidMediaCodecEncoder.h>
 
 CameraWrapper::~CameraWrapper()
 {
-	stop();
+    stop();
     delete pipeLineRender;
     delete pipeLineAnalyzer;
     delete pipeLineDecoderDetector;
@@ -19,18 +20,27 @@
 
 bool CameraWrapper::start()
 {
-	LOG_INFO << "CameraWrapper::start" << LOG_ENDL;
+    LOG_INFO << "CameraWrapper::start" << LOG_ENDL;
 
     pthread_mutex_init(&live_daemon_mut, NULL);
 
     running = true;
-	int ret = pthread_create(&decoder_thid, NULL, CameraWrapper::decoder_thd, this);
-	if(ret != 0)
-	{
-		LOGP(ERROR, "pthread_create decoder_thid: %s/n", strerror(ret));
-		running = false;
-		return false;
-	}
+    int ret = pthread_create(&decoder_thid, NULL, CameraWrapper::decoder_thd, this);
+    if(ret != 0)
+    {
+        LOGP(ERROR, "pthread_create decoder_thid: %s/n", strerror(ret));
+        running = false;
+        return false;
+    }
+
+    //struct sched_param param;
+    //int policy = -1;
+    //int rc = pthread_getschedparam(decoder_thid, &policy, &param);
+    //LOGP(INFO, "pthread_getschedparam, rc=%d, policy=%d, priority=%d", rc, policy, param.__sched_priority);
+    //policy = SCHED_RR;
+    //param.__sched_priority = 1;
+    //rc = pthread_setschedparam(decoder_thid, policy, &param);
+    //LOGP(INFO, "pthread_getschedparam, rc=%d, policy=%d, priority=%d", rc, policy, param.__sched_priority);
 
     ret = pthread_create(&live_daemon_thid, NULL, CameraWrapper::live_daemon_thd, this);
     if(ret != 0)
@@ -40,17 +50,17 @@
         return false;
     }
 
-	return true;
+    return true;
 }
 
 void CameraWrapper::stop()
 {
-	LOG_INFO << "CameraWrapper::stop" << LOG_ENDL;
-	
-	if (!running)
-		return;
+    LOG_INFO << "CameraWrapper::stop" << LOG_ENDL;
 
-	running = false;
+    if (!running)
+        return;
+
+    running = false;
     pthread_join(decoder_thid, NULL);
     pthread_join(live_daemon_thid, NULL);
 
@@ -68,6 +78,9 @@
 
     for (st_ff_vect_t::const_iterator iter = faceFeatures.begin(); iter != faceFeatures.end(); ++iter)
     {
+        if (!iter->test_face_in_cone(35.0f, 35.0f, 35.0f))
+            continue;
+
         RectWrapper rw;
         rw.rect = iter->rect;
         rw.user_score_1 = ((90.0f - std::abs(iter->yaw)) + (90.0f - std::abs(iter->pitch)) + (90.0f - std::abs(iter->roll))) / 90.0f / 3 * iter->score;
@@ -89,6 +102,7 @@
     PipeLine::register_global_elem_creator("PL_Paint", create_PL_Paint);
     PipeLine::register_global_elem_creator("PL_V4L2Source", create_PL_V4L2Source);
     PipeLine::register_global_elem_creator("PL_BlockGrouping", create_PL_BlockGrouping);
+    //PipeLine::register_global_elem_creator("PL_AndroidMediaCodecEncoder", create_PL_AndroidMediaCodecEncoder);
 
     bool ret = initPl_DecoderPl();
     if (!ret)
@@ -127,25 +141,43 @@
             return  false;
         }
 
-		PL_Scale* plScale = (PL_Scale*)pipeLineRender->push_elem("PL_Scale");
-		ret = plScale->init(&plScaleCfg);
-		if (!ret)
-		{
-		    LOG_ERROR << "pipeLineRender.plScale init error" << LOG_ENDL;
-		    return  false;
-		}
+        PL_Scale* plScale = (PL_Scale*)pipeLineRender->push_elem("PL_Scale");
+        plScaleCfg.toWidth = 640;
+        plScaleCfg.toHeight = 480;
+        ret = plScale->init(&plScaleCfg);
+        if (!ret)
+        {
+            LOG_ERROR << "pipeLineRender.plScale init error" << LOG_ENDL;
+            return  false;
+        }
 
-		PL_ColorConv_Config PLColorConvCfg;
-		PL_ColorConv* plColorConv = (PL_ColorConv*)pipeLineRender->push_elem("PL_ColorConv");
-		ret = plColorConv->init(&PLColorConvCfg);
-		if (!ret)
-		{
-		    LOG_ERROR << "pipeLineRender.plPaint init error" << LOG_ENDL;
-		    return  false;
-		}
+        //PL_AndroidMediaCodecEncoder_Config amceCfg;
+        //amceCfg.ak_bit_rate = 5000000; // 512KB
+        //amceCfg.ak_color_format = 21; // COLOR_FormatYUV420SemiPlanar;
+        //amceCfg.ak_frame_rate = 25;
+        //amceCfg.ak_height = 480;
+        //amceCfg.ak_i_frame_interval = 20;
+        //amceCfg.ak_mime = "video/avc";
+        //amceCfg.ak_width = 640;
+        //PL_AndroidMediaCodecEncoder* plAMCE = (PL_AndroidMediaCodecEncoder*)pipeLineRender->push_elem("PL_AndroidMediaCodecEncoder");
+        //ret = plAMCE->init(&amceCfg);
+        //if (!ret)
+        //{
+        //    LOG_ERROR << "pipeLineRender.plAMCE init error" << LOG_ENDL;
+        //    return  false;
+        //}
+
+        PL_ColorConv_Config PLColorConvCfg;
+        PL_ColorConv* plColorConv = (PL_ColorConv*)pipeLineRender->push_elem("PL_ColorConv");
+        ret = plColorConv->init(&PLColorConvCfg);
+        if (!ret)
+        {
+            LOG_ERROR << "pipeLineRender.plPaint init error" << LOG_ENDL;
+            return  false;
+        }
 
         PL_Paint_Config plPaintCfg;
-		plPaintCfg.fontPath = fontPath;
+        plPaintCfg.fontPath = fontPath;
         plPaintCfg.plplCtx = &plplContext;
         PL_Paint* plPaint = (PL_Paint*)pipeLineRender->push_elem("PL_Paint");
         ret = plPaint->init(&plPaintCfg);
@@ -164,7 +196,7 @@
         }
     }
 
-	return true;
+    return true;
 }
 
 bool CameraWrapper::initPl_DecoderPl()
@@ -280,7 +312,7 @@
     {
         plplContext.cmds.push_back(PLPLC_COLOR);
         plplContext.params.push_back('F');
-        if (iter->test_face_in_cone(30.0f, 30.0f, 30.0f))
+        if (iter->test_face_in_cone(35.0f, 35.0f, 35.0f))
         {
             if (iter->outOfFrame)
             {
@@ -388,11 +420,11 @@
 
 /*static*/ void* CameraWrapper::decoder_thd(void* arg)
 {
-	LOG_INFO << "CameraWrapper::decoder_thd start" << LOG_ENDL;
-	CameraWrapper& cameraWrapper = *(CameraWrapper*)arg;
+    LOG_INFO << "CameraWrapper::decoder_thd start" << LOG_ENDL;
+    CameraWrapper& cameraWrapper = *(CameraWrapper*)arg;
 
-	while(cameraWrapper.running)
-	{
+    while(cameraWrapper.running)
+    {
         if (cameraWrapper.killed)
         {
             LOG_WARN << "CameraWrapper::killed" << LOG_ENDL;
@@ -401,12 +433,12 @@
             sleep(2);
         }
 
-		PipeLineElem* last = cameraWrapper.pipeLineDecoderDetector->pipe();
-		bool ret = cameraWrapper.pipeLineDecoderDetector->check_pipe_complete(last);
-		//LOG_DEBUG << "pipe ret=" << ret << LOG_ENDL;
+        PipeLineElem* last = cameraWrapper.pipeLineDecoderDetector->pipe();
+        bool ret = cameraWrapper.pipeLineDecoderDetector->check_pipe_complete(last);
+        //LOG_DEBUG << "pipe ret=" << ret << LOG_ENDL;
 
-		if (!ret)
-			continue;
+        if (!ret)
+            continue;
 
         PipeMaterial pm;
         ret = last->gain(pm);
@@ -429,10 +461,12 @@
         //#debug
         //test_paint(cameraWrapper);
 
-        cameraWrapper.pipeLineRender->pipe(&pm);
+        cameraWrapper.pipeLineRender->pipe(&pm);//#todo
+        //if (cameraWrapper.pipeLineRender->check_pipe_complete(last = cameraWrapper.pipeLineRender->pipe(&pm)))
+        //    last->gain(pm);
     }
-	
-	LOG_INFO << "CameraWrapper::decoder_thd stop, ret=" << LOG_ENDL;
+
+    LOG_INFO << "CameraWrapper::decoder_thd stop, ret=" << LOG_ENDL;
 }
 
 /*static*/ void* CameraWrapper::live_daemon_thd(void* arg)

--
Gitblit v1.8.0