/***************************************************************************** * * SVC4DSP developped in IETR image lab * * * * Médéric BLESTEL <mblestel@insa-rennes.Fr> * Mickael RAULET <mraulet@insa-rennes.Fr> * http://www.ietr.org/ * * * * * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * * $Id$ * **************************************************************************/ #ifndef _SVCDecoder_ietr_api_h #define _SVCDecoder_ietr_api_h #include "SvcInterface.h" enum { SVC_STATUS_ERROR = -1, SVC_STATUS_OK = 0, // no error and no frame ready SVC_IMAGE_READY = 1, // no error and image ready SVC_GHOST_IMAGE = 2 // no image for chosen layer but image could be ready for other layers }; /*====================================================================================================== int SVCDecoder_init(); This method initializes the internal resources of the decoder @return SVC_STATUS_OK if creation is successful ======================================================================================================*/ int SVCDecoder_init(void **PlayerStruct); /*====================================================================================================== void UpdateLayer(int *DqIdTable, int *CurrDqId, int MaxDqId, int Command); Use this method to change of quality, spatial or temporal scalability during the decoding process. The DqIdTable specifies the DqId of each layer present into the stream. CurrDqId specifies the DqId of the current layer. MaxDqId specifies the maximal DqId present into the access unit. Command specifies the action to execute: 0: To switch down of spatial or quality scalability 1: To switch up of spatial or quality scalability 2: To switch up to the layer with the higthest DqId 3: To switch down of temporal scalability 4: To switch up of temporal scalability @return nothing =======================================================================================================*/ void UpdateLayer(int *DqIdTable, int *CurrDqId, int *TemporalCom, int *TemporalId, int MaxDqId, int Command); /*====================================================================================================== void SetCommandLayer(int *Command, int DqIdMax, int CurrDqId, int *TemporalCom, int TemporalId); Use this method to generate the right command for the SVC decoder. The Command is a 4 size table given to the decoder. DqIdMax specifies the maximal DqId present into the access unit. CurrDqId specifies the DqId of the current layer. TemporalCom is the command to use concerning the temporal scalability. 0 -> do nothing 1 -> decode a lower temporal scalability. 2 -> decode a highter temporal scalability. 3 -> define a specific temporal scalability. (use TemporalId variable to set). @return nothing =======================================================================================================*/ void SetCommandLayer(int *Command, int DqIdMax, int CurrDqId, int *TemporalCom, int TemporalId); /*====================================================================================================== int decodeNAL( unsigned char* nal, int nal_length, OPENSVCFRAME *Frame, int DqIdMax); Use this method to give a new NAL Unit to the decoder. The NAL content (no start code) is stored at the address given by the argument pNAL and the length of the NAL is provided by the argument nal_length. Memory of this nal buffer is managed by the application. If the function returns the code SVC_IMAGE_READY, this means that an image is ready and in this case, the arguments *Frame has been updated by the decoder and the image plans are contained at the addresses pY, PU, pV. The image stored at these location is an image centered in a rectangle of size (*pWidth + 32, *pHeight + 32) for Y and ((*pWidth + 32) / 2, (*pHeight + 32) / 2)) for U and V. Memory of these image buffers is managed by the decoder. In case of a SVC stream, the largest DqIq of the Access Unit should be given. @param nal is the address of the buffer that contains the NAL unit @param nal_length is the size of NAL Unit data @param Frame Contains all parameters from the displayed picture @param DQIdMax is the largest DQId of the current access unit @return SVC_STATUS_OK or SVC_STATUS_ERROR or SVC_IMAGE_READY or SVC_GHOST_IMAGE ======================================================================================================*/ int decodeNAL(void *PlayerStruct, unsigned char* nal, int nal_length, OPENSVCFRAME *Frame, int *LayerCommand); /*====================================================================================================== int SVCDecoder_close(); This method releases the internal resources of the decoder @return SVC_STATUS_OK if creation is successfull =======================================================================================================*/ int SVCDecoder_close(void *PlayerStruct); /*====================================================================================================== int GetDqIdMax(const unsigned char *buf, int buf_size, int nal_length_size, int *DqidTable, int is_avc); This method return the max DqId commputed into the access unit. This method should be called once in each access unit. @param buf is the input data to decode @param buf_size is the size of access unit @param nal_length_size is the start code length @param DqidTable is a table in which all DqId will be stored. @param is_avc indicates if the stream contained SVC NAL. =======================================================================================================*/ int GetDqIdMax(const unsigned char *buf, int buf_size, int nal_length_size, int *DqidTable, int is_avc); /*====================================================================================================== void ParseAuPlayers(void *PlayerStruct, const unsigned char *buf, int buf_size, int nal_length_size, int is_avc; This method parses the first access unit in order to configure the decoder. This method has to be done once by video. @param buf is the input data to decode @param buf_size is the size of access unit @param nal_length_size is the start code length @param is_avc indicates if the stream contained SVC NAL. =======================================================================================================*/ void ParseAuPlayers(void *PlayerStruct, const unsigned char *buf, int buf_size, int nal_length_size, int is_avc); #endif // SVCDecoder_ietr_api