⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 aviheader.h

📁 自己移植的linux下的流媒体播放器原代码,支持mms协议,支持ftp和http协议.
💻 H
字号:
#ifndef _aviheader_h#define	_aviheader_h//#include "config.h"	/* get correct definition WORDS_BIGENDIAN */#include "bswap.h"#ifndef MIN#define MIN(a,b) (((a)<(b))?(a):(b))#endif#ifndef min#define min(a,b) (((a)<(b))?(a):(b))#endif#ifndef max#define max(a,b) (((a)>(b))?(a):(b))#endif#ifndef mmioFOURCC#define mmioFOURCC( ch0, ch1, ch2, ch3 )				\		( (uint32_t)(uint8_t)(ch0) | ( (uint32_t)(uint8_t)(ch1) << 8 ) |	\		( (uint32_t)(uint8_t)(ch2) << 16 ) | ( (uint32_t)(uint8_t)(ch3) << 24 ) )#endif/* Macro to make a TWOCC out of two characters */#ifndef aviTWOCC#define aviTWOCC(ch0, ch1) ((uint16_t)(uint8_t)(ch0) | ((uint16_t)(uint8_t)(ch1) << 8))#endif//typedef uint16_t TWOCC;//typedef uint32_t FOURCC;/* form types, list types, and chunk types */#define formtypeAVI             mmioFOURCC('A', 'V', 'I', ' ')#define listtypeAVIHEADER       mmioFOURCC('h', 'd', 'r', 'l')#define ckidAVIMAINHDR          mmioFOURCC('a', 'v', 'i', 'h')#define listtypeSTREAMHEADER    mmioFOURCC('s', 't', 'r', 'l')#define ckidSTREAMHEADER        mmioFOURCC('s', 't', 'r', 'h')#define ckidSTREAMFORMAT        mmioFOURCC('s', 't', 'r', 'f')#define ckidSTREAMHANDLERDATA   mmioFOURCC('s', 't', 'r', 'd')#define ckidSTREAMNAME		mmioFOURCC('s', 't', 'r', 'n')#define listtypeAVIMOVIE        mmioFOURCC('m', 'o', 'v', 'i')#define listtypeAVIRECORD       mmioFOURCC('r', 'e', 'c', ' ')#define ckidAVINEWINDEX         mmioFOURCC('i', 'd', 'x', '1')/*** Stream types for the <fccType> field of the stream header.*/#define streamtypeVIDEO         mmioFOURCC('v', 'i', 'd', 's')#define streamtypeAUDIO         mmioFOURCC('a', 'u', 'd', 's')#define streamtypeMIDI		mmioFOURCC('m', 'i', 'd', 's')#define streamtypeTEXT          mmioFOURCC('t', 'x', 't', 's')/* Basic chunk types */#define cktypeDIBbits           aviTWOCC('d', 'b')#define cktypeDIBcompressed     aviTWOCC('d', 'c')#define cktypePALchange         aviTWOCC('p', 'c')#define cktypeWAVEbytes         aviTWOCC('w', 'b')/* Chunk id to use for extra chunks for padding. */#define ckidAVIPADDING          mmioFOURCC('J', 'U', 'N', 'K')/* flags for use in <dwFlags> in AVIFileHdr */#define AVIF_HASINDEX		0x00000010	// Index at end of file?#define AVIF_MUSTUSEINDEX	0x00000020#define AVIF_ISINTERLEAVED	0x00000100#define AVIF_TRUSTCKTYPE	0x00000800	// Use CKType to find key frames?#define AVIF_WASCAPTUREFILE	0x00010000#define AVIF_COPYRIGHTED	0x00020000typedef struct{    uint32_t		dwMicroSecPerFrame;	// frame display rate (or 0L)    uint32_t		dwMaxBytesPerSec;	// max. transfer rate    uint32_t		dwPaddingGranularity;	// pad to multiples of this                                                // size; normally 2K.    uint32_t		dwFlags;		// the ever-present flags    uint32_t		dwTotalFrames;		// # frames in file    uint32_t		dwInitialFrames;    uint32_t		dwStreams;    uint32_t		dwSuggestedBufferSize;        uint32_t		dwWidth;    uint32_t		dwHeight;        uint32_t		dwReserved[4];} MainAVIHeader;typedef struct rectangle_t {    short  left;    short  top;    short  right;    short  bottom;} rectangle_t;typedef struct {    uint32_t		fccType;    uint32_t		fccHandler;    uint32_t		dwFlags;	/* Contains AVITF_* flags */    uint16_t		wPriority;    uint16_t		wLanguage;    uint32_t		dwInitialFrames;    uint32_t		dwScale;	    uint32_t		dwRate;	/* dwRate / dwScale == samples/second */    uint32_t		dwStart;    uint32_t		dwLength; /* In units above... */    uint32_t		dwSuggestedBufferSize;    uint32_t		dwQuality;    uint32_t		dwSampleSize;    rectangle_t		rcFrame;} AVIStreamHeader;/* Flags for index */#define AVIIF_LIST          0x00000001L // chunk is a 'LIST'#define AVIIF_KEYFRAME      0x00000010L // this frame is a key frame.#define AVIIF_NOTIME	    0x00000100L // this frame doesn't take any time#define AVIIF_COMPUSE       0x0FFF0000L // these bits are for compressor use#define FOURCC_RIFF     mmioFOURCC('R', 'I', 'F', 'F')#define FOURCC_LIST     mmioFOURCC('L', 'I', 'S', 'T')typedef struct{    uint32_t		ckid;    uint32_t		dwFlags;    uint32_t		dwChunkOffset;		// Position of chunk    uint32_t		dwChunkLength;		// Length of chunk} AVIINDEXENTRY;typedef struct _avisuperindex_entry {    uint64_t qwOffset;           // absolute file offset    uint32_t dwSize;             // size of index chunk at this offset    uint32_t dwDuration;         // time span in stream ticks} avisuperindex_entry;typedef struct _avistdindex_entry {    uint32_t dwOffset;           // qwBaseOffset + this is absolute file offset    uint32_t dwSize;             // bit 31 is set if this is NOT a keyframe} avistdindex_entry;// Standard index typedef struct __attribute((packed)) _avistdindex_chunk {    char           fcc[4];       // ix##    uint32_t  dwSize;            // size of this chunk    uint16_t wLongsPerEntry;     // must be sizeof(aIndex[0])/sizeof(DWORD)    uint8_t  bIndexSubType;      // must be 0    uint8_t  bIndexType;         // must be AVI_INDEX_OF_CHUNKS    uint32_t  nEntriesInUse;     // first unused entry    char           dwChunkId[4]; // '##dc' or '##db' or '##wb' etc..    uint64_t qwBaseOffset;       // all dwOffsets in aIndex array are relative to this    uint32_t  dwReserved3;       // must be 0    avistdindex_entry *aIndex;   // the actual frames} avistdindex_chunk;    // Base Index Form 'indx'typedef struct _avisuperindex_chunk {    char           fcc[4];    uint32_t  dwSize;                // size of this chunk    uint16_t wLongsPerEntry;         // size of each entry in aIndex array (must be 4*4 for us)    uint8_t  bIndexSubType;          // future use. must be 0    uint8_t  bIndexType;             // one of AVI_INDEX_* codes    uint32_t  nEntriesInUse;         // index of first unused member in aIndex array    char       dwChunkId[4];         // fcc of what is indexed    uint32_t  dwReserved[3];         // meaning differs for each index type/subtype.                                     // 0 if unused    avisuperindex_entry *aIndex;     // position of ix## chunks    avistdindex_chunk *stdidx;       // the actual std indices} avisuperindex_chunk;typedef struct {	uint32_t CompressedBMHeight;	uint32_t CompressedBMWidth;	uint32_t ValidBMHeight;	uint32_t ValidBMWidth;	uint32_t ValidBMXOffset;	uint32_t ValidBMYOffset;	uint32_t VideoXOffsetInT;	uint32_t VideoYValidStartLine;} VIDEO_FIELD_DESC;typedef struct {	uint32_t VideoFormatToken;	uint32_t VideoStandard;	uint32_t dwVerticalRefreshRate;	uint32_t dwHTotalInT;	uint32_t dwVTotalInLines;	uint32_t dwFrameAspectRatio;	uint32_t dwFrameWidthInPixels;	uint32_t dwFrameHeightInLines;	uint32_t nbFieldPerFrame;	VIDEO_FIELD_DESC FieldInfo[2];} VideoPropHeader;typedef enum {	FORMAT_UNKNOWN,	FORMAT_PAL_SQUARE,	FORMAT_PAL_CCIR_601,	FORMAT_NTSC_SQUARE,	FORMAT_NTSC_CCIR_601,} VIDEO_FORMAT;typedef enum {	STANDARD_UNKNOWN,	STANDARD_PAL,	STANDARD_NTSC,	STANDARD_SECAM} VIDEO_STANDARD;#define MAKE_AVI_ASPECT(a, b) (((a)<<16)|(b))#define GET_AVI_ASPECT(a) ((float)((a)>>16)/(float)((a)&0xffff))/* * Some macros to swap little endian structures read from an AVI file * into machine endian format */#ifdef WORDS_BIGENDIAN#define	le2me_MainAVIHeader(h) {					\    (h)->dwMicroSecPerFrame = le2me_32((h)->dwMicroSecPerFrame);	\    (h)->dwMaxBytesPerSec = le2me_32((h)->dwMaxBytesPerSec);		\    (h)->dwPaddingGranularity = le2me_32((h)->dwPaddingGranularity);	\    (h)->dwFlags = le2me_32((h)->dwFlags);				\    (h)->dwTotalFrames = le2me_32((h)->dwTotalFrames);			\    (h)->dwInitialFrames = le2me_32((h)->dwInitialFrames);		\    (h)->dwStreams = le2me_32((h)->dwStreams);				\    (h)->dwSuggestedBufferSize = le2me_32((h)->dwSuggestedBufferSize);	\    (h)->dwWidth = le2me_32((h)->dwWidth);				\    (h)->dwHeight = le2me_32((h)->dwHeight);				\}#define	le2me_AVIStreamHeader(h) {					\    (h)->fccType = le2me_32((h)->fccType);				\    (h)->fccHandler = le2me_32((h)->fccHandler);			\    (h)->dwFlags = le2me_32((h)->dwFlags);				\    (h)->wPriority = le2me_16((h)->wPriority);				\    (h)->wLanguage = le2me_16((h)->wLanguage);				\    (h)->dwInitialFrames = le2me_32((h)->dwInitialFrames);		\    (h)->dwScale = le2me_32((h)->dwScale);				\    (h)->dwRate = le2me_32((h)->dwRate);				\    (h)->dwStart = le2me_32((h)->dwStart);				\    (h)->dwLength = le2me_32((h)->dwLength);				\    (h)->dwSuggestedBufferSize = le2me_32((h)->dwSuggestedBufferSize);	\    (h)->dwQuality = le2me_32((h)->dwQuality);				\    (h)->dwSampleSize = le2me_32((h)->dwSampleSize);			\    le2me_RECT(&(h)->rcFrame);						\}#define	le2me_RECT(h) {							\    (h)->left = le2me_16((h)->left);					\    (h)->top = le2me_16((h)->top);					\    (h)->right = le2me_16((h)->right);					\    (h)->bottom = le2me_16((h)->bottom);				\}#define le2me_BITMAPINFOHEADER(h) {					\    (h)->biSize = le2me_32((h)->biSize);				\    (h)->biWidth = le2me_32((h)->biWidth);				\    (h)->biHeight = le2me_32((h)->biHeight);				\    (h)->biPlanes = le2me_16((h)->biPlanes);				\    (h)->biBitCount = le2me_16((h)->biBitCount);			\    (h)->biCompression = le2me_32((h)->biCompression);			\    (h)->biSizeImage = le2me_32((h)->biSizeImage);			\    (h)->biXPelsPerMeter = le2me_32((h)->biXPelsPerMeter);		\    (h)->biYPelsPerMeter = le2me_32((h)->biYPelsPerMeter);		\    (h)->biClrUsed = le2me_32((h)->biClrUsed);				\    (h)->biClrImportant = le2me_32((h)->biClrImportant);		\}#define le2me_WAVEFORMATEX(h) {						\    (h)->wFormatTag = le2me_16((h)->wFormatTag);			\    (h)->nChannels = le2me_16((h)->nChannels);				\    (h)->nSamplesPerSec = le2me_32((h)->nSamplesPerSec);		\    (h)->nAvgBytesPerSec = le2me_32((h)->nAvgBytesPerSec);		\    (h)->nBlockAlign = le2me_16((h)->nBlockAlign);			\    (h)->wBitsPerSample = le2me_16((h)->wBitsPerSample);		\    (h)->cbSize = le2me_16((h)->cbSize);				\}#define le2me_AVIINDEXENTRY(h) {					\    (h)->ckid = le2me_32((h)->ckid);					\    (h)->dwFlags = le2me_32((h)->dwFlags);				\    (h)->dwChunkOffset = le2me_32((h)->dwChunkOffset);			\    (h)->dwChunkLength = le2me_32((h)->dwChunkLength);			\}#define le2me_AVISTDIDXCHUNK(h) {\    char c; \    c = (h)->fcc[0]; (h)->fcc[0] = (h)->fcc[3]; (h)->fcc[3] = c;  \    c = (h)->fcc[1]; (h)->fcc[1] = (h)->fcc[2]; (h)->fcc[2] = c;  \    (h)->dwSize = le2me_32((h)->dwSize);  \    (h)->wLongsPerEntry = le2me_16((h)->wLongsPerEntry);  \    (h)->nEntriesInUse = le2me_32((h)->nEntriesInUse);  \    c = (h)->dwChunkId[0]; (h)->dwChunkId[0] = (h)->dwChunkId[3]; (h)->dwChunkId[3] = c;  \    c = (h)->dwChunkId[1]; (h)->dwChunkId[1] = (h)->dwChunkId[2]; (h)->dwChunkId[2] = c;  \    (h)->qwBaseOffset = le2me_64((h)->qwBaseOffset);  \    (h)->dwReserved3 = le2me_32((h)->dwReserved3);  \}#define le2me_AVISTDIDXENTRY(h)  {\    (h)->dwOffset = le2me_32((h)->dwOffset);  \    (h)->dwSize = le2me_32((h)->dwSize);  \}#define le2me_VideoPropHeader(h) {					\    (h)->VideoFormatToken = le2me_32((h)->VideoFormatToken);		\    (h)->VideoStandard = le2me_32((h)->VideoStandard);			\    (h)->dwVerticalRefreshRate = le2me_32((h)->dwVerticalRefreshRate);	\    (h)->dwHTotalInT = le2me_32((h)->dwHTotalInT);			\    (h)->dwVTotalInLines = le2me_32((h)->dwVTotalInLines);		\    (h)->dwFrameAspectRatio = le2me_32((h)->dwFrameAspectRatio);	\    (h)->dwFrameWidthInPixels = le2me_32((h)->dwFrameWidthInPixels);	\    (h)->dwFrameHeightInLines = le2me_32((h)->dwFrameHeightInLines);	\    (h)->nbFieldPerFrame = le2me_32((h)->nbFieldPerFrame);		\}#define le2me_VIDEO_FIELD_DESC(h) {					\    (h)->CompressedBMHeight = le2me_32((h)->CompressedBMHeight);	\    (h)->CompressedBMWidth = le2me_32((h)->CompressedBMWidth);		\    (h)->ValidBMHeight = le2me_32((h)->ValidBMHeight);			\    (h)->ValidBMWidth = le2me_32((h)->ValidBMWidth);			\    (h)->ValidBMXOffset = le2me_32((h)->ValidBMXOffset);		\    (h)->ValidBMYOffset = le2me_32((h)->ValidBMYOffset);		\    (h)->VideoXOffsetInT = le2me_32((h)->VideoXOffsetInT);		\    (h)->VideoYValidStartLine = le2me_32((h)->VideoYValidStartLine);	\}#else#define	le2me_MainAVIHeader(h)	    /**/#define le2me_AVIStreamHeader(h)    /**/#define le2me_RECT(h)		    /**/#define le2me_BITMAPINFOHEADER(h)   /**/#define le2me_WAVEFORMATEX(h)	    /**/#define le2me_AVIINDEXENTRY(h)	    /**/#define le2me_AVISTDIDXCHUNK(h)     /**/#define le2me_AVISTDIDXENTRY(h)     /**/#define le2me_VideoPropHeader(h)    /**/#define le2me_VIDEO_FIELD_DESC(h)   /**/#endiftypedef struct {  // index stuff:  void* idx;  int idx_size;  off_t idx_pos;  off_t idx_pos_a;  off_t idx_pos_v;  off_t idx_offset;  // ennyit kell hozzaadni az index offset ertekekhez  // bps-based PTS stuff:  int video_pack_no;  int audio_block_size;  off_t audio_block_no;  // interleaved PTS stuff:  int skip_video_frames;  int audio_streams;  float avi_audio_pts;  float avi_video_pts;  float pts_correction;  unsigned int pts_corr_bytes;  unsigned char pts_corrected;  unsigned char pts_has_video;  unsigned int numberofframes;  avisuperindex_chunk *suidx;  int suidx_size;  int isodml;} avi_priv_t;#define AVI_PRIV ((avi_priv_t*)(demuxer->priv))#define AVI_IDX_OFFSET(x) ((((uint64_t)(x)->dwFlags&0xffff0000)<<16)+(x)->dwChunkOffset)#endif /* _aviheader_h */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -