PdfDocuments 6.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package PdfDocuments --version 6.0.0                
NuGet\Install-Package PdfDocuments -Version 6.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PdfDocuments" Version="6.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PdfDocuments --version 6.0.0                
#r "nuget: PdfDocuments, 6.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install PdfDocuments as a Cake Addin
#addin nuget:?package=PdfDocuments&version=6.0.0

// Install PdfDocuments as a Cake Tool
#tool nuget:?package=PdfDocuments&version=6.0.0                

PdfDocuments

High level C# library for the easy creation of PDF documents using PdfSharp. Use this library to create beautiful and complex PDF's using a structure similar to XAML with model binding. Objects called PdfSections are aligned to a grid by stacking or creating a parent/child heirarchy. The rendering engine will flow the sections and align them to the grid creating perfect PDF documents every time.

Examples

Invoice Example

Example PDF

View Actual PDF

The library has debug flags to assist in troubleshooting layout issues while developing.

Invoice Debug Version

Debug Version

View Actual PDF

Simple Code Example

The source for the simple example can be in the Examples folder of the project source code.

Add the NuGet package

Open Visual Studio and create a new Console application. Add the NuGet package.

PM> Install-Package PdfDocuments

Add the using statement

In Visual Studio, open the Program.cs file and add the using statement for the library.

using PdfDocuments;

Change Main method Signature

This example uses async/await statements. This requires the main method signature to be changed as shown below.

static async Task<int> Main(string[] args)

Register Encoding

Using the PdfSharp library requires an encoding provider to be registered. Add the following code to the Main method in Program.cs.

Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);

Create a Data Model

The PDF Documents in this library are based on data models. The PDF document uses binding to retrieve data from the instance of the model passed when building the PDF document.

Create a new class in the solution called Message.cs and paste the code shown below into the class.

namespace PdfDocuments.Example.Simple
{
	public class Message : IPdfModel
	{
		public string Id { get; set; }
		public string Text { get; set; }
	}
}

Create PDF Document Generator Class

Create a new class call HelloWorld.cs in the solution and copy the code below to the class.

using PdfSharp.Drawing;
using System.Threading.Tasks;

namespace PdfDocuments.Example.Simple
{
	public class HelloWorld : PdfGenerator<Message>
	{
		public HelloWorld(IPdfStyleManager<Message> styleManager)
			: base(styleManager)
		{
		}

		protected override Task OnInitializeStylesAsync(IPdfStyleManager<Message> styleManager)
		{
			//
			// Add a style for the text. The style name is referenced in the
			// content creation.
			//
			this.StyleManager.Add("HelloWorld.Text", Style.Create<Message>()
						.UseFont("Arial", 48)
						.UseForegroundColor(XColors.Purple)
						.UseBorderWidth(1)
						.UseTextAlignment(XStringFormats.Center)
						.UsePadding(10, 10, 10, 10)
						.Build());

			return Task.CompletedTask;
		}

		protected override Task<IPdfSection<Message>> OnAddContentAsync()
		{
			//
			// Add a basic text block using the style that was created.
			//
			return Task.FromResult(Pdf.TextBlockSection<Message>()
						  .WithText((g, m) => m.Text)
						  .WithStyles("HelloWorld.Text"));
		}
	}
}

The class above overrides OnInitializeStylesAsync to create a single style that is used to style the text. The name of the styles does not matter as long as the style name is referenced with the same name in the section referencing the style.

the class also overrides OnAddContentAsync(). This method is where all of the content for the PDF is added. In this method, there is one section being added using the style that was defined previously. The Text property of the section is bound to the Text property of the Message model.

Generate the PDF

Open the Program.cs file again and add a line to create a new Style Manager instance as shown below.

PdfStyleManager<Message> styleManager = new PdfStyleManager<Message>();

Next add a statement to create an instance of the HelloWorld PDF document as shown below. Notice the Style manager instance is passed into the constructor.

HelloWorld helloWorld = new HelloWorld(styleManager);

Next, create an instance of the data model.

Message model = new Message() { Id = "12345", Text = "Hello World" };

Now we can generate a PDF. The Build() method will create the PDF into a byte array. This byte array can be saved to disk or returned by a REST API to a client application without the need to write to disk first.

(bool result, byte[] fileData) = await generator.Build(model);

The Build method return a Tuple where the first element is a Boolean and indicates if the PDF was successfully created or not. If successful, the second element contains the PDF byte array.

Let's write the PDF to disk. The code below will save the PDF to the desktop folder of the current user using the model type name and Id property of the model to name the file.

string fileName = $@"{Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory)}\{model.GetType().Name} [{model.Id}].pdf";
File.WriteAllBytes(fileName, fileData);

Last, we can launch the default OS PDF viewer to view the new PDF document.

Process.Start(new ProcessStartInfo(fileName) { UseShellExecute = true });

If everything worked, the PDF should look like this:

Simple PDF

View Actual PDF

Troubleshooting the Layout

In more complex documents, it may be necessary to troubleshoot layout and fonts. There are a few debug flags that can be set to reveal the details of how the document was rendered.

helloWorld.DebugMode = helloWorld.DebugMode
		.SetFlag(DebugMode.RevealGrid, true)
		.SetFlag(DebugMode.RevealLayout, true)
		.SetFlag(DebugMode.HideDetails, false)
		.SetFlag(DebugMode.RevealFontDetails, true)
		.SetFlag(DebugMode.OutlineText, false);

In the above code, the PDF renderer will draw the grid, the section outlines and the fonts used. This result in the PDF shown below.

Simple Debug PDF

View Actual PDF

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on PdfDocuments:

Package Downloads
PdfDocuments.IronBarcode

High level C# library for the easy creation of barcodes in PDF documents using PdfSharp.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
9.0.0 119 11/14/2024
8.0.1 169 9/11/2024
8.0.0 1,246 12/27/2023
6.0.0 5,596 1/15/2022
1.2.0 680 5/21/2021
1.1.0 510 5/18/2021
1.0.3 544 5/16/2021
1.0.2 327 5/6/2021
1.0.1 324 5/2/2021
1.0.0 337 4/25/2021