Commit 40a93630 authored by Andreas Rheinhardt's avatar Andreas Rheinhardt

avformat/filmstripenc: Use ff_raw_write_packet()

The only difference of the currently used write_packet()-function to
ff_raw_write_packet() is that the former also counts the number of
frames. Yet doing so in the muxer itself is unnecessary as this is
already done generically in write_packet() in libavformat/mux.c.
Signed-off-by: 's avatarAndreas Rheinhardt <andreas.rheinhardt@gmail.com>
parent 2cae3f60
...@@ -179,7 +179,7 @@ OBJS-$(CONFIG_FFMETADATA_MUXER) += ffmetaenc.o ...@@ -179,7 +179,7 @@ OBJS-$(CONFIG_FFMETADATA_MUXER) += ffmetaenc.o
OBJS-$(CONFIG_FIFO_MUXER) += fifo.o OBJS-$(CONFIG_FIFO_MUXER) += fifo.o
OBJS-$(CONFIG_FIFO_TEST_MUXER) += fifo_test.o OBJS-$(CONFIG_FIFO_TEST_MUXER) += fifo_test.o
OBJS-$(CONFIG_FILMSTRIP_DEMUXER) += filmstripdec.o OBJS-$(CONFIG_FILMSTRIP_DEMUXER) += filmstripdec.o
OBJS-$(CONFIG_FILMSTRIP_MUXER) += filmstripenc.o OBJS-$(CONFIG_FILMSTRIP_MUXER) += filmstripenc.o rawenc.o
OBJS-$(CONFIG_FITS_DEMUXER) += fitsdec.o OBJS-$(CONFIG_FITS_DEMUXER) += fitsdec.o
OBJS-$(CONFIG_FITS_MUXER) += fitsenc.o OBJS-$(CONFIG_FITS_MUXER) += fitsenc.o
OBJS-$(CONFIG_FLAC_DEMUXER) += flacdec.o rawdec.o \ OBJS-$(CONFIG_FLAC_DEMUXER) += flacdec.o rawdec.o \
......
...@@ -26,13 +26,10 @@ ...@@ -26,13 +26,10 @@
#include "libavutil/intreadwrite.h" #include "libavutil/intreadwrite.h"
#include "avformat.h" #include "avformat.h"
#include "rawenc.h"
#define RAND_TAG MKBETAG('R','a','n','d') #define RAND_TAG MKBETAG('R','a','n','d')
typedef struct FilmstripMuxContext {
int nb_frames;
} FilmstripMuxContext;
static int write_header(AVFormatContext *s) static int write_header(AVFormatContext *s)
{ {
if (s->streams[0]->codecpar->format != AV_PIX_FMT_RGBA) { if (s->streams[0]->codecpar->format != AV_PIX_FMT_RGBA) {
...@@ -42,23 +39,14 @@ static int write_header(AVFormatContext *s) ...@@ -42,23 +39,14 @@ static int write_header(AVFormatContext *s)
return 0; return 0;
} }
static int write_packet(AVFormatContext *s, AVPacket *pkt)
{
FilmstripMuxContext *film = s->priv_data;
avio_write(s->pb, pkt->data, pkt->size);
film->nb_frames++;
return 0;
}
static int write_trailer(AVFormatContext *s) static int write_trailer(AVFormatContext *s)
{ {
FilmstripMuxContext *film = s->priv_data;
AVIOContext *pb = s->pb; AVIOContext *pb = s->pb;
AVStream *st = s->streams[0]; AVStream *st = s->streams[0];
int i; int i;
avio_wb32(pb, RAND_TAG); avio_wb32(pb, RAND_TAG);
avio_wb32(pb, film->nb_frames); avio_wb32(pb, st->nb_frames);
avio_wb16(pb, 0); // packing method avio_wb16(pb, 0); // packing method
avio_wb16(pb, 0); // reserved avio_wb16(pb, 0); // reserved
avio_wb16(pb, st->codecpar->width); avio_wb16(pb, st->codecpar->width);
...@@ -76,10 +64,9 @@ AVOutputFormat ff_filmstrip_muxer = { ...@@ -76,10 +64,9 @@ AVOutputFormat ff_filmstrip_muxer = {
.name = "filmstrip", .name = "filmstrip",
.long_name = NULL_IF_CONFIG_SMALL("Adobe Filmstrip"), .long_name = NULL_IF_CONFIG_SMALL("Adobe Filmstrip"),
.extensions = "flm", .extensions = "flm",
.priv_data_size = sizeof(FilmstripMuxContext),
.audio_codec = AV_CODEC_ID_NONE, .audio_codec = AV_CODEC_ID_NONE,
.video_codec = AV_CODEC_ID_RAWVIDEO, .video_codec = AV_CODEC_ID_RAWVIDEO,
.write_header = write_header, .write_header = write_header,
.write_packet = write_packet, .write_packet = ff_raw_write_packet,
.write_trailer = write_trailer, .write_trailer = write_trailer,
}; };
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