From f6aa35eedbc76e7467a68dbe3aba63ec8cb352a5 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期五, 26 七月 2019 10:51:03 +0800
Subject: [PATCH] add log

---
 libcffmpeg.c |   48 +++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 47 insertions(+), 1 deletions(-)

diff --git a/libcffmpeg.c b/libcffmpeg.c
index cb9edf7..e33a376 100644
--- a/libcffmpeg.c
+++ b/libcffmpeg.c
@@ -25,6 +25,10 @@
         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");
@@ -35,12 +39,22 @@
         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_get_avpacket = (lib_cffmpeg_avpacket)dlsym(lib, "c_ffmpeg_get_avpacket");
+        release_if_err(fn_get_avpacket, 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_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());  
     }
@@ -69,6 +83,14 @@
     fn_scale(h, wid, hei, flags);
 }
 
+void wrap_fn_run_gb28181(const cffmpeg h){
+    fn_gb28181(h);
+}
+
+void wrap_fn_use_cpu(const cffmpeg h){
+    fn_cpu(h);
+}
+
 void wrap_fn_recorder(const cffmpeg h, const char* dir, int mind, int maxd){
     fn_recorder(h, dir, mind, maxd);
 }
@@ -89,6 +111,10 @@
     return fn_decoder_pic(h, wid, hei);
 }
 
+void* wrap_fn_get_avpacket(const cffmpeg h, int* size, int* key){
+    return fn_get_avpacket(h, size, key);
+}
+
 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);
 }
@@ -99,4 +125,24 @@
 
 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