KEMBAR78
Find best matched font in TypefaceCompatApi29Impl by RikkaW · Pull Request #1 · RikkaW/androidx · GitHub
Skip to content

Conversation

RikkaW
Copy link
Owner

@RikkaW RikkaW commented Jul 24, 2021

Proposed Changes

Use best-matched font rather than "hardcoded"

The original part

final FontStyle defaultStyle = new FontStyle(
        (style & Typeface.BOLD) != 0 ? FontStyle.FONT_WEIGHT_BOLD
                : FontStyle.FONT_WEIGHT_NORMAL,
        (style & Typeface.ITALIC) != 0 ? FontStyle.FONT_SLANT_ITALIC
                : FontStyle.FONT_SLANT_UPRIGHT
);
return new Typeface.CustomFallbackBuilder(familyBuilder.build())
       .setStyle(defaultStyle)
       .build();

This will make the final Typeface ALWAYS have neither 400 (FONT_WEIGHT_NORMAL) or 700 (FONT_WEIGHT_BOLD) weight. It is incorrect since fonts passed to these methods could have other font-weight. For example, pass only one font with 500 weight, the final Typeface will have 400 weight, making the fallback font displayed as 400 weight rather than 500.

This pull request copies the platform's algorithm to find the best-match font from the font family.

Testing

Test: Observed that the font weight is correct

Issues Fixed

Fixes: Fix https://issuetracker.google.com/issues/194553426

@RikkaW RikkaW merged commit 6d53f95 into androidx-main Jul 24, 2021
@RikkaW RikkaW deleted the RikkaW-patch-1 branch July 24, 2021 13:55
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant