From 18a05d269516a5e33d8460291c2f93e73d95adce Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期二, 26 十二月 2023 10:45:31 +0800
Subject: [PATCH] GetYUV format is NV12

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

diff --git a/csrc/cffmpeg.cpp b/csrc/cffmpeg.cpp
index 293df1d..50fe586 100644
--- a/csrc/cffmpeg.cpp
+++ b/csrc/cffmpeg.cpp
@@ -40,7 +40,19 @@
 
 void c_ffmpeg_run_gb28181(const cffmpeg h){
     Wrapper *s = (Wrapper*)h;
-    s->GB28181();
+    s->gb28181();
+}
+
+char * c_ffmpeg_get_gb28181_pic(const char *rtspUrl, int *retDataLen, const int tt){
+    char * retData = (char *)malloc(sizeof(char) * 3000000);
+    int flag = GetGb28181Pic(rtspUrl, retData, retDataLen, tt);
+    if(flag == -1){
+        free(retData);
+        *retDataLen = 0;
+        return NULL;
+    }
+
+    return retData;
 }
 
 void c_ffmepg_use_cpu(const cffmpeg h){
@@ -50,9 +62,13 @@
 
 
 //////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);
+    s->SetRecMinCacheTime(min, max);
 }
 
 void c_ffmpeg_build_recorder(const cffmpeg h, const char* id, const char *dir, const int64_t fid, int mind, int maxd, int audio){
@@ -62,16 +78,16 @@
     s->BuildRecorder(id, dir, fid, mind, maxd, a);
 }
 
-void c_ffmpeg_fire_recorder(const cffmpeg h, const char* sid, const int64_t id){
+int c_ffmpeg_fire_recorder(const cffmpeg h, const char* sid, const int64_t id){
     Wrapper *s = (Wrapper*)h;
-    s->FireRecorder(sid, id);
+    return s->FireRecorder(sid, id);
 }
 
-void c_ffmpeg_get_info_recorder(const cffmpeg h, int *index, char** recid, int *recidLen, char **fpath, int *pathLen){
+int 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(""), id("");
-    s->GetInfoRecorder(id, i, p);
+    int ret = s->GetInfoRecorder(id, i, p);
 
     // printf("cffmpeg get info : index : %d, file : %s, recid: %s\n", i, p.c_str(), id.c_str());
 
@@ -88,18 +104,17 @@
     memcpy(rid, id.c_str(), *recidLen);
     rid[*recidLen] = '\0';
     *recid = rid;    
+    return ret;
 }
 
 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){
+int c_ffmpeg_get_pic_decoder(const cffmpeg h, unsigned char **data, int *wid, int *hei, int *format, int *length, int64_t *id){
     Wrapper *s = (Wrapper*)h;
-    unsigned char *data = NULL;
-    s->GetPicDecoder(&data, wid, hei, format, length, id);
-    return data;
+    return s->GetPicDecoder(data, wid, hei, format, length, id);
 }
 
 void c_ffmpeg_close_stream(const cffmpeg h){
@@ -114,6 +129,22 @@
     return data;
 }
 
+int c_ffmpeg_get_avpacket2(const cffmpeg h, unsigned char **data, int *size, int *key){
+    Wrapper *s = (Wrapper*)h;
+    return s->GetPacket(data, size, key);
+}
+
+int c_ffmpeg_set_devid(const cffmpeg h, const int devid){
+    Wrapper *s = (Wrapper*)h;
+    return s->SetDevID(devid);
+}
+
+void c_ffmpeg_release_buf(void* buf){
+    if (buf){
+        free(buf);
+    }
+}
+
 // pic encoder
 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);

--
Gitblit v1.8.0