1 /*****************************************************************************
2 * decoder.h: Input decoder functions
3 *****************************************************************************
4 * Copyright (C) 1998-2008 VLC authors and VideoLAN
5 * Copyright (C) 2008 Laurent Aimar
7 * Authors: Laurent Aimar <fenrir@via.ecp.fr>
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU Lesser General Public License as published by
11 * the Free Software Foundation; either version 2.1 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public License
20 * along with this program; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22 *****************************************************************************/
24 #ifndef LIBVLC_INPUT_DECODER_H
25 #define LIBVLC_INPUT_DECODER_H 1
27 #include <vlc_common.h>
28 #include <vlc_codec.h>
29 #include <vlc_mouse.h>
31 struct vlc_input_decoder_callbacks
{
33 void (*on_vout_started
)(vlc_input_decoder_t
*decoder
, vout_thread_t
*vout
,
34 enum vlc_vout_order vout_order
,
36 void (*on_vout_stopped
)(vlc_input_decoder_t
*decoder
, vout_thread_t
*vout
,
38 void (*on_thumbnail_ready
)(vlc_input_decoder_t
*decoder
, picture_t
*pic
,
41 void (*on_new_video_stats
)(vlc_input_decoder_t
*decoder
, unsigned decoded
,
42 unsigned lost
, unsigned displayed
, unsigned late
,
44 void (*on_new_audio_stats
)(vlc_input_decoder_t
*decoder
, unsigned decoded
,
45 unsigned lost
, unsigned played
, void *userdata
);
48 int (*get_attachments
)(vlc_input_decoder_t
*decoder
,
49 input_attachment_t
***ppp_attachment
,
54 vlc_input_decoder_New( vlc_object_t
*parent
, es_format_t
*, vlc_clock_t
*,
55 input_resource_t
*, sout_instance_t
*, bool thumbnailing
,
56 const struct vlc_input_decoder_callbacks
*cbs
,
57 void *userdata
) VLC_USED
;
60 * This function changes the pause state.
61 * The date parameter MUST hold the exact date at which the change has been
62 * done for proper vout/aout pausing.
64 void vlc_input_decoder_ChangePause( vlc_input_decoder_t
*, bool b_paused
, vlc_tick_t i_date
);
67 * Changes the decoder rate.
69 * This function changes rate of the intended playback speed to nominal speed.
71 * \param rate playback rate (default is 1)
73 void vlc_input_decoder_ChangeRate( vlc_input_decoder_t
*dec
, float rate
);
76 * This function changes the delay.
78 void vlc_input_decoder_ChangeDelay( vlc_input_decoder_t
*, vlc_tick_t i_delay
);
81 * This function makes the decoder start waiting for a valid data block from its fifo.
83 void vlc_input_decoder_StartWait( vlc_input_decoder_t
* );
86 * This function waits for the decoder to actually receive data.
88 void vlc_input_decoder_Wait( vlc_input_decoder_t
* );
91 * This function exits the waiting mode of the decoder.
93 void vlc_input_decoder_StopWait( vlc_input_decoder_t
* );
96 * This function returns true if the decoder fifo is empty and false otherwise.
98 bool vlc_input_decoder_IsEmpty( vlc_input_decoder_t
* );
101 * This function activates the request closed caption channel.
103 int vlc_input_decoder_SetCcState( vlc_input_decoder_t
*, vlc_fourcc_t
, int i_channel
, bool b_decode
);
106 * This function returns an error if the requested channel does not exist and
107 * set pb_decode to the channel status(active or not) otherwise.
109 int vlc_input_decoder_GetCcState( vlc_input_decoder_t
*, vlc_fourcc_t
, int i_channel
, bool *pb_decode
);
112 * This function get cc channels descriptions
114 void vlc_input_decoder_GetCcDesc( vlc_input_decoder_t
*, decoder_cc_desc_t
* );
117 * This function force the display of the next picture and fills the stream
120 void vlc_input_decoder_FrameNext( vlc_input_decoder_t
*p_dec
, vlc_tick_t
*pi_duration
);
123 * This function will return true if the ES format or meta data have changed since
124 * the last call. In which case, it will do a copy of the current es_format_t if p_fmt
125 * is not NULL and will do a copy of the current description if pp_meta is non NULL.
126 * The es_format_t MUST be freed by es_format_Clean and *pp_meta MUST be freed by
128 * Otherwise it will return false and will not initialize p_fmt and *pp_meta.
130 bool vlc_input_decoder_HasFormatChanged( vlc_input_decoder_t
*p_dec
, es_format_t
*p_fmt
, vlc_meta_t
**pp_meta
);
133 * This function returns the current size in bytes of the decoder fifo
135 size_t vlc_input_decoder_GetFifoSize( vlc_input_decoder_t
*p_dec
);
137 int vlc_input_decoder_GetVbiPage( vlc_input_decoder_t
*, bool *opaque
);
138 int vlc_input_decoder_SetVbiPage( vlc_input_decoder_t
*, unsigned page
);
139 int vlc_input_decoder_SetVbiOpaque( vlc_input_decoder_t
*, bool opaque
);
141 void vlc_input_decoder_SetVoutMouseEvent( vlc_input_decoder_t
*, vlc_mouse_event
, void * );
142 int vlc_input_decoder_AddVoutOverlay( vlc_input_decoder_t
*, subpicture_t
*, size_t * );
143 int vlc_input_decoder_DelVoutOverlay( vlc_input_decoder_t
*, size_t );