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/mp4v/avi_mp4v_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/mp4v/avi_mp4v_decoder.h')
| -rw-r--r-- | Src/mp4v/avi_mp4v_decoder.h | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/Src/mp4v/avi_mp4v_decoder.h b/Src/mp4v/avi_mp4v_decoder.h new file mode 100644 index 00000000..ff65f631 --- /dev/null +++ b/Src/mp4v/avi_mp4v_decoder.h @@ -0,0 +1,40 @@ +#pragma once +#include "../Plugins/Input/in_avi/ifc_avivideodecoder.h" +#include "../Plugins/Input/in_avi/svc_avidecoder.h" +#include "MFTDecoder.h" + +// {3E450454-0286-4ad8-811F-60A49C933E9B} +static const GUID avi_mp4v_guid = +{ 0x3e450454, 0x286, 0x4ad8, { 0x81, 0x1f, 0x60, 0xa4, 0x9c, 0x93, 0x3e, 0x9b } }; + +class AVIDecoderCreator : public svc_avidecoder +{ +public: + static const char *getServiceName() { return "MPEG-4 Part 2 AVI Decoder"; } + static GUID getServiceGuid() { return avi_mp4v_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 AVIMP4V : public ifc_avivideodecoder +{ +public: + AVIMP4V(MFTDecoder *decoder, const nsavi::STRH *stream_header, const nsavi::video_format *stream_format); + ~AVIMP4V(); + + 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(); + int GetPicture(void **data, void **decoder_data); + void FreePicture(void *data, void *decoder_data); + void EndOfStream(); + void HurryUp(int state); + void Close(); +private: + MFTDecoder *decoder; + const nsavi::STRH *stream_header; + const nsavi::video_format *stream_format; +protected: + RECVS_DISPATCH; +};
\ No newline at end of file |
