Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Signed-off-by: Anton Khirnov <anton@khirnov.net>
| ... | ... |
@@ -385,12 +385,14 @@ static int config_input(AVFilterLink *inlink) |
| 385 | 385 |
|
| 386 | 386 |
#define SET_PIXEL_YUV(picref, yuva_color, val, x, y, hsub, vsub) { \
|
| 387 | 387 |
luma_pos = ((x) ) + ((y) ) * picref->linesize[0]; \ |
| 388 |
- chroma_pos1 = ((x) >> (hsub)) + ((y) >> (vsub)) * picref->linesize[1]; \ |
|
| 389 |
- chroma_pos2 = ((x) >> (hsub)) + ((y) >> (vsub)) * picref->linesize[2]; \ |
|
| 390 | 388 |
alpha = yuva_color[3] * (val) * 129; \ |
| 391 | 389 |
picref->data[0][luma_pos] = (alpha * yuva_color[0] + (255*255*129 - alpha) * picref->data[0][luma_pos] ) >> 23; \ |
| 392 |
- picref->data[1][chroma_pos1] = (alpha * yuva_color[1] + (255*255*129 - alpha) * picref->data[1][chroma_pos1]) >> 23; \ |
|
| 393 |
- picref->data[2][chroma_pos2] = (alpha * yuva_color[2] + (255*255*129 - alpha) * picref->data[2][chroma_pos2]) >> 23; \ |
|
| 390 |
+ if (((x) & ((1<<(hsub)) - 1)) == 0 && ((y) & ((1<<(vsub)) - 1)) == 0) {\
|
|
| 391 |
+ chroma_pos1 = ((x) >> (hsub)) + ((y) >> (vsub)) * picref->linesize[1]; \ |
|
| 392 |
+ chroma_pos2 = ((x) >> (hsub)) + ((y) >> (vsub)) * picref->linesize[2]; \ |
|
| 393 |
+ picref->data[1][chroma_pos1] = (alpha * yuva_color[1] + (255*255*129 - alpha) * picref->data[1][chroma_pos1]) >> 23; \ |
|
| 394 |
+ picref->data[2][chroma_pos2] = (alpha * yuva_color[2] + (255*255*129 - alpha) * picref->data[2][chroma_pos2]) >> 23; \ |
|
| 395 |
+ }\ |
|
| 394 | 396 |
} |
| 395 | 397 |
|
| 396 | 398 |
static inline int draw_glyph_yuv(AVFilterBufferRef *picref, FT_Bitmap *bitmap, unsigned int x, |