mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 20:42:07 +01:00
text: Refactoring
This commit is contained in:
parent
4b4292a856
commit
9908fe0d31
29
text/text.go
29
text/text.go
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user