From 18a05d269516a5e33d8460291c2f93e73d95adce Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期二, 26 十二月 2023 10:45:31 +0800
Subject: [PATCH] GetYUV format is NV12

---
 csrc/wrapper.hpp |   46 +++++++++++++++++++++++++++++-----------------
 1 files changed, 29 insertions(+), 17 deletions(-)

diff --git a/csrc/wrapper.hpp b/csrc/wrapper.hpp
index 3e68b46..42f0c91 100644
--- a/csrc/wrapper.hpp
+++ b/csrc/wrapper.hpp
@@ -11,7 +11,7 @@
 #include <memory>
 #include "common/callback.hpp"
 
-
+class CPacket;
 
 namespace ffwrapper{
     class FormatIn;
@@ -34,7 +34,7 @@
         std::unique_ptr<ffwrapper::FormatIn> init_reader(const char* input);
 
         void init_worker(ffwrapper::FormatIn *in);
-        int run_worker(ffwrapper::FormatIn *in, std::shared_ptr<ffwrapper::CodedData> data, int64_t &id);
+        int run_worker(ffwrapper::FormatIn *in, const CPacket &pkt);
         void deinit_worker();
     public: 
         int RunStream(const char* input);
@@ -43,24 +43,37 @@
     public: //recorder
         void BuildRecorder(const char* id, const char *dir, const int64_t &fid, const int mind, const int maxd, const bool audio);
         int FireRecorder(const char* sid,const int64_t &id);
-        void GetInfoRecorder(std::string &recID, int &index, std::string &path);
+        int GetInfoRecorder(std::string &recID, int &index, std::string &path);
     
     public:
-        void GB28181(){gb_ = 1;}
+        void gb28181(){gb_ = 1;}
         void CPUDec(){cpu_ = 1;}
         void AudioSwitch(const bool a);
-        void SetRecMinCacheTime(const int mind);
+        void SetRecMinCacheTime(const int mind, const int maxd);
+
+        int GetFPS(){return fps_;}
     public: //decoder
-        void BuildDecoder();
-        void GetPicDecoder(unsigned char **data, int *w, int *h, int *format, int *length, int64_t *id);
+        void OpenDecoder();
+        int GetPicDecoder(unsigned char **data, int *w, int *h, int *format, int *length, int64_t *id);
     public: // push stream
-        void GetPacket(unsigned char **pktData, int *size, int *key);
+        void CloseStream();
+        int GetPacket(unsigned char **pktData, int *size, int *key);
+    public: // recorder
+        void OpenRecorder();
+
+    public:
+        // set device id
+        int SetDevID(const int devid){ devid_ = devid; return 0;}
+
     private:
         // stream 鍙傛暟
         std::string input_url_;
         bool audio_;
-        int gb_, cpu_;
+        int gb_, cpu_, devid_;
         bool run_dec_;
+        bool run_stream_;
+        bool run_rec_;
+        bool work_start;
         // decoder 鍙傛暟
         std::unique_ptr<std::thread> thread_;
         std::atomic_bool    stop_stream_;
@@ -74,18 +87,17 @@
         // 褰曞儚璇锋眰缂撳瓨,绛夊緟runstream鍚庢坊鍔�
         std::function<void()> fn_rec_lazy_;
         bool logit_;
+        int fps_;
+        // 涓哄吋瀹规枃浠惰В鐮佸仛鐨勮ˉ涓�
+        bool file_finished_;
+        int min_duration_;
     };
 
-    uint8_t* Decode(const char *file, const int gb, 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 *CreateEncoder(const int w, const int h, const int fps, const int br, 
+                        const int pix_fmt, 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);
-
-    void *CreateConvertor(const int srcW, const int srcH, const int srcFormat,
-                          const int dstW, const int dstH, const int dstFormat, const int flag);
-    uint8_t *Convert(void *h, uint8_t *src);
-    void DestoryConvertor(void *h);
+    int GetGb28181Pic(const char *filename, char *retData, int *retDataLen, const int tt);
 }
 
 #endif
\ No newline at end of file

--
Gitblit v1.8.0