From e6725cb3cf4ced3a6985d4d3db4d5cf1336a30d8 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期五, 19 七月 2019 16:53:35 +0800
Subject: [PATCH] merge so
---
csrc/ffmpeg/format/FormatIn.cpp | 31 +++++++++++++++++++++++++++----
1 files changed, 27 insertions(+), 4 deletions(-)
diff --git a/csrc/ffmpeg/format/FormatIn.cpp b/csrc/ffmpeg/format/FormatIn.cpp
index 9ebdb3d..81d6c5f 100644
--- a/csrc/ffmpeg/format/FormatIn.cpp
+++ b/csrc/ffmpeg/format/FormatIn.cpp
@@ -21,6 +21,7 @@
#include "../data/FrameData.hpp"
#include "../../common/gpu/info.h"
+#include "PsToEs.hpp"
using namespace logif;
@@ -52,7 +53,7 @@
}
////////////////////////////////////////////////////////////////////////
- int FormatIn::openWithCustomIO(read_packet fn, AVDictionary **options/*=NULL*/){
+ int FormatIn::openWithCustomIO(void *opaque, read_packet fn, AVDictionary **options/*=NULL*/){
ctx_ = avformat_alloc_context();
if(!ctx_){
logIt("open with custom io create format error");
@@ -64,21 +65,43 @@
return -1;
}
- io_ctx_ = avio_alloc_context(read_io_buff_, read_io_buff_size_, 0, NULL, fn, NULL, NULL);
+ io_ctx_ = avio_alloc_context(read_io_buff_, read_io_buff_size_, 0, opaque, fn, NULL, NULL);//opaque
if(!io_ctx_){
logIt("open with custom io create custom avio error");
return -1;
}
ctx_->pb = io_ctx_;
- auto err = av_probe_input_buffer(io_ctx_, &ctx_->iformat, NULL, NULL, 0, read_io_buff_size_);
+ auto err = av_probe_input_buffer(ctx_->pb, &ctx_->iformat, NULL, NULL, 0, read_io_buff_size_);
if(err != 0){
- logIt("open with custom io prob input buffer error");
+ logIt("open with custom io prob input buffer error:%d", err);
+ logIt("failed:%s", getAVErrorDesc(err).c_str());
return -1;
}
+
return 0;
}
+ int FormatIn::openGb28181(const char *filename, AVDictionary **options){
+
+ std::string fn = filename;
+ addCamera(fn);
+
+ int ret = openWithCustomIO(NULL, readData, options);
+ if(ret < 0){
+ logIt("do openWithCustomIO failed:%d",ret);
+ }
+
+ ret = avformat_open_input(&ctx_, "", NULL, options);
+ if(ret < 0){
+ logIt("open %s failed:%s",filename,
+ getAVErrorDesc(ret).c_str());
+
+ }
+
+ return ret;
+ }
+
/////////////////////////////////////////////////////////////////////////
int FormatIn::open(const char *filename, AVDictionary **options){
--
Gitblit v1.8.0