-
Notifications
You must be signed in to change notification settings - Fork 1.7k
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
font issues in DOM renderer #5164
Comments
Which browser and which xtermjs version is that? There were some corrections applied to the width measuring in the newer xtermjs versions. Can you retry with these global patches applied: // width measure container
document.querySelector('.xterm-width-cache-measure-container').style.fontVariantLigatures='none';
// terminal output
document.querySelector('.xterm-rows').style.fontVariantLigatures='none';
Because, other than in the canvas/webgl renderer, we have no control in the DOM renderer how the browser's font renderer gonna output a certain glyph on the screen. It may pick the glyph from a different font or apply different widths for bold/italics. Furthermore some monospace fonts are not perfectly monospaced for all their glyphs. Btw - in your mc output it looks like the bold glyphs cause the misalignment. Originally posted by @jerch in #4881 (comment) |
@jerch are there any tunable to turn off these corrections ? If a font is not perfect we will not use it! It would also be nice to get your recommendations on which font is the most trouble-free. And possibly well-known bad monospace fonts (like Roboto Mono). My colleague will write answer to your questions above in few minutes. Originally posted by @socketpair in #4881 (comment) |
Nope, thats not configurable from outside, as half of the renderer logic relies on the measurement results. I just tried to repro it under ubuntu 22 with chrome and firefox and Roboto Mono. Its all fine here with the repo demo, even if I switch to russian locale in mc. So my guess - its either a version issue (which xtermjs version you are using?) or some CSS font settings on the terminal container in your integration not being compatible.
Roboto Mono behaves correctly for me. Also I dont have any list of bad or good fonts. The letter-spacing trick should level out single glyph metrics issues (thats why even Arial will work there), but it cannot address higher level font features like certain ligatures out of the box. So in general try to avoid monospace fonts using ligature trickery, that are not grid stable (see #5156 for some context). Originally posted by @jerch in #4881 (comment) |
@jerch, hello! We use @xterm/xterm 5.5.0, @xterm/addon-attach 0.11.0 and @xterm/addon-fit 0.10.0. One more example with Originally posted by @ithrforu in #4881 (comment) |
@ithrforu Can you repro it with the demo of the repo? Edit: Looks correct to me here with Roboto Mono Originally posted by @jerch in #4881 (comment) |
@ithrforu please take a look on this issue |
@jerch can you help with the sandbox for reproduction? |
Nope, I have never done anything with codesandbox, no clue about it. |
@jerch, hello. I reproduced the bug with |
@ithrforu Thats not valid javascript. Whats |
👍 good catch, there definitely are sync problems when using webfonts. This is why https://www.npmjs.com/package/xterm-webfont was created by a community member. |
@ithrforu I tried running your example with the vite tasks - it is as I expected, you run into a race condition between font loading and terminal bootstrapping. The vite css magic does not place a waiting condition on the css loads, thus the terminal initialization runs too early. |
@jerch, @Tyriar, i tried to load fonts and css from index.html with Roboto Mono from Google Fonts: It works correctly without xterm-webfont. In the first example i used Roboto Mono from fontsource (1, 2). I think problem with I also tried to use xterm-webfont and it doesn't work:
|
@ithrforu It seems xterm-webfont is quite outdated and still relies on an old API call. If you want to use a webfont - does |
@jerch, yes, with
The peculiarity is that the |
@ithrforu Hmm, idk anything about that interface, but a comment on your linked page says:
Maybe style a hidden element in the document with your webfonts to force the browser to fully load them? Just a guess ... |
@ithrforu Here is a variant of your sandbox example above, which seems to work correctly (also added bold and some test output): import { Terminal } from '@xterm/xterm';
import { FitAddon } from '@xterm/addon-fit';
import '@xterm/xterm/css/xterm.css';
import "@fontsource/roboto-mono";
import "@fontsource/roboto-mono/400.css";
import "@fontsource/roboto-mono/400-italic.css";
import "@fontsource/roboto-mono/700.css";
import "@fontsource/roboto-mono/700-italic.css";
function initTerminal() {
const terminal = new Terminal({
fontFamily: "Roboto Mono",
});
const fitAddon = new FitAddon();
terminal.loadAddon(fitAddon);
const terminalContainer = document.getElementById('xterm-container');
terminal.open(terminalContainer);
terminal.onKey(({ key }) => {
terminal.write(key);
});
const resizeObserver = new ResizeObserver(() => {
requestAnimationFrame(() => fitAddon.fit());
});
resizeObserver.observe(terminalContainer);
// write test after some time...
setTimeout(() => {
terminal.write('0123456789\r\n');
terminal.write('\x1b[1m0123456789\r\n');
terminal.write('\x1b[0;3m0123456789\r\n');
terminal.write('\x1b[1;3m0123456789\r\n');
terminal.write('\x1b[mЮжЮжЮжЮжЮж\r\n');
terminal.write('\x1b[1mЮжЮжЮжЮжЮж\r\n');
terminal.write('\x1b[0;3mЮжЮжЮжЮжЮж\r\n');
terminal.write('\x1b[1;3mЮжЮжЮжЮжЮж\r\n');
}, 100);
}
document.fonts.ready.then(
fontFaceSet => Promise.all(Array.from(fontFaceSet).map(el => el.load())).then(initTerminal)
); The issue with the fontsource webfont is, that they splitted the font across multiple font files. Each of these font files are not loaded until really needed by the browser, but by then it is already too late for xtermjs. The Edit: Tested with chrome && firefox, no clue about safari. Would be nice, if xterm-webfont addon would get an upgrade to reflect the newer APIs (@vincentwoo). |
@jerch thank you! It works correctly. |
@jerch offtop: where can i find a @xterm/addon-canvas source code? |
@ithrforu The canvas addon got removed for the next major version and you prolly should not rely on it anymore. v5.5 still contains the source (https://github.com/xtermjs/xterm.js/tree/5.5.0/addons). Gonna close this issue as resolved, plz open questions not directly related to issues or code bugs under discussions. |
Does anyone know a powerline-supporting font that works? I'm really struggling, every font I've tried has too much space between letters and setting |
It working for me, but seems not support variable fonts. |
@devhaozi What do you mean by "variable fonts"? Non monospace fonts? Those should also work, but ofc will look quite ugly due their glyphs getting grid positioned. In general it is not a good idea to run a terminal with a variable width font. Or do you mean variable as of changing the font of an already running terminal? Thats also possible, but there you have to make sure, that all webfont assets are readily loaded before doing the font switch. |
Like this: https://fontsource.org/fonts/jetbrains-mono/install |
Idk what variable vs. static means in this context. Care to explain? |
Variable fonts contain all weights from 100 to 800, which can be adjusted at will without repeated import. |
Oh I found the reason, the variable font needs to use the |
@devhaozi This is indeed not fully supported yet, as it needs font variation settings, which are currently not exposed/configurable from terminal API. So yes it will work, if you await a font-face object to be loaded with those subspecs and only have that one as only font-family member in To further track this --> #5197 |
Moved from #4881
Also this kind of things. Just why? I use Roboto Mono, which is a mono-width font. Just why we need any corrections ?
Originally posted by @socketpair in #4881 (comment)
The text was updated successfully, but these errors were encountered: