Implement support for AV1 Still Image File Format (AVIF)
Categories
(Core :: Graphics: ImageLib, enhancement, P3)
Tracking
()
People
(Reporter: Virtual, Unassigned)
References
(Depends on 21 open bugs, Blocks 1 open bug, )
Details
(Keywords: feature, nightly-community, Whiteboard: [gfx-noted])
Attachments
(9 files)
More info here - https://aomediacodec.github.io/av1-avif/ Some comparison to other formats here - https://wyohknott.github.io/image-formats-comparison/
Reporter | ||
Updated•7 years ago
|
Reporter | ||
Updated•7 years ago
|
Updated•7 years ago
|
Updated•7 years ago
|
Comment 1•6 years ago
|
||
Netflix now has a bunch of AVIF samples: http://download.opencontent.netflix.com/?prefix=AV1/Chimera/AVIF/
Comment 2•6 years ago
|
||
Some more: https://github.com/AOMediaCodec/av1-avif/tree/master/testFiles/Microsoft Especially the tiled one (Summer_in_Tomsk_720p_5x4_grid.avif) is tricky.
v1.0.0 has been released:
https://github.com/AOMediaCodec/av1-avif/releases/tag/v1.0.0
Comment 4•5 years ago
|
||
Chromium also opened an issue to implement AVIF.
Aside from using libaom (or dav1d) directly for encoding (or decoding) and muxing into an .avif file, libavif could also be considered. Here is an implementation in Colorist as example.
Comment 5•5 years ago
|
||
The Windows 10 May 2019 Update is now rolling out, which contains AVIF support (including File Explorer and Paint).
Hello! I'm the author of libavif, and similarly to the Chromium issue cited above, I thought I'd jump in here and see if there was anything I could do to help with supporting this potential feature. Chromium uses libdav1d already (supported by libavif) for decoding and (now) has a pipeline to draw HDR YUV+A, but I don't have have any idea what Firefox's pipeline and library usage is.
I'm available for libavif support or general questions, and I'd love to see AVIF support in Firefox someday even if libavif isn't used. The more adoption, the better! I'd just like to get the conversation (re-)started.
Updated•5 years ago
|
Reporter | ||
Updated•5 years ago
|
Comment 7•5 years ago
|
||
I've implemented support for importing and exporting AVIF files in darktable [1] using libavif with the help of Joe Drago (thanks again). It will be available in version 3.0.1 soon. In case you need more pictures than just AVIF example files mentioned above.
[1] https://darktable.org/ - raw image developer
Comment 8•5 years ago
|
||
That's great, Andreas! I'll definitely be checking it out as soon as 3.0.1 is released.
Comment 10•5 years ago
|
||
I created a test page to see which browser support AVIF without any JavaScript polyfill code:
http://188.121.162.14/avif/
Konqueror with patched khtml is able (the screenshot in the following article):
https://www.reddit.com/r/AV1/comments/faayy9/avif_image_browser_test/
I'd love to see AVIF support in Firefox too.
Comment 11•5 years ago
|
||
That's a cool test, dnovomesky. One thing that might make it even better is using a test image URL that gets served with the image/avif
content type. The one you're using gets served up as binary/octet-stream
since that server isn't configured to be aware of the AVIF MIME type.
Comment 12•5 years ago
|
||
That's a good remark Jon! I will try to change my test page in the future so the returned .avif will have proper mimetype image/avif .
Comment 13•4 years ago
|
||
Setting dev-doc-needed so we track documenting this. If there winds up being a separate "enable for release" bug, please add dev-doc-needed to that one too. Thanks!
Comment 14•4 years ago
|
||
I see that there is no registered media type (MIME type) for AVIF https://www.iana.org/assignments/media-types/media-types.xhtml#image
I can help with registerig a type if needed.
Comment 15•4 years ago
|
||
That would be great, Chris. I'm a bit surprised that hasn't already happened given what the spec says. Probably the spec editors are the best point of contact for synchronizing around that work.
Comment 16•4 years ago
|
||
Its now common to develop a media type registration in parallel with the rest of spec development. The trick is judging when to send it to IANA for comment. Too early and things aren't stable enough; too late and it is hard to change things that are wrong, due to existing deployment.
Comment 17•4 years ago
|
||
1553289 blocks this because libavif's lossless mode uses the identity matrix. https://github.com/AOMediaCodec/libavif/issues/243
Comment 18•4 years ago
|
||
https://aomediacodec.github.io/av1-avif/#change-list
Changes since v1.0.0 release
Remove the definition of the image/avif-sequence MIME type.
Adding bitdepth constraint for alpha and master images. This is a non-backwards compatible change.
Comment 19•4 years ago
|
||
FYI if you try to encode an AVIF image with squoosh.app, and you have image.avif.enabled turned on, it will crash. This works fine in Chrome 85 which has AVIF support enabled by default.
Let me know if you think i should file a bug for this.
Comment 20•4 years ago
|
||
(In reply to atjn from comment #19)
FYI if you try to encode an AVIF image with squoosh.app, and you have image.avif.enabled turned on, it will crash. This works fine in Chrome 85 which has AVIF support enabled by default.
Let me know if you think i should file a bug for this.
You should file a bug. FWIW, I couldn't reproduce that.
Comment 21•4 years ago
|
||
Please do file a bug that blocks this one, atjn. I generated an AVIF with squoosh just now (attached) and it opened successfully for me in both nightly and beta.
Comment 22•4 years ago
|
||
Arh, sorry for causing a stir. My beta and nightly browsers were both on version 80.x π€¦ββοΈ
This doesn't currently work in stable, but i can confirm it is fixed in Firefox 81+
Comment 23•4 years ago
|
||
Yeah, image.avif.enabled
isn't turned on by default in stable yet. Though with 80.0, I'm still able to view that image if I turn it on. You said you were getting a crash. Can you reproduce that? If so, I'm interested in figuring out how.
Comment 24•4 years ago
|
||
Though with 80.0, I'm still able to view that image if I turn it on. You said you were getting a crash. Can you reproduce that? If so, I'm interested in figuring out how.
Oh, interesting. In that case, here is a bug for it.
Comment 25•4 years ago
|
||
I'm just a user, not a dev, so I didn't want to make a new bug for this until I had commented here to verify it.
Currently (80.0.1), Firefox is not applying color management to AVIF images.
I have image.avif.enabled
and image.avif.use-dav1d
enabled. I also have color management enabled for all images via gfx.color_management.mode=1
and a monitor profile set.
Comparing two identical images, one AVIF, one PNG, it's immediately obvious that the AVIF one is not color managed. This is obviously an issue because it means that a JPEG or PNG image replaced with an identical AVIF image will look completely different. For example, this screws up my image codec comparison.
I attempted to add a sRGB profile to an AVIF image using MP4Box and the icc_path=
option. Even with the color profile explicitly added, Firefox ignored it and did no color corrections. I can't be certain that the profile was added correctly, though, as the tooling around AVIF is still very janky.
Comment 26•4 years ago
|
||
If you'd like to see if an ICC profile is present in an AVIF, you can just use:
avifdec --info image.avif
One of the lines it'll print will be something like:
- ICC Profile : Absent (0 bytes)
If it says "Present" and has a byte count, and that count is identical to the .icc file you supplied, the ICC profile probably made it intact.
If you'd like to extract the ICC profile from the AVIF, this should work:
colorist convert image.avif image.icc
Comment 27•4 years ago
|
||
Err, as a note on the colorist line:
If you do that statement, it will emit something as an ICC profile even if there isn't one present, but if there wasn't one, the output will say something like:
[ decode] No embedded ICC profile, using SRGB
If you see that, no ICC profile is in the file.
Comment 28•4 years ago
|
||
(In reply to adam.m.fontenot from comment #25)
I have
image.avif.enabled
andimage.avif.use-dav1d
enabled. I also have color management enabled for all images viagfx.color_management.mode=1
and a monitor profile set.
Please note that the full color management mode isn't supported by default yet. See bug 455077. So if there is a problem with AVIF only please file a new bug and mark it blocking the former bug. Thanks.
Comment 29•4 years ago
|
||
(In reply to Henrik Skupin (:whimboo) [βοΈUTC+2] from comment #28)
Please note that the full color management mode isn't supported by default yet. See bug 455077. So if there is a problem with AVIF only please file a new bug and mark it blocking the former bug. Thanks.
(adam.m.fontenot from comment #25)
β¦ I also have color management enabled for all images via
gfx.color_management.mode=1
and a monitor profile set.
I think there is already an AVIF-ICC bug filed at https://bugzilla.mozilla.org/show_bug.cgi?id=1634741.
Comment 30•4 years ago
|
||
avifdec --info image.avif
Thank you for this, I was actually unaware of avifenc / avifdec and had been using aomenc to output an IVF frame and then muxing that to AVIF with MP4Box. I will at least start testing avifenc and switch to using that if it gives equivalent quality to aomenc (as I expect it should).
In any case I can confirm that my embedded ICC profile did show up with avifdec. So Firefox is ignoring the profile, but as mentioned above there's already bug 1634741 for that.
So if there is a problem with AVIF only please file a new bug and mark it blocking the former bug. Thanks.
The specific issue I'm having is that when in full color management mode, AVIF images (whether untagged or tagged with sRGB) aren't treated as sRGB gamut images, so they look very wrong on high quality modern screens. PNG, JPEG, WEBP, etc etc all seem to work fine. You want the bug marked as blocking bug 455077 and not this bug? I'll try to file it later today.
Comment 31•4 years ago
|
||
adam.m.fontenot: since I think this is AVIF-specific, I'm happy to make bug 1634741 more of a general-purpose AVIF color management bug and save you the trouble of filing a new one.
Comment 32•4 years ago
|
||
(In reply to Jon Bauman [:jbauman:] from comment #31)
adam.m.fontenot: since I think this is AVIF-specific, I'm happy to make bug 1634741 more of a general-purpose AVIF color management bug and save you the trouble of filing a new one.
Works for me, thanks!
Comment 33•4 years ago
|
||
For the MDN docs I started populating a section about AVIF in the Image file type and format guide > AVIF.
The table at the end is missing information about maximum dimensions and supported color modes. It would be good to get parity with the other formats like JPG where we have info on resolution and supported colour modes. However all the information I can find on the codec appears relevant to video and doesn't cover this sort of thing.
This is therefore best probably done by someone who knows something about both image formats and this particular code.
Can you please suggest:
- What you would expect to see there - modes etc.
- Where the information might be obtained, or who best to ask.
If not we can leave it empty, but I'd prefer to add useful information if you guys have it.
Comment 34•4 years ago
|
||
AVIF doesn't really have max width or height limits defined. It depends on the encoder you use. The limit is probably UINT32_MAX x UINT32_MAX. As that's the datatype the implmentations use.
- color modes: YUV444, YUV422, YUV420
- greyscale support: yes (YUV400)
- bits: 8/10/12 bit
- alpha support: yes
- ICC profile support
- NCLX supports: sRGB, linear sRGB, linear Rec2020, PQ Rec2020, HLG Rec2020, PQ P3, HLG P3 (there are more but those are the interesting ones)
- Compression: lossless and lossy
- Tiling support
Does that help?
Comment 35•4 years ago
|
||
As far as maximum dimensions, AVIF is based on the generic image format HEIF (ISO/IEC 23008-12:2017), which requires an Image spatial extents (ispe
) property. That property defines each dimension as a unsigned 32-bit value. In practice libaom returns this metadata on the decoded image as unsigned int
and dav1d uses int
. So, definitely no larger than UINT32_MAX
, but I wouldn't expect uniform behavior of implementations beyond the maximum positive value of a platform int
.
For everything else, Andreas's comment looks perfect to me.
Comment 36•4 years ago
|
||
Disclaimer: Everything Andreas and Jon said is correct.
As a note, Wan-Teh Chang and I put in a semi-artificial ceiling in libavif right now which blocks images whose total area is greater than 16384^2. I'm sure we'll reassess when people come up with legitimate usage for such image sizes in AVIF, but for now, this feels like a reasonable protection as otherwise a super tiny AVIF could advertise a monstrous file size and we'd have a 42.zip on our hands.
From avif/internal.h:
// A maximum image size to avoid out-of-memory errors or integer overflow in
// (32-bit) int or unsigned int arithmetic operations.
#define AVIF_MAX_IMAGE_SIZE (16384 * 16384)
It is up to you all to come up with your own level of tolerance for massive AVIFs. :-)
Comment 37•4 years ago
|
||
(In reply to joedrago from comment #36)
when people come up with legitimate usage for such image sizes in AVIF
Oh! 16k feels positively like 1990s in my humblest of opinions. People came up with legitimate uses for much more ages ago; first example that comes to mind:
https://commons.wikimedia.org/wiki/Category:Gigapixel_images_from_the_Google_Art_Project
I play with the software I use on JPEGs over an artificial 32k limit imposed by some writers⦠and when it barfs, I file a bug ;-) They are 8bit, I know, but still. Artificially limiting the new format at such a low value by such a high-profile project risks setting a very dangerous example. For example: for Firefox.
Comment 38•4 years ago
|
||
Sorry, I didn't mean to be dismissive with that choice of words. Nothing in libavif (other than that explicit define) assumes any other limits like this. In theory, you could set that number as high as you want (on a x64 build) and I imagine libavif would handle it just fine.
I'm sure someone will send me a PR someday which adds a CMake option to dodge these kinds of limitations. I still think it is a sensible default for now.
Comment 39•4 years ago
|
||
For the record, Firefox imposes no such limit currently and uses dav1d for decoding by default. I haven't dug into the dav1d sources enough to know whether there are limits lower than the maximum positive int
on the platform in dav1d, but if you want to create a super large AVIF and file a bug should it break in Firefox, please feel free.
Comment 40•4 years ago
|
||
dav1d has a configurable setting dav1dSettings.frame_size_limit
, which I believe defaults to 0
unless dav1d detects it is a 32bit build and clamps to 8192^2. So yes, I think if you have an x64 build and don't manually set frame_size_limit
, you can decode any size you can fit.
Comment 41•4 years ago
|
||
Phew! It is me who is sorry: I misunderstood that this is just a config default tweakable by the lib implementer. Thank you both for alleviating my fears! :-)
Comment 42•4 years ago
|
||
A few comments on the MDN article
https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types#AVIF
(e.g. lossy AVIF images are around 50% smaller than JPEG images). Good compression relative to WebP, which compresses the same images to around 30% of the JPEG size.
That is slightly confusing (one uses % smaller than, one uses % of) and seems to say that WebP does better than AVIF. Is that true?
MIME type image/avif
No such MIME type has been registered, see https://www.iana.org/assignments/media-types/media-types.xhtml#image
I can push on the authors of the AVIF format to register it, and help them if needed.
The color modes supported are given in section 6.4.2. Color config semantics, of the AV1 Bitstream & Decoding Process Specification
In practice though, BT.2020 primaries (which are also used for HDR with BT.2100) will be the most widely used.
Comment 43•4 years ago
|
||
AVIF is a subtype of HEIF, and there is a MIME registration for image/heif
https://www.iana.org/assignments/media-types/image/heif
but it is oddly constrained to one particular subtype of HEIF, so AVIF would not be able to use they same MIME type.
Comment 44•4 years ago
|
||
OK, I pushed on the AVIF authors to register sooner rather then later
https://github.com/AOMediaCodec/av1-avif/issues/119
Comment 45•4 years ago
|
||
Chris, Andreas, Jon et al. Thank you. I think this is more than sufficient.
That is slightly confusing (one uses % smaller than, one uses % of) and seems to say that WebP does better than AVIF. Is that true?
Thanks for pointing that out. Generally AVIF does better, though it is going to depend on the particular setup. I have reworded this and linked to the source doc I got the comparison from
Generally AVIF has better compression than WebP β median 50% vs 30% compression for the same JPG set (source: AVIF WebP Comparision (CTRL Blog)).
No such MIME type has been registered, see https://www.iana.org/assignments/media-types/media-types.xhtml#image
Thanks, I have clarified that the MIME type is what Chrome and Firefox use, and that at time of writing not yet registered.
Re maximum size
I have put in 2,147,483,647Γ2,147,483,647 pixels. I take the view that we talk about what the spec offers, not particular implementation limitations.
Re colour modes.
I copied in Andreas' info from above, and also mentioned Chris's point to the spec where this is defined. I didn't mention that "In practice though, BT.2020 primaries (which are also used for HDR with BT.2100) will be the most widely used." because to my mind that is beyond what the broad audience will need to know or will find useful.
Anyway, feel free to edit/clarify further in the docs.
Comment 46•4 years ago
|
||
Rumour has it that this feature will be enabled by default in FF83 next week. Can anyone confirm or deny?
Comment 47•4 years ago
|
||
It's not even enabled in nightly so that is highly highly unlikely.
Comment 48•4 years ago
|
||
When enabling AVIF support, images are not requested with HTTP Accept containing image/avif, like this is done for image/webp. Is that already handled or should I open a bug about this?
Comment 49•4 years ago
|
||
Note to future documenter, most of the work needed when this is accepted into an official release has been done and is described here: https://github.com/mdn/sprints/issues/3804#issuecomment-711544431 (PS, thanks Timothy for note above).
Comment 50•4 years ago
|
||
(In reply to Vincent Bernat from comment #48)
When enabling AVIF support, images are not requested with HTTP Accept containing image/avif, like this is done for image/webp. Is that already handled or should I open a bug about this?
This should've been fixed ~5 months ago with bug 1641208. Is your version of Firefox 79 or newer? If so, can you please provide your repro steps so we can see if there's something additional to fix?
One thing to note: if you have a value set for image.http.accept
in about:config, that will take precedence and be used regardless of whether image.avif.enabled
is turned on or not. To ensure dynamic behavior of the Accept
header according to whether AVIF (and WebP) are enabled, make sure image.http.accept
is set to the empty string (which is the default value).
Comment 51•4 years ago
|
||
(In reply to Jon Bauman [:jbauman:] from comment #50)
(In reply to Vincent Bernat from comment #48)
When enabling AVIF support, images are not requested with HTTP Accept containing image/avif, like this is done for image/webp. Is that already handled or should I open a bug about this?
This should've been fixed ~5 months ago with bug 1641208. Is your version of Firefox 79 or newer? If so, can you please provide your repro steps so we can see if there's something additional to fix?
One thing to note: if you have a value set for
image.http.accept
in about:config, that will take precedence and be used regardless of whetherimage.avif.enabled
is turned on or not. To ensure dynamic behavior of theAccept
header according to whether AVIF (and WebP) are enabled, make sureimage.http.accept
is set to the empty string (which is the default value).
Very sorry about that. I have just tried again, and image/avif is present. I have also tried in an existing tab and it's here too.
Comment 52•4 years ago
|
||
(In reply to Vincent Bernat from comment #51)
Very sorry about that. I have just tried again, and image/avif is present. I have also tried in an existing tab and it's here too.
OK, it's not here when requesting an image directly, while image/webp
is. For example, browse https://www.mozilla.org/media/contentcards/img/home-2020/card_1/card1-high-res.1726940bba0b.png and look at the "Network" tab in devtools. So, this is pretty minor.
Comment 53•4 years ago
|
||
OK, it's not here when requesting an image directly, while
image/webp
is. For example, browse https://www.mozilla.org/media/contentcards/img/home-2020/card_1/card1-high-res.1726940bba0b.png and look at the "Network" tab in devtools. So, this is pretty minor.
Ah! That's because when you request an image directly (as opposed to in the context of an <img>
element), the request is considered to be in the "document" context rather than the "image" context and the code for generating the Accept
header is different. Fortunately, that's about to be addressed via bug 1658008 which is nearly ready to merge thanks to sagudev.
Updated•4 years ago
|
Comment 54•4 years ago
|
||
Is there any plan on supporting animated AVIF? Currently it doesn't seem to work despite this codec being extremely performant with animation.
Joining a simple animation as an example.
Comment 55•4 years ago
|
||
Yes, we'd like to support animations and image sequences. Nobody had filed a bug on it yet, so I went ahead and added bug 1686338. Thanks for the reminder!
Comment 56•4 years ago
|
||
I'm not sure if this should go in a new bug, but there seems to be some caching issues with avif.
On my website, quackack.com, on first loading, the avif images load. But on second loading, they don't. However, they will load if you reload with control+F5.
I choose the images programatically in javascript through react when the page loads. My website is a single page web app hosted on S3.
There seems to be something wrong with the caching logic for avif images, and chrome suffers from a similar issue.
Comment 57•4 years ago
|
||
(In reply to quackackjac from comment #56)
I'm not sure if this should go in a new bug, but there seems to be some caching issues with avif.
You can file a bug that blocks this one. The point of this meta bug is to collect all AVIF-related issues.
However, it seems unlikely to me that there would be anything wrong on the browser side related to AVIF-specific caching since nothing about Firefox's caching behavior is AVIF specific. The fact that you're seeing similar behavior in Chrome makes me wonder if the issue could something else entirely. In the bug you file, please include details for reproducing the behavior, including your OS and browser versions (the details for Chrome as well would be helpful).
Comment 58•4 years ago
|
||
(In reply to Jon Bauman [:jbauman:] from comment #57)
I filed a bug for this at https://bugzilla.mozilla.org/show_bug.cgi?id=1690001
I think you are right that its not actually an AVIF issue at all, but something dumb in the default way the react service worker handles avif files. My website is a very vanilla react website with very minimal configuration, so I am having trouble figuring out where exactly the issue is. I'll need to continue investigating this. I suppose that is what I get for deciding to use a framework at all.
Comment 59•4 years ago
|
||
(In reply to quackackjac from comment #58)
(In reply to Jon Bauman [:jbauman:] from comment #57)
I filed a bug for this at https://bugzilla.mozilla.org/show_bug.cgi?id=1690001
It was an old, cached service worker on my laptop from when I tried to add AVIF support late 2019. I should have tested this on another machine. Sorry for the noise.
Comment 60•4 years ago
|
||
No worries! Thanks for following up and thanks for giving AVIF a try with Firefox
Comment 61•4 years ago
|
||
Adding this just in case:
In the following website comparing AV1 to other formats, the lossy AVIF images seem to lose a lot of colour information under section comparing Flat illustrations : https://jakearchibald.com/2020/avif-has-landed/
Screencapture video: https://www.youtube.com/watch?v=uQ1QOztHHes
Firefox Beta 86.0
Build ID: 20210217195321
OS: Linux 5.10.16-arch1-1 #1 SMP PREEMPT Sat, 13 Feb 2021 20:50:18 +0000
All av1 flags set to true in config.
Comment 62•4 years ago
|
||
As I mentioned in bug 1634741. I'm concerned Firefox is going to enable AVIF by default before relevant colour bugs are fixed. As things stand now, it seems like AVIF colour is broken on non-sRGB displays. It also seems like this colour inaccuracy may go beyond the typical colour inaccuracy around Firefox's continued mishandling of untagged colour on some displays and operating systems (as demonstrated here: https://kornel.ski/en/color).
My particular concern around shipping AVIF on-by-default-but-buggy is that this would mean that services like CDN image optimizers will not be able to trust the Accept
header for working AVIF support. If the colour can't be trusted to be correct, image optimization using AVIF will be incorrect. Not being able to trust the Accept
header adds a lot of complication that nobody wants. Similar issues with the Accept
header and WebP support in Chrome meant that the header wasn't trustable for years (who knows how many buggy and out of date installations were around) and I would hate to see the same thing happen again with AVIF. In the past, this meant determining image support using the User-Agent
but that is definitely not a desirable solution and, with new privacy measures being taken, will be impossible in the future.
I would say that it is very important that either these colour issues are fixed before enabling AVIF by default. I would delay enabling it by default if necessary.
Comment 63•4 years ago
|
||
Sorry to push so hard on this but Firefox 86 is going to be released in two days and AVIF support is not ready enough to ship. Please see my comments on bug 1682995.
Comment 64•4 years ago
|
||
I agree with Nick that Firefox shouldn't ship AVIF enabled by default without fixing AVIF critical bugs. Can we please postpone enabling AVIF by default to subsequent versions until colour issues are fixed?
Comment 65•4 years ago
|
||
I agree with Nick that shipping with critical bugs will have an overall chilling effect on being able to depend on AVIF support.
Comment 66•4 years ago
|
||
https://github.com/AOMediaCodec/libavif/releases
libavif 0.9.0 released, Firefox Nightly should be updated to the latest version.
Comment 67•4 years ago
|
||
Here Firefox 86.0, can't see the picture in this url: https://petapixel.com/2021/02/20/android-12-will-support-avif-photos/
Comment 68•4 years ago
|
||
Firefox 86 does not have avif afterall, it was disabled in 86 at the last minute.
Comment hidden (obsolete) |
Comment 70•4 years ago
|
||
Here are 20 AVIF Images That Firefox Cannot Display with image.avif.enabled = true :
Please see the response in bug 1700723
Updated•4 years ago
|
Comment 71•3 years ago
|
||
I sure hope you guys turn this on in Firefox 89. I was expecting you to turn this on in 87 (by reading your timeline back then) and I converted a lot of images to avif (in early March) with enthusiastic anticipation for default support in 87.
For now, I've had to flip a flag on all my user's workstations because I'm already using AVIF heavily. Those images work fine in Firefox (when I turn it on), so I don't see why the feature isn't default yet.
I realize my post here isn't too useful, but I just wanted you guys to know I'm eagerly looking forward to this flag being remove in 89:
https://caniuse.com/avif
Comment 72•3 years ago
|
||
I sure hope you guys turn this on in Firefox 89.
AFAIK the current plan is to enable it in Firefox 90.
and I converted a lot of images to avif (in early March) with enthusiastic anticipation for default support in 87. For now, I've had to flip a flag on all my user's workstations
It is a very bad practice to rely on a whole new image format without providing a fallback. You shouldn't force your users to specific browsers and browser configurations.
so I don't see why the feature isn't default yet.
See the open dependencies of bug 1682995
Comment 73•3 years ago
|
||
(In reply to Lonnie Lee Best from comment #71)
I sure hope you guys turn this on in Firefox 89. I was expecting you to turn this on in 87 (by reading your timeline back then) and I converted a lot of images to avif (in early March) with enthusiastic anticipation for default support in 87.
For now, I've had to flip a flag on all my user's workstations because I'm already using AVIF heavily. Those images work fine in Firefox (when I turn it on), so I don't see why the feature isn't default yet.
I realize my post here isn't too useful, but I just wanted you guys to know I'm eagerly looking forward to this flag being remove in 89:
https://caniuse.com/avif
I've been waiting on this for a while as well, but I also want the implementation to be sustainable once turned on. Probably best to look into the html picture
element for providing fall back image types. If you're looking to use AVIF in css (like for background-image
) things are a bit harder there as css image-set() with the type() option has no browser support at the moment. So this require a javascript solution.
Comment 74•3 years ago
|
||
Hi,
I'm not sure if the right place to ask but this implementation will support 12 bit images, right? There has been some conflict among us laymen about weather avif supports 12 bit or not, being that it doesn't have a profile compared to 10 and 8 bit which do.
Thanks.
Comment 75•3 years ago
|
||
See https://bugzilla.mozilla.org/show_bug.cgi?id=1696092: AVIF support for 10-bit or 12-bit channels
Comment hidden (advocacy) |
Comment 77•3 years ago
|
||
(In reply to Ewout ter Hoeven from comment #1)
Netflix now has a bunch of AVIF samples:
http://download.opencontent.netflix.com/?prefix=AV1/Chimera/AVIF/
Current beta (92.0b7) can't open any of the images from the above sample, which Chrome did able.
Comment 78•3 years ago
|
||
(In reply to Irvin (MozTW) from comment #77)
(In reply to Ewout ter Hoeven from comment #1)
Netflix now has a bunch of AVIF samples:
http://download.opencontent.netflix.com/?prefix=AV1/Chimera/AVIF/Current beta (92.0b7) can't open any of the images from the above sample, which Chrome did able.
They all open fine for me in Nightly (93.0a1 2021-08-22).
Comment 79•3 years ago
|
||
(In reply to Timothy Nikkel (:tnikkel) from comment #78)
(In reply to Irvin (MozTW) from comment #77)
(In reply to Ewout ter Hoeven from comment #1)
Netflix now has a bunch of AVIF samples:
http://download.opencontent.netflix.com/?prefix=AV1/Chimera/AVIF/Current beta (92.0b7) can't open any of the images from the above sample, which Chrome did able.
They all open fine for me in Nightly (93.0a1 2021-08-22).
confirmed nightly (93.0a1 2021-08-22) ok, beta for developer (92.0b7, 64 bit on Mac) no.
Comment 80•3 years ago
•
|
||
tl;dr the current plan for AVIF in Firefox is:
- Ship AVIF enabled by default in Firefox 92 (releasing September 7, 2021) but with
image.avif.compliance_strictness
default changed from 1 (normal) to 0 (maximally permissive). See tracking bug 1727448. - Add telemetry to determine what fraction of images would be rejected and why if
image.avif.compliance_strictness
were returned to 1. Note that this setting only rejects images which are invalid according to the specifications. See bug 1696045 (and likely follow-ups). - After evaluating the telemetry for a release or two and working with the sources of invalid files, add targeted exceptions for the issues that cannot reasonably be fixed via regenerating files or amending specifications (like bug 1725022 and bug 1727033).
- No later than Firefox 94 (releasing November 2, 2021), revert the default value of
image.avif.compliance_strictness
to 1; hopefully for good. See tracking bug 1727449.
Some rationale:
Given that AVIF is a very new format, there are only a few independent implementations of readers and writers. Part of what determines whether it will be broadly adopted in the real world is how well they all interoperate. Even for openly-developed libraries, testing every reader/writer combination for compatibility is untenable, so we depend on specifications and independent validators like Compliance Warden for this.
Though it can be tempting to make readers as permissive as possible (people just want to see the images!), this comes at the cost of normalizing invalid files, making the standards less useful and making future implementations more challenging. Since the number of AVIFs in circulation is only going to increase, it's generally not feasible to make implementations stricter in the future. That means now is the time to be as strict as is reasonably practical in order to surface as many implementation errors as early as possible and help make the format as valuable and easy to work with as we can.
Comment 81•3 years ago
|
||
(In reply to Irvin (MozTW) from comment #77)
(In reply to Ewout ter Hoeven from comment #1)
Netflix now has a bunch of AVIF samples:
http://download.opencontent.netflix.com/?prefix=AV1/Chimera/AVIF/Current beta (92.0b7) can't open any of the images from the above sample, which Chrome did able.
For the record, all those images are technically invalid due to the missing pixi
boxes. See bug 1725022 and the corresponding chromium issue for more detail.
Updated•3 years ago
|
Comment 82•3 years ago
|
||
Hi there,
I tried this feature in the current nightly (94.0a1 (2021-09-07) (64-Bit)) using the attached file "IMG_IPHONE12PRO_0_6761.avif" but FireFox failed to display the file whereas Google Chrome had no issues with the same file. Also see attached screenshots.
Comment 86•3 years ago
|
||
(In reply to Lars Sonchocky-Helldorf from comment #82)
Hi there,
I tried this feature in the current nightly (94.0a1 (2021-09-07) (64-Bit)) using the attached file "IMG_IPHONE12PRO_0_6761.avif" but FireFox failed to display the file whereas Google Chrome had no issues with the same file. Also see attached screenshots.
This is bug 1729071, confirmed from the log:
[2021-09-08T16:48:07Z ERROR mp4parse] Multiple values for colr: [Colour(Icc(IccColourInformation { data: 548 bytes })), Colour(Nclx(NclxColourInformation { colour_primaries: 2, transfer_characteristics: 2, matrix_coefficients: 2, full_range_flag: true }))]
See bug 1729071 comment 4 for more details.
Comment 87•3 years ago
|
||
(In reply to Jon Bauman [:jbauman:] from comment #86)
(In reply to Lars Sonchocky-Helldorf from comment #82)
Hi there,
I tried this feature in the current nightly (94.0a1 (2021-09-07) (64-Bit)) using the attached file "IMG_IPHONE12PRO_0_6761.avif" but FireFox failed to display the file whereas Google Chrome had no issues with the same file. Also see attached screenshots.
This is bug 1729071, confirmed from the log:
[2021-09-08T16:48:07Z ERROR mp4parse] Multiple values for colr: [Colour(Icc(IccColourInformation { data: 548 bytes })), Colour(Nclx(NclxColourInformation { colour_primaries: 2, transfer_characteristics: 2, matrix_coefficients: 2, full_range_flag: true }))]
See bug 1729071 comment 4 for more details.
I asked the developer of the Software with which the "IMG_IPHONE12PRO_0_6761.avif" was created ( https://www.lemkesoft.de/produkte/graphicconverter ) about this issue. He said: (translated using https://www.deepl.com/translator ):
"Hello,
the AVIF is created via the libAVIF. I can only pass a color profile there. Then it is certainly due to the libAVIF.
But this is also still under development.
Greetings
Thorsten Lemke"
IIRC FireFox is also using libAVIF, so it might be a libAVIF issue?
regards,
Lars
Comment 88•3 years ago
|
||
IIRC FireFox is also using libAVIF, so it might be a libAVIF issue?
No, firefox does not use libavif. It uses mp4parse-rust for parsing AVIF inputs.
Yes, it is a libavif issue, which is fully explained in bug 1729071 comment 4. If you have any further questions, please comment there, but do know that the issue is well understood and fix is already in progress.
Updated•3 years ago
|
Updated•3 years ago
|
Updated•3 years ago
|
Comment hidden (advocacy) |
Comment 90•3 years ago
|
||
We removed the Webcompat Priority because we don't have any breakage for the previous identified webcompat issues.
If some issues appear on specific websites, we will be adding this to the specific bug related to AVIF.
Updated•3 years ago
|
Comment 91•2 years ago
|
||
Removed the dev-doc-needed flag because this feature already got documented in bug 1682995.
Sebastian
Comment 92•2 years ago
|
||
In the process of migrating remaining bugs to the new severity system, the severity for this bug cannot be automatically determined. Please retriage this bug using the new severity system.
Comment 93•11 months ago
|
||
Comment 94•11 months ago
|
||
Comment 95•11 months ago
|
||
Currently, AVIF color matrix metadata is not respected, BT.470 B/G is always assumed, and the image therefore incorrectly decoded in cases where a color matrix other than BT.470 B/G is used. See the provided attachments, they were created identically aside from the different color matrix used and then correctly provided in metadata. But they still look quite different in Firefox, while they should not, as decoding them with avifdec to PNG shows.
Comment 96•11 months ago
|
||
Well, that's embarassing... Looks like the bug is exclusive to 10-bit (and probably 12 bit as well). So the attached images don't demonstrate anything. I chose to encode in 8-bit this time, because Firefox also suffers from a general issue with high bit depth images as well, that would have conflicted somewhat with my demonstration...
But I'll upload 10-bit versions as well.
Comment 97•11 months ago
|
||
Comment 98•11 months ago
|
||
Comment 99•11 months ago
|
||
As you can probably see, they look quite different, while they should not. However, considering the general issue with high bit depth images, and considering that everything works fine for 8-bit AVIf, I assume that it's not a failure to read AVIf color matrix metadata, but that YUV to RGB conversion in high bit depth is always done using the BT.470 B/G matrix, regardless of image format?
Comment 100•11 months ago
|
||
Bug 1805278 and bug 1788866 are almost certainly related, with bug 1696092 covering the more general case. With this you've narrowed down a specific problem (needs 709 and 2020 10- and 12-bit matrices, at minimum) and it would be worthy of its own bug, though, and if the fix happens to fix others then so be it.
Comment 101•11 months ago
|
||
(In reply to Emily Bowman from comment #100)
Bug 1805278 and bug 1788866 are almost certainly related, with bug 1696092 covering the more general case. With this you've narrowed down a specific problem (needs 709 and 2020 10- and 12-bit matrices, at minimum) and it would be worthy of its own bug, though, and if the fix happens to fix others then so be it.
Thanks. Since none of these bugs address the more fundamental issue of even simple RGB high bit depth images being rendered incorrectly, I'll create a new bug report.
Comment 102•11 months ago
|
||
In general please create new bugs. This bug is just a tracking bug, so it is only meant to discuss the issue in general and track any related bugs as dependencies.
Description
•