![]() |
VOOZH | about |
dotnet add package usebeq.wrappers.itext7 --version 1.0.9
NuGet\Install-Package usebeq.wrappers.itext7 -Version 1.0.9
<PackageReference Include="usebeq.wrappers.itext7" Version="1.0.9" />
<PackageVersion Include="usebeq.wrappers.itext7" Version="1.0.9" />Directory.Packages.props
<PackageReference Include="usebeq.wrappers.itext7" />Project file
paket add usebeq.wrappers.itext7 --version 1.0.9
#r "nuget: usebeq.wrappers.itext7, 1.0.9"
#:package usebeq.wrappers.itext7@1.0.9
#addin nuget:?package=usebeq.wrappers.itext7&version=1.0.9Install as a Cake Addin
#tool nuget:?package=usebeq.wrappers.itext7&version=1.0.9Install as a Cake Tool
PdfWrapper es una librería que permite la creación de documentos PDF de manera sencilla y eficiente haciendo uso de la librería itext7. Con esta librería, es posible insertar texto, imágenes y tablas en un documento PDF, así como también personalizar su diseño y formato.
La interfaz IPdfWrapper es la clase principal de la librería y es la encargada de proporcionar las funcionalidades para la creación de documentos PDF. Esta interfaz está compuesta por los siguientes métodos:
Este método permite establecer la información básica del documento PDF, como la plantilla pdf con la que deseamos trabajar.
PdfData pdfData = new PdfData {
DownloadName = "MiDocumento.pdf",
Layout = layout // MemoryStream con la plantilla pdf para nuestro nuevo PDF
};
using(IPdfWrapper pdfWrapper = new PdfWrapper()) {
pdfWrapper.SetPdfData(pdfData);
// ... Insertar texto, imágenes y tablas ...
MemoryStream stream = pdfWrapper.Download();
}
En este ejemplo, se crea una instancia de la clase PdfData y se asigna un nombre de descarga al archivo PDF y se establece el Layout en layout (archivo MemoryStream). Luego, se crea una instancia de la interfaz IPdfWrapper y se llama al método SetPdfData para establecer los datos del PDF. Finalmente, se llama al método Download para obtener el archivo PDF en un MemoryStream.
Usa el método
AdapTemplatede la claseTemplateAdapterpara convertir un documento PDF en un objetoMemoryStreamque puedas usar como template para el métodoSetPdfDatade la interfaz principalIPdfWrapper
// Primero, definimos la ruta al archivo PDF que queremos utilizar como plantilla
string path = @"C:\path\to\template.pdf";
// Luego, definimos un diccionario que indique la cantidad de veces que queremos copiar cada página del archivo
IDictionary<int, int> iterations = new Dictionary<int, int> {
{ 1, 3 }, // Copiar la página 1 tres veces
{ 2, 2 } // Copiar la página 2 dos veces
};
// Finalmente, llamamos al método AdapTemplate y recibimos un MemoryStream con el resultado
MemoryStream layout = TemplateAdapter.AdapTemplate(path, iterations);
Este método permite insertar texto en las páginas del documento PDF. Es posible insertar texto en una o varias páginas, y es posible personalizar el formato de cada una de ellas.
using (var pdfWrapper = new PdfWrapper()) {
// Creamos una lista de páginas con texto a insertar
var pagesData = new List<PageData> {
new PageData {
Number = 1,
Data = new List<dynamic> {
new SingleData {
Text = "Texto de prueba 1",
Coor = new Coor { X = 100, Y = 100 }
},
new SingleRowData {
Data = new {
String = "string",
Int = 10,
Double = 12.12d,
Float = 12.12f,
Decimal = 12.12m,
Bool = true,
Char = _char,
Byte = _byte,
SByte = _sbyte,
Short = _short,
UShort = _ushort,
Uint = _uint,
Long = _long,
Ulong = _ulong
},
Coors = new List<Coor> {
new Coor { Name = "String", X = 100, Y = 100 },
new Coor { Name = "Int", X = 100, Y = 120 },
new Coor { Name = "Double", X = 100, Y = 140 },
new Coor { Name = "Float", X = 100, Y = 160 },
new Coor { Name = "Decimal", X = 100, Y = 180 },
new Coor { Name = "Bool", X = 100, Y = 200 },
new Coor { Name = "Char", X = 100, Y = 220 },
new Coor { Name = "Byte", X = 100, Y = 240 },
new Coor { Name = "SByte", X = 100, Y = 260 },
new Coor { Name = "Short", X = 100, Y = 280 },
new Coor { Name = "UShort", X = 100, Y = 300 },
new Coor { Name = "Uint", X = 100, Y = 320 },
new Coor { Name = "Long", X = 100, Y = 340 },
new Coor { Name = "Ulong", X = 100, Y = 360 }
}
},
new TableData {
Data = new List<dynamic> {
new { Nombre = "Verónica", Edad = 12, Registro = DateTime.Now },
new { Nombre = "Luis", Edad = 11, Registro = DateTime.Now },
new { Nombre = "Rodrigo", Edad = 12, Registro = DateTime.Now },
new { Nombre = "Vanesa", Edad = 10, Registro = DateTime.Now }
},
Coors = new List<Coor> {
new Coor { Name = "Nombre", X = 150, Y = 150 },
new Coor { Name = "Edad", X = 200, Y = 150 },
new Coor { Name = "Registro", X = 250, Y = 150 }
},
StepInY = 20
}
}
}
};
// Insertamos el texto en el PDF
pdfWrapper.InsertText(pagesData);
// Descargamos el PDF resultante
var pdfStream = pdfWrapper.Download();
}
Este método permite insertar tablas en el documento PDF. Es posible personalizar el formato de las tablas, tales como el ancho de las columnas, el color y tamaño de la fuente, entre otros.
A continuación se muestra un ejemplo detallado para proporcionar la configuración de la tabla a insertar.
La configuración de diseño de la clase
CellConfiges opcional puesto que se herada la configuración de la claseTableConfig.
using (IPdfWrapper pdfWrapper = new PdfWrapper()) {
pdfWrapper.SetPdfData(new PdfData {
Layout = stream
});
TableConfig config = new TableConfig {
UseAllAvailableWidth = true,
PreserveMarginTopOnSplit = false,
ColumnsWidth = new float[] { 100, 100, 100 },
PageNumber = 1,
Position = new float[] { 50, 50 },
Rows = new List<List<CellConfig>> {
new List<CellConfig> {
new CellConfig {
Text = "Celda 1, 1",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
},
new CellConfig {
Text = "Celda 1, 2",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
},
new CellConfig {
Text = "Celda 1, 3",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
}
},
new List<CellConfig> {
new CellConfig {
Text = "Celda 2, 1",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
},
new CellConfig {
Text = "Celda 2, 2",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
},
new CellConfig {
Text = "Celda 2, 3",
Rowspan = 1,
Colspan = 1,
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
}
}
},
FontName = "Times-Roman",
FontSize = 12,
FontColor = new RGB { R = 0, G = 0, B = 0 },
Align = TextAlign.LEFT,
Valign = VerticalAlign.MIDDLE
};
pdfWrapper.InsertTable(config);
var result = pdfWrapper.Download();
}
Estos métodos permiten insertar imágenes en el documento PDF. Es posible insertar imágenes a partir de una ruta en el sistema de archivos o a partir de un stream de memoria.
Ejemplo de uso;
using (IPdfWrapper pdfWrapper = new PdfWrapper()) {
pdfWrapper.SetPdfData(new PdfData {
Layout = layout,
});
// Insertar una imagen proporcionado una ruta de acceso
string path = Path.Combine(_webHostEnvironment.WebRootPath, "demo.jpg");
pdfWrapper.AddImage(new ImageOptions(), path);
// Insertar una imagen proporcionando un stream de memoria
byte[] imageBytes = System.IO.File.ReadAllBytes(path);
MemoryStream memoryStream = new MemoryStream(imageBytes);
memoryStream.Position = 0;
pdfWrapper.AddImage(new ImageOptions { Botton = 500 }, memoryStream);
var result = pdfWrapper.Download();
}
Este método permite descargar el documento PDF en un stream de memoria.
PdfWrapper - La clase PdfWrapper es la clase concreta que implementa la interfaz IPdfWrapper. Esta clase es la encargada de realizar las tareas necesarias para crear y descargar el documento PDF.
PdfData - La clase PdfData es una clase de datos que permite establecer la información básica del documento PDF, tales como el nombre de descarga y el template para generar el nuevo documento.
Clase PageData - La clase PageData es una clase de datos que permite insertar texto en una página específica del documento PDF.
SingleData, SingleRowData y TableData - Estas son clases de datos que permiten insertar texto en el documento PDF. SingleData permite insertar un solo párrafo de texto, SingleRowData permite insertar varios párrafos en una sola fila y TableData permite insertar una tabla en el documento PDF.
ImageOptions - La clase ImageOptions permite especificar las opciones para agregar una imagen al PDF. Esta clase incluye los siguientes atributos:
TableConfig - La clase TableConfig es una clase que se utiliza para describir una tabla en un documento PDF. Contiene diferentes propiedades que determinan el aspecto y la posición de la tabla en el documento, así como la información sobre los datos que se van a incluir en la tabla.
Las propiedades incluyen:
| Propiedad | Descripción |
|---|---|
UseAllAvailableWidth |
Una bandera que indica si la tabla debe ocupar todo el ancho disponible en la página. |
PreserveMarginTopOnSplit |
Una bandera que indica si se debe preservar el margen superior al dividir una tabla en varias páginas. |
ColumnsWidth |
Un arreglo de flotantes que representa el ancho de cada columna de la tabla. |
PageNumber |
Un entero que indica el número de página en la que se agregará la tabla. |
Position |
Un arreglo de flotantes que representa la posición de la tabla en la página en coordenadas X e Y. |
Rows |
Una lista de listas de objetos CellConfig que describen cada celda de la tabla. |
FontName |
Una cadena que indica el nombre de la fuente que se usará para dibujar el texto de la tabla. |
FontSize |
Un flotante que indica el tamaño de la fuente que se usará para dibujar el texto de la tabla. |
FontColor |
Un objeto RGB que indica el color de la fuente que se usará para dibujar el texto de la tabla. |
Align |
Una enumeración que indica la alineación horizontal de la tabla. |
Valign |
Una enumeración que indica la alineación vertical de la tabla. |
Border |
Un objeto Border que describe el borde de la tabla. |
CellConfig - La clase CellConfig se utiliza para describir cada celda individual de la tabla y contiene propiedades como el texto a incluir en la celda, el número de filas y columnas que abarca la celda, la fuente, el tamaño de la fuente, el color de la fuente, la alineación horizontal y vertical, entre otras.
Las contribuciones son bienvenidas. Por favor, envía una solicitud de extracción con tus cambios.
Licencia Affero General Public License (AGPL)
Este programa es software libre: puedes redistribuirlo y/o modificarlo bajo los términos de la Licencia Pública General Affero, publicada por la Fundación para el Software Libre, ya sea la versión 3 de la Licencia o (a tu elección) cualquier versión posterior.
Este programa se distribuye con la esperanza de que sea útil, pero SIN NINGUNA GARANTÍA; sin siquiera la garantía implícita de COMERCIABILIDAD o APTITUD PARA UN PROPÓSITO PARTICULAR. Consulta la Licencia Pública General Affero para más detalles.
Deberías haber recibido una copia de la Licencia Pública General Affero junto con este programa. Si no es así, consulta https://www.gnu.org/licenses/.
Nota Importante: Este proyecto utiliza la biblioteca iText, que está licenciada bajo AGPL o bajo licencia comercial. Consulta https://itextpdf.com/ para más detalles sobre los términos de licencia de iText.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 was computed. net5.0-windows net5.0-windows was computed. net6.0 net6.0 was computed. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 was computed. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 netcoreapp2.0 was computed. netcoreapp2.1 netcoreapp2.1 was computed. netcoreapp2.2 netcoreapp2.2 was computed. netcoreapp3.0 netcoreapp3.0 was computed. netcoreapp3.1 netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 netstandard2.0 is compatible. netstandard2.1 netstandard2.1 was computed. |
| .NET Framework | net461 net461 was computed. net462 net462 was computed. net463 net463 was computed. net47 net47 was computed. net471 net471 was computed. net472 net472 was computed. net48 net48 was computed. net481 net481 was computed. |
| MonoAndroid | monoandroid monoandroid was computed. |
| MonoMac | monomac monomac was computed. |
| MonoTouch | monotouch monotouch was computed. |
| Tizen | tizen40 tizen40 was computed. tizen60 tizen60 was computed. |
| Xamarin.iOS | xamarinios xamarinios was computed. |
| Xamarin.Mac | xamarinmac xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos xamarinwatchos was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|