--- libavfilter/vf_colorkey.c | 36 +++++++++++++++++++++++++++--------- 1 file changed, 27 insertions(+), 9 deletions(-)
diff --git a/libavfilter/vf_colorkey.c b/libavfilter/vf_colorkey.c index 6c76991..6964809 100644 --- a/libavfilter/vf_colorkey.c +++ b/libavfilter/vf_colorkey.c @@ -29,6 +29,8 @@ typedef struct ColorkeyContext { /* color offsets rgba */ int co[4]; + int i_similarity; + int i_blend; uint8_t colorkey_rgba[4]; float similarity; @@ -107,18 +109,20 @@ static int offset_a(int fmt) } } +#define SHIFT 8 + static uint8_t do_colorkey_pixel(ColorkeyContext *ctx, uint8_t r, uint8_t g, uint8_t b) { - int dr = (int)r - ctx->colorkey_rgba[0]; - int dg = (int)g - ctx->colorkey_rgba[1]; - int db = (int)b - ctx->colorkey_rgba[2]; + int dr = ((int)r - ctx->colorkey_rgba[0]) << SHIFT; + int dg = ((int)g - ctx->colorkey_rgba[1]) << SHIFT; + int db = ((int)b - ctx->colorkey_rgba[2]) << SHIFT; - double diff = sqrt((dr * dr + dg * dg + db * db) / (255.0 * 255.0)); + int diff = (int)sqrt(dr * dr + dg * dg + db * db) - ctx->i_similarity; - if (ctx->blend > 0.0001) { - return av_clipd(FFMAX(diff - ctx->similarity, 0.0) / ctx->blend, 0.0, 1.0) * 255.0; + if (ctx->i_blend) { + return av_clip(FFMAX(diff, 0) * ctx->i_blend, 0, 255 << (SHIFT + SHIFT)) >> (SHIFT + SHIFT); } else { - return ((diff - ctx->similarity) > 0.0) ? 255 : 0; + return (diff > 0) ? 255 : 0; } } @@ -164,7 +168,7 @@ static int filter_frame(AVFilterLink *link, AVFrame *frame) return ff_filter_frame(avctx->outputs[0], frame); } -static int config_output(AVFilterLink *outlink) +static av_cold int config_output(AVFilterLink *outlink) { AVFilterContext *avctx = outlink->src; ColorkeyContext *ctx = avctx->priv; @@ -183,7 +187,7 @@ static int config_output(AVFilterLink *outlink) return 0; } -static int query_formats(AVFilterContext *avctx) +static av_cold int query_formats(AVFilterContext *avctx) { static const enum AVPixelFormat pixel_fmts_in[] = { AV_PIX_FMT_0RGB, @@ -222,6 +226,19 @@ static int query_formats(AVFilterContext *avctx) return 0; } +static av_cold int init(AVFilterContext *avctx) +{ + ColorkeyContext *ctx = avctx->priv; + + ctx->i_similarity = ctx->similarity * 255.0 * 1000.0; + ctx->i_blend = (1.0 / ctx->blend) * 1000.0; + + ctx->i_similarity = (ctx->i_similarity << SHIFT) / 1000; + ctx->i_blend = (ctx->i_blend << SHIFT) / 1000; + + return 0; +} + static const AVFilterPad colorkey_inputs[] = { { .name = "default", @@ -255,6 +272,7 @@ AVFILTER_DEFINE_CLASS(colorkey); AVFilter ff_vf_colorkey = { .name = "colorkey", .description = NULL_IF_CONFIG_SMALL("colorkey filter"), + .init = init, .priv_size = sizeof(ColorkeyContext), .priv_class = &colorkey_class, .query_formats = query_formats, -- 2.3.6 _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-devel