2008-07-29 23:46:06 -07:00
|
|
|
/*
|
|
|
|
Copyright (C) 2003 Commonwealth Scientific and Industrial Research
|
|
|
|
Organisation (CSIRO) Australia
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
|
|
|
|
- Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
|
|
|
|
- Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
|
|
|
|
- Neither the name of CSIRO Australia nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived from
|
|
|
|
this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
|
|
|
PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ORGANISATION OR
|
|
|
|
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
|
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
|
|
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
|
|
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
|
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/** @file
|
2008-07-29 23:46:06 -07:00
|
|
|
* oggplay_callback_info.h
|
|
|
|
*
|
2009-09-23 21:22:23 -07:00
|
|
|
* @authors
|
2008-07-29 23:46:06 -07:00
|
|
|
* Shane Stephens <shane.stephens@annodex.net>
|
2009-09-23 21:22:23 -07:00
|
|
|
* Michael Martin
|
|
|
|
* Viktor Gal
|
2008-07-29 23:46:06 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __OGGPLAY_CALLBACK_INFO__
|
|
|
|
#define __OGGPLAY_CALLBACK_INFO__
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/** structure for storing a YUV video frame */
|
2008-07-29 23:46:06 -07:00
|
|
|
typedef struct {
|
2009-09-23 21:22:23 -07:00
|
|
|
unsigned char * y; /**< Y-plane */
|
|
|
|
unsigned char * u; /**< U-plane*/
|
|
|
|
unsigned char * v; /**< V-plane */
|
2008-07-29 23:46:06 -07:00
|
|
|
} OggPlayVideoData;
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/** structure for storing a video frame in RGB fromat */
|
2009-04-03 05:56:22 -07:00
|
|
|
typedef struct {
|
2009-09-23 21:22:23 -07:00
|
|
|
unsigned char * rgba; /**< may be NULL if no alpha */
|
|
|
|
unsigned char * rgb; /**< may be NULL if alpha */
|
|
|
|
size_t width; /**< width in pixels */
|
|
|
|
size_t height; /**< height in pixels */
|
|
|
|
size_t stride; /**< stride */
|
2009-04-03 05:56:22 -07:00
|
|
|
} OggPlayOverlayData;
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/** Type for representing audio data */
|
2008-07-29 23:46:06 -07:00
|
|
|
typedef void * OggPlayAudioData;
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/** Type for representing text data */
|
2008-07-29 23:46:06 -07:00
|
|
|
typedef char OggPlayTextData;
|
|
|
|
|
|
|
|
struct _OggPlayDataHeader;
|
2009-09-23 21:22:23 -07:00
|
|
|
/** Header for the various data formats */
|
2008-07-29 23:46:06 -07:00
|
|
|
typedef struct _OggPlayDataHeader OggPlayDataHeader;
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Get the data type of the given OggPlayCallbackInfo.
|
|
|
|
*
|
|
|
|
* @param info
|
|
|
|
* @returns The data type of the given OggPlayCallbackInfo
|
|
|
|
* @see OggPlayDataType
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayDataType
|
|
|
|
oggplay_callback_info_get_type(OggPlayCallbackInfo *info);
|
2009-09-23 21:22:23 -07:00
|
|
|
|
2008-07-29 23:46:06 -07:00
|
|
|
int
|
|
|
|
oggplay_callback_info_get_available(OggPlayCallbackInfo *info);
|
2009-09-23 21:22:23 -07:00
|
|
|
|
|
|
|
|
2008-07-29 23:46:06 -07:00
|
|
|
int
|
|
|
|
oggplay_callback_info_get_required(OggPlayCallbackInfo *info);
|
2009-09-23 21:22:23 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the array of records stored in the OggPlayCallbackInfo
|
|
|
|
*
|
|
|
|
* @param info
|
|
|
|
* @returns array of records
|
|
|
|
* @retval NULL if the supplied OggPlayCallbackInfo is a NULL pointer
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayDataHeader **
|
|
|
|
oggplay_callback_info_get_headers(OggPlayCallbackInfo *info);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Get the size of the given record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns The number of samples in the record.
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
ogg_int64_t
|
|
|
|
oggplay_callback_info_get_record_size(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Extract the video frame from the supplied record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns the video frame
|
|
|
|
* @retval NULL if the supplied OggPlayCallbackInfo is a NULL pointer
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayVideoData *
|
|
|
|
oggplay_callback_info_get_video_data(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Extract the overlay data from the supplied record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns OggPlayOverlayData
|
|
|
|
* @retval NULL if the supplied OggPlayCallbackInfo is a NULL pointer
|
|
|
|
*/
|
2009-04-03 05:56:22 -07:00
|
|
|
OggPlayOverlayData *
|
|
|
|
oggplay_callback_info_get_overlay_data(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Extract the audio data from the supplied record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns OggPlayAudioData.
|
|
|
|
* @retval NULL if the supplied OggPlayCallbackInfo is a NULL pointer
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayAudioData *
|
|
|
|
oggplay_callback_info_get_audio_data(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Extract the text data from the supplied record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns OggPlayTextData
|
|
|
|
* @retval NULL if the supplied OggPlayCallbackInfo is a NULL pointer
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayTextData *
|
|
|
|
oggplay_callback_info_get_text_data(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Get the state of the stream.
|
|
|
|
*
|
|
|
|
* @param info
|
|
|
|
* @returns State of the given stream.
|
|
|
|
* @see OggPlayStreamInfo
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
OggPlayStreamInfo
|
|
|
|
oggplay_callback_info_get_stream_info(OggPlayCallbackInfo *info);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
|
2008-07-29 23:46:06 -07:00
|
|
|
void
|
|
|
|
oggplay_callback_info_lock_item(OggPlayDataHeader *header);
|
|
|
|
|
|
|
|
void
|
|
|
|
oggplay_callback_info_unlock_item(OggPlayDataHeader *header);
|
|
|
|
|
2009-09-23 21:22:23 -07:00
|
|
|
/**
|
|
|
|
* Get the presentation time of the given record.
|
|
|
|
*
|
|
|
|
* @param header
|
|
|
|
* @returns presentation time of the given frame in milliseconds.
|
|
|
|
*/
|
2008-07-29 23:46:06 -07:00
|
|
|
long
|
|
|
|
oggplay_callback_info_get_presentation_time(OggPlayDataHeader *header);
|
|
|
|
|
|
|
|
#endif
|