Comments (6)
Hi,
You should use the same context for getting the text size too. Otherwise you will need to load the fonts twice, etc.
There are a couple of state helpers you can use to make sure that you don't mess things up. nvgSave() will save the current state (fonts, fills, etc), nvgReset() resets the state, nvgRestore() restores the state.
If that sounds too much trouble, I don't mind adding a font state struct and allow you to use that for text related query functions. nvgTextBounds() and nvgVertMetrics() do not issue any draw calls. They may update the font cache, which will update anyway when you render text.
from nanovg.
It sounds like using the same context would cause problems with threaded rendering though? Similar issues with nvgTextBounds if they are updating textures or font related information. (This isn't a huge concern, but would have been nice to get setup.)
Was nvgTextBounds calculating the correct text size give the current transform scale and performing the pixel alignment? I'm about to look through the code, but it seemed like this would cause some "badness" if the drawing calculated a different final bounds due to the pixel alignment.
Thanks again for the help!
from nanovg.
NanoVG rendering is not thread safe. So if you use multiple threads you should do some buffering or use multiple contexts (current fonts and images cannot be shared across contexts).
You are correct that nvgTextBounds takes current transform into account. Transform is part of the state so you can use the nvgSave(), nvgReset(), , nvgRestore() sequences to get a clean slate at any given time.
from nanovg.
Ok, I assumed it was setup this way. At what point does the font texture get created? Just wondering if there's a way to not create the actual GL resource for my layout-only context. I wasn't sure if calculating the text bounds required the glyphs to be added to the font texture?
from nanovg.
Currently the glyphs are generated on first access, including calculating text bounds. The magic happens in fontstash.h fons__getGlyph()
from nanovg.
Ok thanks, I'll check it out more today.
from nanovg.
Related Issues (20)
- nvgTextBounds doesn't calculate for spaces at the end of a string HOT 5
- Manually loading images / Generating custom MipMaps for images HOT 3
- Disable blend for certain paths HOT 3
- 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
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.