|
|
@ -55,8 +55,6 @@ static const AVOption maskedthreshold_options[] = { |
|
|
|
{ NULL } |
|
|
|
{ NULL } |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
static int query_formats(AVFilterContext *ctx) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
static const enum AVPixelFormat pix_fmts[] = { |
|
|
|
static const enum AVPixelFormat pix_fmts[] = { |
|
|
|
AV_PIX_FMT_YUVA444P, AV_PIX_FMT_YUV444P, AV_PIX_FMT_YUV440P, |
|
|
|
AV_PIX_FMT_YUVA444P, AV_PIX_FMT_YUV444P, AV_PIX_FMT_YUV440P, |
|
|
|
AV_PIX_FMT_YUVJ444P, AV_PIX_FMT_YUVJ440P, |
|
|
|
AV_PIX_FMT_YUVJ444P, AV_PIX_FMT_YUVJ440P, |
|
|
@ -79,9 +77,6 @@ static int query_formats(AVFilterContext *ctx) |
|
|
|
AV_PIX_FMT_NONE |
|
|
|
AV_PIX_FMT_NONE |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
return ff_set_common_formats_from_list(ctx, pix_fmts); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void threshold8(const uint8_t *src, const uint8_t *ref, uint8_t *dst, int threshold, int w) |
|
|
|
static void threshold8(const uint8_t *src, const uint8_t *ref, uint8_t *dst, int threshold, int w) |
|
|
|
{ |
|
|
|
{ |
|
|
|
for (int x = 0; x < w; x++) |
|
|
|
for (int x = 0; x < w; x++) |
|
|
@ -287,7 +282,7 @@ const AVFilter ff_vf_maskedthreshold = { |
|
|
|
.activate = activate, |
|
|
|
.activate = activate, |
|
|
|
FILTER_INPUTS(maskedthreshold_inputs), |
|
|
|
FILTER_INPUTS(maskedthreshold_inputs), |
|
|
|
FILTER_OUTPUTS(maskedthreshold_outputs), |
|
|
|
FILTER_OUTPUTS(maskedthreshold_outputs), |
|
|
|
FILTER_QUERY_FUNC(query_formats), |
|
|
|
FILTER_PIXFMTS_ARRAY(pix_fmts), |
|
|
|
.flags = AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL | AVFILTER_FLAG_SLICE_THREADS, |
|
|
|
.flags = AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL | AVFILTER_FLAG_SLICE_THREADS, |
|
|
|
.process_command = ff_filter_process_command, |
|
|
|
.process_command = ff_filter_process_command, |
|
|
|
}; |
|
|
|
}; |
|
|
|