Skip to content
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

Ensure Monaco measures fonts after the font is loaded #1106

Merged
merged 1 commit into from
Oct 9, 2024

Conversation

shepmaster
Copy link
Member

As soon as Monaco is instantiated, it measures various aspects of the
chosen font. Since the playground fetches fonts, the fonts may not yet
be available to be measured. After a bit, the fonts are loaded but
Monaco's cached results are now out of date.

We now trigger a remeasurement of the fonts after our fonts are
available.

For some reason, this has only been reported by people using Microsoft
Edge, but theoretically it should occur in any browser. Perhaps
there's something unique about Edge's text rendering? It also only
occurs at certain original zoom levels — on my computer, it needed
125% zoom. Note that each zoom level has different font metrics, so
changing the zoom once the font is loaded will work although the
original incorrect metrics will still be cached.

Fixes #1103

As soon as Monaco is instantiated, it measures various aspects of the
chosen font. Since the playground fetches fonts, the fonts may not yet
be available to be measured. After a bit, the fonts are loaded but
Monaco's cached results are now out of date.

We now trigger a remeasurement of the fonts after our fonts are
available.

For some reason, this has only been reported by people using Microsoft
Edge, but theoretically it should occur in any browser. Perhaps
there's something unique about Edge's text rendering? It also only
occurs at certain original zoom levels — on my computer, it needed
125% zoom. Note that each zoom level has different font metrics, so
changing the zoom once the font is loaded will work although the
original incorrect metrics will still be cached.

Fixes #1103
@shepmaster shepmaster added the bug The playground isn't doing what it was intended to label Oct 9, 2024
@shepmaster shepmaster merged commit 08c5f86 into main Oct 9, 2024
12 checks passed
@shepmaster shepmaster deleted the monaco-font-measure branch October 9, 2024 13:05
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug The playground isn't doing what it was intended to
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Cursor position is incorrect in the Monaco editor when using Microsoft Edge
1 participant