|
|
|
@ -59,7 +59,6 @@ typedef struct OutputStream { |
|
|
|
|
/* audio output */ |
|
|
|
|
|
|
|
|
|
static float t, tincr, tincr2; |
|
|
|
|
static int16_t *samples; |
|
|
|
|
static int audio_input_frame_size; |
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
@ -122,20 +121,24 @@ static void open_audio(AVFormatContext *oc, AVStream *st) |
|
|
|
|
audio_input_frame_size = 10000; |
|
|
|
|
else |
|
|
|
|
audio_input_frame_size = c->frame_size; |
|
|
|
|
samples = av_malloc(audio_input_frame_size * |
|
|
|
|
av_get_bytes_per_sample(c->sample_fmt) * |
|
|
|
|
c->channels); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* Prepare a 16 bit dummy audio frame of 'frame_size' samples and
|
|
|
|
|
* 'nb_channels' channels. */ |
|
|
|
|
static void get_audio_frame(int16_t *samples, int frame_size, int nb_channels) |
|
|
|
|
static void get_audio_frame(AVFrame *frame, int nb_channels) |
|
|
|
|
{ |
|
|
|
|
int j, i, v; |
|
|
|
|
int16_t *q; |
|
|
|
|
int j, i, v, ret; |
|
|
|
|
int16_t *q = (int16_t*)frame->data[0]; |
|
|
|
|
|
|
|
|
|
q = samples; |
|
|
|
|
for (j = 0; j < frame_size; j++) { |
|
|
|
|
/* when we pass a frame to the encoder, it may keep a reference to it
|
|
|
|
|
* internally; |
|
|
|
|
* make sure we do not overwrite it here |
|
|
|
|
*/ |
|
|
|
|
ret = av_frame_make_writable(frame); |
|
|
|
|
if (ret < 0) |
|
|
|
|
exit(1); |
|
|
|
|
|
|
|
|
|
for (j = 0; j < frame->nb_samples; j++) { |
|
|
|
|
v = (int)(sin(t) * 10000); |
|
|
|
|
for (i = 0; i < nb_channels; i++) |
|
|
|
|
*q++ = v; |
|
|
|
@ -149,18 +152,22 @@ static void write_audio_frame(AVFormatContext *oc, AVStream *st) |
|
|
|
|
AVCodecContext *c; |
|
|
|
|
AVPacket pkt = { 0 }; // data and size must be 0;
|
|
|
|
|
AVFrame *frame = av_frame_alloc(); |
|
|
|
|
int got_packet; |
|
|
|
|
int got_packet, ret; |
|
|
|
|
|
|
|
|
|
av_init_packet(&pkt); |
|
|
|
|
c = st->codec; |
|
|
|
|
|
|
|
|
|
get_audio_frame(samples, audio_input_frame_size, c->channels); |
|
|
|
|
frame->nb_samples = audio_input_frame_size; |
|
|
|
|
avcodec_fill_audio_frame(frame, c->channels, c->sample_fmt, |
|
|
|
|
(uint8_t *)samples, |
|
|
|
|
audio_input_frame_size * |
|
|
|
|
av_get_bytes_per_sample(c->sample_fmt) * |
|
|
|
|
c->channels, 1); |
|
|
|
|
frame->sample_rate = c->sample_rate; |
|
|
|
|
frame->nb_samples = audio_input_frame_size; |
|
|
|
|
frame->format = AV_SAMPLE_FMT_S16; |
|
|
|
|
frame->channel_layout = c->channel_layout; |
|
|
|
|
ret = av_frame_get_buffer(frame, 0); |
|
|
|
|
if (ret < 0) { |
|
|
|
|
fprintf(stderr, "Could not allocate an audio frame.\n"); |
|
|
|
|
exit(1); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
get_audio_frame(frame, c->channels); |
|
|
|
|
|
|
|
|
|
avcodec_encode_audio2(c, &pkt, frame, &got_packet); |
|
|
|
|
if (!got_packet) |
|
|
|
@ -179,8 +186,6 @@ static void write_audio_frame(AVFormatContext *oc, AVStream *st) |
|
|
|
|
static void close_audio(AVFormatContext *oc, AVStream *st) |
|
|
|
|
{ |
|
|
|
|
avcodec_close(st->codec); |
|
|
|
|
|
|
|
|
|
av_free(samples); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/**************************************************************/ |
|
|
|
|