From 3a5f09c61a87adb8dba2cc4a5366893886ba1c1d Mon Sep 17 00:00:00 2001 From: dupengyue <dupengyue@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 20 七月 2017 17:31:40 +0800 Subject: [PATCH] 接口初步完成 --- RtspFace/PipeLine.h | 67 +++++++++++++++++++++++++-------- 1 files changed, 51 insertions(+), 16 deletions(-) diff --git a/RtspFace/PipeLine.h b/RtspFace/PipeLine.h index 79e1984..7af5305 100644 --- a/RtspFace/PipeLine.h +++ b/RtspFace/PipeLine.h @@ -8,12 +8,18 @@ #define PLGP_RTSP_SDP "RTSP_SDP" #define PLGP_RTSP_FMTP "RTSP_FMTP" +#define PLGP_RTSP_WIDTH "RTSP_WIDTH" +#define PLGP_RTSP_HEIGHT "RTSP_HEIGHT" +#define PLGP_RTSP_FPS "RTSP_FPS" + +#define ENABLE_PIPELINE_ELEM_TIMING_DEBUGGER class PipeLineElem; class PipeLine; struct PipeMaterial; -typedef void (* pm_deleter_func)(PipeMaterial* pm); +typedef void (* pm_deleter_func)(PipeMaterial* pm, bool lastRet); +typedef bool (* pm_breaker_func)(const PipeMaterial* pm, void* args); // return true if continue breaking up // PipeMaterial instance should be unref when pay() finished struct PipeMaterial @@ -21,11 +27,12 @@ enum PipeMaterialBufferType { PMT__FIRST, - PMT_NONE, // buffer = nullptr, buffSize = 0 - PMT_BYTES, // buffer = uint8_t[N], buffSize = N - PMT_FRAME, // buffer = MB_Frame*, buffSize = 0 - PMT_PM_LIST, // buffer = PipeMaterial*[N], buffSize = N - PMT_FRAME_LIST, // buffer = MB_Frame*[N], buffSize = N + PMT_NONE, // buffer = nullptr, buffSize = 0 + PMT_BYTES, // buffer = uint8_t[N], buffSize = N + PMT_PTR, // buffer = void*, buffSize = 0 + PMT_FRAME, // buffer = MB_Frame*, buffSize = 0 + PMT_PM_LIST, // buffer = PipeMaterial*[N], buffSize = N + PMT_FRAME_LIST, // buffer = MB_Frame*[N], buffSize = N PMT__LAST }; @@ -38,7 +45,19 @@ PipeMaterial(); - void exec_deleter(); + void exec_deleter(bool lastRet); + + void reset() + { + PipeMaterial _temp; + *this = _temp; + } + + int breake(PipeMaterialBufferType selectPmType, int _selectMbfType, + pm_breaker_func breaker, void* args = nullptr) const; + + //#todo assemble pm/mbf into this pm + void assemble(); }; class PipeLineElem @@ -59,6 +78,7 @@ }; typedef PipeLineElem* (*elem_create_func_t)(); +typedef void (*elem_destory_func_t)(PipeLineElem* elem); // 0 (there is no elem). do nothing // 1 (there is one elem). gain --> pm.deleter @@ -76,30 +96,45 @@ ~PipeLine(); bool register_elem_creator(const std::string& type, elem_create_func_t func); + static bool register_global_elem_creator(const std::string& type, elem_create_func_t func); + void push_elem(PipeLineElem* elem); PipeLineElem* push_elem(const std::string& type); + void push_front_elem(PipeLineElem* elem); + bool remove_elem(PipeLineElem* elem); + PipeLineElem* at(int idx); + + void finit(elem_destory_func_t elem_destory_func); + + bool check_pipe_complete(PipeLineElem* lastRetElem) const; // do pipe sync. returns the element who returns false, or the last one. // if false return, the element should deal with pm, clean up. PipeLineElem* pipe(PipeMaterial* pm = nullptr); - // do pipe async - void pipe_start(); - void pipe_notify(PipeLineElem*); - void pipe_stop(); - - void set_global_param(const std::string& name, const std::string& value); - std::string get_global_param(const std::string& name) const; + void set_param(const std::string& name, const std::string& value); + std::string get_param(const std::string& name) const; private: typedef std::map<const std::string, elem_create_func_t> elem_create_func_map_t; elem_create_func_map_t elem_create_func_map; + static elem_create_func_map_t global_elem_create_func_map; typedef std::vector<PipeLineElem*> elem_vec_t; elem_vec_t elems; - typedef std::map<const std::string, std::string> global_params_map_t; - global_params_map_t global_params_map; + typedef std::map<const std::string, std::string> params_map_t; + params_map_t params_map; +}; + +class PipeLineElemTimingDebugger +{ +public: + PipeLineElemTimingDebugger(const PipeLineElem* _elem); + ~PipeLineElemTimingDebugger(); + + const PipeLineElem* elem; + uint64_t beginTime; }; #endif -- Gitblit v1.8.0