input: rename vlc_input_event_times variables
[vlc.git] / src / input / decoder.h
blobf8dede8417956cb94206231802663179d1bfe00f
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 {
32 /* notifications */
33 void (*on_vout_started)(vlc_input_decoder_t *decoder, vout_thread_t *vout,
34 enum vlc_vout_order vout_order,
35 void *userdata);
36 void (*on_vout_stopped)(vlc_input_decoder_t *decoder, vout_thread_t *vout,
37 void *userdata);
38 void (*on_thumbnail_ready)(vlc_input_decoder_t *decoder, picture_t *pic,
39 void *userdata);
41 void (*on_new_video_stats)(vlc_input_decoder_t *decoder, unsigned decoded,
42 unsigned lost, unsigned displayed, unsigned late,
43 void *userdata);
44 void (*on_new_audio_stats)(vlc_input_decoder_t *decoder, unsigned decoded,
45 unsigned lost, unsigned played, void *userdata);
47 /* requests */
48 int (*get_attachments)(vlc_input_decoder_t *decoder,
49 input_attachment_t ***ppp_attachment,
50 void *userdata);
53 vlc_input_decoder_t *
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;
59 /**
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 );
66 /**
67 * Changes the decoder rate.
69 * This function changes rate of the intended playback speed to nominal speed.
70 * \param dec decoder
71 * \param rate playback rate (default is 1)
73 void vlc_input_decoder_ChangeRate( vlc_input_decoder_t *dec, float rate );
75 /**
76 * This function changes the delay.
78 void vlc_input_decoder_ChangeDelay( vlc_input_decoder_t *, vlc_tick_t i_delay );
80 /**
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 * );
85 /**
86 * This function waits for the decoder to actually receive data.
88 void vlc_input_decoder_Wait( vlc_input_decoder_t * );
90 /**
91 * This function exits the waiting mode of the decoder.
93 void vlc_input_decoder_StopWait( vlc_input_decoder_t * );
95 /**
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
118 * time consumed.
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
127 * vlc_meta_Delete.
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 );
145 #endif