-
Notifications
You must be signed in to change notification settings - Fork 816
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
Geometric Shapes triangle characters don't fill whole cells #783
Comments
As you mentioned, those are from an older geometric shapes block, and fonts don't agree on whether these should be square and centered or stretched to fill their cells. I think the best would be to have a stylistic set option to select to make them full cell, but as the Cascadia team is busy with Cascadia Next, I didn't submit any new thing, especially since I would need some help to handle that properly. Anyway, this can only be worked on if Cascadia Code/Mono isn't frozen, so the decision would be in the team's hands. |
@PhMajerus: What you say makes sense. To my knowledge, there are no characters in Symbols for Legacy Computing that could replace the half-cell black diagonal triangles U+25E2..U+25E5. Correct me if I'm wrong. For example, there's no "LOWER RIGHT BLOCK DIAGONAL LOWER LEFT TO UPPER RIGHT" in U+1FB3C..U+1FB67. It's as if Unicode decided to unify it with U+25E2 "BLACK LOWER RIGHT TRIANGLE". If this is true, this makes it all the more important for Cascadia to support stretching U+25E2 across its cell, so it can be used with U+1FB3C..U+1FB67. Hopefully this will be addressed after work on Cascadia Code/Mono resumes. Thanks again for your work. |
I can confirm there are no similar diagonals in either of the legacy computing blocks, and am fairly sure the rationale is to avoid duplicates in Unicode. This is also why the pseudo-pixels mosaics do not duplicate the shapes that already exist in existing half blocks and quadrants. |
I just found a similar issue for Source Code Pro (adobe-fonts/source-code-pro#301). It links to an article about Chafa using these characters for printing PETSCII-like semigraphics in terminals. It notes this same problem: I recently encountered a similar issue with Source Code Pro (adobe-fonts/source-code-pro#301). The issue links to an article about Chafa using these characters for printing PETSCII-like semigraphics in terminals. The article mentions the same problem:
As @clort81 rightly points out in the Source Code Pro issue, the prevailing modern practice of rendering these characters as half-height triangles positioned on the typographic baseline "precludes their use as a block-graphic element", and "lacking full-height diagonals makes rendering historic works of computer art impossible, as well as denying us the ability to draw diagonal elements". |
Cascadia family version
2404.23
Cascadia family variant(s)
Cascadia Code (the version with ligatures), Cascadia Mono (the version without ligatures)
Font file format(s)
Windows Terminal included version (TTF (variable)), .ttf (variable)
Platform
Windows 11; macOS 14.7
Other Software
No response
What happened?
Thanks to @PhMajerus's work in #597, #708, #709, #711, #723 etc., Cascadia has excellent support for semigraphics diagonals.
But there are some basic triangle characters that don't seem to be supported: U+25E2..U+25E5, U+25F8..U+25FA, and U+25FF (
◢ ◣ ◤ ◥ ◸ ◹ ◺ ◿
) from the Geometric Shapes block. They seem to either be missing or not fill their whole character cells, unlike the Symbols for Legacy Computing diagonals in #723. The Geometric Shapes triangles are much older than the Symbols for Legacy Computing diagonals, but they're still important.Here is an example of NeoVim text art using Geometric Shapes triangles using Cascadia Code 2404.23 in Windows Terminal v1.21.2911.0:
This looks the same in Visual Studio Code v1.94 on Windows 11.
I expected it to look seamless, like this render from the Kitty terminal:
Raw text of the NeoVim text art
The outline versions of the triangles from the same block, U+25F8..U+25FA, and U+25FF (
◸ ◹ ◺ ◿
), also currently form jagged art in Cascadia. They should also fill their whole character blocks, without seams.Many older terminals and the modern Kitty terminal render these characters using seamless triangles. Unscii and GNU Unifont also employ seamless triangles. They are essential for printing PETSCII-like semigraphics in terminal applications.
Thanks all for your work on Cascadia.
The text was updated successfully, but these errors were encountered: