Blog post

How to build a .NET WinUI3 PDF viewer with Nutrient Web SDK

Illustration: How to build a .NET WinUI3 PDF viewer with Nutrient Web SDK

In this post, you’ll learn how to build a .NET WinUI3 PDF viewer with Nutrient Web SDK.

WinUI 3 is the native UI platform component that ships with the Windows App SDK, which is completely decoupled from Windows SDKs. The Windows App SDK provides a unified set of APIs and tools that can be used to create production desktop apps that target Windows 10 and later and can be published to the Microsoft Store.

Information

You can use similar steps to build a PDF viewer using Nutrient on other .NET platforms like WPF, WinForms, and anything else that supports WebView2.

Prerequisites

  • Windows 10 or later

  • Visual Studio or Visual Studio Code (this tutorial uses Visual Studio)

  • Select the Windows application development component in the installer when installing Visual Studio.

windows application development component

Follow the steps outlined below to build a WinUI3 PDF viewer with Nutrient Web SDK.

Creating a new project

  1. Open Visual Studio.

  2. Choose Create New Project.

  3. Choose Blank App, Packaged (WinUI 3 in Desktop) from the list. project type

  4. Click Next.

  5. Under Project name, enter PSPDFKitWinUI3Example. Then, press Create.

  6. Once the new solution is created, the project tree will look like what’s shown in the following image. initial project structure

Adding Nutrient

  1. Download the latest Nutrient Web SDK.

  2. Extract the ZIP file and copy the contents of package/dist to the Assets folder.

Displaying a PDF in WinUI3

  1. Add the PDF document you want to display, e.g. document.pdf, in the Assets folder.

  2. Add the index.html file to the Assets folder, and add the following code to the index.html file:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<meta
			name="viewport"
			content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"
		/>
		<title>Nutrient Example App</title>

		<style>
			html,
			body {
				margin: 0;
				padding: 0;
				background: #f6f7fa;
			}

			header {
				display: none;
			}

			#root {
				width: 100vw;
				height: 100vh;
			}
		</style>
	</head>

	<body>
		<header></header>
		<div id="root"></div>

		<script src="./pspdfkit.js"></script>

		<script type="module">
			let instance = null;

			async function load(document) {
				if (instance) {
					PSPDFKit.unload(instance);
					hasUnsavedAnnotations = false;
					instance = null;
				}

				const configuration = {
					document,
					container: '#root',
					// Add when using a license key.
					// licenseKey: "LICENSE KEY GOES HERE",
				};

				instance = await PSPDFKit.load(configuration);
			}

			window.onload = () => load('./document.pdf');
		</script>
	</body>
</html>
  1. Double-click the project name to access the project file (PSPDFKitWinUI3Example.csproj) and replace the following:

<ItemGroup>
  <Content Include="Assets\SplashScreen.scale-200.png" />
  <Content Include="Assets\LockScreenLogo.scale-200.png" />
  <Content Include="Assets\Square150x150Logo.scale-200.png" />
  <Content Include="Assets\Square44x44Logo.scale-200.png" />
  <Content Include="Assets\Square44x44Logo.targetsize-24_altform-unplated.png" />
  <Content Include="Assets\StoreLogo.png" />
  <Content Include="Assets\Wide310x150Logo.scale-200.png" />
</ItemGroup>

With this:

<ItemGroup>
  <Content Include="Assets\**\*" />
</ItemGroup>
  1. Replace the contents of the MainPage Window with:

<WebView2 x:Name="WebView" Loaded="WebView_Loaded" />
  1. Add the Loaded event handler in the MainPage.xaml.cs file to open index.html and display the PDF:

private async void WebView_Loaded(object sender, RoutedEventArgs e)
{
    await WebView.EnsureCoreWebView2Async();

    // Set the virtual host for the assets folder.
    WebView.CoreWebView2.SetVirtualHostNameToFolderMapping(
        "pspdfkit-example",
        "Assets",
        Microsoft.Web.WebView2.Core.CoreWebView2HostResourceAccessKind.Deny);

    WebView.CoreWebView2.Navigate("https://pspdfkit-example/index.html");
}

Running the application

  1. Press F5 to run the application.

  2. The application will open with the PDF document displayed in the WebView2 control.

    PDF displayed in WebView2 control

Sample code

The code for the example in this post can be found in our PSPDFKit-labs GitHub repository.

Conclusion

In this post, you learned how to build a WinUI3 PDF viewer with Nutrient Web SDK. You can use similar steps to build a PDF viewer using Nutrient on other .NET platforms like WPF and WinForms, or anything that supports WebView2.

Author
Shantanu Methikar
Shantanu Methikar .NET Engineer

Shantanu likes to explore and experiment — be it with technology, traveling, food, or almost anything else.

Free trial Ready to get started?
Free trial