From 68a19a73681301c6712e10d55bc64324716dbd24 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期三, 09 十月 2019 15:38:47 +0800
Subject: [PATCH] split scale

---
 csrc/cffmpeg.cpp |  106 ++++++++++++++++++++++++++--------------------------
 1 files changed, 53 insertions(+), 53 deletions(-)

diff --git a/csrc/cffmpeg.cpp b/csrc/cffmpeg.cpp
index cbb0b1f..9ade6f9 100644
--- a/csrc/cffmpeg.cpp
+++ b/csrc/cffmpeg.cpp
@@ -10,15 +10,17 @@
 }
 #endif
 
-#ifndef LIB_CFFMPEG
-#include "csrc/all.hpp"
-#endif
 #include "csrc/wrapper.hpp"
 
 using namespace cffmpeg_wrap;
 
 cffmpeg c_ffmpeg_create(){
-    return new Wrapper;
+    
+    return new Wrapper();
+}
+
+cffmpeg c_ffmpeg_create2(const char *logfile){
+    return new Wrapper(logfile);
 }
 
 void c_ffmpeg_destroy(const cffmpeg h){
@@ -31,48 +33,51 @@
     s->RunStream(input);
 }
 
-void c_ffmpeg_scale(const cffmpeg h, const int wid, const int hei, const int flags){
-    Wrapper *s = (Wrapper*)h;
-    s->ScalePicture(wid, hei, flags);
-}
-
 void c_ffmpeg_run_gb28181(const cffmpeg h){
     Wrapper *s = (Wrapper*)h;
-    s->UseGB28181();
+    s->GB28181();
 }
 
 void c_ffmepg_use_cpu(const cffmpeg h){
     Wrapper *s = (Wrapper*)h;
-    s->UseCPU();
+    s->CPUDec();
 }
 
 
 //////passive api
-void c_ffmpeg_build_recorder(const cffmpeg h, const char *dir, int mind, int maxd){
+void c_ffmpeg_build_recorder(const cffmpeg h, const char* id, const char *dir, int mind, int maxd, int audio){
     Wrapper *s = (Wrapper*)h;
-    s->BuildRecorder(dir, mind, maxd);
+
+    bool a = audio == 0 ? false : true;
+    s->BuildRecorder(id, dir, mind, maxd, a);
 }
 
-void c_ffmpeg_fire_recorder(const cffmpeg h, const int64_t id){
+void c_ffmpeg_fire_recorder(const cffmpeg h, const char* sid, const int64_t id){
     Wrapper *s = (Wrapper*)h;
-    s->FireRecorder(id);
+    s->FireRecorder(sid, id);
 }
 
-char* c_ffmpeg_get_info_recorder(const cffmpeg h, int *index, int *length){
+void c_ffmpeg_get_info_recorder(const cffmpeg h, int *index, char** recid, int *recidLen, char **fpath, int *pathLen){
     Wrapper *s = (Wrapper*)h;
     int i;
-    std::string p;
-    s->GetInfoRecorder(i, p);
-    if(p.empty()){
-        return NULL;
-    }
-    *index = i;
-    *length = p.length();
-    char *path = (char*)malloc(*length + 1);
-    memcpy(path, p.c_str(), *length);
-    path[*length] = '\0';
+    std::string p(""), id("");
+    s->GetInfoRecorder(id, i, p);
 
-    return path;
+    // printf("cffmpeg get info : index : %d, file : %s, recid: %s\n", i, p.c_str(), id.c_str());
+
+    *index = i;
+    
+    *pathLen = p.length();
+    char *path = (char*)malloc(*pathLen + 1);
+    memcpy(path, p.c_str(), *pathLen);
+    path[*pathLen] = '\0';
+    *fpath = path;
+
+    *recidLen = id.length();
+    char *rid = (char*)malloc(*recidLen + 1);
+    memcpy(rid, id.c_str(), *recidLen);
+    rid[*recidLen] = '\0';
+    *recid = rid;    
 }
 
 void c_ffmpeg_build_decoder(const cffmpeg h){
@@ -80,10 +85,10 @@
     s->BuildDecoder();
 }
 
-void* c_ffmpeg_get_pic_decoder(const cffmpeg h, int *wid, int *hei){
+void* c_ffmpeg_get_pic_decoder(const cffmpeg h, int *wid, int *hei, int *format, int *length, int64_t *id){
     Wrapper *s = (Wrapper*)h;
     unsigned char *data = NULL;
-    s->GetPicDecoder(&data, wid, hei);
+    s->GetPicDecoder(&data, wid, hei, format, length, id);
     return data;
 }
 
@@ -93,32 +98,10 @@
     s->GetPacket(&data, size, key);
     return data;
 }
-/////////////////////active api
-void c_ffmpeg_active_recorder(const cffmpeg h, const char *dir, int mind, int maxd, 
-                                    rec_func fn){
-    Wrapper *s = (Wrapper*)h;
-
-    s->ActiveRecorder(dir, mind, maxd,[fn](std::string &p, int &i){
-        fn((char*)p.c_str(), i);
-    });
-}
-
-void c_ffmpeg_active_decoder(const cffmpeg h, dec_func fn){
-    Wrapper *s = (Wrapper*)h;
-    s->ActiveDecoder([fn](void* d, int wid, int hei){
-        fn(d, wid, hei);
-    });
-}
-
 
 /////////////////////test
-void* c_ffmpeg_decode_jpeg(const cffmpeg h, const char *file, int *wid, int *hei){
-    Wrapper *s = (Wrapper*)h;
-    uint8_t *p = s->decodeJPEG(file, wid, hei);
-    if(!p){
-        *wid = *hei = 0;
-    }
-    return p;
+void* c_ffmpeg_decode(const char *file, const int gb, int *wid, int *hei){
+    return Decode(file, gb, wid, hei);
 }
 
 // pic encoder
@@ -133,3 +116,20 @@
 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 flag){
+    return CreateConvertor(srcW, srcH, srcFormat, dstW, dstH, flag);
+}
+
+void *c_ffmpeg_conv(void *h, uint8_t *in){
+    return Convert(h, in);
+}
+
+void c_ffmpeg_destroy_conv(void *h){
+    DestoryConvertor(h);
+}
+
+void* c_gpu_conv(uint8_t *in, const int w, const int h, const int dst_w, const int dst_h, int *length){
+    return ConvertYUV2BGR(in, w, h, dst_w, dst_h, length);
+}
\ No newline at end of file

--
Gitblit v1.8.0