Comments (5)
Currently there is no way to stroke text as the text rendering is done using texture atlas for best quality. I've been thinking about adding a function to allow to turn text to paths, which would be great for large text, and it would allow stroking too. It might take a little while until I get there, though.
from nanovg.
@memononen Thank you for reply! but I think we'd better not implement text stroke in this way (though this way is also useful). I noticed that we can set font blur, so Why not just implement text stroke just as blur? i.e. this can be done in fontstash, not in NanoVG.
from nanovg.
That is another option. Can you tell more about how you're planning to use the text outline?
There are number of ways to implement it. For example, should the stroke be outside, center or inside in relation to the outline. Also, another common way to render outlined text is to first render the stroke as a dilated (expanded) version of the glyphs using fill, and then render the fonts again without dilation. This makes sure that the stroke outlines do not overlap the actual fonts and the text is more readable.
from nanovg.
We only want a outlined text, e.g. "empty" text, and sometimes we need use colors in text. so a "fillAndStrokeText" is needed. So outside is better. I prefer your ways to implement it. but in this way, it's better to give a API to both fill and stroke text -- it implemented more easy. and only one pass to render the text. I have looked into the way to blur font, I think to use the same way to stroke is prefer. but that need a new routine.
we can use nvgStrokeWidth, nvgFillColor and nvgStrokeColor to control the style of outline. and a new nvgStrokeText is needed, but use transparent for fill color, we can rename current nvgText to nvgFillText, and make nvgText to do both fill and stroke.
from nanovg.
Have you considered using "signed distance fields" [PDF]?
If perfect quality is of utmost importance, I guess it won't be an option, since you don't get hinting, and the text appears slightly rounder.
from nanovg.
Related Issues (20)
- FONS_GLYPH_BITMAP_OPTIONAL doesn't inhibit FT_LOAD in fons__tt_buildGlyphBitmap
- Fundamental text layout problem in nanovg
- Layer based drawing HOT 3
- outlines donβt draw properly HOT 2
- Edges of the curve are drawn at an angle HOT 9
- Draw an Arc with a Hole HOT 2
- Multiple scissors HOT 3
- Draw fill problems for complex polygons HOT 2
- Fix for MinGW: Replace -lGLEW with -lglew32
- support android ARGB format HOT 1
- Memory leak with freetype fonts [fix] HOT 4
- nvgArc does some ugly overdraw HOT 2
- [nvgTextBounds] string ending with space does not return expected bounds HOT 2
- `nvgArc` and `nvgArcTo` parameters correspondence and conversion
- building into a shared library HOT 6
- Transformation from Screen Space to World Space? HOT 1
- Arab, Hebrew and Persian
- ANSI Color Escape Sequences HOT 2
- Richtext HOT 2
- Proposal: Support for different NVGcontext types
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
π Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. πππ
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google β€οΈ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from nanovg.