QuestPDF 2024.3.4
See the version list below for details.
dotnet add package QuestPDF --version 2024.3.4
NuGet\Install-Package QuestPDF -Version 2024.3.4
<PackageReference Include="QuestPDF" Version="2024.3.4" />
paket add QuestPDF --version 2024.3.4
#r "nuget: QuestPDF, 2024.3.4"
// Install QuestPDF as a Cake Addin #addin nuget:?package=QuestPDF&version=2024.3.4 // Install QuestPDF as a Cake Tool #tool nuget:?package=QuestPDF&version=2024.3.4
QuestPDF is a modern open-source .NET library for PDF document generation. Offering comprehensive layout engine powered by concise and discoverable C# Fluent API. Easily generate PDF documents, reports, invoices, exports etc.
👨💻 Design PDF documents using C# and employ a code-only approach. Utilize your version control system to its fullest potential.
🧱 Compose PDF document with a range of powerful and predictable structural elements, such as text, image, border, table, and many more.
⚙️ Utilize a comprehensive layout engine, specifically designed for PDF document generation and paging support.
📖 Write code using concise and easy-to-understand C# Fluent API. Utilize IntelliSense to quickly discover available options.
🔗 Don't be limited to any proprietary scripting language or format. Follow your experience and leverage all modern C# features.
⌛ Save time thanks to a hot-reload capability, allowing real-time PDF document preview without code recompilation.
Simplicity is the key
How easy it is to start and prototype with QuestPDF? Really easy thanks to its minimal API! Please analyse the code below that generates basic PDF document:
using QuestPDF.Fluent;
using QuestPDF.Helpers;
using QuestPDF.Infrastructure;
// code in your main method
Document.Create(container =>
{
container.Page(page =>
{
page.Size(PageSizes.A4);
page.Margin(2, Unit.Centimetre);
page.Background(Colors.White);
page.DefaultTextStyle(x => x.FontSize(20));
page.Header()
.Text("Hello PDF!")
.SemiBold().FontSize(36).FontColor(Colors.Blue.Medium);
page.Content()
.PaddingVertical(1, Unit.Centimetre)
.Column(x =>
{
x.Spacing(20);
x.Item().Text(Placeholders.LoremIpsum());
x.Item().Image(Placeholders.Image(200, 100));
});
page.Footer()
.AlignCenter()
.Text(x =>
{
x.Span("Page ");
x.CurrentPageNumber();
});
});
})
.GeneratePdf("hello.pdf");
Let's get started
Begin exploring the QuestPDF library today. You are 250 lines of C# code away from creating a fully functional PDF invoice implementation.
Read the Getting Started tutorial to familiarize yourself with general library architecture, important layout structures as well as to better understand helpful patterns and practices.
Easily start designing your PDF documents, reports, invoices, exports and even more.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. 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 is compatible. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net40 is compatible. net403 was computed. net45 was computed. net451 was computed. 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 | 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. |
-
.NETStandard 2.0
- No dependencies.
-
net6.0
- No dependencies.
-
net8.0
- No dependencies.
NuGet packages (43)
Showing the top 5 NuGet packages that depend on QuestPDF:
Package | Downloads |
---|---|
AgentHub.Service.Financial.Domain.Shared
Package Description |
|
HTMLToQPDF
Relorer.QuestPDF.HTML is an extension for QuestPDF that allows to generate PDF from HTML |
|
DH.QuestPDF
DH框架的Pdf处理库。基于https://github.com/QuestPDF/QuestPDF |
|
Verify.QuestPDF
Extends Verify (https://github.com/VerifyTests/Verify) to allow verification via QuestPDF. |
|
QuestPDF.Markdown
QuestPDF.Markdown is an open-source helper library that allows rendering markdown into a QuestPDF document |
GitHub repositories (15)
Showing the top 5 popular GitHub repositories that depend on QuestPDF:
Repository | Stars |
---|---|
nopSolutions/nopCommerce
ASP.NET Core eCommerce software. nopCommerce is a free and open-source shopping cart.
|
|
beto-rodriguez/LiveCharts2
Simple, flexible, interactive & powerful charts, maps and gauges for .Net, LiveCharts2 can now practically run everywhere Maui, Uno Platform, Blazor-wasm, WPF, WinForms, Xamarin, Avalonia, WinUI, UWP.
|
|
Pixeval/Pixeval
Wow. Yet another Pixiv client!
|
|
ariacom/Seal-Report
Database Reporting Tool and Tasks (.Net)
|
|
neozhu/CleanArchitectureWithBlazorServer
This is a repository for creating a Blazor Server dashboard application following the principles of Clean Architecture
|
Version | Downloads | Last updated | |
---|---|---|---|
2024.12.0-rc2 | 106 | 11/22/2024 | |
2024.12.0-rc1 | 68 | 11/22/2024 | |
2024.12.0-rc0 | 516 | 11/18/2024 | |
2024.10.4 | 1,289 | 11/22/2024 | |
2024.10.3 | 25,646 | 11/8/2024 | |
2024.10.2 | 45,283 | 10/24/2024 | |
2024.10.1 | 39,124 | 10/14/2024 | |
2024.10.0 | 30,727 | 10/4/2024 | |
2024.10.0-rc4 | 2,176 | 9/26/2024 | |
2024.10.0-rc3 | 5,962 | 9/17/2024 | |
2024.10.0-rc2 | 301 | 9/16/2024 | |
2024.10.0-rc1 | 291 | 9/13/2024 | |
2024.10.0-rc0 | 3,130 | 9/4/2024 | |
2024.7.3 | 148,997 | 8/27/2024 | |
2024.7.2 | 113,536 | 8/1/2024 | |
2024.7.1 | 58,056 | 7/22/2024 | |
2024.7.0 | 33,159 | 7/15/2024 | |
2024.7.0-rc0 | 1,687 | 7/4/2024 | |
2024.6.4 | 70,682 | 6/25/2024 | |
2024.6.3 | 335 | 6/25/2024 | |
2024.6.2 | 26,485 | 6/20/2024 | |
2024.6.1 | 21,818 | 6/15/2024 | |
2024.6.0 | 48,207 | 6/11/2024 | |
2024.3.10 | 77,246 | 5/25/2024 | |
2024.3.9 | 9,706 | 5/23/2024 | |
2024.3.8 | 236 | 5/23/2024 | |
2024.3.7 | 21,388 | 5/20/2024 | |
2024.3.6 | 34,203 | 5/14/2024 | |
2024.3.5 | 24,361 | 5/12/2024 | |
2024.3.4 | 26,280 | 5/6/2024 | |
2024.3.3 | 9,537 | 5/2/2024 | |
2024.3.2 | 31,867 | 4/25/2024 | |
2024.3.1 | 31,853 | 4/22/2024 | |
2024.3.0 | 60,918 | 4/12/2024 | |
2024.3.0-rc2 | 4,112 | 3/30/2024 | |
2024.3.0-rc1 | 244 | 3/29/2024 | |
2024.3.0-rc | 618 | 3/27/2024 | |
2024.3.0-beta1 | 2,275 | 3/18/2024 | |
2024.3.0-beta | 3,510 | 2/29/2024 | |
2024.3.0-alpha | 1,691 | 2/15/2024 | |
2023.12.6 | 283,835 | 2/21/2024 | |
2023.12.5 | 72,316 | 2/7/2024 | |
2023.12.4 | 143,855 | 1/15/2024 | |
2023.12.3 | 20,031 | 1/12/2024 | |
2023.12.2 | 62,556 | 1/1/2024 | |
2023.12.1 | 68,061 | 12/15/2023 | |
2023.12.0 | 52,183 | 12/3/2023 | |
2023.10.2 | 84,241 | 11/13/2023 | |
2023.10.1 | 44,649 | 10/31/2023 | |
2023.10.0 | 32,275 | 10/23/2023 | |
2023.10.0-alpha0 | 379 | 10/13/2023 | |
2023.9.1 | 46,876 | 10/6/2023 | |
2023.9.0 | 37,104 | 9/25/2023 | |
2023.6.3 | 144,047 | 8/27/2023 | |
2023.6.2 | 640 | 8/26/2023 | |
2023.6.1 | 104,480 | 7/20/2023 | |
2023.6.0 | 74,761 | 6/28/2023 | |
2023.5.3 | 88,266 | 6/12/2023 | |
2023.5.2 | 62,069 | 5/31/2023 | |
2023.5.1 | 28,183 | 5/22/2023 | |
2023.5.0 | 12,607 | 5/15/2023 | |
2023.4.2 | 14,184 | 5/9/2023 | |
2023.4.1 | 4,813 | 5/4/2023 | |
2023.4.0 | 1,427 | 5/4/2023 | |
2022.12.15 | 226,213 | 2/7/2024 | |
2022.12.14 | 32,203 | 1/12/2024 | |
2022.12.13 | 9,323 | 1/1/2024 | |
2022.12.12 | 24,091 | 12/15/2023 | |
2022.12.11 | 21,543 | 12/3/2023 | |
2022.12.10 | 11,714 | 11/13/2023 | |
2022.12.9 | 3,402 | 10/31/2023 | |
2022.12.8 | 24,537 | 10/23/2023 | |
2022.12.7 | 95,927 | 10/6/2023 | |
2022.12.6 | 464,506 | 5/9/2023 | |
2022.12.5 | 152,806 | 4/27/2023 | |
2022.12.4 | 34,065 | 4/22/2023 | |
2022.12.3 | 77,140 | 4/16/2023 | |
2022.12.2 | 325,179 | 3/12/2023 | |
2022.12.1 | 581,874 | 1/13/2023 | |
2022.12.0 | 157,574 | 12/14/2022 | |
2022.11.0 | 392,184 | 11/5/2022 | |
2022.11.0-alpha1 | 359 | 11/1/2022 | |
2022.11.0-alpha0 | 322 | 10/28/2022 | |
2022.9.1 | 94,474 | 10/15/2022 | |
2022.9.0 | 141,040 | 9/18/2022 | |
2022.9.0-alpha1 | 303 | 9/16/2022 | |
2022.8.2 | 166,983 | 8/21/2022 | |
2022.8.1 | 21,026 | 8/19/2022 | |
2022.8.0 | 99,188 | 8/15/2022 | |
2022.6.3 | 55,645 | 7/18/2022 | |
2022.6.2 | 129,957 | 6/22/2022 | |
2022.6.1 | 23,248 | 6/12/2022 | |
2022.6.0 | 163,772 | 6/12/2022 | |
2022.6.0-prerelease | 1,765 | 5/30/2022 | |
2022.5.0 | 287,573 | 5/9/2022 | |
2022.4.1 | 112,555 | 4/8/2022 | |
2022.4.0 | 70,607 | 4/4/2022 | |
2022.4.0-alpha1 | 339 | 3/27/2022 | |
2022.4.0-alpha0 | 307 | 3/27/2022 | |
2022.3.1 | 99,078 | 3/15/2022 | |
2022.3.0 | 2,597 | 3/14/2022 | |
2022.2.7 | 1,764 | 3/12/2022 | |
2022.2.6 | 6,582 | 3/8/2022 | |
2022.2.5 | 20,669 | 2/18/2022 | |
2022.2.4 | 710 | 2/18/2022 | |
2022.2.3 | 11,359 | 2/7/2022 | |
2022.2.2 | 2,062 | 2/1/2022 | |
2022.2.1 | 1,624 | 1/30/2022 | |
2022.2.0 | 1,893 | 1/29/2022 | |
2022.2.0-beta1 | 335 | 1/24/2022 | |
2022.1.0 | 26,289 | 1/10/2022 | |
2022.1.0-beta5 | 986 | 1/7/2022 | |
2022.1.0-beta4 | 346 | 1/6/2022 | |
2022.1.0-beta3 | 317 | 1/5/2022 | |
2022.1.0-beta2 | 334 | 1/5/2022 | |
2022.1.0-beta1 | 336 | 1/3/2022 | |
2022.1.0-beta0 | 314 | 12/30/2021 | |
2022.1.0-alpha0 | 362 | 12/30/2021 | |
2021.12.0 | 32,582 | 12/6/2021 | |
2021.12.0-alpha1 | 1,164 | 11/29/2021 | |
2021.12.0-alpha0 | 391 | 11/18/2021 | |
2021.11.4 | 22,786 | 11/14/2021 | |
2021.11.3 | 4,922 | 11/7/2021 | |
2021.11.0-beta3 | 403 | 11/3/2021 | |
2021.11.0-beta2 | 434 | 10/28/2021 | |
2021.11.0-beta | 467 | 10/23/2021 | |
2021.10.1 | 10,099 | 9/30/2021 | |
2021.10.0 | 614 | 9/30/2021 | |
2021.10.0-beta.2 | 280 | 9/14/2021 | |
2021.10.0-beta | 420 | 9/13/2021 | |
2021.9.3 | 6,401 | 9/12/2021 | |
2021.9.2 | 733 | 9/1/2021 | |
2021.9.1 | 564 | 9/1/2021 | |
2021.9.0 | 527 | 8/30/2021 | |
2021.8.0 | 2,495 | 8/2/2021 | |
2021.5.2 | 3,310 | 5/5/2021 | |
2021.4.0 | 773 | 4/2/2021 | |
2021.3.1 | 7,128 | 3/1/2021 | |
2021.3.0 | 587 | 3/1/2021 | |
2021.2.0 | 633 | 2/8/2021 | |
2021.1.0 | 696 | 1/4/2021 | |
2020.11.0 | 10,820 | 11/1/2020 |
Version 2024.3.0
The primary theme of this release is the removal of the SkiaSharp dependency and the introduction of a custom native layer built on top of Skia M124.
This change was necessary to provide much higher flexibility and enable several new long-awaited features:
- Font subsetting - this feature includes only necessary font glyphs in the output document, greatly reducing the file size, especially when using glyph-rich fonts supporting multiple languages,
- Improved text-related capabilities, including but not limited to text justification, bi-directionality, enhanced line breaking algorithms, more styles for text decoration, word spacing, and more,
- Introduced additional document compression to further reduce file size,
- Integrated native SVG support,
- In future releases: enhanced accessibility through support for PDF tags.
Other changes:
- Removed the SkiaSharp dependency, thereby making QuestPDF a standalone library,
- Updated the Lato font to the latest version (2.015),
- Included licenses of the third-party dependencies in the NuGet package,
- Included a list of Contributors in the NuGet package to acknowledge the valuable input from our Community in improving QuestPDF.
Unfortunately, this release also introduces breaking changes:
- Removed support for injecting SkiaSharp content directly into the document. It is still possible to integrate SkiaSharp through vector and raster graphics; please consult the documentation for more details,
- Removed support for platforms: Android, iOS, UWP, WASM, and Linux-Alpine. We are currently investigating reintroducing support for WASM and Linux-Alpine in future releases.
We would like to thank the SkiaSharp project, its maintainers, and contributors, for creating a fantastic graphics library. It was a fantastic foundation for QuestPDF for over 3 years.
Version 2024.3.1
- Enhanced discoverability of text alignment options (AlignLeft, AlignCenter, AlignRight, AlignStart, AlignEnd and Justify) when using the shorthand Text method (common use case).
- To enhance compatibility with existing codebases, we've removed the breaking change associated with the deprecation of the TextStyle.Fallback method. Although this method remains obsolete, we've reintroduced it with a compatibility layer to prevent disruptions.
- Enhanced compatibility with dotnet standard projects.
- Fix: on the Windows platform, the "Could not find an appropriate font fallback for the following glyphs: $U-000D" exception is thrown when the "QuestPDF.Settings.CheckIfAllTextGlyphsAreAvailable" is set true, and the "TextDescriptor.Line" method is used (that inserts the '\r' character).
- Fix: resolved an issue where the positioning of hyperlinks was incorrect when text contained injected block items.
Version 2024.3.2
- Introduced support for the linux-musl-x64 platform.
- Adjusted how the Lato font is embedded in the NuGet package to prevent issues with the files not being provided on the platform-specific runtimes.
- Improved compatibility with texts that contain the carriage return character '\r'.
- Enhanced exception messages when the FontManager.RegisterFont method fails due to an invalid font file.
- Enhanced the Canvas element deprecation message by adding a link to the documentation.
- Fixed: the SVG image is not always scaled properly, especially when uses relative units internally (percentage, cm, "mm", etc.).
- Fixed a sporadic `AccessViolationException` that occurred when UseEnvironmentFonts was set to `false` and documents were generated in parallel.
- Fixed an issue where dynamic SVG images were not utilizing the available space correctly. This resulted in images with a zero size.
Version 2024.3.3
- Improved the default scaling behavior of Image and SvgImage elements when they are direct descendants of the Constrained element (Width, Height, MinWidth, MinHeight, MaxWidth, MaxHeight).
- Enhanced handling of texts containing the carriage return character '\r' within the custom page format setting.
- Fixed: enhanced the handling of the TextStyle.LineHeight modifier for better consistency with industry-standard software, as well as adjusted the default value.
- Fixed: when the UseEnvironmentFonts setting is enabled, the Lato font was not being properly registered. This issue could lead to runtime exceptions in specific minimal environments.
- Fixed: Addressed a potential null reference exception in the SvgImage object’s finalizer that could lead to application crashes when handling invalid SVG content.
Version 2024.3.4
- Improved font rendering by setting half-leading when line-height is overridden.
- Enhanced exception messages for unsupported x86 platforms.