Fusion
Fusion basica
Combinar dos PDFs en uno.
merged, _ := gpdf.Merge([]gpdf.Source{
{Data: cover},
{Data: body},
})
Extraccion de rango de paginas
Extraer las paginas 2 a 4 de un documento de 5 paginas.
extracted, _ := gpdf.Merge([]gpdf.Source{
{Data: full, Pages: gpdf.PageRange{From: 2, To: 4}},
})
Con metadatos
Establecer titulo, autor y productor en la salida fusionada.
merged, _ := gpdf.Merge(
[]gpdf.Source{
{Data: cover},
{Data: body},
{Data: appendix},
},
gpdf.WithMergeMetadata("Policy Bundle", "Example Ltd", "gpdf"),
)
Fusion + Numeros de pagina
Fusionar documentos, luego superponer numeros de pagina en cada pagina.
// Fusionar
merged, _ := gpdf.Merge([]gpdf.Source{
{Data: cover},
{Data: body},
})
// Abrir y agregar numeros de pagina
doc, _ := gpdf.Open(merged)
count, _ := doc.PageCount()
doc.EachPage(func(i int, p *template.PageBuilder) {
p.Absolute(document.Mm(170), document.Mm(285), func(c *template.ColBuilder) {
c.Text(fmt.Sprintf("%d / %d", i+1, count),
template.FontSize(10),
template.AlignRight(),
)
}, template.AbsoluteWidth(document.Mm(20)))
})
result, _ := doc.Save()
Portada + Generado + Adjunto parcial
Un escenario de produccion: combinar una portada escaneada, un cuerpo generado con gpdf y las primeras 3 paginas de un adjunto.
coverPage, _ := os.ReadFile("cover.pdf")
attachment, _ := os.ReadFile("attachment.pdf")
// Generar el cuerpo con gpdf
doc := template.New(template.WithPageSize(document.A4))
page := doc.AddPage()
page.AutoRow(func(r *template.RowBuilder) {
r.Col(12, func(c *template.ColBuilder) {
c.Text("Generated Content", template.FontSize(20), template.Bold())
})
})
generated, _ := doc.Generate()
// Fusionar todo junto
merged, _ := gpdf.Merge(
[]gpdf.Source{
{Data: coverPage},
{Data: generated},
{Data: attachment, Pages: gpdf.PageRange{From: 1, To: 3}},
},
gpdf.WithMergeMetadata("Policy Bundle", "Example Ltd", ""),
)