Index: source/libvpx/examples/decode_with_drops.c |
=================================================================== |
--- source/libvpx/examples/decode_with_drops.c (revision 251189) |
+++ source/libvpx/examples/decode_with_drops.c (working copy) |
@@ -52,126 +52,103 @@ |
// The example decides whether to drop the frame based on the current |
// frame number, immediately before decoding the frame. |
-#include <stdarg.h> |
#include <stdio.h> |
#include <stdlib.h> |
#include <string.h> |
+ |
#define VPX_CODEC_DISABLE_COMPAT 1 |
-#include "./vpx_config.h" |
+ |
#include "vpx/vp8dx.h" |
#include "vpx/vpx_decoder.h" |
-#define interface (vpx_codec_vp8_dx()) |
+#include "./tools_common.h" |
+#include "./video_reader.h" |
+#include "./vpx_config.h" |
-#define IVF_FILE_HDR_SZ (32) |
-#define IVF_FRAME_HDR_SZ (12) |
+static const char *exec_name; |
-static unsigned int mem_get_le32(const unsigned char *mem) { |
- return (mem[3] << 24)|(mem[2] << 16)|(mem[1] << 8)|(mem[0]); |
+void usage_exit() { |
+ fprintf(stderr, "Usage: %s <infile> <outfile> <N-M|N/M>\n", exec_name); |
+ exit(EXIT_FAILURE); |
} |
-static void die(const char *fmt, ...) { |
- va_list ap; |
+int main(int argc, char **argv) { |
+ int frame_cnt = 0; |
+ FILE *outfile = NULL; |
+ vpx_codec_ctx_t codec; |
+ const VpxInterface *decoder = NULL; |
+ VpxVideoReader *reader = NULL; |
+ const VpxVideoInfo *info = NULL; |
+ int n = 0; |
+ int m = 0; |
+ int is_range = 0; |
+ char *nptr = NULL; |
- va_start(ap, fmt); |
- vprintf(fmt, ap); |
- if(fmt[strlen(fmt)-1] != '\n') |
- printf("\n"); |
- exit(EXIT_FAILURE); |
-} |
+ exec_name = argv[0]; |
-static void die_codec(vpx_codec_ctx_t *ctx, const char *s) { |
- const char *detail = vpx_codec_error_detail(ctx); |
+ if (argc != 4) |
+ die("Invalid number of arguments."); |
- printf("%s: %s\n", s, vpx_codec_error(ctx)); |
- if(detail) |
- printf(" %s\n",detail); |
- exit(EXIT_FAILURE); |
-} |
+ reader = vpx_video_reader_open(argv[1]); |
+ if (!reader) |
+ die("Failed to open %s for reading.", argv[1]); |
+ if (!(outfile = fopen(argv[2], "wb"))) |
+ die("Failed to open %s for writing.", argv[2]); |
-int main(int argc, char **argv) { |
- FILE *infile, *outfile; |
- vpx_codec_ctx_t codec; |
- int flags = 0, frame_cnt = 0; |
- unsigned char file_hdr[IVF_FILE_HDR_SZ]; |
- unsigned char frame_hdr[IVF_FRAME_HDR_SZ]; |
- unsigned char frame[256*1024]; |
- vpx_codec_err_t res; |
- int n, m, is_range; |
+ n = strtol(argv[3], &nptr, 0); |
+ m = strtol(nptr + 1, NULL, 0); |
+ is_range = (*nptr == '-'); |
+ if (!n || !m || (*nptr != '-' && *nptr != '/')) |
+ die("Couldn't parse pattern %s.\n", argv[3]); |
- (void)res; |
- /* Open files */ |
- if(argc!=4) |
- die("Usage: %s <infile> <outfile> <N-M|N/M>\n", argv[0]); |
- { |
- char *nptr; |
- n = strtol(argv[3], &nptr, 0); |
- m = strtol(nptr+1, NULL, 0); |
- is_range = *nptr == '-'; |
- if(!n || !m || (*nptr != '-' && *nptr != '/')) |
- die("Couldn't parse pattern %s\n", argv[3]); |
- } |
- if(!(infile = fopen(argv[1], "rb"))) |
- die("Failed to open %s for reading", argv[1]); |
- if(!(outfile = fopen(argv[2], "wb"))) |
- die("Failed to open %s for writing", argv[2]); |
+ info = vpx_video_reader_get_info(reader); |
- /* Read file header */ |
- if(!(fread(file_hdr, 1, IVF_FILE_HDR_SZ, infile) == IVF_FILE_HDR_SZ |
- && file_hdr[0]=='D' && file_hdr[1]=='K' && file_hdr[2]=='I' |
- && file_hdr[3]=='F')) |
- die("%s is not an IVF file.", argv[1]); |
+ decoder = get_vpx_decoder_by_fourcc(info->codec_fourcc); |
+ if (!decoder) |
+ die("Unknown input codec."); |
- printf("Using %s\n",vpx_codec_iface_name(interface)); |
- /* Initialize codec */ |
- if(vpx_codec_dec_init(&codec, interface, NULL, flags)) |
- die_codec(&codec, "Failed to initialize decoder"); |
+ printf("Using %s\n", vpx_codec_iface_name(decoder->interface())); |
- /* Read each frame */ |
- while(fread(frame_hdr, 1, IVF_FRAME_HDR_SZ, infile) == IVF_FRAME_HDR_SZ) { |
- int frame_sz = mem_get_le32(frame_hdr); |
- vpx_codec_iter_t iter = NULL; |
- vpx_image_t *img; |
+ if (vpx_codec_dec_init(&codec, decoder->interface(), NULL, 0)) |
+ die_codec(&codec, "Failed to initialize decoder."); |
+ while (vpx_video_reader_read_frame(reader)) { |
+ vpx_codec_iter_t iter = NULL; |
+ vpx_image_t *img = NULL; |
+ size_t frame_size = 0; |
+ int skip; |
+ const unsigned char *frame = vpx_video_reader_get_frame(reader, |
+ &frame_size); |
+ if (vpx_codec_decode(&codec, frame, frame_size, NULL, 0)) |
+ die_codec(&codec, "Failed to decode frame."); |
- frame_cnt++; |
- if(frame_sz > sizeof(frame)) |
- die("Frame %d data too big for example code buffer", frame_sz); |
- if(fread(frame, 1, frame_sz, infile) != frame_sz) |
- die("Frame %d failed to read complete frame", frame_cnt); |
+ ++frame_cnt; |
- if((is_range && frame_cnt >= n && frame_cnt <= m) |
- ||(!is_range && m - (frame_cnt-1)%m <= n)) { |
- putc('X', stdout); |
- continue; |
- } |
- putc('.', stdout); |
- fflush(stdout); |
- /* Decode the frame */ |
- if(vpx_codec_decode(&codec, frame, frame_sz, NULL, 0)) |
- die_codec(&codec, "Failed to decode frame"); |
+ skip = (is_range && frame_cnt >= n && frame_cnt <= m) || |
+ (!is_range && m - (frame_cnt - 1) % m <= n); |
- /* Write decoded data to disk */ |
- while((img = vpx_codec_get_frame(&codec, &iter))) { |
- unsigned int plane, y; |
+ if (!skip) { |
+ putc('.', stdout); |
- for(plane=0; plane < 3; plane++) { |
- unsigned char *buf =img->planes[plane]; |
- |
- for(y=0; y < (plane ? (img->d_h + 1) >> 1 : img->d_h); y++) { |
- (void) fwrite(buf, 1, (plane ? (img->d_w + 1) >> 1 : img->d_w), |
- outfile); |
- buf += img->stride[plane]; |
- } |
- } |
- } |
+ while ((img = vpx_codec_get_frame(&codec, &iter)) != NULL) |
+ vpx_img_write(img, outfile); |
+ } else { |
+ putc('X', stdout); |
} |
- printf("Processed %d frames.\n",frame_cnt); |
- if(vpx_codec_destroy(&codec)) |
- die_codec(&codec, "Failed to destroy codec"); |
- fclose(outfile); |
- fclose(infile); |
- return EXIT_SUCCESS; |
+ fflush(stdout); |
+ } |
+ |
+ printf("Processed %d frames.\n", frame_cnt); |
+ if (vpx_codec_destroy(&codec)) |
+ die_codec(&codec, "Failed to destroy codec."); |
+ |
+ printf("Play: ffplay -f rawvideo -pix_fmt yuv420p -s %dx%d %s\n", |
+ info->frame_width, info->frame_height, argv[2]); |
+ |
+ vpx_video_reader_close(reader); |
+ fclose(outfile); |
+ |
+ return EXIT_SUCCESS; |
} |