From 4eab3ca9bf020df2bb53fa2a36aa4f57d684225c Mon Sep 17 00:00:00 2001 From: zhangmeng <775834166@qq.com> Date: 星期三, 07 八月 2019 17:25:03 +0800 Subject: [PATCH] add rec notify, try catch --- csrc/wrapper.hpp | 34 +++++++++++++++++++++------------- 1 files changed, 21 insertions(+), 13 deletions(-) diff --git a/csrc/wrapper.hpp b/csrc/wrapper.hpp index 8c866fd..b11c9ca 100644 --- a/csrc/wrapper.hpp +++ b/csrc/wrapper.hpp @@ -35,6 +35,8 @@ unsigned char *data; int w; int h; + + int64_t id; }pic_bgr24; namespace buz{ @@ -61,7 +63,7 @@ std::shared_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); + void cache_pic(std::shared_ptr<ffwrapper::FrameData> &frame, int64_t &id); void cacheAVPacket(const AVPacket &pkt); public: @@ -72,21 +74,17 @@ 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(std::string &sid, int &index, std::string &path); - - // active api - void ActiveRecorder(const char *dir, const int mind, const int maxd, - FUNC_REC func); + void GetInfoRecorder(int &index, std::string &path); + std::string GetRecorderID(const std::string &path); void ScalePicture(const int w, const int h, const int flags); void UseGB28181(); void UseCPU(); public: //decoder void BuildDecoder(); - void GetPicDecoder(unsigned char **data, int *w, int *h); + void GetPicDecoder(unsigned char **data, int *w, int *h, int64_t *id); void GetPacket(unsigned char **pktData, int *size, int *key); //active api - void ActiveDecoder(FUNC_DEC fn); private: @@ -102,11 +100,13 @@ //passive api struct record_file_info{ - std::string id; 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_; @@ -115,12 +115,20 @@ std::list<AVPacket> list_avpkt_; std::mutex mutex_avpkt_; - // active api - FUNC_REC func_rec_; - FUNC_DEC func_dec_; - 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); -- Gitblit v1.8.0