wcap-decode: Add 444 YUV Planar output

Done in the most simple way possible, for those who like nice things
This commit is contained in:
David Richards
2013-06-30 18:20:13 -07:00
committed by Kristian Høgsberg
parent b08b3296b8
commit 7e5b57e7b8
+56 -6
View File
@@ -133,16 +133,57 @@ convert_to_yv12(struct wcap_decoder *decoder, unsigned char *out)
} }
static void static void
output_yuv_frame(struct wcap_decoder *decoder) convert_to_yuv444(struct wcap_decoder *decoder, unsigned char *out)
{
unsigned char *yp, *up, *vp;
uint32_t *rp, *end;
int u, v;
int i, stride, psize;
uint32_t format = decoder->format;
stride = decoder->width;
psize = stride * decoder->height;
for (i = 0; i < decoder->height; i++) {
yp = out + stride * i;
up = yp + (psize * 2);
vp = yp + (psize * 1);
rp = decoder->frame + decoder->width * i;
end = rp + decoder->width;
while (rp < end) {
u = 0;
v = 0;
yp[0] = rgb_to_yuv(format, rp[0], &u, &v);
up[0] = clamp_uv(u/.3);
vp[0] = clamp_uv(v/.3);
up++;
vp++;
yp++;
rp++;
}
}
}
static void
output_yuv_frame(struct wcap_decoder *decoder, int depth)
{ {
static unsigned char *out; static unsigned char *out;
int size; int size;
if (depth == 444) {
size = decoder->width * decoder->height * 3;
} else {
size = decoder->width * decoder->height * 3 / 2; size = decoder->width * decoder->height * 3 / 2;
}
if (out == NULL) if (out == NULL)
out = malloc(size); out = malloc(size);
if (depth == 444) {
convert_to_yuv444(decoder, out);
} else {
convert_to_yv12(decoder, out); convert_to_yv12(decoder, out);
}
printf("FRAME\n"); printf("FRAME\n");
fwrite(out, 1, size, stdout); fwrite(out, 1, size, stdout);
} }
@@ -155,6 +196,7 @@ usage(int exit_code)
"\t[--rate=<num:denom>] <wcap file>\n\n" "\t[--rate=<num:denom>] <wcap file>\n\n"
"\t--help\t\t\tthis help text\n" "\t--help\t\t\tthis help text\n"
"\t--yuv4mpeg2\t\tdump wcap file to stdout in yuv4mpeg2 format\n" "\t--yuv4mpeg2\t\tdump wcap file to stdout in yuv4mpeg2 format\n"
"\t--yuv4mpeg2-444\t\tdump wcap file to stdout in yuv4mpeg2 444 format\n"
"\t--frame=<frame>\t\twrite out the given frame number as png\n" "\t--frame=<frame>\t\twrite out the given frame number as png\n"
"\t--all\t\t\twrite all frames as pngs\n" "\t--all\t\t\twrite all frames as pngs\n"
"\t--rate=<num:denom>\treplay frame rate for yuv4mpeg2,\n" "\t--rate=<num:denom>\treplay frame rate for yuv4mpeg2,\n"
@@ -169,11 +211,14 @@ int main(int argc, char *argv[])
int i, j, output_frame = -1, yuv4mpeg2 = 0, all = 0, has_frame; int i, j, output_frame = -1, yuv4mpeg2 = 0, all = 0, has_frame;
int num = 30, denom = 1; int num = 30, denom = 1;
char filename[200]; char filename[200];
char *mode;
uint32_t msecs, frame_time, *frame, frame_size; uint32_t msecs, frame_time, *frame, frame_size;
for (i = 1, j = 1; i < argc; i++) { for (i = 1, j = 1; i < argc; i++) {
if (strcmp(argv[i], "--yuv4mpeg2") == 0) { if (strcmp(argv[i], "--yuv4mpeg2-444") == 0) {
yuv4mpeg2 = 1; yuv4mpeg2 = 444;
} else if (strcmp(argv[i], "--yuv4mpeg2") == 0) {
yuv4mpeg2 = 420;
} else if (strcmp(argv[i], "--help") == 0) { } else if (strcmp(argv[i], "--help") == 0) {
usage(EXIT_SUCCESS); usage(EXIT_SUCCESS);
} else if (strcmp(argv[i], "--all") == 0) { } else if (strcmp(argv[i], "--all") == 0) {
@@ -215,8 +260,13 @@ int main(int argc, char *argv[])
} }
if (yuv4mpeg2) { if (yuv4mpeg2) {
printf("YUV4MPEG2 C420jpeg W%d H%d F%d:%d Ip A0:0\n", if (yuv4mpeg2 == 444) {
decoder->width, decoder->height, num, denom); mode = "C444";
} else {
mode = "C420jpeg";
}
printf("YUV4MPEG2 %s W%d H%d F%d:%d Ip A0:0\n",
mode, decoder->width, decoder->height, num, denom);
fflush(stdout); fflush(stdout);
} }
@@ -236,7 +286,7 @@ int main(int argc, char *argv[])
fprintf(stderr, "wrote %s\n", filename); fprintf(stderr, "wrote %s\n", filename);
} }
if (yuv4mpeg2) if (yuv4mpeg2)
output_yuv_frame(decoder); output_yuv_frame(decoder, yuv4mpeg2);
i++; i++;
msecs += frame_time; msecs += frame_time;
while (decoder->msecs < msecs && has_frame) while (decoder->msecs < msecs && has_frame)