26 #define VLC_FILTER_H 1 80 bool b_allow_fmt_out_change;
96 void (*pf_video_blend)( filter_t *,
picture_t *,
const picture_t *,
173 msg_Warn( p_filter,
"can't get output picture" );
219 msg_Warn( p_filter,
"can't get output subpicture" );
235 ppp_attachment, pi_attachment );
247 # define filter_AddProxyCallbacks(a, b, c) \ 248 filter_AddProxyCallbacks(VLC_OBJECT(a), b, c) 258 # define filter_DelProxyCallbacks(a, b, c) \ 259 filter_DelProxyCallbacks(VLC_OBJECT(a), b, c) 295 #define VIDEO_FILTER_WRAPPER( name ) \ 296 static picture_t *name ## _Filter ( filter_t *p_filter, \ 299 picture_t *p_outpic = filter_NewPicture( p_filter ); \ 302 name( p_filter, p_pic, p_outpic ); \ 303 picture_CopyProperties( p_outpic, p_pic ); \ 305 picture_Release( p_pic ); \ 326 #define filter_chain_NewSPU( a, b ) filter_chain_NewSPU( VLC_OBJECT( a ), b ) 339 #define filter_chain_NewVideo( a, b, c ) \ 340 filter_chain_NewVideo( VLC_OBJECT( a ), b, c ) 473 int (*cb)(
filter_t *,
void * ),
void *opaque );
This file defines picture structures and functions in vlc.
const es_format_t * filter_chain_GetFmtOut(const filter_chain_t *chain)
Get last output format of the last element in the filter chain.
Definition: filter_chain.c:390
static int filter_GetInputAttachments(filter_t *p_filter, input_attachment_t ***ppp_attachment, int *pi_attachment)
This function gives all input attachments at once.
Definition: vlc_filter.h:229
void filter_chain_VideoFlush(filter_chain_t *)
Flush a video filter chain.
Definition: filter_chain.c:444
int filter_chain_ForEach(filter_chain_t *chain, int(*cb)(filter_t *, void *), void *opaque)
Definition: filter_chain.c:373
Video picture.
Definition: vlc_picture.h:126
filter_owner_t owner
Private structure for the owner of the filter.
Definition: vlc_filter.h:151
es_format_t fmt_out
Definition: vlc_filter.h:80
#define filter_chain_NewSPU(a, b)
Definition: vlc_filter.h:327
Video subtitle region.
Definition: vlc_subpicture.h:59
int(* pf_get_attachments)(filter_t *, input_attachment_t ***, int *)
Definition: vlc_filter.h:148
void(* pf_change_viewpoint)(filter_t *, const vlc_viewpoint_t *)
Change viewpoint.
Definition: vlc_filter.h:130
block_t *(* pf_audio_drain)(filter_t *)
Drain (audio filter)
Definition: vlc_filter.h:115
es_format_t fmt_in
Chain input format (constant)
Definition: filter_chain.c:53
int filter_chain_AppendFromString(filter_chain_t *chain, const char *str)
Append new filter to filter chain from string.
Definition: filter_chain.c:328
Video subtitle.
Definition: vlc_subpicture.h:166
void filter_DeleteBlend(vlc_blender_t *)
It destroys a blend filter created by filter_NewBlend.
Definition: filter.c:171
Internal module descriptor.
Definition: modules.h:75
subpicture_t * filter_chain_SubFilter(filter_chain_t *chain, subpicture_t *subpic)
Apply filter chain to subpictures.
Definition: filter_chain.c:469
subpicture_t *(* buffer_new)(filter_t *)
Definition: vlc_filter.h:48
#define msg_Warn(p_this,...)
Definition: vlc_messages.h:104
static block_t * filter_DrainAudio(filter_t *p_filter)
This function will drain, then flush an audio filter.
Definition: vlc_filter.h:199
picture_t * filter_chain_VideoFilter(filter_chain_t *chain, picture_t *pic)
Apply the filter chain to a video picture.
Definition: filter_chain.c:421
static picture_t * filter_NewPicture(filter_t *p_filter)
This function will return a new picture usable by p_filter as an output buffer.
Definition: vlc_filter.h:163
int64_t vlc_tick_t
High precision date or time interval.
Definition: vlc_tick.h:45
Definition: vlc_configuration.h:331
uint32_t vlc_fourcc_t
Definition: fourcc_gen.c:33
void filter_chain_Reset(filter_chain_t *, const es_format_t *, const es_format_t *)
Reset filter chain will delete all filters in the chain and reset p_fmt_in and p_fmt_out to the new v...
Definition: filter_chain.c:173
Viewpoints.
Definition: vlc_viewpoint.h:41
bool filter_chain_IsEmpty(const filter_chain_t *chain)
Checks if the filter chain is empty.
Definition: filter_chain.c:385
void filter_chain_DeleteFilter(filter_chain_t *chain, filter_t *filter)
Delete filter from filter chain.
Definition: filter_chain.c:293
#define filter_chain_NewVideo(a, b, c)
Definition: vlc_filter.h:340
filter_t * filter_chain_AppendFilter(filter_chain_t *chain, const char *name, config_chain_t *cfg, const es_format_t *fmt_in, const es_format_t *fmt_out)
Append a filter to the chain.
Definition: filter_chain.c:278
picture_t *(* buffer_new)(filter_t *)
Definition: vlc_filter.h:43
picture_t * picture_NewFromFormat(const video_format_t *restrict fmt)
Definition: picture.c:251
int filter_chain_AppendConverter(filter_chain_t *chain, const es_format_t *fmt_in, const es_format_t *fmt_out)
Append a conversion to the chain.
Definition: filter_chain.c:286
const char name[16]
Definition: httpd.c:1236
Mouse state.
Definition: vlc_mouse.h:45
void filter_chain_Clear(filter_chain_t *)
Remove all existing filters.
Definition: filter_chain.c:152
struct filter_owner_t filter_owner_t
int filter_Blend(vlc_blender_t *, picture_t *p_dst, int i_dst_x, int i_dst_y, const picture_t *p_src, int i_alpha)
It blends a picture into another one.
Definition: filter.c:160
#define filter_DelProxyCallbacks(a, b, c)
Definition: vlc_filter.h:259
Definition: vlc_filter.h:41
#define VLC_API
Definition: fourcc_gen.c:31
int filter_ConfigureBlend(vlc_blender_t *, int i_dst_width, int i_dst_height, const video_format_t *p_src)
It configures blend filter parameters that are allowed to changed after the creation.
Definition: filter.c:128
filter_t vlc_blender_t
Definition: vlc_filter.h:262
Subpicture unit descriptor.
Definition: vlc_spu.h:47
const struct filter_subpicture_callbacks * sub
Definition: vlc_filter.h:56
const char * psz_name
Definition: vlc_codecs.h:313
#define VLC_EGENERIC
Unspecified error.
Definition: vlc_common.h:472
Structure describing a filter.
Definition: vlc_filter.h:68
int(* vlc_callback_t)(vlc_object_t *, char const *, vlc_value_t, vlc_value_t, void *)
Definition: vlc_common.h:491
const struct filter_video_callbacks * video
Definition: vlc_filter.h:55
Definition: vlc_block.h:117
Definition: vlc_filter.h:46
Definition: filter_chain.c:46
static void filter_ChangeViewpoint(filter_t *p_filter, const vlc_viewpoint_t *vp)
Definition: vlc_filter.h:189
vlc_blender_t * filter_NewBlend(vlc_object_t *, const video_format_t *p_dst_chroma)
It creates a blend filter.
Definition: filter.c:104
static subpicture_t * filter_NewSubpicture(filter_t *p_filter)
This function will return a new subpicture usable by p_filter as an output buffer.
Definition: vlc_filter.h:216
static void filter_Flush(filter_t *p_filter)
Flush a filter.
Definition: vlc_filter.h:183
This file defines the elementary streams format types.
es_format_t fmt_out
Chain current output format.
Definition: filter_chain.c:54
VLC object common members.
Definition: vlc_objects.h:43
void(* pf_flush)(filter_t *)
Flush.
Definition: vlc_filter.h:122
int filter_chain_MouseFilter(filter_chain_t *, struct vlc_mouse_t *, const struct vlc_mouse_t *)
Apply the filter chain to a mouse state.
Definition: vlc_filter.h:51
#define VLC_USED
Definition: fourcc_gen.c:32
#define filter_AddProxyCallbacks(a, b, c)
Definition: vlc_filter.h:248
void filter_chain_SubSource(filter_chain_t *chain, spu_t *, vlc_tick_t display_date)
Generate subpictures from a chain of subpicture source "filters".
Definition: filter_chain.c:457
void filter_chain_Delete(filter_chain_t *)
Delete filter chain will delete all filters in the chain and free all allocated data.
Definition: filter_chain.c:161