mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-11 18:09:36 +00:00
Get all the stride stuff right so that we actually get the colours
right. Originally committed as revision 1944 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
41fc0dd5a3
commit
25a2ee7dd6
52
vhook/fish.c
52
vhook/fish.c
@ -45,13 +45,29 @@
|
|||||||
#include "framehook.h"
|
#include "framehook.h"
|
||||||
#include "dsputil.h"
|
#include "dsputil.h"
|
||||||
|
|
||||||
#define SCALE_BITS 10
|
#define SCALEBITS 10
|
||||||
|
#define ONE_HALF (1 << (SCALEBITS - 1))
|
||||||
|
#define FIX(x) ((int) ((x) * (1<<SCALEBITS) + 0.5))
|
||||||
|
|
||||||
|
#define YUV_TO_RGB1_CCIR(cb1, cr1)\
|
||||||
|
{\
|
||||||
|
cb = (cb1) - 128;\
|
||||||
|
cr = (cr1) - 128;\
|
||||||
|
r_add = FIX(1.40200*255.0/224.0) * cr + ONE_HALF;\
|
||||||
|
g_add = - FIX(0.34414*255.0/224.0) * cb - FIX(0.71414*255.0/224.0) * cr + \
|
||||||
|
ONE_HALF;\
|
||||||
|
b_add = FIX(1.77200*255.0/224.0) * cb + ONE_HALF;\
|
||||||
|
}
|
||||||
|
|
||||||
|
#define YUV_TO_RGB2_CCIR(r, g, b, y1)\
|
||||||
|
{\
|
||||||
|
yt = ((y1) - 16) * FIX(255.0/219.0);\
|
||||||
|
r = cm[(yt + r_add) >> SCALEBITS];\
|
||||||
|
g = cm[(yt + g_add) >> SCALEBITS];\
|
||||||
|
b = cm[(yt + b_add) >> SCALEBITS];\
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#define C_Y (76309 >> (16 - SCALE_BITS))
|
|
||||||
#define C_RV (117504 >> (16 - SCALE_BITS))
|
|
||||||
#define C_BU (138453 >> (16 - SCALE_BITS))
|
|
||||||
#define C_GU (13954 >> (16 - SCALE_BITS))
|
|
||||||
#define C_GV (34903 >> (16 - SCALE_BITS))
|
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -154,6 +170,8 @@ int Configure(void **ctxp, int argc, char *argv[])
|
|||||||
ci->bright.h,
|
ci->bright.h,
|
||||||
ci->bright.s,
|
ci->bright.s,
|
||||||
ci->bright.v);
|
ci->bright.v);
|
||||||
|
fprintf(stderr, " Threshold is %d%% pixels\n", ci->threshold / 10);
|
||||||
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -234,25 +252,19 @@ void Process(void *ctx, AVPicture *picture, enum PixelFormat pix_fmt, int width,
|
|||||||
pixcnt = ((h_start - h_end) >> 1) * (w_start - w_end);
|
pixcnt = ((h_start - h_end) >> 1) * (w_start - w_end);
|
||||||
|
|
||||||
y = picture->data[0] + h_end * picture->linesize[0] + w_end * 2;
|
y = picture->data[0] + h_end * picture->linesize[0] + w_end * 2;
|
||||||
u = picture->data[1] + h_end * picture->linesize[1] + w_end;
|
u = picture->data[1] + h_end * picture->linesize[1] / 2 + w_end;
|
||||||
v = picture->data[2] + h_end * picture->linesize[2] + w_end;
|
v = picture->data[2] + h_end * picture->linesize[2] / 2 + w_end;
|
||||||
|
|
||||||
for (h = h_start; h > h_end; h -= 2) {
|
for (h = h_start; h > h_end; h -= 2) {
|
||||||
int w;
|
int w;
|
||||||
|
|
||||||
for (w = w_start; w > w_end; w--) {
|
for (w = w_start; w > w_end; w--) {
|
||||||
int r,g,b;
|
unsigned int r,g,b;
|
||||||
int Y, U, V;
|
|
||||||
HSV hsv;
|
HSV hsv;
|
||||||
|
int cb, cr, yt, r_add, g_add, b_add;
|
||||||
|
|
||||||
U = u[0] - 128;
|
YUV_TO_RGB1_CCIR(u[0], v[0]);
|
||||||
V = v[0] - 128;
|
YUV_TO_RGB2_CCIR(r, g, b, y[0]);
|
||||||
|
|
||||||
Y = (y[0] - 16) * C_Y;
|
|
||||||
|
|
||||||
r = cm[(Y + C_RV * V + (1 << (SCALE_BITS - 1))) >> SCALE_BITS];
|
|
||||||
g = cm[(Y + - C_GU * U - C_GV * V + (1 << (SCALE_BITS - 1))) >> SCALE_BITS];
|
|
||||||
b = cm[(Y + C_BU * U + (1 << (SCALE_BITS - 1))) >> SCALE_BITS];
|
|
||||||
|
|
||||||
get_hsv(&hsv, r, g, b);
|
get_hsv(&hsv, r, g, b);
|
||||||
|
|
||||||
@ -266,7 +278,9 @@ void Process(void *ctx, AVPicture *picture, enum PixelFormat pix_fmt, int width,
|
|||||||
hsv.v >= ci->dark.v && hsv.v <= ci->bright.v) {
|
hsv.v >= ci->dark.v && hsv.v <= ci->bright.v) {
|
||||||
inrange++;
|
inrange++;
|
||||||
} else if (ci->zapping) {
|
} else if (ci->zapping) {
|
||||||
y[0] = y[1] = y[rowsize] = y[rowsize + 1] = 0;
|
y[0] = y[1] = y[rowsize] = y[rowsize + 1] = 16;
|
||||||
|
u[0] = 128;
|
||||||
|
v[0] = 128;
|
||||||
}
|
}
|
||||||
|
|
||||||
y+= 2;
|
y+= 2;
|
||||||
|
Loading…
Reference in New Issue
Block a user