text: Refactoring

This commit is contained in:
Hajime Hoshi 2017-07-17 01:54:10 +09:00
parent 4b4292a856
commit 9908fe0d31

View File

@ -50,9 +50,6 @@ type glyph struct {
} }
func (g *glyph) size() (int, int) { func (g *glyph) size() (int, int) {
if g.bounds.Empty() {
g.bounds, _ = font.BoundString(g.char.face, string(g.char.rune))
}
p := g.bounds.Max.Sub(g.bounds.Min) p := g.bounds.Max.Sub(g.bounds.Min)
return p.X.Ceil(), p.Y.Ceil() return p.X.Ceil(), p.Y.Ceil()
} }
@ -110,11 +107,21 @@ var (
) )
type atlas struct { type atlas struct {
// image is the back-end image to hold glyph cache.
image *ebiten.Image image *ebiten.Image
// tmpImage is the temporary image as a renderer source for glyph.
tmpImage *ebiten.Image tmpImage *ebiten.Image
// size is the size of one glyph in the cache.
// This value is always power of 2.
size int size int
// glyphs is the set of glyph information.
glyphs []*glyph glyphs []*glyph
count int
// num is the number of glyphs the atlas holds.
num int
} }
func (a *atlas) at(glyph *glyph) (int, int) { func (a *atlas) at(glyph *glyph) (int, int) {
@ -128,7 +135,7 @@ func (a *atlas) at(glyph *glyph) (int, int) {
} }
func (a *atlas) append(glyph *glyph) { func (a *atlas) append(glyph *glyph) {
if a.count == len(a.glyphs) { if a.num == len(a.glyphs) {
idx := -1 idx := -1
t := int64(math.MaxInt64) t := int64(math.MaxInt64)
for i, g := range a.glyphs { for i, g := range a.glyphs {
@ -158,7 +165,7 @@ func (a *atlas) append(glyph *glyph) {
if idx < 0 { if idx < 0 {
panic("not reached") panic("not reached")
} }
a.count++ a.num++
glyph.index = idx glyph.index = idx
a.glyphs[idx] = glyph a.glyphs[idx] = glyph
a.draw(glyph) a.draw(glyph)
@ -198,8 +205,13 @@ func getGlyphFromCache(face font.Face, r rune, now int64) *glyph {
return g return g
} }
b, _, ok := face.GlyphBounds(r)
if !ok {
return nil
}
g = &glyph{ g = &glyph{
char: ch, char: ch,
bounds: b,
atime: now, atime: now,
} }
if g.empty() { if g.empty() {
@ -259,6 +271,7 @@ func Draw(dst *ebiten.Image, face font.Face, text string, x, y int, lineHeight i
runes := []rune(text) runes := []rune(text)
for _, c := range runes { for _, c := range runes {
// TODO: What if c is '\r'?
if c == '\n' { if c == '\n' {
fx = ofx fx = ofx
y += lineHeight y += lineHeight
@ -270,13 +283,13 @@ func Draw(dst *ebiten.Image, face font.Face, text string, x, y int, lineHeight i
fx += face.Kern(prevC, c) fx += face.Kern(prevC, c)
} }
g := getGlyphFromCache(face, c, n) if g := getGlyphFromCache(face, c, n); g != nil {
if !g.empty() { if !g.empty() {
g.draw(dst, fx.Ceil(), y, clr) g.draw(dst, fx.Ceil(), y, clr)
} }
a, _ := face.GlyphAdvance(c) a, _ := face.GlyphAdvance(c)
fx += a fx += a
}
prevC = c prevC = c
} }