diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/h264/avi_h264_decoder.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/h264/avi_h264_decoder.h')
-rw-r--r-- | Src/h264/avi_h264_decoder.h | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/Src/h264/avi_h264_decoder.h b/Src/h264/avi_h264_decoder.h new file mode 100644 index 00000000..81a55f76 --- /dev/null +++ b/Src/h264/avi_h264_decoder.h @@ -0,0 +1,42 @@ +#pragma once +#include "../Plugins/Input/in_avi/ifc_avivideodecoder.h" +#include "../Plugins/Input/in_avi/svc_avidecoder.h" +#include "MFTDecoder.h" +#include <vector> + +// {AFA1BB51-F41B-4522-9251-25A8DF923DBE} +static const GUID avi_h264_guid = +{ 0xafa1bb51, 0xf41b, 0x4522, { 0x92, 0x51, 0x25, 0xa8, 0xdf, 0x92, 0x3d, 0xbe } }; + + +class AVIDecoderCreator : public svc_avidecoder +{ +public: + static const char *getServiceName() { return "H.264 AVI Decoder"; } + static GUID getServiceGuid() { return avi_h264_guid; } + int CreateVideoDecoder(const nsavi::AVIH *avi_header, const nsavi::STRH *stream_header, const nsavi::STRF *stream_format, const nsavi::STRD *stream_data, ifc_avivideodecoder **decoder); +protected: + RECVS_DISPATCH; +}; + +class AVIH264 : public ifc_avivideodecoder +{ +public: + AVIH264(MFTDecoder *ctx, const nsavi::STRH *stream_header); + ~AVIH264(); + + int GetOutputProperties(int *x, int *y, int *color_format, double *aspect_ratio, int *flip); + int DecodeChunk(uint16_t type, const void *inputBuffer, size_t inputBufferBytes); + void Flush(); + void Close(); + int GetPicture(void **data, void **decoder_data); + void FreePicture(void *data, void *decoder_data); + void EndOfStream(); + void HurryUp(int state); +private: + MFTDecoder *decoder; + const nsavi::STRH *stream_header; + std::vector<nullsoft_h264_frame_data> buffered_frames; +protected: + RECVS_DISPATCH; +};
\ No newline at end of file |