mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
parent
b8b8b16098
commit
b05c272499
@ -78,8 +78,10 @@ func float64ToFixed26_6(x float64) fixed.Int26_6 {
|
|||||||
return fixed.Int26_6(i)<<6 + fixed.Int26_6(frac*(1<<6))
|
return fixed.Int26_6(i)<<6 + fixed.Int26_6(frac*(1<<6))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const glyphVariationCount = 4
|
||||||
|
|
||||||
func adjustOffsetGranularity(x fixed.Int26_6) fixed.Int26_6 {
|
func adjustOffsetGranularity(x fixed.Int26_6) fixed.Int26_6 {
|
||||||
return x / (1 << 4) * (1 << 4)
|
return x / (1 << glyphVariationCount) * (1 << glyphVariationCount)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Glyph represents one glyph to render.
|
// Glyph represents one glyph to render.
|
||||||
@ -197,3 +199,38 @@ func Measure(text string, face Face, lineHeightInPixels float64) (width, height
|
|||||||
secondary := float64(lineCount-1)*lineHeightInPixels + m.VAscent + m.VDescent
|
secondary := float64(lineCount-1)*lineHeightInPixels + m.VAscent + m.VDescent
|
||||||
return secondary, primary
|
return secondary, primary
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CacheGlyphs pre-caches the glyphs for the given text and the given font face into the cache.
|
||||||
|
//
|
||||||
|
// CacheGlyphs doesn't treat multiple lines.
|
||||||
|
//
|
||||||
|
// Glyphs used for rendering are cached in the least-recently-used way.
|
||||||
|
// Then old glyphs might be evicted from the cache.
|
||||||
|
// As the cache capacity has limitations, it is not guaranteed that all the glyphs for runes given at CacheGlyphs are cached.
|
||||||
|
// The cache is shared with Draw and AppendGlyphs.
|
||||||
|
//
|
||||||
|
// One rune can have multiple variations of glyphs due to sub-pixels in X or Y direction.
|
||||||
|
// CacheGlyphs creates all such variations for one rune, while Draw and AppendGlyphs create only necessary glyphs.
|
||||||
|
//
|
||||||
|
// Draw and AppendGlyphs automatically create and cache necessary glyphs, so usually you don't have to call CacheGlyphs explicitly.
|
||||||
|
// However, for example, when you call Draw for each rune of one big text, Draw tries to create the glyph cache and render it for each rune.
|
||||||
|
// This is very inefficient because creating a glyph image and rendering it are different operations
|
||||||
|
// (`(*ebiten.Image).WritePixels` and `(*ebiten.Image).DrawImage`) and can never be merged as one draw call.
|
||||||
|
// CacheGlyphs creates necessary glyphs without rendering them so that these operations are likely merged into one draw call regardless of the size of the text.
|
||||||
|
//
|
||||||
|
// CacheGlyphs is concurrent-safe.
|
||||||
|
func CacheGlyphs(text string, face Face) {
|
||||||
|
var x, y float64
|
||||||
|
|
||||||
|
var buf []Glyph
|
||||||
|
// Create all the possible variations (#2528).
|
||||||
|
for i := 0; i < 4; i++ {
|
||||||
|
if face.direction().isHorizontal() {
|
||||||
|
x += 1.0 / glyphVariationCount
|
||||||
|
} else {
|
||||||
|
y += 1.0 / glyphVariationCount
|
||||||
|
}
|
||||||
|
buf = AppendGlyphs(buf, text, face, x, y)
|
||||||
|
buf = buf[:0]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user