From 6f9d46539bce25828e3229db6cd9c0dbae1f3e11 Mon Sep 17 00:00:00 2001 From: zhangmeng <775834166@qq.com> Date: 星期日, 19 一月 2020 11:43:34 +0800 Subject: [PATCH] update ffmpeg --- csrc/cffmpeg.cpp | 50 +++++++++++++++++++++++++++++--------------------- 1 files changed, 29 insertions(+), 21 deletions(-) diff --git a/csrc/cffmpeg.cpp b/csrc/cffmpeg.cpp index 6e54de4..fc92229 100644 --- a/csrc/cffmpeg.cpp +++ b/csrc/cffmpeg.cpp @@ -33,9 +33,26 @@ s->RunStream(input); } +int c_ffmpeg_get_fps(const cffmpeg h){ + Wrapper *s = (Wrapper*)h; + return s->GetFPS(); +} + void c_ffmpeg_run_gb28181(const cffmpeg h){ Wrapper *s = (Wrapper*)h; s->GB28181(); +} + +char * c_ffmpeg_get_gb28181_pic(const char *rtspUrl, int *retDataLen){ + char * retData = (char *)malloc(sizeof(char) * 3000000); + int flag = GetGb28181Pic(rtspUrl, retData, retDataLen); + if(flag == -1){ + free(retData); + *retDataLen = 0; + return NULL; + } + + return retData; } void c_ffmepg_use_cpu(const cffmpeg h){ @@ -45,6 +62,10 @@ //////passive api +void c_ffmpeg_open_recorder(const cffmpeg h){ + Wrapper *s = (Wrapper*)h; + s->OpenRecorder(); +} void c_ffmpeg_set_record_duration(const cffmpeg h, const int min, const int max){ Wrapper *s = (Wrapper*)h; s->SetRecMinCacheTime(min); @@ -87,7 +108,7 @@ void c_ffmpeg_build_decoder(const cffmpeg h){ Wrapper *s = (Wrapper*)h; - s->BuildDecoder(); + s->OpenDecoder(); } void* c_ffmpeg_get_pic_decoder(const cffmpeg h, int *wid, int *hei, int *format, int *length, int64_t *id){ @@ -97,6 +118,11 @@ return data; } +void c_ffmpeg_close_stream(const cffmpeg h){ + Wrapper *s = (Wrapper*)h; + s->CloseStream(); +} + void* c_ffmpeg_get_avpacket(const cffmpeg h, int *size, int *key){ Wrapper *s = (Wrapper*)h; unsigned char *data = NULL; @@ -104,14 +130,9 @@ return data; } -/////////////////////test -void* c_ffmpeg_decode(const char *file, const int gb, int *wid, int *hei){ - return Decode(file, gb, wid, hei); -} - // pic encoder -void *c_ffmpeg_create_encoder(const int w, const int h, const int fps, const int br, const int scale_flag, const int gi){ - return CreateEncoder(w, h, fps, br, scale_flag, gi); +void *c_ffmpeg_create_encoder(const int w, const int h, const int fps, const int br, const int pix_fmt, const int scale_flag, const int gi){ + return CreateEncoder(w, h, fps, br, pix_fmt, scale_flag, gi); } void c_ffmpeg_destroy_encoder(void *h){ @@ -120,17 +141,4 @@ int c_ffmpeg_encode(void *hdl, uint8_t *in, const int w, const int h, uint8_t **out, int *size, int *key){ return Encode(hdl, in, w, h, out, size, key); -} - -void *c_ffmpeg_create_conv(const int srcW, const int srcH, const int srcFormat, - const int dstW, const int dstH, const int dstFormat, const int flag){ - return CreateConvertor(srcW, srcH, srcFormat, dstW, dstH, dstFormat, flag); -} - -void *c_ffmpeg_conv(void *h, uint8_t *in){ - return Convert(h, in); -} - -void c_ffmpeg_destroy_conv(void *h){ - DestoryConvertor(h); } -- Gitblit v1.8.0