-
-
Notifications
You must be signed in to change notification settings - Fork 125
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
[Feature Request] Add jxl(JPEG XL) support #306
Comments
Ok for sanity check also gave it a test with a zip containing only jxl files and currently it's not detected at all. |
Supporting JXL itself (sending the files directly to the browser) would be trivial - we just need to add it to the list below. I will include this in the coming release. For on-the-fly conversion to other formats we can easily link C libraries in Crystal, but I think I would give this feature a low priority. I don't think JXL is used by many users, and including the additional libraries will increase the file size of the binary we ship. |
Just sending it would be an awesome start 👍 |
Did a test build with jxl added and everything works Guess I'll now spend a moment creating a small tool to convert my entire lib to jxl. |
Another small note for the readme: when trying to build mango on Windows, git will convert the linebreaks by default, causing compile errors with config.cr due to the |
Ok one issue I noticed, sometimes on first opening of a chapter, it loads all images with After a Control+F5 it's fixed. (just F5 doesn't work) And to why I care about JXL: I've now converted a copy of one of my libraries to JXL with a quality setting of 50(note that 0 is not "no quality", you can go really far into the - range), and it turned 57GB into 3.8GB(4.5GB on filesystem), saving mindblowing 54GB(or 94%). The only downside is the loss of finer noise, but personally, I'm more than okay with that for Mangas(https://squoosh.app/ is good to see the visual difference). I'll keep an eye open for anything odd other than the 0-size issue. |
I updated the wiki to include the |
Hi there! The feature has been added in v0.27.0. Thanks for the feature request! |
Is your feature request related to a problem? Please describe.
It would be really nice to have support for https://jpeg.org/jpegxl/index.html (https://github.com/libjxl/libjxl) due to it's REALLY good file size.
Describe the solution you'd like
Bestcase have support to send out the jxl files to the browser(Browsers support it, but apparently not yet by default without enabling it). Also having an option to serverside on the fly turn them back into .png for clients to show.
Describe a small use-case for this feature request
This would decrease the library size multiple times. In my test(default settings), a simple Manga page got compressed from 1.86mb down to 228kb without any quality loss. That's about 8 times smaller! Some more numbers playing with the quality setting:
100: 1.171mb(lossless version of the png)
80: 153kb with just small changes in the sub-pixel noise
50: 87kb(21x smaller!) with just a slight loss in fine details(but no apparent blocky artifacts like jpeg's, on a phone/normal zoom level basically not visible).
With on-the-fly server conversions, this process could become fully transparent to the end clients that might not support this feature, and if supported it can heavily save on bandwidth for mobile use-cases, while also turning an entire chapter into the size of one page in png format.
Additional context
JPEG XL is in the final stages of standardization and its codestream and file format are frozen.
, so the fileformat itself is save, but currently the main implementation is only in C++. That works for me since for my tools I can use JNA in Java to use the .ddl/.so files, not 100% sure about Crystals abilities to do that. Worst case it needs to be expanded to be able to use external parsers/decoders(which would be possible with pr 305), or keep this issue in the back of the mind till it becomes possible.Edit: also looks like tachiyomi added support last year https://github.com/tachiyomiorg/tachiyomi/releases/tag/v0.12.1
https://github.sre.pub/leechy/imgsupport can base as an example to auto fall back to .png in case jxl isn't supported?
The text was updated successfully, but these errors were encountered: