summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnton Khirnov <anton@khirnov.net>2016-09-22 09:32:08 +0200
committerAnton Khirnov <anton@khirnov.net>2016-09-28 10:01:52 +0200
commit67d28f4a0fbb52d0734ca3682b85035e96d294fb (patch)
tree4f5f0d0163ffd268b2c73e2df6a3e3fbbfc1b294
parent7bf8db4db61eb09fac00eb665d8ec58de8817da6 (diff)
downloadffmpeg-67d28f4a0fbb52d0734ca3682b85035e96d294fb.tar.gz
examples/output: switch to the new encoding API
-rw-r--r--doc/examples/output.c71
1 files changed, 44 insertions, 27 deletions
diff --git a/doc/examples/output.c b/doc/examples/output.c
index 44a55f5645..bb0da30041 100644
--- a/doc/examples/output.c
+++ b/doc/examples/output.c
@@ -233,25 +233,37 @@ static AVFrame *get_audio_frame(OutputStream *ost)
static int encode_audio_frame(AVFormatContext *oc, OutputStream *ost,
AVFrame *frame)
{
- AVPacket pkt = { 0 }; // data and size must be 0;
- int got_packet;
+ int ret;
- av_init_packet(&pkt);
- avcodec_encode_audio2(ost->enc, &pkt, frame, &got_packet);
+ ret = avcodec_send_frame(ost->enc, frame);
+ if (ret < 0) {
+ fprintf(stderr, "Error submitting a frame for encoding\n");
+ exit(1);
+ }
- if (got_packet) {
- pkt.stream_index = ost->st->index;
+ while (ret >= 0) {
+ AVPacket pkt = { 0 }; // data and size must be 0;
- av_packet_rescale_ts(&pkt, ost->enc->time_base, ost->st->time_base);
+ av_init_packet(&pkt);
- /* Write the compressed frame to the media file. */
- if (av_interleaved_write_frame(oc, &pkt) != 0) {
- fprintf(stderr, "Error while writing audio frame\n");
+ ret = avcodec_receive_packet(ost->enc, &pkt);
+ if (ret < 0 && ret != AVERROR(EAGAIN) && ret != AVERROR_EOF) {
+ fprintf(stderr, "Error encoding a video frame\n");
exit(1);
+ } else if (ret >= 0) {
+ av_packet_rescale_ts(&pkt, ost->enc->time_base, ost->st->time_base);
+ pkt.stream_index = ost->st->index;
+
+ /* Write the compressed frame to the media file. */
+ ret = av_interleaved_write_frame(oc, &pkt);
+ if (ret < 0) {
+ fprintf(stderr, "Error while writing video frame\n");
+ exit(1);
+ }
}
}
- return (frame || got_packet) ? 0 : 1;
+ return ret == AVERROR_EOF;
}
/*
@@ -517,36 +529,41 @@ static int write_video_frame(AVFormatContext *oc, OutputStream *ost)
int ret;
AVCodecContext *c;
AVFrame *frame;
- AVPacket pkt = { 0 };
- int got_packet = 0;
c = ost->enc;
frame = get_video_frame(ost);
- av_init_packet(&pkt);
-
/* encode the image */
- ret = avcodec_encode_video2(c, &pkt, frame, &got_packet);
+ ret = avcodec_send_frame(c, frame);
if (ret < 0) {
- fprintf(stderr, "Error encoding a video frame\n");
+ fprintf(stderr, "Error submitting a frame for encoding\n");
exit(1);
}
- if (got_packet) {
- av_packet_rescale_ts(&pkt, c->time_base, ost->st->time_base);
- pkt.stream_index = ost->st->index;
+ while (ret >= 0) {
+ AVPacket pkt = { 0 };
- /* Write the compressed frame to the media file. */
- ret = av_interleaved_write_frame(oc, &pkt);
- }
+ av_init_packet(&pkt);
- if (ret != 0) {
- fprintf(stderr, "Error while writing video frame\n");
- exit(1);
+ ret = avcodec_receive_packet(c, &pkt);
+ if (ret < 0 && ret != AVERROR(EAGAIN) && ret != AVERROR_EOF) {
+ fprintf(stderr, "Error encoding a video frame\n");
+ exit(1);
+ } else if (ret >= 0) {
+ av_packet_rescale_ts(&pkt, c->time_base, ost->st->time_base);
+ pkt.stream_index = ost->st->index;
+
+ /* Write the compressed frame to the media file. */
+ ret = av_interleaved_write_frame(oc, &pkt);
+ if (ret < 0) {
+ fprintf(stderr, "Error while writing video frame\n");
+ exit(1);
+ }
+ }
}
- return (frame || got_packet) ? 0 : 1;
+ return ret == AVERROR_EOF;
}
static void close_stream(AVFormatContext *oc, OutputStream *ost)