Commit 13502fa3 authored by reimar's avatar reimar

Fix blend_subrect to respect the boundaries of the destination image


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@10019 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 73c9ce8b
...@@ -422,31 +422,36 @@ void fill_border(VideoState *s, int x, int y, int w, int h, int color) ...@@ -422,31 +422,36 @@ void fill_border(VideoState *s, int x, int y, int w, int h, int color)
#define BPP 1 #define BPP 1
static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect, int imgw, int imgh)
{ {
int wrap, wrap3, width2, skip2; int wrap, wrap3, width2, skip2;
int y, u, v, a, u1, v1, a1, w, h; int y, u, v, a, u1, v1, a1, w, h;
uint8_t *lum, *cb, *cr; uint8_t *lum, *cb, *cr;
const uint8_t *p; const uint8_t *p;
const uint32_t *pal; const uint32_t *pal;
int dstx, dsty, dstw, dsth;
lum = dst->data[0] + rect->y * dst->linesize[0];
cb = dst->data[1] + (rect->y >> 1) * dst->linesize[1]; dstx = FFMIN(FFMAX(rect->x, 0), imgw);
cr = dst->data[2] + (rect->y >> 1) * dst->linesize[2]; dstw = FFMIN(FFMAX(rect->w, 0), imgw - dstx);
dsty = FFMIN(FFMAX(rect->y, 0), imgh);
width2 = (rect->w + 1) >> 1; dsth = FFMIN(FFMAX(rect->h, 0), imgh - dsty);
skip2 = rect->x >> 1; lum = dst->data[0] + dsty * dst->linesize[0];
cb = dst->data[1] + (dsty >> 1) * dst->linesize[1];
cr = dst->data[2] + (dsty >> 1) * dst->linesize[2];
width2 = (dstw + 1) >> 1;
skip2 = dstx >> 1;
wrap = dst->linesize[0]; wrap = dst->linesize[0];
wrap3 = rect->linesize; wrap3 = rect->linesize;
p = rect->bitmap; p = rect->bitmap;
pal = rect->rgba_palette; /* Now in YCrCb! */ pal = rect->rgba_palette; /* Now in YCrCb! */
if (rect->y & 1) { if (dsty & 1) {
lum += rect->x; lum += dstx;
cb += skip2; cb += skip2;
cr += skip2; cr += skip2;
if (rect->x & 1) { if (dstx & 1) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
lum[0] = ALPHA_BLEND(a, lum[0], y, 0); lum[0] = ALPHA_BLEND(a, lum[0], y, 0);
cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0); cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0);
...@@ -456,7 +461,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) ...@@ -456,7 +461,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect)
lum++; lum++;
p += BPP; p += BPP;
} }
for(w = rect->w - (rect->x & 1); w >= 2; w -= 2) { for(w = dstw - (dstx & 1); w >= 2; w -= 2) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
u1 = u; u1 = u;
v1 = v; v1 = v;
...@@ -481,17 +486,17 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) ...@@ -481,17 +486,17 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect)
cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0); cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0);
cr[0] = ALPHA_BLEND(a >> 2, cr[0], v, 0); cr[0] = ALPHA_BLEND(a >> 2, cr[0], v, 0);
} }
p += wrap3 + (wrap3 - rect->w * BPP); p += wrap3 + (wrap3 - dstw * BPP);
lum += wrap + (wrap - rect->w - rect->x); lum += wrap + (wrap - dstw - dstx);
cb += dst->linesize[1] - width2 - skip2; cb += dst->linesize[1] - width2 - skip2;
cr += dst->linesize[2] - width2 - skip2; cr += dst->linesize[2] - width2 - skip2;
} }
for(h = rect->h - (rect->y & 1); h >= 2; h -= 2) { for(h = dsth - (dsty & 1); h >= 2; h -= 2) {
lum += rect->x; lum += dstx;
cb += skip2; cb += skip2;
cr += skip2; cr += skip2;
if (rect->x & 1) { if (dstx & 1) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
u1 = u; u1 = u;
v1 = v; v1 = v;
...@@ -511,7 +516,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) ...@@ -511,7 +516,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect)
p += -wrap3 + BPP; p += -wrap3 + BPP;
lum += -wrap + 1; lum += -wrap + 1;
} }
for(w = rect->w - (rect->x & 1); w >= 2; w -= 2) { for(w = dstw - (dstx & 1); w >= 2; w -= 2) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
u1 = u; u1 = u;
v1 = v; v1 = v;
...@@ -566,18 +571,18 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) ...@@ -566,18 +571,18 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect)
p += -wrap3 + BPP; p += -wrap3 + BPP;
lum += -wrap + 1; lum += -wrap + 1;
} }
p += wrap3 + (wrap3 - rect->w * BPP); p += wrap3 + (wrap3 - dstw * BPP);
lum += wrap + (wrap - rect->w - rect->x); lum += wrap + (wrap - dstw - dstx);
cb += dst->linesize[1] - width2 - skip2; cb += dst->linesize[1] - width2 - skip2;
cr += dst->linesize[2] - width2 - skip2; cr += dst->linesize[2] - width2 - skip2;
} }
/* handle odd height */ /* handle odd height */
if (h) { if (h) {
lum += rect->x; lum += dstx;
cb += skip2; cb += skip2;
cr += skip2; cr += skip2;
if (rect->x & 1) { if (dstx & 1) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
lum[0] = ALPHA_BLEND(a, lum[0], y, 0); lum[0] = ALPHA_BLEND(a, lum[0], y, 0);
cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0); cb[0] = ALPHA_BLEND(a >> 2, cb[0], u, 0);
...@@ -587,7 +592,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect) ...@@ -587,7 +592,7 @@ static void blend_subrect(AVPicture *dst, const AVSubtitleRect *rect)
lum++; lum++;
p += BPP; p += BPP;
} }
for(w = rect->w - (rect->x & 1); w >= 2; w -= 2) { for(w = dstw - (dstx & 1); w >= 2; w -= 2) {
YUVA_IN(y, u, v, a, p, pal); YUVA_IN(y, u, v, a, p, pal);
u1 = u; u1 = u;
v1 = v; v1 = v;
...@@ -705,7 +710,8 @@ static void video_image_display(VideoState *is) ...@@ -705,7 +710,8 @@ static void video_image_display(VideoState *is)
pict.linesize[2] = vp->bmp->pitches[1]; pict.linesize[2] = vp->bmp->pitches[1];
for (i = 0; i < sp->sub.num_rects; i++) for (i = 0; i < sp->sub.num_rects; i++)
blend_subrect(&pict, &sp->sub.rects[i]); blend_subrect(&pict, &sp->sub.rects[i],
vp->bmp->w, vp->bmp->h);
SDL_UnlockYUVOverlay (vp->bmp); SDL_UnlockYUVOverlay (vp->bmp);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment