diff --git a/output_example.c b/output_example.c index 0e06b0cbb619246b7e18821a8d8323fabfd70f2a..42153f1103ab780027dcc0c852f8facb000fb2e4 100644 --- a/output_example.c +++ b/output_example.c @@ -115,21 +115,33 @@ void open_audio(AVFormatContext *oc, AVStream *st) samples = malloc(audio_input_frame_size * 2 * c->channels); } +/* prepare a 16 bit dummy audio frame of 'frame_size' samples and + 'nb_channels' channels */ +void get_audio_frame(int16_t *samples, int frame_size, int nb_channels) +{ + int j, i, v; + int16_t *q; + + q = samples; + for(j=0;j<frame_size;j++) { + v = (int)(sin(t) * 10000); + for(i = 0; i < nb_channels; i++) + *q++ = v; + t += tincr; + tincr += tincr2; + } +} + void write_audio_frame(AVFormatContext *oc, AVStream *st) { - int j, out_size; + int out_size; AVCodecContext *c; c = &st->codec; - for(j=0;j<audio_input_frame_size;j++) { - samples[2*j] = (int)(sin(t) * 10000); - samples[2*j+1] = samples[2*j]; - t += tincr; - tincr += tincr2; - } - + get_audio_frame(samples, audio_input_frame_size, c->channels); + out_size = avcodec_encode_audio(c, audio_outbuf, audio_outbuf_size, samples); /* write the compressed frame in the media file */