183 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
 | |
|  *
 | |
|  *  Use of this source code is governed by a BSD-style license
 | |
|  *  that can be found in the LICENSE file in the root of the source
 | |
|  *  tree. An additional intellectual property rights grant can be found
 | |
|  *  in the file PATENTS.  All contributing project authors may
 | |
|  *  be found in the AUTHORS file in the root of the source tree.
 | |
|  */
 | |
| 
 | |
| #ifndef WEBRTC_MODULES_RTP_RTCP_SOURCE_H263_INFORMATION_H_
 | |
| #define WEBRTC_MODULES_RTP_RTCP_SOURCE_H263_INFORMATION_H_
 | |
| 
 | |
| #include "typedefs.h"
 | |
| 
 | |
| #include "video_codec_information.h"
 | |
| 
 | |
| #define MAX_NUMBER_OF_H263_GOB 32  // 5 bits
 | |
| 
 | |
| namespace webrtc {
 | |
| class H263Info
 | |
| {
 | |
| public:
 | |
|     H263Info()
 | |
|         :
 | |
|         uiH263PTypeFmt(0),
 | |
|         codecBits(0),
 | |
|         pQuant(0),
 | |
|         numOfGOBs(0),
 | |
|         totalNumOfMBs(0),
 | |
|         cpmBit(0),
 | |
|         fType(0)
 | |
|         {
 | |
|             memset(ptrGOBbuffer,     0, sizeof(ptrGOBbuffer));
 | |
|             memset(ptrGOBbufferSBit, 0, sizeof(ptrGOBbufferSBit));
 | |
|             memset(ptrGQuant,        0, sizeof(ptrGQuant));
 | |
|             memset(ptrNumOfMBs,      0, sizeof(ptrNumOfMBs));
 | |
|             memset(ptrGroupNum,      0, sizeof(ptrGroupNum));
 | |
|         }
 | |
| 
 | |
|     WebRtc_Word32 CalculateMBOffset(const WebRtc_UWord8 numOfGOB) const;
 | |
| 
 | |
|     WebRtc_UWord8     uiH263PTypeFmt;     // Defines frame size
 | |
|     WebRtc_UWord8     codecBits;
 | |
|     WebRtc_UWord8     pQuant;
 | |
|     WebRtc_UWord8     numOfGOBs;          // Total number of GOBs of current frame
 | |
| 
 | |
|     WebRtc_UWord16    totalNumOfMBs;
 | |
|     WebRtc_UWord8     cpmBit;
 | |
|     WebRtc_UWord8     fType;              // 0 - intra frame, 1 - inter frame
 | |
| 
 | |
|     WebRtc_UWord16    ptrNumOfMBs[MAX_NUMBER_OF_H263_GOB];        // Total number of MBs of current GOB
 | |
|     WebRtc_UWord32    ptrGOBbuffer[MAX_NUMBER_OF_H263_GOB];       // GOB buffer (start byte of GOBs)
 | |
|     WebRtc_UWord8     ptrGroupNum[MAX_NUMBER_OF_H263_GOB];
 | |
|     WebRtc_UWord8     ptrGOBbufferSBit[MAX_NUMBER_OF_H263_GOB];   // sBit buffer (number of start bits to ignore for corresponding GOB)
 | |
|     WebRtc_UWord8     ptrGQuant[MAX_NUMBER_OF_H263_GOB];          // quantizer information for GOBs
 | |
| };
 | |
| 
 | |
| struct H263MBInfo
 | |
| {
 | |
|     H263MBInfo()
 | |
|         :
 | |
|         bufferSize(0),
 | |
|         ptrBuffer(0),
 | |
|         ptrBufferHMV(0),
 | |
|         ptrBufferVMV(0)
 | |
|         {
 | |
|         }
 | |
| 
 | |
|     WebRtc_UWord32          bufferSize;     // Size of MB buffer
 | |
|     WebRtc_UWord32*         ptrBuffer;      // MB buffer
 | |
|     WebRtc_UWord8*          ptrBufferHMV;   // Horizontal motion vector for corresponding MB
 | |
|     WebRtc_UWord8*          ptrBufferVMV;   // Vertical motion vector for corresponding MB
 | |
| };
 | |
| 
 | |
| class H263Information : public VideoCodecInformation
 | |
| {
 | |
| public:
 | |
|     H263Information();
 | |
|     ~H263Information();
 | |
| 
 | |
|     /*******************************************************************************
 | |
|     * void Reset();
 | |
|     *
 | |
|     * Resets the members to zero.
 | |
|     *
 | |
|     */
 | |
|     virtual void Reset();
 | |
| 
 | |
|     virtual RtpVideoCodecTypes Type();
 | |
| 
 | |
|    /*******************************************************************************
 | |
|     * WebRtc_Word32 GetInfo(WebRtc_UWord8* ptrEncodedBuffer,
 | |
|     *             WebRtc_UWord32 length,
 | |
|     *             const H263Info*& ptrInfo);
 | |
|     *
 | |
|     * Gets information from an encoded stream.
 | |
|     *
 | |
|     * Input:
 | |
|     *          - ptrEncodedBuffer  : PoWebRtc_Word32er to encoded stream.
 | |
|     *          - length            : Length in bytes of encoded stream.
 | |
|     *
 | |
|     * Output:
 | |
|     *          - ptrInfo           : PoWebRtc_Word32er to struct with H263 info.
 | |
|     *
 | |
|     * Return value:
 | |
|     *          - 0                 : ok
 | |
|     *          - (-1)              : Error
 | |
|     */
 | |
|     virtual WebRtc_Word32 GetInfo(const WebRtc_UWord8* ptrEncodedBuffer,
 | |
|                                 const WebRtc_UWord32 length,
 | |
|                                 const H263Info*& ptrInfo);
 | |
| 
 | |
|     /*******************************************************************************
 | |
|     * WebRtc_Word32 GetMBInfo(const WebRtc_UWord8* ptrEncodedBuffer,
 | |
|     *               WebRtc_UWord32 length,
 | |
|     *               WebRtc_Word32 numOfGOB,
 | |
|     *               const H263MBInfo*& ptrInfoMB);
 | |
|     *
 | |
|     * Gets macroblock positions for a GOB.
 | |
|     * Also, the horizontal and vertical motion vector for each MB are returned.
 | |
|     *
 | |
|     * Input:
 | |
|     *          - ptrEncodedBuffer     : Pointer to encoded stream.
 | |
|     *          - length               : Length in bytes of encoded stream.
 | |
|     *          - numOfGOB             : Group number of current GOB.
 | |
|     *
 | |
|     * Output:
 | |
|     *          - ptrInfoMB            : Pointer to struct with MB positions in bits for a GOB.
 | |
|     *                                   Horizontal and vertical motion vector for each MB.
 | |
|     *
 | |
|     * Return value:
 | |
|     *          - 0                    : ok
 | |
|     *          - (-1)                 : Error
 | |
|     */
 | |
|     WebRtc_Word32 GetMBInfo(const WebRtc_UWord8* ptrEncodedBuffer,
 | |
|                   const WebRtc_UWord32 length,
 | |
|                   const WebRtc_UWord8 numOfGOB,
 | |
|                   const H263MBInfo*& ptrInfoMB);
 | |
| 
 | |
| protected:
 | |
|     bool HasInfo(const WebRtc_UWord32 length);
 | |
|     WebRtc_Word32  FindInfo(const WebRtc_UWord8* ptrEncodedBuffer, const WebRtc_UWord32 length);
 | |
| 
 | |
|     bool PictureStartCode();
 | |
|     WebRtc_Word32  FindPTypeFMT();
 | |
|     void FindFType();
 | |
|     void FindCodecBits();
 | |
|     void FindPQUANT();
 | |
|     void FindCPMbit();
 | |
|     WebRtc_Word32 SetNumOfMBs();
 | |
| 
 | |
|     WebRtc_Word32  FindGOBs(const WebRtc_UWord32 length);
 | |
| 
 | |
|     // MB info
 | |
|     WebRtc_Word32  VerifyAndAllocateMB();
 | |
|     bool HasMBInfo(const WebRtc_UWord8 numOfGOB);
 | |
|     WebRtc_Word32  FindMBs(const WebRtc_UWord8* ptrEncodedBuffer,
 | |
|                          const WebRtc_UWord8 numOfGOB,
 | |
|                          const WebRtc_UWord32 length);
 | |
| 
 | |
|     void FindGQUANT(WebRtc_Word32 numOfGOB);
 | |
|     WebRtc_Word32  FindMCBPC(WebRtc_Word32 &mbType, char *cbp);
 | |
|     WebRtc_Word32  FindCBPY(WebRtc_Word32 mbType, char *cbp);
 | |
|     WebRtc_Word32  FindMVD(WebRtc_Word32 numOfMB, WebRtc_Word32 verORhor, WebRtc_UWord8 *hmv1, WebRtc_UWord8 *vmv1);
 | |
|     WebRtc_Word32  FindTCOEF(WebRtc_Word32 &last);
 | |
|     bool IsGBSC();
 | |
|     WebRtc_UWord8 IsBitOne(const WebRtc_Word32 bitCnt) const;
 | |
|     void ByteAlignData(WebRtc_Word32 numOfBytes);
 | |
|     void OutputBits(WebRtc_Word32 length);
 | |
| 
 | |
| private:
 | |
|     WebRtc_Word32           _bitCnt;
 | |
|     const WebRtc_UWord8*    _ptrData;
 | |
|     WebRtc_UWord8           _dataShifted[5];
 | |
| 
 | |
|     H263Info          _info;
 | |
|     H263MBInfo        _infoMB;
 | |
| };
 | |
| } // namespace webrtc
 | |
| 
 | |
| #endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_H263_INFORMATION_H_
 | 
