-
-
Notifications
You must be signed in to change notification settings - Fork 2.3k
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
Fix incorrect color blending for overlapping glyphs #7497
Merged
radarhere
merged 21 commits into
python-pillow:main
from
ZachNagengast:fix-alpha-for-overlapping-glyphs
Dec 24, 2023
Merged
Changes from 19 commits
Commits
Show all changes
21 commits
Select commit
Hold shift + click to select a range
f97570f
Blend colors with alpha when pasting
ZachNagengast 49fd211
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] 76f758e
Merge branch 'main' into fix-alpha-for-overlapping-glyphs
radarhere bb0eff4
Update blending logic
ZachNagengast a7f805d
Merge branch 'fix-alpha-for-overlapping-glyphs' of ssh://github.com/Zβ¦
ZachNagengast e1aaec3
Merge branch 'main' of ssh://github.com/python-pillow/Pillow into fixβ¦
ZachNagengast b15b2d4
Update src/_imagingft.c
ZachNagengast fdecfca
Update gray glyph blending logic and tests
ZachNagengast 8ecf2e9
Merge branch 'fix-alpha-for-overlapping-glyphs' of ssh://github.com/Zβ¦
ZachNagengast 11bea8f
Merge branch 'main' of ssh://github.com/python-pillow/Pillow into fixβ¦
ZachNagengast d127600
Update test images for overlapping text
ZachNagengast 0a33b30
Update caron_below_ttb test image
ZachNagengast 29ca3fc
Update caron_below_ttb_lb test image
ZachNagengast f3b3442
add test for glyph alpha blending
nulano 0cef9f2
fix drawing text alpha on RGBA image on big-endian platforms
nulano 38992f6
Merge pull request #1 from nulano/fix-alpha-for-overlapping-glyphs
ZachNagengast 9c60e85
Apply suggestions from code review
ZachNagengast 78f78d2
Update src/_imagingft.c
ZachNagengast e800026
Update Tests/test_imagefont.py
ZachNagengast bd2977c
Update src/PIL/ImageDraw.py
ZachNagengast a6a612c
Merge branch 'main' into fix-alpha-for-overlapping-glyphs
radarhere File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
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.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Searching through Pillow's existing code, the tradition has been to use native mode implicitly rather than explicitly.
Pillow/src/PIL/SpiderImagePlugin.py
Line 259 in 76446ee
Pillow/src/PIL/SgiImagePlugin.py
Lines 184 to 188 in 76446ee
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The default is
@
mode, which is not equivalent to=
.From https://docs.python.org/3/library/struct.html#byte-order-size-and-alignment:
The
s
andf
formats are the same for both@
and=
.l
is platform dependent with@
, but is used with>
in the quoted code above.i
is platform dependent, so changing=
to@
can change the behavior here.However, in the C code, I see that
int
is assumed to be at least 4 bytes, so it is likely the same on all currently supported platforms even if it is not the same in general.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@radarhere what do you think? Happy to adjust as needed
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hadn't read the linked documentation in enough detailed to notice the distinction before I made my suggestion. Thanks nulano for catching that.
I don't have strong feelings, I was just trying to follow a convention. If there is a preference to future proof this code by using
=
, that's fine with me.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Makes sense, @nulano let us know if you want to be sure to include this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking more specifically at the
_draw_ink
function which provides theink
value, the ink is created in anINT32
type (which corresponds to a=i
format), but is cast to a Cint
(corresponding to@i
ori
format) before returning it (for future reference, the cast should probably be along
instead):Pillow/src/_imaging.c
Lines 2848 to 2861 in 80d0ed4
When it is later received in
font_render
, it is stored in along long
and converted tounsigned int
before being read as bytes:Pillow/src/_imagingft.c
Lines 805 to 806 in b51dcc0
Pillow/src/_imagingft.c
Line 842 in b51dcc0
Pillow/src/_imagingft.c
Line 847 in b51dcc0
So if
int
is smaller than 4 bytes, thegetink
function will discard data, and ifint
is larger than 4 bytes, the ink will be read as black on a big-endian platform. Either way, there will be an issue before this code is reached.Therefore, I think it's fine to leave the format specifier as
i
and leave this thread "unresolved" to document it.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @nulano, just marked this thread as unresolved.