Allow code to pass data to filters it creates.
[ffmpeg-lucabe.git] / libavfilter / avfilter.h
bloba508e7387de8474ee43e4d8c8013ec2beb1b5a2a
1 /*
2 * Filter layer
3 * copyright (c) 2007 Bobby Bingham
5 * This file is part of FFmpeg.
7 * FFmpeg is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * FFmpeg is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with FFmpeg; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 #ifndef FFMPEG_AVFILTER_H
23 #define FFMPEG_AVFILTER_H
25 #include "avcodec.h"
27 typedef struct AVFilterContext AVFilterContext;
28 typedef struct AVFilterLink AVFilterLink;
29 typedef struct AVFilterPad AVFilterPad;
31 /* TODO: look for other flags which may be useful in this structure (interlace
32 * flags, etc)
34 /**
35 * A reference-counted picture data type used by the filter system. Filters
36 * should not store pointers to this structure directly, but instead use the
37 * AVFilterPicRef structure below
39 typedef struct AVFilterPic
41 uint8_t *data[4];
42 int linesize[4]; ///< number of bytes per line
43 enum PixelFormat format;
45 unsigned refcount;
46 void *priv;
47 void (*free)(struct AVFilterPic *pic);
48 } AVFilterPic;
50 /**
51 * A reference to an AVFilterPic. Since filters can manipulate the origin of
52 * a picture to, for example, crop image without any memcpy, the picture origin
53 * and dimensions are per-reference properties. Linesize is also useful for
54 * image flipping, frame to field filters, etc, and so is also per-reference.
56 * TODO: add anything necessary for frame reordering
58 typedef struct AVFilterPicRef
60 AVFilterPic *pic;
61 uint8_t *data[4];
62 int linesize[4];
63 int w, h;
65 int64_t pts; ///< presentation timestamp in milliseconds
67 int perms; ///< permissions
68 #define AV_PERM_READ 0x01 ///< can read from the buffer
69 #define AV_PERM_WRITE 0x02 ///< can write to the buffer
70 #define AV_PERM_PRESERVE 0x04 ///< nobody else can overwrite the buffer
71 #define AV_PERM_REUSE 0x08 ///< can output the buffer multiple times
72 } AVFilterPicRef;
74 /**
75 * Add a new reference to a picture.
76 * @param ref An existing reference to the picture
77 * @param pmask A bitmask containing the allowable permissions in the new reference
78 * @return A new reference to the picture with the same properties as the old
80 AVFilterPicRef *avfilter_ref_pic(AVFilterPicRef *ref, int pmask);
82 /**
83 * Remove a reference to a picture. If this is the last reference to the
84 * picture, the picture itself is also automatically freed.
85 * @param ref Reference to the picture.
87 void avfilter_unref_pic(AVFilterPicRef *ref);
89 struct AVFilterPad
91 /**
92 * Pad name. The name is unique among inputs and among oututs, but an
93 * input may have the same name as an output.
95 char *name;
97 /**
98 * AVFilterPad type. Only video supported now, hopefully someone will
99 * add audio in the future.
101 int type;
102 #define AV_PAD_VIDEO 0
105 * Callback to get a list of supported formats. The returned list should
106 * be terminated by -1. This is used for both input and output pads and
107 * is required for both.
109 int *(*query_formats)(AVFilterLink *link);
112 * Callback called before passing the first slice of a new frame. If
113 * NULL, the filter layer will default to storing a reference to the
114 * picture inside the link structure.
116 void (*start_frame)(AVFilterLink *link, AVFilterPicRef *picref);
119 * Callback function to get a buffer. If NULL, the filter system will
120 * handle buffer requests. Only required for input video pads.
122 AVFilterPicRef *(*get_video_buffer)(AVFilterLink *link, int perms);
125 * Callback called after the slices of a frame are completely sent. If
126 * NULL, the filter layer will default to releasing the reference stored
127 * in the link structure during start_frame().
129 void (*end_frame)(AVFilterLink *link);
132 * Slice drawing callback. This is where a filter receives video data
133 * and should do its processing. Only required for input video pads.
135 void (*draw_slice)(AVFilterLink *link, uint8_t *data[4], int y, int height);
138 * Frame request callback. A call to this should result in at least one
139 * frame being output over the given link. Video output pads only.
141 void (*request_frame)(AVFilterLink *link);
144 * Link configuration callback. For output pads, this should set the link
145 * properties such as width/height. NOTE: this should not set the format
146 * property - that is negotiated between filters by the filter system using
147 * the query_formats() callback.
149 * For input pads, this should check the properties of the link, and update
150 * the filter's internal state as necessary.
152 int (*config_props)(AVFilterLink *link);
155 /* the default implementations of start_frame() and end_frame() */
156 void avfilter_default_start_frame(AVFilterLink *link, AVFilterPicRef *picref);
157 void avfilter_default_end_frame(AVFilterLink *link);
159 typedef struct
161 char *name;
162 char *author;
164 int priv_size;
167 * Filter initialization function. Args contains the user-supplied
168 * parameters. FIXME: maybe an AVOption-based system would be better?
169 * opaque is data provided by the code requesting creation of the filter,
170 * and is used to pass data to the filter.
172 int (*init)(AVFilterContext *ctx, const char *args, const void *opaque);
173 void (*uninit)(AVFilterContext *ctx);
175 const AVFilterPad *inputs; /// NULL terminated list of inputs. NULL if none
176 const AVFilterPad *outputs; /// NULL terminated list of outputs. NULL if none
177 } AVFilter;
179 struct AVFilterContext
181 AVClass *av_class;
183 AVFilter *filter;
185 char *name;
187 AVFilterLink **inputs;
188 AVFilterLink **outputs;
190 void *priv;
193 struct AVFilterLink
195 AVFilterContext *src;
196 unsigned int srcpad;
198 AVFilterContext *dst;
199 unsigned int dstpad;
201 int w, h;
202 enum PixelFormat format;
204 AVFilterPicRef *cur_pic;
205 AVFilterPicRef *outpic;
208 /** Link two filters together */
209 int avfilter_link(AVFilterContext *src, unsigned srcpad,
210 AVFilterContext *dst, unsigned dstpad);
212 AVFilterPicRef *avfilter_get_video_buffer(AVFilterLink *link, int perms);
213 void avfilter_request_frame(AVFilterLink *link);
214 void avfilter_start_frame(AVFilterLink *link, AVFilterPicRef *picref);
215 void avfilter_end_frame(AVFilterLink *link);
216 void avfilter_draw_slice(AVFilterLink *link, uint8_t *data[4], int y, int h);
218 void avfilter_init(void);
219 void avfilter_uninit(void);
220 void avfilter_register(AVFilter *filter);
221 AVFilter *avfilter_get_by_name(char *name);
223 AVFilterContext *avfilter_create(AVFilter *filter, char *inst_name);
224 AVFilterContext *avfilter_create_by_name(char *name, char *inst_name);
225 int avfilter_init_filter(AVFilterContext *filter, const char *args, void *opaque);
226 void avfilter_destroy(AVFilterContext *filter);
228 int *avfilter_make_format_list(int len, ...);
230 #endif /* FFMPEG_AVFILTER_H */