Load and render bitmap fonts in the format of AngelCode's bitmap font generator.
A Go package to load and render bitmap fonts
created with AngelCode’s bitmap font generator
or other tools that generate output in the same format.
This package uses the text format
for font descriptor files (.fnt), not the binary format.
Package documentation is available on pkg.go.dev.
Load a bitmap font and draw text to an image:
package main
import (
"log"
"github.com/fzipp/bmfont"
)
func main() {
font, err := bmfont.Load("ExampleFont.fnt")
if err != nil {
log.Fatal(err)
}
img := image.NewRGBA(image.Rect(0, 0, 600, 300))
font.DrawText(img, image.Pt(10, 20), `hello, world
This is an example.
abcdefghijklmnopqrstuvwxyz
ABCDEFGHIJKLMNOPQRSTUVWXYZ`)
// ...
}
Measure the text before drawing in order to determine the size of the image:
package main
import (
"log"
"github.com/fzipp/bmfont"
)
func main() {
font, err := bmfont.Load("ExampleFont.fnt")
if err != nil {
log.Fatal(err)
}
text := `hello, world
This is an example.
abcdefghijklmnopqrstuvwxyz
ABCDEFGHIJKLMNOPQRSTUVWXYZ`
bounds := font.MeasureText(text)
img := image.NewRGBA(image.Rect(0, 0, bounds.Dx(), bounds.Dy()))
font.DrawText(img, image.Point{}.Sub(bounds.Min), text)
// ...
}
Only load the descriptor of a bitmap font:
package main
import (
"fmt"
"log"
"github.com/fzipp/bmfont"
)
func main() {
desc, err := bmfont.LoadDescriptor("ExampleFont.fnt")
if err != nil {
log.Fatal(err)
}
fmt.Println(desc.Info.Face)
fmt.Println("line height:", desc.Common.LineHeight)
fmt.Println("letter A width:", desc.Chars['A'].Width)
}
This project is free and open source software licensed under the
BSD 3-Clause License.