fix(web): properly project profile picture #16095
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
This PR fixes an issue where users were unable to set a profile picture due to incorrect transparency detection. The issue originates from the
hasTransparentPixels
function in profile-image-cropper.svelte.Root Cause
The issue occurs because the blob generated in the
handleSetProfilePicture
function does not accurately represent the portion of the image selected by the user. Users can zoom and drag the image in thephoto-viewer
component, but the generated blob includes additional image areas and empty canvas space, leading to incorrect transparency detection.When the blob is projected onto a canvas for transparency checking, the canvas contains:
Since the
hasTransparentPixels
function evaluates the entire canvas, the presence of empty space causes false positives, preventing users from setting their profile pictures.Solution
imgElement
height and width to only get portion of the image that the user has selected.This fix ensures both transparency detection and the final profile picture selection work as expected.
Fixes #15812.
How Has This Been Tested?
This PR has been tested manually with different image types:
Before the Fix:
User-selected image:
data:image/s3,"s3://crabby-images/fd0b4/fd0b47d117d1c74f2e236578078f180f188e2bce" alt="Screenshot 2025-02-13 at 5 40 22 PM"
Image projected onto canvas (incorrect):
data:image/s3,"s3://crabby-images/988eb/988eb5f9b8bbdfa86eb18dd5058eb49a5a11b1c9" alt="Screenshot 2025-02-13 at 5 40 33 PM"
Note: Contains empty space and additional image areas beyond the user’s selection.
After Transparency Fix:
User-selected image:
data:image/s3,"s3://crabby-images/dda6b/dda6bc1f67a929bd3757d2c7f0dc244d96bddda4" alt="Screenshot 2025-02-13 at 5 41 02 PM"
Image projected onto canvas (corrected):
data:image/s3,"s3://crabby-images/638e8/638e8de98cb116ca80e44225bc5581eb3ac4b233" alt="Screenshot 2025-02-13 at 5 41 17 PM"
Note: Now accurately reflects only the selected portion of the image.
After Fix:
Note: The selected profile pic now correctly matches the user’s selection.
data:image/s3,"s3://crabby-images/f263f/f263f7935453ef776058469bdebd7c535621db70" alt="Screenshot 2025-02-13 at 6 48 14 PM"
Further Considerations
Checklist: