mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-13 20:42:07 +01:00
text: add comments about positioning
This commit is contained in:
parent
9e9cec249a
commit
003474152c
13
text/text.go
13
text/text.go
@ -60,10 +60,15 @@ func drawGlyph(dst *ebiten.Image, face font.Face, r rune, img *ebiten.Image, dx,
|
|||||||
*op2 = *op
|
*op2 = *op
|
||||||
op2.GeoM.Reset()
|
op2.GeoM.Reset()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Adjust the position to the integers.
|
||||||
|
// The current glyph images assume that they are rendered on integer positions so far.
|
||||||
|
// The nearest filter cannot handle float positions.
|
||||||
op2.GeoM.Translate(math.Floor(fixed26_6ToFloat64(dx+b.Min.X)), math.Floor(fixed26_6ToFloat64(dy+b.Min.Y)))
|
op2.GeoM.Translate(math.Floor(fixed26_6ToFloat64(dx+b.Min.X)), math.Floor(fixed26_6ToFloat64(dy+b.Min.Y)))
|
||||||
if op != nil {
|
if op != nil {
|
||||||
op2.GeoM.Concat(op.GeoM)
|
op2.GeoM.Concat(op.GeoM)
|
||||||
}
|
}
|
||||||
|
|
||||||
dst.DrawImage(img, op2)
|
dst.DrawImage(img, op2)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -125,18 +130,19 @@ func getGlyphImage(face font.Face, r rune) *ebiten.Image {
|
|||||||
Src: image.White,
|
Src: image.White,
|
||||||
Face: face,
|
Face: face,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Adjust the dot position so that the glyph image can be rendered on integer positions.
|
||||||
|
// The nearest filter cannot handle float positions.
|
||||||
x, y := -b.Min.X, -b.Min.Y
|
x, y := -b.Min.X, -b.Min.Y
|
||||||
x, y = fixed.I(x.Ceil()), fixed.I(y.Ceil())
|
x, y = fixed.I(x.Ceil()), fixed.I(y.Ceil())
|
||||||
d.Dot = fixed.Point26_6{X: x, Y: y}
|
d.Dot = fixed.Point26_6{X: x, Y: y}
|
||||||
d.DrawString(string(r))
|
d.DrawString(string(r))
|
||||||
|
|
||||||
img := ebiten.NewImageFromImage(rgba)
|
img := ebiten.NewImageFromImage(rgba)
|
||||||
if _, ok := glyphImageCache[face][r]; !ok {
|
|
||||||
glyphImageCache[face][r] = &glyphImageCacheEntry{
|
glyphImageCache[face][r] = &glyphImageCacheEntry{
|
||||||
image: img,
|
image: img,
|
||||||
atime: now(),
|
atime: now(),
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return img
|
return img
|
||||||
}
|
}
|
||||||
@ -433,6 +439,9 @@ func AppendGlyphs(glyphs []Glyph, face font.Face, text string) []Glyph {
|
|||||||
|
|
||||||
if img := getGlyphImage(face, r); img != nil {
|
if img := getGlyphImage(face, r); img != nil {
|
||||||
b := getGlyphBounds(face, r)
|
b := getGlyphBounds(face, r)
|
||||||
|
// Adjust the position to the integers.
|
||||||
|
// The current glyph images assume that they are rendered on integer positions so far.
|
||||||
|
// The nearest filter cannot handle float positions.
|
||||||
glyphs = append(glyphs, Glyph{
|
glyphs = append(glyphs, Glyph{
|
||||||
Rune: r,
|
Rune: r,
|
||||||
Image: img,
|
Image: img,
|
||||||
|
Loading…
Reference in New Issue
Block a user