-
Notifications
You must be signed in to change notification settings - Fork 37
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
examples: add shaped-text2svg
for generating SVGs from shaped Unicode text.
#70
base: main
Are you sure you want to change the base?
Conversation
Update: I've narrowed down most of the weird differences caused by ASCII to Another way to control this is with the At this point I would have to port this example to use EDIT: given that I see no changes when I force |
Oh wow, thanks! Wasn't expecting someone to dive into this. I was planning to write something like this myself, by didn't had time. I'm not sure we need full browser compatibility in this demo/example. Even resvg has a far simpler implementation. And it's the reason rustybuzz exists. As for language and bidi - harfbuzz/rustybuzz are pretty low-level libraries. You cannot use them directly. You do need a text layout library on top of them. Like Honestly, I'm not even sure we need bidi in this example. Either way, it's good enough for me already. And you want to improve it a bit - I do not mind. But we should not try implementing a text layout library in a simple example. |
I would recommend having bidi in the example because it's a useful illustration of all the parts needed to handle text right, and prevents people from using the library naively. (And because bidi is weird and complicated and the integration of a bidi algorithm implementation with a shaping engine is not necessarily immediately obvious) |
@Manishearth Depending on you definition of a text layout, one can have thousands lines of code on top of rustybuzz. I do have plans on writing an easy to use text layout/rustybuzz wrapper eventually, but time is not on my side.
Meanwhile I keep telling people to stop using rustybuzz... In a sense that it must not be used directly. You do need a higher level wrapper for it. |
This, specially integrating bidi, is very useful, thank you @eddyb, I wish you can turn integrate COLRv1 of newer versions of ttf-parser's font2svg https://github.com/RazrFalcon/ttf-parser/blob/master/examples/font2svg.rs and maybe releasing it even in a separate crate if possible. While ago I wanted to build some web service font rendering for an open source website (which the proposal there didn't go that well) and specially I didn't know what to do for that bidi part as all I did was copying font2svg and wrapping it in a service https://github.com/ebraminio/fontoid/blob/main/src/main.rs taking one font as input and being able to bidi and COLRv1 and output SVG was all I wanted which you've done that already and I wish you can turn it to something better, either in this repo or somewhere else. Thanks |
This is based on the
ttf-parser
examplefont2svg
, and uses a combination ofunicode-bidi
andrustybuzz
on top of it, to offer a relatively compact but (hopefully) complete usage example forrustybuzz
.While discussing such a self-contained "complete example" with @Manishearth, he mentioned that it may be possible for
rustybuzz
to offer a "complete Unicode bidirectional shaping solution", to avoid having the user correctly useunicode-bidi
etc.Using
Go Noto Universal
6.0
'sGoNotoCurrent.ttf
, and the UDHR, I was able to get some examples:(all images are chosen samples, with links above them for the full original version, due to GitHub limitations)
shaped-text2svg
outputeng
(
---
are misaligned - all languages hit this)arb
(Latin glyphs appear to misalign Arabic ones)
hin
(no idea what's going on here, more investigation needed)
cmn_hans
(
(III)
confirmed to shape differently in browser vsrustybuzz
)A few notes about that that diff in the last column:
mix-blend-mode: difference;
(III)
, compared torustybuzz
(III)
has all 5 glyphs aligned at the top in the browser, but vertically centered inrustybuzz
rustybuzz
and/orttf-parser
APIs, but at this point I'm not sureTODO: try more languages, maybe emoji (hard to mix emoji & non-emoji w/o font fallback), try to improve diffing against browser rendering