Shane32.EasyPDF 3.0.3

There is a newer version of this package available.
See the version list below for details.
dotnet add package Shane32.EasyPDF --version 3.0.3                
NuGet\Install-Package Shane32.EasyPDF -Version 3.0.3                
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="Shane32.EasyPDF" Version="3.0.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Shane32.EasyPDF --version 3.0.3                
#r "nuget: Shane32.EasyPDF, 3.0.3"                
#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 Shane32.EasyPDF as a Cake Addin
#addin nuget:?package=Shane32.EasyPDF&version=3.0.3

// Install Shane32.EasyPDF as a Cake Tool
#tool nuget:?package=Shane32.EasyPDF&version=3.0.3                

Shane32.EasyPDF

NuGet Coverage Status

Basic setup

  1. Create a new instance with one of the constructors:
// Create a PDF file which will be saved to a byte array via ToArray()
var pdf = new PDFWriter();

// Create a PDF file at the specified path on the hard drive
var pdf = new PDFWriter(filename);

// Create a PDF file that will write to the specified Stream
var pdf = new PDFWriter(stream);
  1. Set the desired scaling mode
pdf.ScaleMode = ScaleModes.Inches;  // points, inches and hundredths are supported; hundredths are default
  1. Add a new page via NewPage()
pdf.NewPage(PaperKind.Letter, false);        // create a Letter sized page in portrait mode
pdf.NewPage(11, 17, true);                   // create a 11" x 17" page in landscape mode
pdf.NewPage(PaperKind.Letter, false, 1, 1);  // create a Letter sized page with 1" margins
  1. Add drawing instructions
pdf.Write("The quick brown fox jumps over the lazy dog", true);
  1. Save the result and/or close the document
var data = pdf.ToArray();   // supported only by the default constructor
pdf.Close();

Properties

Property Description
CurrentX The current X position
CurrentY The current Y position
FillColor The color for filling polygons and drawing barcodes
Font The font name, size, and style used when writing text
FontAlignment The alignment of text in relation to the current position
FontLineSpacing The line spacing multiple when printing multiple lines of text
ForeColor The color for printing text, lines and borders
LineCap The style used to draw the end of a line
LineDash The dash style used to draw lines and borders
LineJoin The style used to draw joined line segments and borders
LineWidth The pen width when drawing lines and borders
PageSize Returns the size of the current page ignoring margins
PictureAlignment The alignment of pictures and barcodes in relation to the current position
Pos The current position
ScaleMode The scaling mode for the coordinates used by all other commands

Note that drawing coordinates are always specified or returned based on the current ScaleMode setting, and coordinate (0, 0) is the top-left corner of the page/margin.

Text drawing commands

Method Description
RegisterFont Registers a font contained within a file to be able to be used
TextAscent Returns the distance between the baseline and the top of the highest letters
TextCapHeight Returns the distance between the baseline and the top of capital letters
TextDescent Returns the distance between the baseline and the bottom of the lowest letters (j's, etc)
TextHeight Returns the height of a single line of text, including space between rows (ascent + descent + leading)
TextLeading Returns the amount of additional line spacing besides the ascent and descent
TextWidth Returns the width of the specified text
Write Writes one or more lines of text at the current position with no word wrapping
WriteAt Writes one or more lines of text at the specified position with no word wrapping
WriteLine Writes a single line of text, stopping where necessary due to word wrapping
WriteLines Writes one or more lines of text at the current position with word wrapping
WriteLinesAt Writes one or more lines of text at the specified position with word wrapping

Examples below:

// Write "Hello world!" and advance to the next line
pdf.Write("Hello world!", true);

// Write "Hello world!" except with "world" in red
pdf.Write("Hello ");
pdf.ForeColor = Color.Red;
pdf.Write("world");
pdf.ForeColor = Color.Black;
pdf.Write("!", true);
pdf.CurrentY = 0;  // reposition cursor; otherwise it would be underneath the exclamation mark

// Center a header on the page
pdf.TextAlignment = TextAlignment.CenterTop;
pdf.Font = new Font(StandardFonts.Times, 20);
pdf.WriteAt(false, pdf.PageSize.Width / 2, 0.5f, "Hello there!");

// Write a paragraph of text over 4" of space with no indentation and with justification
pdf.WriteLines(4, 0, 0, "Hello there!  The quick brown fox jumps over the lazy dog.  Did you know that?", true);

Note that by default, all system fonts are registered and can be used (embedded) into the PDF. There are 5 standard fonts available to PDF files which do not require embedding; they are Times, Helvetica, Courier, Symbol and ZapfDingbats.

Picture drawing commands

There is a single command, PaintPicture which can print a ITextImage instance to the PDF file. Pictures are positioned according to the PictureAlignment property.

Line drawing commands

Method Description
BezierTo Starts or continues a line or polygon around a bezier curve
Circle Draws a circle at the specified coordinates
CornerTo Starts or continues a line or polygon around a rounded corner to another coordinate (draws an arc)
FinishLine Ends the line and draws it
FinishPolygon Ends a polygon and draws it
Line Starts a new line or polygon from a specified coordinate to another specified coordinate
LineTo Starts or continues a line or polygon to another specified coordinate
Rectangle Draws a rectangle at the specified coordinates, optionally filling it (with/without border) and/or rounding the corners
RectangleDualOffset Draws a rectangle at the specified coordinates, and then draws another rectangle inset by the specified amount

Note that once a line or polygon has begun, any call to a method other than LineTo, CornerTo, BezierTo, FinishLine or FinishPolygon will implicitly call FinishLine to draw the line on the page.

Barcode / QR code commands

Method Description
Barcode Draws a barcode at the current position of the specified size
BarcodeSize Returns the default width of a specified barcode
QRCode Draws a QR code at the current position of the specified size
QRCodeSize Returns the default size of a specified QR code

Barcodes are positioned according to the PictureAlignment property and colored via the FillColor property.

Setup and miscellaneous commands

Method Description
AnnotatePage Can be used to take an existing PDF and overlay drawing actions on top of it
Close Close/saves the PDF
GetDirectContent Returns the underlying iTextSharp.text.pdf.PdfContentByte which can be used to perform nearly any drawing action on the PDF
GetDocument Returns the underlying iTextSharp.text.Document instance
GetWriter Returns the underlying iTextSharp.text.pdf.iTextPdfWriter instance
NewPage Creates or appends a new page of the specified size; required before writing to the document
PrintAsync Prints the page to a specified network-attached printer that supports direct PDF printing
ToArray Returns the PDF as a byte array

Credits

Glory to Jehovah, Lord of Lords and King of Kings, creator of Heaven and Earth, who through his Son Jesus Christ, has reedemed me to become a child of God. -Shane32

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 was computed.  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. 
.NET Core netcoreapp1.0 was computed.  netcoreapp1.1 was computed.  netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard1.5 is compatible.  netstandard1.6 was computed.  netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net451 is compatible.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen30 was computed.  tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
7.0.0 2,310 10/29/2024
6.0.0 4,690 4/28/2024
5.1.1 658 4/8/2024
5.1.0 119 4/5/2024
5.0.0 7,780 4/12/2023
4.0.3 224 4/9/2023
4.0.2 201 4/7/2023
4.0.1 288 2/12/2023
3.0.3 4,112 8/15/2022
2.2.0 2,396 1/20/2022
2.1.0 418 1/20/2022
2.0.0 737 1/11/2022
1.0.0 287 1/6/2022