From 927a49bc04984400cb9b968e41d299cc977e4988 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期一, 16 九月 2019 12:54:33 +0800
Subject: [PATCH] update so file

---
 csrc/wrapper.hpp |   99 ++++++++++---------------------------------------
 1 files changed, 21 insertions(+), 78 deletions(-)

diff --git a/csrc/wrapper.hpp b/csrc/wrapper.hpp
index 66f2aca..d398ed4 100644
--- a/csrc/wrapper.hpp
+++ b/csrc/wrapper.hpp
@@ -19,40 +19,16 @@
 
 namespace ffwrapper{
     class FormatIn;
-    class FormatOut;
     
     class VideoProp;
     class CodedData;
-    class FrameData;
-
-    class cvbridge;
 }
 
 namespace cffmpeg_wrap{
 
-
-    typedef struct _pic_bgr24{
-        unsigned char *data;
-        int w;
-        int h;
-
-        int64_t id;
-    }pic_bgr24;
-
-    namespace buz{
-        class Recorder;
-        struct avpacket;
-    }
-
-    // typedef std::function<std::shared_ptr<buz::Recorder>(ffwrapper::FormatIn*)> FN_REC;
-
-    typedef struct _fn_rec{
-        std::string rid;
-        std::string dir;
-        int min;
-        int max;
-        std::unique_ptr<buz::Recorder> rec;    
-    }FnRec;
+    class stream;
+    class decoder;
+    class rec;
 
     class Wrapper{
         public:
@@ -61,14 +37,10 @@
 
         private: 
             std::unique_ptr<ffwrapper::FormatIn> init_reader(const char* input);
-            // ffwrapper::FormatIn* init_reader_gb28181(const char* input);
-            void run_worker(ffwrapper::FormatIn *in, buz::avpacket &pkt);
-            std::unique_ptr<buz::Recorder> init_recorder(ffwrapper::FormatIn *in, std::string id,std::string dir, const int mind, const int maxd);
-
-            void cache_rec_info(std::string &id, int &index, std::string &path);
-            void cache_pic(std::shared_ptr<ffwrapper::FrameData> &frame, int64_t &id);
-
-            void cacheAVPacket(const AVPacket &pkt);
+            void init_stream();
+            void init_decoder(ffwrapper::FormatIn *in);
+            void init_rec(ffwrapper::FormatIn *in);
+            
         public: 
             int RunStream(const char* input);
         private: 
@@ -77,8 +49,7 @@
         public: //recorder
             void BuildRecorder(const char* id,const char *dir, const int mind, const int maxd);
             int FireRecorder(const char* sid,const int64_t &id);
-            void GetInfoRecorder(int &index, std::string &path);
-            std::string GetRecorderID(const std::string &path);
+            void GetInfoRecorder(std::string &recID, int &index, std::string &path);
 
             void ScalePicture(const int w, const int h, const int flags);
             void UseGB28181();
@@ -87,57 +58,29 @@
             void BuildDecoder();
             void GetPicDecoder(unsigned char **data, int *w, int *h, int64_t *id);
             void GetPacket(unsigned char **pktData, int *size, int *key);
-            //active api
 
         private:
-
+            // stream 鍙傛暟
             std::string input_url_;
+            int scale_w_, scale_h_, scale_f_;
+            int gb_, cpu_;
+            bool use_decoder_;
 
+            // decoder 鍙傛暟
             std::unique_ptr<std::thread> thread_;
             std::atomic_bool    stop_stream_;
 
-            ffwrapper::cvbridge *bridge_;
-
-            bool use_decoder_;
-            std::unordered_map<std::string, FnRec> map_rec_;
-
-            //passive api
-            struct record_file_info{
-                int file_frame_index;
-                std::string file_path;
-                std::string rec_id;
-            };
-            std::list<struct record_file_info>  list_rec_;
-            std::unordered_map<std::string, std::string> list_rec_map_;
-
-            std::mutex mutex_rec_;
-
-            std::list<pic_bgr24> list_pic_;
-            std::mutex mutex_pic_;
-
-            std::list<AVPacket> list_avpkt_;
-            std::mutex mutex_avpkt_;
-
-            int scale_w_, scale_h_, scale_f_;
-            int gb_, cpu_;
-
-            typedef struct recpkt{
-                std::shared_ptr<ffwrapper::CodedData> data;
-                int64_t id;
-            }recpkt;
-            std::list<recpkt> list_rec_pkt_;
-            std::mutex mtx_rec_pkt_;
-            int cache_rec_pkt(const buz::avpacket &pkt);
-            void maybe_dump_rec_pkt();
-            int     maxduration;
-            int     minduration;
-
-        //////////////////test frame to bgr24
-        public:
-            uint8_t *decodeJPEG(const char *file, int *w, int *h);
+            // 涓氬姟绫�
+            // 鎺ㄦ祦绫�
+            stream* stream_;
+            // 瑙g爜绫�
+            decoder* decoder_;
+            // 褰曞儚绫�
+            rec* rec_;
 
     };
 
+    uint8_t *DecodeJPEG(const char *file, int *w, int *h);
     void *CreateEncoder(const int w, const int h, const int fps, const int br, const int scale_flag, const int gi);
     void DestroyEncoder(void *h);
     int Encode(void *hdl, uint8_t *in, const int w, const int h, uint8_t **out, int *size, int *key);

--
Gitblit v1.8.0