From afcb649c8a2785c6095be5762c6077f9e15afd1a Mon Sep 17 00:00:00 2001
From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期三, 02 八月 2017 10:33:31 +0800
Subject: [PATCH] c++ dupl image

---
 VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.h |   56 +++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 39 insertions(+), 17 deletions(-)

diff --git a/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.h b/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.h
index 649caf5..7628226 100644
--- a/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.h
+++ b/VisitFace/RtspNativeCodec/app/src/main/cpp/CameraWrapper.h
@@ -10,8 +10,9 @@
 #include <PL_RTSPClient.h>
 #include <PL_AndroidMediaCodecDecoder.h>
 #include <PL_AndroidSurfaceViewRender.h>
-#include <PL_SensetimeFaceTrack.h>
-
+#include <PL_SensetimeFaceTrackMultiTrd.h>
+#include <PL_Paint.h>
+#include <PL_Scale.h>
 //#include "looper.h"
 #include <android/native_window_jni.h>
 #include <media/NdkMediaCodec.h>
@@ -22,32 +23,47 @@
 class CameraWrapper
 {
 public:
-	PipeLine* pipeLine;
-	
+	PipeLine* pipeLineDecoderDetector;
+	PipeLine* pipeLineAnalyzer;
+	PipeLine* pipeLineRender;
+
 	PL_RTSPClient_Config rtspConfig;
-    PL_AndroidMediaCodecDecoder_Config amcdConfig;
-    PL_AndroidSurfaceViewRender_Config asvrConfig;
-    SensetimeFaceTrackConfig sftConfig;
+	PL_AndroidMediaCodecDecoder_Config amcdConfig;
+	PL_AndroidSurfaceViewRender_Config asvrConfig;
+	SensetimeFaceTrackConfig sftConfig;
+	PL_Scale_Config plScaleCfg;
 
 	int cameraIdx;
-    JavaVM* javaVM;
-    JNIEnv* javaEnv;
+	JavaVM* javaVM;
+	JNIEnv* javaEnv;
 	jclass faceCallbackClazz;
 	jmethodID faceCallbackFunc;
 	void* windowRender;
 	void* windowDecode;
 
+	pthread_t decoder_thid;
 	pthread_t live_daemon_thid;
+	pthread_mutex_t live_daemon_mut;
 	bool running;
-	
+	volatile bool killed;
+	time_t lastAliveTime;
+
 	bool faceCacheLocked;
-	FaceCache faceCache;
+	//FaceCache faceCache;
+	FaceCacheForPLBG faceCache;
+
+	PLPLContext plplContext;
+
+	std::map<int, std::wstring> faceLabels;
+
+	std::string fontPath;
 
 	CameraWrapper() : 
-		pipeLine(nullptr), rtspConfig(), amcdConfig(), sftConfig(), asvrConfig(),
-        cameraIdx(0), javaVM(nullptr), javaEnv(nullptr), faceCallbackClazz(0), faceCallbackFunc(0), windowRender(nullptr), windowDecode(nullptr),
-		live_daemon_thid(0), running(false),
-		faceCacheLocked(false), faceCache()
+		pipeLineDecoderDetector(nullptr), pipeLineAnalyzer(nullptr), pipeLineRender(nullptr), rtspConfig(), amcdConfig(), asvrConfig(), sftConfig(),
+		cameraIdx(0), javaVM(nullptr), javaEnv(nullptr), faceCallbackClazz(0), faceCallbackFunc(0), windowRender(nullptr), windowDecode(nullptr),
+		decoder_thid(0), live_daemon_thid(0), live_daemon_mut(), running(false), killed(false), lastAliveTime(0),
+		faceCacheLocked(false), faceCache(),
+		plplContext(), faceLabels(), fontPath()
 	{
 	}
 	
@@ -56,12 +72,18 @@
 	bool start();
 	void stop();
 	bool initPl();
-	
+
 	void lockFace();
 	void releaseFace();
 
+	void setFaceLabel(int st_track_id, const std::wstring& label);
+
 private:
-	static void* live_daemon_thd(void* arg);
+	static void* decoder_thd(void *arg);
+	static void* live_daemon_thd(void *arg);
+
+	bool resetPl();
+	bool initPl_DecoderPl();
 };
 
 #endif

--
Gitblit v1.8.0