Commit a434657d authored by Clément Bœsch's avatar Clément Bœsch

Merge commit 'f27e262d'

* commit 'f27e262d':
  examples/encode_audio: switch to the new audio encoding API
Merged-by: 's avatarClément Bœsch <u@pkh.me>
parents 54e195cf f27e262d
...@@ -92,14 +92,42 @@ static int select_channel_layout(const AVCodec *codec) ...@@ -92,14 +92,42 @@ static int select_channel_layout(const AVCodec *codec)
return best_ch_layout; return best_ch_layout;
} }
static void encode(AVCodecContext *ctx, AVFrame *frame, AVPacket *pkt,
FILE *output)
{
int ret;
/* send the frame for encoding */
ret = avcodec_send_frame(ctx, frame);
if (ret < 0) {
fprintf(stderr, "Error sending the frame to the encoder\n");
exit(1);
}
/* read all the available output packets (in general there may be any
* number of them */
while (ret >= 0) {
ret = avcodec_receive_packet(ctx, pkt);
if (ret == AVERROR(EAGAIN) || ret == AVERROR_EOF)
return;
else if (ret < 0) {
fprintf(stderr, "Error encoding audio frame\n");
exit(1);
}
fwrite(pkt->data, 1, pkt->size, output);
av_packet_unref(pkt);
}
}
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
const char *filename; const char *filename;
const AVCodec *codec; const AVCodec *codec;
AVCodecContext *c= NULL; AVCodecContext *c= NULL;
AVFrame *frame; AVFrame *frame;
AVPacket pkt; AVPacket *pkt;
int i, j, k, ret, got_output; int i, j, k, ret;
FILE *f; FILE *f;
uint16_t *samples; uint16_t *samples;
float t, tincr; float t, tincr;
...@@ -154,6 +182,13 @@ int main(int argc, char **argv) ...@@ -154,6 +182,13 @@ int main(int argc, char **argv)
exit(1); exit(1);
} }
/* packet for holding encoded output */
pkt = av_packet_alloc();
if (!pkt) {
fprintf(stderr, "could not allocate the packet\n");
exit(1);
}
/* frame containing input raw audio */ /* frame containing input raw audio */
frame = av_frame_alloc(); frame = av_frame_alloc();
if (!frame) { if (!frame) {
...@@ -176,10 +211,6 @@ int main(int argc, char **argv) ...@@ -176,10 +211,6 @@ int main(int argc, char **argv)
t = 0; t = 0;
tincr = 2 * M_PI * 440.0 / c->sample_rate; tincr = 2 * M_PI * 440.0 / c->sample_rate;
for (i = 0; i < 200; i++) { for (i = 0; i < 200; i++) {
av_init_packet(&pkt);
pkt.data = NULL; // packet data will be allocated by the encoder
pkt.size = 0;
/* make sure the frame is writable -- makes a copy if the encoder /* make sure the frame is writable -- makes a copy if the encoder
* kept a reference internally */ * kept a reference internally */
ret = av_frame_make_writable(frame); ret = av_frame_make_writable(frame);
...@@ -194,34 +225,16 @@ int main(int argc, char **argv) ...@@ -194,34 +225,16 @@ int main(int argc, char **argv)
samples[2*j + k] = samples[2*j]; samples[2*j + k] = samples[2*j];
t += tincr; t += tincr;
} }
/* encode the samples */ encode(c, frame, pkt, f);
ret = avcodec_encode_audio2(c, &pkt, frame, &got_output);
if (ret < 0) {
fprintf(stderr, "Error encoding audio frame\n");
exit(1);
}
if (got_output) {
fwrite(pkt.data, 1, pkt.size, f);
av_packet_unref(&pkt);
}
} }
/* get the delayed frames */ /* flush the encoder */
for (got_output = 1; got_output; i++) { encode(c, NULL, pkt, f);
ret = avcodec_encode_audio2(c, &pkt, NULL, &got_output);
if (ret < 0) {
fprintf(stderr, "Error encoding frame\n");
exit(1);
}
if (got_output) {
fwrite(pkt.data, 1, pkt.size, f);
av_packet_unref(&pkt);
}
}
fclose(f); fclose(f);
av_frame_free(&frame); av_frame_free(&frame);
av_packet_free(&pkt);
avcodec_free_context(&c); avcodec_free_context(&c);
return 0; return 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment