-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
(bug) Image uploads are rescaled to 2000x2000, even if source image is smaller #1101
Comments
I saved an image from Bluesky and can see that the size is almost 2000x2000 (but the file size is only 231 KB) This really needs to be fixed ASAP. |
I've accidentally submitted this issue with the "feature request" label - this was intended to be a bug report, sorry. One behavior that leaves me puzzled: image URLs include the line "\rs:fit:2000:2000:1:0", leaving me to believe that this scaling might actually be performed when delivering it to a user, and not on upload as I originally assumed. But I don't understand why this step would even be necessary. Browsers have long supported arbitrary scaling of images, and it's a common feature of any modern graphics rendering library. What does this step actually achieve? |
I think is a question for @devinivy, I'm not sure what the backend logic is and I'm 75% sure we don't scale up in the client |
That's right, images are resized on demand and then cached. So if the original image in a user's repository is very large, we can still serve a resized, compressed, jpeg version of it to the client as e.g. their avatar which is generally displayed much smaller. The next time another user asks for the same avatar image, they will be served the cached version. Especially in the federated setting where the originals could be varied in size/format/etc, this ensures clients are getting consistent views of images on the network. We'll take a look into the upscaling issue 👍 |
This bug hasn't been fixed yet. |
I too am greatly vexed by this. Especially for jpeg works, as it makes the jpeging around the edges much more noticeable, though it's also especially bothersome for creators that post things at particularly small resolutions. |
Adding another example here: https://bsky.app/profile/qazm.bsky.social/post/3l3yad77cag2s The original is a 1.04 KB PNG, the CDN version is a 70.5 KB JPEG. Please consider using |
Does anyone know whether upscaling is done by the client or at a later stage? I.e. are the originals on PDS correct or is the client borking it. |
https://atproto-browser.vercel.app/at/did:plc:2shmwstgqmlu4ymg7ctjcdc7/app.bsky.feed.post/3l3yad77cag2s says the blob content size for my image is 2113 [bytes?] and the dimensions are 32x32, so that's fine(-ish. Would be better/smaller if it was still a PNG, but it shouldn't fully skip the reencode when uploading so that meta data is still stripped). I'm pretty sure it's mainly the CDN that's causing issues here, but the client should receive a patch to display low-res images better, too. |
Just wanted to chime in to say that this is very noticeable on one of my accounts, which primarily posts computer screenshots at 640x480 and smaller. For example, this 512x384 image really didn't need to get scaled up: https://bsky.app/profile/cd-i.bsky.social/post/3l43jrdmk2p2r The filesize was also bloated: the original 512x384 PNG is 24KB, but the upscaled 2000x1500 JPG is 205KB. |
Maybe the client should skip the CDN and use the blob directly if the blob size is known to be small. If the aspect ratio for embedded images is guaranteed to equal the size of the original image this would be rather easy to implement. Otherwise reading file headers (for PNG) or SOF (for JPEG) would give the original image size without having to download all of it. |
Can't be done this way. That's a deanonymisation vector. It doesn't matter anyway though, as both the CDN and client are controlled by Bluesky, so they can fix the CDN here (which would also reduce load on their hosting infrastructure). |
If it's a CDN-side issue - is the CDN open-source or closed-source? Is there somewhere this issue should be filed to be more actionable? |
@mistydemeo I couldn't find references to the CDN anywhere, so it seems like its closed source.
@devinivy is this still on your radar? I know it seems like a fairly small issue but the upscaling also impacts downloading images in the app. They're much larger than they need to be. |
The images being upscaled appear to also give them very pronounced ringing, which looks absolutely hideous for stuff like pixel art and web screenshots. This really should be dealt with as soon as possible, this issue makes images uploaded to Bluesky lower quality across the board |
Yes, totally hearing yall 👍 It remains on our radar and we intend to patch it up soon. As mentioned above, it is a bsky CDN issue and the path to fixing it up looks clear. |
Once this is fixed, would you consider (slowly, if necessary) invalidating the cache for older images too? |
@ds84182 The CDN being used by Bluesky is currently imageproxy. |
This should finally be resolved! https://bsky.app/profile/divy.zone/post/3l6ipmrzso42b Newly-posted images will get the fix immediately, and old images will gradually (within days) fall out of the cache and be replaced with new versions. |
Confirmed! https://bsky.app/profile/cdrom.ca/post/3l6ipu6q6vh2r Thank you very much! It looks like the other half of the issue is still here though: the source image for that post is a 6KB PNG, but it was recompressed into a 137KB JPEG. |
Good to see the resolution part of this issue is finally resolved, very happy to see it. Would be great to see file-size be accounted for as well, especially for instances like the case above - unnecessary conversion of PNGs to JPGs when the the former is far smaller than the latter. |
Probably not super important, but the effective quality for tiny images got worse 😰
(Still slightly larger than the original PNG, but not by much.) It would be great if Bluesky supported pixel icon art without having to scale it up at some point. |
Seems like the remaining issue is JPG -> PNG conversion, let's track that in #5855. |
There's also the fact that Bluesky still scale up images (client-side) and doesn't do well with pixel art (see previous comment #1101 (comment)) |
Bluesky appears to rescale images to fit a maximum resolution of 2000x2000 pixels. While this step is understandable for handling larger images, it makes no sense to perform this on smaller images.
This also likely means that file size does not appear to be a factor in whether an image is processed and recompressed. Images are simply made to fit 2000x2000 indiscriminately. If these images are being stored at this resolution, they'd be wasting more server space and network bandwidth than necessary in the process.
I've noticed this with my own images posted via PC (Win 11, Firefox), and also in many images uploaded by other users.
Ideally, if an image is smaller than the max resolution or file size, simply leave it be. Additionally, the front-end should state the max resolution and file size somewhere, so that users can better prepare their images for the platform if they have the means.
The text was updated successfully, but these errors were encountered: