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/ffmpeg/format/FormatIn.hpp |   25 ++++++++++++-------------
 1 files changed, 12 insertions(+), 13 deletions(-)

diff --git a/csrc/ffmpeg/format/FormatIn.hpp b/csrc/ffmpeg/format/FormatIn.hpp
index a569524..e904145 100644
--- a/csrc/ffmpeg/format/FormatIn.hpp
+++ b/csrc/ffmpeg/format/FormatIn.hpp
@@ -19,8 +19,6 @@
 namespace ffwrapper{
 
 	class VideoProp;
-	class CodedData;
-	class FrameData;
 
 	class FormatIn
 	{
@@ -35,30 +33,31 @@
 		int open(const char *filename, AVDictionary **options);
 		bool findStreamInfo(AVDictionary **options);
 
-		bool openCodec(const int type, AVDictionary **options);
+		bool openCodec(AVDictionary **options);
 		
-		bool readPacket(AVPacket &pkt_out, int stream_index = 0);
-		bool readPacket(std::shared_ptr<CodedData> &data, int stream_index = 0);
+		int readPacket(AVPacket *pkt_out);
 
-		int decode(AVFrame* &frame, AVPacket &pkt);
-		int decode(std::shared_ptr<FrameData> &frame_data,
-					std::shared_ptr<CodedData> &data);
+		int decode(AVFrame* frame, AVPacket *pkt);
 		
-		int readFrame(AVFrame* &frame);
-		int readFrame(std::shared_ptr<FrameData> &frame_data);
-
+		bool isVideoPkt(AVPacket *pkt);
+		bool isAudioPkt(AVPacket *pkt);
+		bool notVideoAudio(AVPacket *pkt);
 	private:
 		bool allocCodec(AVCodec *dec, AVStream *s, AVDictionary **options);
 	public:
-		AVStream *getStream(int type = 0);
+		AVStream *getStream(int type = -1);
 		AVCodecContext *getCodecContext(int type = 0);
+		AVFormatContext *getFromatContext(){return ctx_;}
+		const double getFPS()const{return fps_;}
+		const bool IsHEVC()const;
 	private:
 	 	AVFormatContext 	*ctx_;
 	 	AVCodecContext 		*dec_ctx_;
 	 	int 				vs_idx_;
+		int 				as_idx_;
 
 	 	bool 				hw_accl_;
-
+		double 				fps_;
 	private:
 		AVIOContext			*io_ctx_;
 		uint8_t 			*read_io_buff_;

--
Gitblit v1.8.0