From e878e92811a2dbfb6b4d3f7b2c357435f56e28db Mon Sep 17 00:00:00 2001 From: zhangmeng <775834166@qq.com> Date: 星期日, 29 九月 2019 10:27:21 +0800 Subject: [PATCH] add trytime --- libcffmpeg.c | 89 ++++++++++++++++++++++++++++++++++---------- 1 files changed, 68 insertions(+), 21 deletions(-) diff --git a/libcffmpeg.c b/libcffmpeg.c index a5beec6..69fcbb9 100644 --- a/libcffmpeg.c +++ b/libcffmpeg.c @@ -19,10 +19,18 @@ if(lib){ fn_create = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create"); release_if_err(fn_create, lib); + fn_create2 = (lib_cffmpeg_create)dlsym(lib, "c_ffmpeg_create2"); + release_if_err(fn_create2, lib); fn_destroy = (lib_cffmpeg_destroy)dlsym(lib, "c_ffmpeg_destroy"); release_if_err(fn_destroy, lib); fn_run = (lib_cffmpeg_run)dlsym(lib, "c_ffmpeg_run"); release_if_err(fn_run, lib); + fn_scale = (lib_cffmpeg_scale)dlsym(lib, "c_ffmpeg_scale"); + release_if_err(fn_scale, lib); + fn_gb28181 = (lib_cffmpeg_gb28181)dlsym(lib, "c_ffmpeg_run_gb28181"); + release_if_err(fn_gb28181, lib); + fn_cpu = (lib_cffmpeg_cpu)dlsym(lib, "c_ffmepg_use_cpu"); + release_if_err(fn_cpu, lib); fn_recorder = (lib_cffmpeg_recorder)dlsym(lib, "c_ffmpeg_build_recorder"); release_if_err(fn_recorder, lib); fn_fire_recorder = (lib_cffmpeg_fire_recorder)dlsym(lib, "c_ffmpeg_fire_recorder"); @@ -33,12 +41,18 @@ release_if_err(fn_decoder, lib); fn_decoder_pic = (lib_cffmpeg_pic)dlsym(lib, "c_ffmpeg_get_pic_decoder"); release_if_err(fn_decoder_pic, lib); - fn_active_recorder = (lib_cffmpeg_active_recorder)dlsym(lib, "c_ffmpeg_active_recorder"); - release_if_err(fn_active_recorder, lib); - fn_active_decoder = (lib_cffmpeg_active_decoder)dlsym(lib, "c_ffmpeg_active_decoder"); - release_if_err(fn_active_decoder, lib); - fn_dec_jpeg = (lib_cffmpeg_decode_jpeg)dlsym(lib, "c_ffmpeg_decode_jpeg"); - release_if_err(fn_dec_jpeg, lib); + fn_get_avpacket = (lib_cffmpeg_avpacket)dlsym(lib, "c_ffmpeg_get_avpacket"); + release_if_err(fn_get_avpacket, lib); + fn_decode = (lib_cffmpeg_decode)dlsym(lib, "c_ffmpeg_decode"); + release_if_err(fn_decode, lib); + + fn_create_encoder = (lib_cffmpeg_create_encoder)dlsym(lib, "c_ffmpeg_create_encoder"); + release_if_err(fn_create_encoder, lib); + fn_destroy_encoder = (lib_cffmpeg_destroy_encoder)dlsym(lib, "c_ffmpeg_destroy_encoder"); + release_if_err(fn_destroy_encoder, lib); + fn_encode = (lib_cffmpeg_encode)dlsym(lib, "c_ffmpeg_encode"); + release_if_err(fn_encode, lib); + }else{ printf("dlopen - %s\n", dlerror()); } @@ -55,6 +69,10 @@ return fn_create(); } +cffmpeg wrap_fn_create2(const char *logfile){ + return fn_create2(logfile); +} + void wrap_fn_destroy(const cffmpeg h){ fn_destroy(h); } @@ -63,34 +81,63 @@ fn_run(h, input); } -void wrap_fn_recorder(const cffmpeg h, const char* dir, int mind, int maxd){ - fn_recorder(h, dir, mind, maxd); +void wrap_fn_scale(const cffmpeg h, const int wid, const int hei, const int flags){ + fn_scale(h, wid, hei, flags); } -void wrap_fn_fire_recorder(const cffmpeg h, const int64_t id){ - fn_fire_recorder(h, id); +void wrap_fn_run_gb28181(const cffmpeg h){ + fn_gb28181(h); } -char* wrap_fn_info_recorder(const cffmpeg h, int* index, int* length){ - return fn_info_recorder(h, index, length); +void wrap_fn_use_cpu(const cffmpeg h){ + fn_cpu(h); +} + +void wrap_fn_recorder(const cffmpeg h, const char* id, const char* dir, int mind, int maxd, int audio){ + fn_recorder(h, id, dir, mind, maxd, audio); +} + +void wrap_fn_fire_recorder(const cffmpeg h, const char* sid, const int64_t id){ + fn_fire_recorder(h, sid, id); +} + +void wrap_fn_info_recorder(const cffmpeg h, int* index, char** recid, int* recidLen, char** fpath, int* pathLen){ + return fn_info_recorder(h, index, recid, recidLen, fpath, pathLen); } void wrap_fn_decoder(const cffmpeg h){ fn_decoder(h); } -void* wrap_fn_decoder_pic(const cffmpeg h, int* wid, int* hei){ - return fn_decoder_pic(h, wid, hei); +void* wrap_fn_decoder_pic(const cffmpeg h, int* wid, int* hei, int64_t *id){ + return fn_decoder_pic(h, wid, hei, id); } -void wrap_fn_active_recorder(const cffmpeg h, const char* dir, int mind, int maxd, rec_func fn){ - fn_active_recorder(h, dir, mind, maxd, fn); +void* wrap_fn_get_avpacket(const cffmpeg h, int* size, int* key){ + return fn_get_avpacket(h, size, key); } -void wrap_fn_active_decoder(const cffmpeg h, dec_func fn){ - fn_active_decoder(h, fn); +// return val: -1 open error; -2, find stream error; -3, converter create error +void* wrap_fn_decode(const char* file, const int gb, int* wid, int* hei){ + return fn_decode(file, gb, wid, hei); } -void* wrap_fn_decode_jpeg(const cffmpeg h, const char* file, int* wid, int* hei){ - return fn_dec_jpeg(h, file, wid, hei); -} \ No newline at end of file +// for encoder +cencoder wrap_fn_create_encoder(const int w, const int h, const int fps, const int br, const int scale_flag, const int gi){ + return fn_create_encoder(w, h, fps, br, scale_flag, gi); +} + +void wrap_fn_destroy_encoder(const cencoder h){ + fn_destroy_encoder(h); +} + +void* wrap_fn_encode(cencoder hdl, void *in, const int w, const int h, int *out_size, int *key){ + uint8_t *out = NULL; + const int flag = fn_encode(hdl, (uint8_t*)in, w, h, &out, out_size, key); + if (flag > 0 && out != NULL) { + return out; + } + *out_size = 0; + *key = 0; + return NULL; +} -- Gitblit v1.8.0