summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libavfilter/vf_datascope.c30
1 files changed, 26 insertions, 4 deletions
diff --git a/libavfilter/vf_datascope.c b/libavfilter/vf_datascope.c
index a0482cdb75..467663556e 100644
--- a/libavfilter/vf_datascope.c
+++ b/libavfilter/vf_datascope.c
@@ -455,8 +455,8 @@ static const AVOption pixscope_options[] = {
{ "w", "set scope width", POFFSET(w), AV_OPT_TYPE_INT, {.i64=7}, 1, 80, FLAGS },
{ "h", "set scope height", POFFSET(h), AV_OPT_TYPE_INT, {.i64=7}, 1, 80, FLAGS },
{ "o", "set window opacity", POFFSET(o), AV_OPT_TYPE_FLOAT, {.dbl=0.5}, 0, 1, FLAGS },
- { "wx", "set window x offset", POFFSET(wx), AV_OPT_TYPE_FLOAT, {.dbl=1}, 0, 1, FLAGS },
- { "wy", "set window y offset", POFFSET(wy), AV_OPT_TYPE_FLOAT, {.dbl=0}, 0, 1, FLAGS },
+ { "wx", "set window x offset", POFFSET(wx), AV_OPT_TYPE_FLOAT, {.dbl=-1}, -1, 1, FLAGS },
+ { "wy", "set window y offset", POFFSET(wy), AV_OPT_TYPE_FLOAT, {.dbl=-1}, -1, 1, FLAGS },
{ NULL }
};
@@ -542,8 +542,30 @@ static int pixscope_filter_frame(AVFilterLink *inlink, AVFrame *in)
w = s->ww / s->w;
h = s->ww / s->h;
- X = (in->width - s->ww) * s->wx;
- Y = (in->height - s->wh) * s->wy;
+ if (s->wx >= 0) {
+ X = (in->width - s->ww) * s->wx;
+ } else {
+ X = (in->width - s->ww) * -s->wx;
+ }
+ if (s->wy >= 0) {
+ Y = (in->height - s->wh) * s->wy;
+ } else {
+ Y = (in->height - s->wh) * -s->wy;
+ }
+
+ if (s->wx < 0) {
+ if (s->x + s->w >= X && (s->x + s->w <= X + s->ww) &&
+ s->y + s->h >= Y && (s->y + s->h <= Y + s->wh)) {
+ X = (in->width - s->ww) * (1 + s->wx);
+ }
+ }
+
+ if (s->wy < 0) {
+ if (s->x + s->w >= X && (s->x + s->w <= X + s->ww) &&
+ s->y + s->h >= Y && (s->y + s->h <= Y + s->wh)) {
+ Y = (in->height - s->wh) * (1 + s->wy);
+ }
+ }
ff_blend_rectangle(&s->draw, &s->dark, out->data, out->linesize,
out->width, out->height,