-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
JPEG XL image format #700
Comments
Here's a different, related Chromium ticket with a lot of activity about reopening the JXL issue. I'll also copy a comment I recently left there that summarizes some recent coordination between the JPEG-XL team at Google Research, the Firefox team at Mozilla, and the jxl-oxide maintainer.
Meanwhile, Apple has continued to develop its JXL support on their product lines. Earlier today, Apple confirmed iPhone 16 Pros will be able to use JPEG-XL compression for ProRAW photos:
|
This year we must demand an explanation if the proposition is turned down again. No more backroom shenanigans. |
Agreed, unless there's a valid explanation for this format not being accepted through this platform (which is unlikely), its rejection after clearing due process is wholly unacceptable. |
As much as I would love to see Chrome forced to implement JPEG XL, I'm afraid these comments making "demands" are based on a misunderstanding of who and what Interop is. The Interop team is based on voluntary participation from the browser makers and has no authority to force anyone to do anything. If the Interop team approves a proposal that a browser maker has no intention of implementing, then it still won't be implemented and the process serves no purpose. See the Team Charter for more info. A key quote:
Basically, if Chrome opposes JPEG XL then it won't be approved, period. |
How do we know that Chrome blocks the adoption of JPEG XL within Interop? We don't know for sure who blocks it because the whole thing is opaque for us plebeians, so you can only assume. This is what I am talking about. We need transparency, if the chrome team blocks JXL, it needs to be known. The more a company abuses its position the more likely for it to be considered a monopoly and broken up. Last month, Google's search engine was found to be an illegal monopoly and the judge is considering forcing Google to spin off the Chrome browser. Another anti-trust lawsuit will look into Google's ad business this month. Hopefully this will knock some sense into them. |
Given some comments last year suggested including the description in that comment thread, rather than just linking to a previous discussion, perhaps someone should do the same this year, ensuring there's a clear explanation of what JPEG-XL is and why it matters, allowing this proposal to stand on its own? As a start I'll note that JPEG-XL's interop proposal for 2024 received far more community support than any other proposals, with nearly 700 "👍" reactions on the proposal's first message. Combined with the over 200 "👍" reactions from this year's proposal, accumulated over just the last 3 days, it's clear that the developer community is very interested in this proposal. |
During last years biggest performance meetup, PerfNow, at the pre-conference meetup, there was a very convincing song live played. Give JXL a Chance - https://www.youtube.com/watch?v=VJaa1Le4W7c Also unrelated to the song I think this sums it up pretty good: |
Dear JPEG XL and Interop communities, let's focus on the future of JPEG XL in Interop 2025. I have two suggestions to help move forward:
Since the reason for excluding JPEG XL in Interop 2024 is "We did not have consensus to include this proposal." and not a more precisely communicated specific issue, we need a general overview of the format, its benefits and its current positioning and future plans in browsers and other digital platforms (including the slight adjustment in Mozilla's position) rather than to address a specific technical issue. There might be a connection to the Rust decoder issue we discussed last year. To address this, and Mozilla's recently adjusted position on JPEG XL, volunteers and the JPEG XL developers at Google are working on jxl-rs, a new Rust-based decoder. Key Points:
|
To the JPEG XL community: One of the key issues that affect JPEG XLs inclusion is the lack of transparency in the Interop process. We (Open Web Advocacy) believe that we should require this transparency. We are pushing for transparency via this issue Interop Lack of Transparency & Accountability |
DICOM, or Digital Imaging and Communications in Medicine is a worldwide standard for the storage and transfer of medical imaging data, with "a near universal level of acceptance among medical imaging equipment vendors and healthcare IT organizations". They just updated their standard to adopt JPEG-XL as a payload codec. Here are some slides covering the decision. Some snippets:
They of course mention that incomplete web browser support is a downside but have gone ahead anyway. And based on what we've heard from Mozilla recently (detailed above), there's a fair chance that the "incomplete" support will be "most Chromium-based browsers" in the near future. Also of note from the standard:
Here's an IEEE proposal from a conference in June 2023 that was advocating for DICOM to adopt JXL's lossless compression as "a universal replacement for medical file size reduction." |
Mozilla's concern is stated clearly
Chrome's position is also often misrepresented/reduced to just "not enough interest" (blatantly false ofc), but also
I think Mozilla's position is entirely reasonable. They are working with Google to develop a rust-based decoder that could resolve their concerns. I don't think it's fair to push them when they're actively looking into a solution that addresses their concerns Chrome's position needs further elaboration and could probably be argued against. |
This issue is even more important than people commonly think. There will be a successor to JPEG, but JPEG-XL is the only candidate that allows a lossless transcoding from JPEG to JPEG-XL with a ~20% size reduction (according to my own tests). Images on the web have already degraded due to generation loss from recompression. With WEBP, AVIF or HEIC you don't have any other choice than to recompress again with a loss, if you want to get any size reduction when switching to these formats. I do think we owe it to the people that come after us to choose the successor to JPEG wisely and to consider the impact that our choice has on the preservation of images that already exist right now. It would be a shame to see them reduced to a porridge of pixels by the time they would be used to teach history lessons. |
One of the advantages of JXL is that even in JXL to JXL recompression, the standard is designed to limit generation loss as we see in the JPEG to JPEG recompression. This is a huge advantage in some kinds of web communities |
Depending on the site, data usage can be limited by simply partially downloading JXL files. Legacy clients can still be served transcoded files, as the overhead is under 60ms to revert back to JPEG, further reducing storage costs. Google's own saliency demo shows that regions of images can be prioritised, improving responsiveness with the aforementioned partial requests. Showing the focus first and the background last. It's also redundant to data loss or corruption, albeit not currently enabled in libjxl. The image can still be rendered with missing AC or DC blocks, so long as the header is intact. I think others have already said the common use cases and examples. The Spec is also being updated to allow UltraHDR transcoding, further futureproofing the format and retaining backwards compatibility. |
Good news! The jxl-rs project (a safe and fast JPEG XL decoder implementation in Rust) is progressing well. We are currently on track to deliver the following milestones: End of February 2025: Initial decoding capabilities and a preliminary API. We are also prepared to integrate jxl-rs into the main browsers. We appreciate the community's continued interest and support. Please remember to treat each other with respect in all project discussions. A positive and collaborative environment is crucial for the success of JPEG XL. |
On the last day of this year, I thought it would be helpful to share an update from theguardian.com as we have publicly voiced support for the format, and reiterate that we would like browser engineering teams to focus on supporting this image format. Earlier this year, in the summer, we started serving JPEG XL images to our readers when supported by their browsers. We were the first customer of our CDN image service to do so, and you can see impact on their global requests breakdown by format for them: We are impatiently waiting for an increased support by browsers and image processing software, as we aim to be able to use JPEG XL end-to-end from photographer’s camera to end users. We therefore consider Mozilla's new position an excellent news! We would also appreciate it if Webkit could support progressive decoding and in general better support progressive images rendering while loading. Finally as we’ve seen with AVIF, codecs improve over time. We think the best way for them all to reach their full potential is to allow them to compete by ensuring fair support. |
@mo271 will it include support for animated JPEG XL? It’s a shame that the Safari implementation doesn’t include animation. There are use cases that require both animation and transparency. Hopefully Interop will be for all features of JPEG-XL. It's partly its feature set that makes JPEG-XL a worthwhile format in the first place. |
@o-t-w jxl-rs can already read animations to some basic degree. |
@Schweinepriester it might be worth editing the description above to note that, in addition to Safari (WebKit), JPEG XL is also working out-of-the-box in WebKitGTK-based browsers and applications, such as Epiphany and others (ex: desktop email clients / feed readers / social media clients that use WebKitGTK, and presumably browsers in the embedded space, etc.). That information is unfortuntely not reflected on the CanIUse website. |
Yes, we plan to include support for animated JPEG XL images. |
Description
Same as last year, see #430 and the year before #176.
Specification
https://jpeg.org/jpegxl/documentation.html; ISO/IEC 18181
Additional Signals
The text was updated successfully, but these errors were encountered: