RFR: 8290866: Apple Color Emoji turns gray after JavaFX version 18
Andy Goryachev
angorya at openjdk.org
Fri Feb 24 19:31:25 UTC 2023
On Fri, 24 Feb 2023 19:06:59 GMT, Kevin Rushforth <kcr at openjdk.org> wrote:
>> This fix properly supports colour rendering of Emoji on macOS
>>
>>
>> On other platforms the Emoji will be rendered as ordinary greyscale glyphs - if there is font
>> support for the requested code point.
>>
>> A simple manual test is provided which uses a Text node, Label control
>> and editable TextField control.
>>
>> Some highlights of the code
>> - To determine if it is a color emoji glyph probe the 'sbix' font table which is what is used by Apple
>> - Text runs now break at an Emoji glyph
>> - The Emoji is retrieved as an BGRA image - ie 4 channel including alpha
>> - It was necessary to retrieve the Emoji glyph bounds via a different CoreText API since
>> the bounds that were being retrieved were wrong for the Emoji image - causing clipping
>> - It was necessary to retrieve the Emoji code point advance via a CoreText API since
>> the HMTX metrics were very wrong - causing overlapping glyphs
>> - drawString checks if it is an Emoji run and redirects to a new drawColorGlyph method
>> which draws the image as a texture
>> - All 3 rendering pipelines have this support and have been verified on all 3 desktop platforms
>
> modules/javafx.graphics/src/main/java/com/sun/javafx/font/PrismFontFile.java line 1456:
>
>> 1454: private boolean isSbixGlyph(int glyphID) {
>> 1455: if (sbixStrikes == null) {
>> 1456: synchronized (this) {
>
> This looks like a double-checked locking pattern, which is not guaranteed to be thread-safe.
>
> Suggestion: move the `synchronized` before the `if`.
or check for null again after synchronized(this)
-------------
PR: https://git.openjdk.org/jfx/pull/1047
More information about the openjfx-dev
mailing list