#include <float.h>
#include "libavutil/opt.h"
#include "libavutil/imgutils.h"
#include "avfilter.h"
#include "formats.h"
#include "internal.h"
#include "video.h"
Go to the source code of this file.
|
static int | average_slice8 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | average_slice16 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | minmax_slice8 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | minmax_slice16 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | median_8 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | median_16 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | colorcorrect_slice8 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | colorcorrect_slice16 (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs) |
|
static int | filter_frame (AVFilterLink *inlink, AVFrame *frame) |
|
static av_cold int | config_input (AVFilterLink *inlink) |
|
static av_cold void | uninit (AVFilterContext *ctx) |
|
| AVFILTER_DEFINE_CLASS (colorcorrect) |
|
◆ PROCESS
Value: float y = yptr[x * chroma_w] * imax; \
float
u = uptr[x] * imax - .5f; \
float v = vptr[x] * imax - .5f; \
float nu, nv; \
\
nu = saturation * (
u + y * bd + bl); \
nv = saturation * (v + y * rd + rl);
Definition at line 306 of file vf_colorcorrect.c.
◆ OFFSET
◆ VF
◆ AnalyzeMode
Enumerator |
---|
MANUAL | |
AVERAGE | |
MINMAX | |
MEDIAN | |
NB_ANALYZE | |
Definition at line 30 of file vf_colorcorrect.c.
◆ average_slice8()
◆ average_slice16()
◆ minmax_slice8()
◆ minmax_slice16()
◆ median_8()
◆ median_16()
◆ colorcorrect_slice8()
◆ colorcorrect_slice16()
◆ filter_frame()
◆ config_input()
◆ uninit()
◆ AVFILTER_DEFINE_CLASS()
AVFILTER_DEFINE_CLASS |
( |
colorcorrect |
| ) |
|
◆ pixel_fmts
◆ colorcorrect_inputs
◆ colorcorrect_outputs
◆ colorcorrect_options
◆ ff_vf_colorcorrect
Initial value:= {
.name = "colorcorrect",
.description =
NULL_IF_CONFIG_SMALL(
"Adjust color white balance selectively for blacks and whites."),
.priv_class = &colorcorrect_class,
}
Definition at line 539 of file vf_colorcorrect.c.
#define AV_PIX_FMT_YUVA422P16
#define u(width, name, range_min, range_max)
#define FILTER_PIXFMTS_ARRAY(array)
#define AV_PIX_FMT_YUVA422P9
#define AV_PIX_FMT_YUVA420P16
#define AV_PIX_FMT_YUVA420P10
static const AVFilterPad colorcorrect_inputs[]
#define AV_PIX_FMT_YUV420P10
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
#define AV_PIX_FMT_YUVA422P10
static av_cold int config_input(AVFilterLink *inlink)
#define AV_PIX_FMT_YUVA420P9
#define AV_PIX_FMT_YUVA444P16
#define AV_PIX_FMT_YUV422P9
#define AV_PIX_FMT_YUV444P10
@ AV_PIX_FMT_YUVJ411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples) full scale (JPEG), deprecated in favor ...
#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...
@ AV_PIX_FMT_YUVA420P
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
#define AV_PIX_FMT_YUV444P16
#define AV_PIX_FMT_YUVA444P12
#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
static enum AVPixelFormat pixel_fmts[]
#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
int ff_filter_process_command(AVFilterContext *ctx, const char *cmd, const char *arg, char *res, int res_len, int flags)
Generic processing of user supplied commands that are set in the same way as the filter options.
@ AV_PIX_FMT_YUVA444P
planar YUV 4:4:4 32bpp, (1 Cr & Cb sample per 1x1 Y & A samples)
#define AV_PIX_FMT_YUVA444P10
#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 int filter_frame(AVFilterLink *inlink, AVFrame *frame)
@ 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_YUVA444P9
#define AV_PIX_FMT_YUV420P12
#define AV_PIX_FMT_YUV422P14
static av_cold void uninit(AVFilterContext *ctx)
#define AV_PIX_FMT_YUVA422P12
@ 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)
static const AVFilterPad colorcorrect_outputs[]
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
#define AV_PIX_FMT_YUV440P12
#define AV_PIX_FMT_YUV444P14
static int analyze(const uint8_t *buf, int size, int packet_size, int probe)
@ AV_PIX_FMT_YUVA422P
planar YUV 4:2:2 24bpp, (1 Cr & Cb sample per 2x1 Y & A samples)
#define AV_PIX_FMT_YUV420P14
#define AVFILTERPAD_FLAG_NEEDS_WRITABLE
The filter expects writable frames from its input link, duplicating data buffers if needed.