-
Notifications
You must be signed in to change notification settings - Fork 53
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
Multiple windows / buffers per cache #97
Comments
rusttype's gpu_cache API is modelled on a single I am aiming to design a new draw cache with a different use style that's more flexible. For now I'd just use multiple glyph_brush instances each with their own cache. The positioning & vertex caches aren't very useful to share between different sections anyway. If gpu memory is the issue, fair enough. But the rusttype gpu_cache module is already quite heavy on memory usage and, I think, has lower hanging fruit there.
I don't understand this, does this mean ensuring that the fonts don't draw past their bounds? They already do that in all glyph_brush examples. It's done by simply respecting the bounds in the vertex generation function. So take the paragraph example using |
Yes; however, the |
I was just looking at |
You can already have your own extra draw bounds outside the vertex gen
closure. Take an intersection between that and the section bounds and apply
the same logic.
However, if the external bounds change the vertex cache will need to be
invalidated, which iirc can't be done easily right now.
…On Tue, 3 Mar 2020, 11:02 Diggory Hardy, ***@***.***> wrote:
I was just looking at GlyphPositioner::bounds_rect: this calculates
bounds based on glyph geometry. I'd like to use the intersection of this
rect with user-provided draw_bounds.
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#97?email_source=notifications&email_token=AARZHVYWRRUFW7SPMQ6BYX3RFTPV5A5CNFSM4LAHDSXKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOENTBQFA#issuecomment-593893396>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AARZHV7PDPKE47YJLQDKDETRFTPV5ANCNFSM4LAHDSXA>
.
|
I'm now moving to using the I still have this comment in KAS: that ideally the glyph cache should only once for the application (while the render surface is per-window in a multi-window GUI). I leave it to you whether you wish to do this. |
So, for any application / library using multiple windows / render targets, it makes sense to track the draw queue and cache validation status per window, but it may still make sense to share the actual cache across windows. Lets consider introducing
GlyphBrushBuffer
to track a per-window/target queue.The motivation is better resource-sharing across windows and better cache management. Additionally, a separate buffer could be used per clip-region (see kas-gui/kas#20: currently KAS does not clip fonts within a scroll-region, while last I checked Iced does but with sub-optimal cache behaviour) — although since drawing fonts amounts to copying a rect from a texture, it may be easier to solve this by specifying more explicit boundaries within the
Section
— I'll probably open a separate issue/PR about this.Investigation
I took a look at the
GlyphBrush
type, and it looks like everything besidesfonts
,texture_cache
andcache_glyph_drawing
should belong toGlyphBrushBuffer
(except thatframe_seq_id_sections
may no longer have a reason to exist if users can use a separate buffer for each "similar frame").But, there's a problem:
texture_cache
considers any glyph not queued since the last cache update to be ripe-for-removal, when it may still be in use by a different buffer. So, thegpu_cache
code also needs updating — I see you already have plans here.Waffling on about caches ...
It may seem like there's an easy answer to cache validation: draw each window in order, then clear anything not used since the last draw cycle, but this assumes that each window/target gets drawn in sequence. In a general UI system a window may only get redrawn when its contents change, so this assumption doesn't hold.
The best option for cache-removal may then be to clear not-recently-used items, where "recently" means "in the last N queues" or some such. (Each buffer could track and remove unwanted sections it has added, but this doesn't deal with shared glyphs, and any method for calculating exactly which of those are wanted requires a holistic list of all active buffers — complicated and difficult to use.)
The text was updated successfully, but these errors were encountered: