From: Vignesh Venkatasubramanian <vigneshv-at-google.com@ffmpeg.org>
To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org>
Subject: Re: [FFmpeg-devel] [PATCH 3/3] avformat/movenc: Add support for AVIF muxing
Date: Mon, 2 May 2022 14:34:56 -0700
Message-ID: <CAOJaEPK9bjKjU5uNoCC-f8O0aKuoE1-gjPZ2G1mXLWjBs5PmVA@mail.gmail.com> (raw)
In-Reply-To: <CABWgkXJW8tbL05+iVoHin-JnboQTc_=Ge4MduDv_775cP2AcQg@mail.gmail.com>
On Mon, May 2, 2022 at 10:28 AM James Zern
<jzern-at-google.com@ffmpeg.org> wrote:
>
> On Wed, Apr 13, 2022 at 1:40 PM Vignesh Venkatasubramanian
> <vigneshv-at-google.com@ffmpeg.org> wrote:
> >
> > Add an AVIF muxer by re-using the existing the mov/mp4 muxer.
> >
> > AVIF Specification: https://aomediacodec.github.io/av1-avif
> >
> > Sample usage for still image:
> > ffmpeg -i image.png -c:v libaom-av1 -avif-image 1 image.avif
> >
> > Sample usage for animated AVIF image:
> > ffmpeg -i video.mp4 animated.avif
> >
> > We can re-use any of the AV1 encoding options that will make
> > sense for image encoding (like bitrate, tiles, encoding speed,
> > etc).
> >
> > The files generated by this muxer has been verified to be valid
> > AVIF files by the following:
> > 1) Displays on Chrome (both still and animated images).
> > 2) Displays on Firefox (only still images, firefox does not support
> > animated AVIF yet).
> > 3) Verified to be valid by Compliance Warden:
> > https://github.com/gpac/ComplianceWarden
> >
> > Fixes the encoder/muxer part of Trac Ticket #7621
> >
> > Signed-off-by: Vignesh Venkatasubramanian <vigneshv@google.com>
> > ---
> > configure | 1 +
> > libavformat/allformats.c | 1 +
> > libavformat/movenc.c | 337 ++++++++++++++++++++++++++++++++++++---
> > libavformat/movenc.h | 5 +
> > 4 files changed, 319 insertions(+), 25 deletions(-)
> >
>
> It would be good to have a Changelog entry after the ticket is fixed.
>
Acknowledged. Will do.
> > [...]
> > @@ -2823,7 +2848,10 @@ static int mov_write_hdlr_tag(AVFormatContext *s, AVIOContext *pb, MOVTrack *tra
> >
> > if (track) {
> > hdlr = (track->mode == MODE_MOV) ? "mhlr" : "\0\0\0\0";
> > - if (track->par->codec_type == AVMEDIA_TYPE_VIDEO) {
> > + if (track->mode == MODE_AVIF) {
> > + hdlr_type = "pict";
> > + descr = "ffmpeg";
>
> Should this be PictureHandler or blank? What's written for heic?
>
Hmm, i used the string "ffmpeg" because libavif was writing "libavif"
[1]. But i think it makes sense to be consistent with the other types
here. I have updated the string to be "PictureHandler".
[1] https://github.com/AOMediaCodec/libavif/blob/45b6b1b88b54de6031c15b4f9dbee10f86244d1b/src/write.c#L456
> > [...]
> > +static int mov_write_ispe_tag(AVIOContext *pb, MOVMuxContext *mov, AVFormatContext *s)
> > +{
> > + int64_t pos = avio_tell(pb);
> > + avio_wb32(pb, 0); /* size */
> > + ffio_wfourcc(pb, "ispe");
> > + avio_wb32(pb, 0); /* Version & flags */
> > + avio_wb32(pb, s->streams[0]->codecpar->width); /* image_width */
> > + avio_wb32(pb, s->streams[0]->codecpar->height); /* image_height */
> > + return update_size(pb, pos);
> > +}
> > +
> > +
>
> This extra line could be removed.
Removed.
>
> > [...]
> > + /* AVIF output must have exactly one video stream */
> > + if (mov->mode == MODE_AVIF) {
> > + if (s->nb_streams > 1) {
> > + av_log(s, AV_LOG_ERROR, "AVIF output requires exactly one stream\n");
> > + return AVERROR(EINVAL);
> > + }
> > + if (s->streams[0]->codecpar->codec_type != AVMEDIA_TYPE_VIDEO) {
> > + av_log(s, AV_LOG_ERROR, "AVIF output requires one video stream\n");
> > + return AVERROR(EINVAL);
> > + }
> > + }
> > +
> > +
>
> This one too.
Removed.
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
--
Vignesh
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next prev parent reply other threads:[~2022-05-02 21:35 UTC|newest]
Thread overview: 71+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-02-17 5:51 [FFmpeg-devel] [PATCH 1/3] avcodec/libaomenc: Add parameter for avif single image encoding Vignesh Venkatasubramanian
2022-02-17 5:51 ` [FFmpeg-devel] [PATCH 2/3] avformat/av1: Add a parameter to av1c to omit seq header Vignesh Venkatasubramanian
2022-03-02 22:57 ` James Almer
2022-03-02 23:22 ` Vignesh Venkatasubramanian
2022-03-02 23:23 ` Vignesh Venkatasubramanian
2022-03-02 23:27 ` James Almer
2022-03-28 20:48 ` Vignesh Venkatasubramanian
2022-04-13 20:40 ` Vignesh Venkatasubramanian
2022-05-02 21:36 ` Vignesh Venkatasubramanian
2022-02-17 5:51 ` [FFmpeg-devel] [PATCH 3/3] avformat/movenc: Add support for AVIF muxing Vignesh Venkatasubramanian
2022-02-22 18:40 ` Vignesh Venkatasubramanian
2022-02-22 20:03 ` James Almer
2022-02-22 21:37 ` Vignesh Venkatasubramanian
2022-02-22 21:38 ` Vignesh Venkatasubramanian
2022-02-22 21:43 ` Vignesh Venkatasubramanian
2022-02-24 17:34 ` Vignesh Venkatasubramanian
2022-03-01 16:49 ` Vignesh Venkatasubramanian
2022-03-03 15:36 ` James Almer
2022-03-03 19:16 ` Vignesh Venkatasubramanian
2022-03-04 11:24 ` James Almer
2022-03-04 17:52 ` Vignesh Venkatasubramanian
2022-03-04 17:54 ` Vignesh Venkatasubramanian
2022-03-09 19:34 ` Vignesh Venkatasubramanian
2022-03-10 16:01 ` Andreas Rheinhardt
2022-03-10 18:12 ` Vignesh Venkatasubramanian
2022-03-21 20:46 ` Andreas Rheinhardt
2022-03-22 16:45 ` Vignesh Venkatasubramanian
2022-03-22 16:46 ` Vignesh Venkatasubramanian
2022-03-28 17:06 ` Vignesh Venkatasubramanian
2022-03-28 20:49 ` Vignesh Venkatasubramanian
2022-04-07 18:25 ` Vignesh Venkatasubramanian
2022-04-13 17:21 ` James Zern
2022-04-13 20:40 ` Vignesh Venkatasubramanian
2022-04-13 21:01 ` Andreas Rheinhardt
2022-04-13 21:33 ` Vignesh Venkatasubramanian
2022-05-02 17:28 ` James Zern
2022-05-02 21:34 ` Vignesh Venkatasubramanian [this message]
2022-05-02 21:35 ` Vignesh Venkatasubramanian
2022-05-03 23:39 ` James Zern
2022-05-04 2:46 ` "zhilizhao(赵志立)"
2022-05-04 16:45 ` Vignesh Venkatasubramanian
2022-05-04 16:48 ` Vignesh Venkatasubramanian
2022-05-04 17:10 ` "zhilizhao(赵志立)"
2022-05-04 17:14 ` Vignesh Venkatasubramanian
2022-05-04 17:15 ` Vignesh Venkatasubramanian
2022-05-11 16:54 ` Vignesh Venkatasubramanian
2022-05-11 17:25 ` Gyan Doshi
2022-05-12 10:26 ` Gyan Doshi
2022-05-12 16:23 ` Vignesh Venkatasubramanian
2022-05-12 16:23 ` Vignesh Venkatasubramanian
2022-05-13 7:22 ` Gyan Doshi
2022-04-13 20:41 ` Vignesh Venkatasubramanian
2022-04-13 21:04 ` Andreas Rheinhardt
2022-04-13 21:35 ` Vignesh Venkatasubramanian
2022-04-21 16:38 ` Vignesh Venkatasubramanian
2022-04-29 16:03 ` Vignesh Venkatasubramanian
2022-03-10 18:14 ` Vignesh Venkatasubramanian
2022-03-15 15:59 ` Vignesh Venkatasubramanian
2022-03-21 17:07 ` Vignesh Venkatasubramanian
2022-03-03 19:20 ` Vignesh Venkatasubramanian
2022-03-03 19:46 ` James Almer
2022-03-03 19:57 ` Vignesh Venkatasubramanian
2022-02-17 18:09 ` [FFmpeg-devel] [PATCH 1/3] avcodec/libaomenc: Add parameter for avif single image encoding James Zern
2022-02-17 19:33 ` Vignesh Venkatasubramanian
2022-02-17 20:59 ` James Almer
2022-02-17 21:18 ` [FFmpeg-devel] [PATCH] " Vignesh Venkatasubramanian
2022-02-17 21:20 ` [FFmpeg-devel] [PATCH 1/3] " Vignesh Venkatasubramanian
2022-02-22 21:36 ` Vignesh Venkatasubramanian
2022-03-28 20:47 ` Vignesh Venkatasubramanian
2022-04-13 20:39 ` Vignesh Venkatasubramanian
2022-05-02 21:37 ` Vignesh Venkatasubramanian
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CAOJaEPK9bjKjU5uNoCC-f8O0aKuoE1-gjPZ2G1mXLWjBs5PmVA@mail.gmail.com \
--to=vigneshv-at-google.com@ffmpeg.org \
--cc=ffmpeg-devel@ffmpeg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git