Fontes
Registrando Fontes
Registre fontes TrueType ao criar um documento:
fontData, _ := os.ReadFile("fonts/NotoSansJP-Regular.ttf")
doc := template.New(
template.WithPageSize(document.A4),
template.WithFont("NotoSansJP", fontData),
template.WithDefaultFont("NotoSansJP", 12),
)
Multiplas Familias de Fontes
Registre multiplas fontes para diferentes casos de uso:
regular, _ := os.ReadFile("fonts/NotoSansJP-Regular.ttf")
bold, _ := os.ReadFile("fonts/NotoSansJP-Bold.ttf")
mono, _ := os.ReadFile("fonts/RobotoMono-Regular.ttf")
doc := template.New(
template.WithFont("NotoSansJP", regular),
template.WithFont("NotoSansJP-Bold", bold),
template.WithFont("RobotoMono", mono),
template.WithDefaultFont("NotoSansJP", 12),
)
Use FontFamily() para alternar fontes nos elementos de texto:
c.Text("Regular text") // uses default NotoSansJP
c.Text("Bold heading", template.FontFamily("NotoSansJP-Bold"), template.FontSize(18))
c.Text("Code snippet", template.FontFamily("RobotoMono"), template.FontSize(10))
Suporte CJK
gpdf tem suporte de primeira classe para texto em japones, chines e coreano. Os recursos CJK incluem quebra de linha automatica com regras kinsoku (proibicao de certos caracteres no inicio/fim das linhas).
fontData, _ := os.ReadFile("fonts/NotoSansJP-Regular.ttf")
doc := template.New(
template.WithPageSize(document.A4),
template.WithMargins(document.UniformEdges(document.Mm(20))),
template.WithFont("NotoSansJP", fontData),
template.WithDefaultFont("NotoSansJP", 12),
)
page := doc.AddPage()
page.AutoRow(func(r *template.RowBuilder) {
r.Col(12, func(c *template.ColBuilder) {
c.Text("日本語テキストのサンプル", template.FontSize(18))
c.Text("gpdfは純Go・ゼロ依存のPDF生成ライブラリです。")
c.Text("CJKテキストの改行やレイアウトを正しく処理します。")
})
})
Documentos CJK multilíngues
Para documentos com várias línguas CJK, registre cada fonte separadamente e alterne com FontFamily():
jpFont, _ := os.ReadFile("fonts/NotoSansJP-Regular.ttf")
scFont, _ := os.ReadFile("fonts/NotoSansSC-Regular.ttf")
krFont, _ := os.ReadFile("fonts/NotoSansKR-Regular.ttf")
doc := template.New(
template.WithPageSize(document.A4),
template.WithFont("NotoSansJP", jpFont),
template.WithFont("NotoSansSC", scFont),
template.WithFont("NotoSansKR", krFont),
template.WithDefaultFont("NotoSansJP", 12),
)
page := doc.AddPage()
page.AutoRow(func(r *template.RowBuilder) {
r.Col(4, func(c *template.ColBuilder) {
c.Text("こんにちは", template.FontFamily("NotoSansJP"))
})
r.Col(4, func(c *template.ColBuilder) {
c.Text("你好", template.FontFamily("NotoSansSC"))
})
r.Col(4, func(c *template.ColBuilder) {
c.Text("안녕하세요", template.FontFamily("NotoSansKR"))
})
})
QR Codes com Conteudo CJK
QR codes suportam conteudo Unicode incluindo japones:
c.QRCode("こんにちは世界", template.QRSize(document.Mm(30)))
Subsetting de Fontes
gpdf automaticamente faz subset de fontes TrueType — apenas os glifos realmente utilizados no documento sao incorporados. Isso reduz significativamente o tamanho do arquivo, especialmente para fontes CJK que podem conter dezenas de milhares de glifos.
Formatos de Fonte Suportados
| Formato | Suporte |
|---|---|
| TrueType (.ttf) | Totalmente suportado |
| OpenType (.otf) | Suporte parcial (contornos TrueType) |
| WOFF / WOFF2 | Nao suportado |
| Type 1 | Nao suportado |
Fontes Recomendadas
| Fonte | Caso de Uso |
|---|---|
| Noto Sans JP | Texto em japones |
| Noto Sans SC | Chines simplificado |
| Noto Sans KR | Texto em coreano |
| Noto Sans | Texto latino/ocidental |
| Inter | Documentos com estilo moderno de UI |
| Roboto Mono | Codigo e texto monospacado |
Uso de Fontes no JSON Schema
Ao usar JSON schema, as fontes sao registradas via opcoes Go:
fontData, _ := os.ReadFile("fonts/NotoSansJP-Regular.ttf")
schema := []byte(`{
"page": {"size": "A4"},
"body": [
{"row": {"cols": [
{"span": 12, "text": "日本語テキスト", "style": {"font": "NotoSansJP"}}
]}}
]
}`)
doc, err := template.FromJSON(schema, nil,
template.WithFont("NotoSansJP", fontData),
)
Proximos Passos
- Cabecalhos e Rodapes — Conteudo em nivel de pagina
- Elementos — Todos os tipos de elementos de conteudo