Go to the source code of this file.
|
static int | apply_unsharp_c (AVFilterContext *ctx, AVFrame *in, AVFrame *out) |
|
static void | set_filter_param (UnsharpFilterParam *fp, int msize_x, int msize_y, float amount) |
|
static av_cold int | init (AVFilterContext *ctx) |
|
static int | init_filter_param (AVFilterContext *ctx, UnsharpFilterParam *fp, const char *effect_type, int width) |
|
static int | config_input (AVFilterLink *inlink) |
|
static void | free_filter_param (UnsharpFilterParam *fp, int nb_threads) |
|
static av_cold void | uninit (AVFilterContext *ctx) |
|
static int | filter_frame (AVFilterLink *link, AVFrame *in) |
|
| AVFILTER_DEFINE_CLASS (unsharp) |
|
blur / sharpen filter, ported to FFmpeg from MPlayer libmpcodecs/unsharp.c.
This code is based on:
An Efficient algorithm for Gaussian blur using finite-state machines Frederick M. Waltz and John W. V. Miller
SPIE Conf. on Machine Vision Systems for Inspection and Metrology VII Originally published Boston, Nov 98
http://www.engin.umd.umich.edu/~jwvm/ece581/21_GBlur.pdf
Definition in file vf_unsharp.c.
◆ DEF_UNSHARP_SLICE_FUNC
#define DEF_UNSHARP_SLICE_FUNC |
( |
|
name, |
|
|
|
nbits |
|
) |
| |
◆ OFFSET
◆ FLAGS
◆ MIN_SIZE
◆ MAX_SIZE
◆ apply_unsharp_c()
◆ set_filter_param()
◆ init()
◆ init_filter_param()
◆ config_input()
◆ free_filter_param()
◆ uninit()
◆ filter_frame()
◆ AVFILTER_DEFINE_CLASS()
AVFILTER_DEFINE_CLASS |
( |
unsharp |
| ) |
|
◆ pix_fmts
◆ unsharp_options
◆ avfilter_vf_unsharp_inputs
Initial value:= {
{
.name = "default",
},
}
Definition at line 334 of file vf_unsharp.c.
◆ avfilter_vf_unsharp_outputs
Initial value:= {
{
.name = "default",
},
}
Definition at line 343 of file vf_unsharp.c.
◆ ff_vf_unsharp
Initial value:= {
.name = "unsharp",
.priv_class = &unsharp_class,
}
Definition at line 350 of file vf_unsharp.c.
#define FILTER_PIXFMTS_ARRAY(array)
#define AV_PIX_FMT_YUV420P10
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
static av_cold void uninit(AVFilterContext *ctx)
static int filter_frame(AVFilterLink *link, AVFrame *in)
static int config_input(AVFilterLink *inlink)
#define AV_PIX_FMT_YUV422P9
static av_cold int init(AVFilterContext *ctx)
#define AV_PIX_FMT_YUV444P10
#define AV_PIX_FMT_YUV422P16
@ AV_PIX_FMT_YUVJ422P
planar YUV 4:2:2, 16bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV422P and setting col...
#define AV_PIX_FMT_YUV444P16
#define AV_PIX_FMT_YUV420P9
#define AV_PIX_FMT_YUV420P16
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
#define FILTER_INPUTS(array)
@ AV_PIX_FMT_YUVJ444P
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
@ AV_PIX_FMT_YUVJ420P
planar YUV 4:2:0, 12bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV420P and setting col...
#define AV_PIX_FMT_YUV440P10
#define AV_PIX_FMT_YUV422P10
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
#define AV_PIX_FMT_YUV422P12
#define AV_PIX_FMT_YUV444P12
#define AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC
Some filters support a generic "enable" expression option that can be used to enable or disable a fil...
static const AVFilterPad avfilter_vf_unsharp_outputs[]
static enum AVPixelFormat pix_fmts[]
@ AV_PIX_FMT_YUVJ440P
planar YUV 4:4:0 full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV440P and setting color_range
#define AV_PIX_FMT_YUV444P9
#define AV_PIX_FMT_YUV420P12
static const AVFilterPad avfilter_vf_unsharp_inputs[]
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
#define AVFILTER_FLAG_SLICE_THREADS
The filter supports multithreading by splitting frames into multiple parts and processing them concur...
@ AV_PIX_FMT_YUV422P
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
#define FILTER_OUTPUTS(array)
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
@ AV_PIX_FMT_YUV410P
planar YUV 4:1:0, 9bpp, (1 Cr & Cb sample per 4x4 Y samples)
#define AV_PIX_FMT_YUV440P12