Test dans un environnement réel
Test en production sans filigrane.
Fonctionne partout où vous en avez besoin.
.NET MAUI est la nouvelle génération de .NET qui permet aux développeurs de créer des applications multiplateformes de bureau, Web et mobiles, y compris Xamarin.Forms, avec une base de code unique. Avec.NET MAUIvous pouvez écrire votre application une seule fois et la déployer sur plusieurs plateformes, y compris Windows, macOS, iOS, Android et tvOS, avec le même nom de projet. .NET MAUI vous permet également de tirer parti des dernières fonctionnalités d'interface utilisateur de chaque plateforme, telles que le mode sombre et la prise en charge du tactile sur macOS, ou la reconnaissance vocale sur Windows 10.
Cet article explique comment utiliser IronPDF dans l'application .NET MAUI pour créer des documents PDF avec de nombreux avantages.
IronPDF est une bibliothèque .NET qui permet de générer et d'éditer des fichiers PDF. Il est parfait pour les applications .NET MAUI, car il offre un large éventail de fonctionnalités qui peuvent être personnalisées pour répondre à vos besoins spécifiques. Grâce à son API facile à utiliser, IronPDF facilite l'intégration de la fonctionnalité PDF dans votre projet .NET MAUI.
Il existe certaines conditions préalables à la création de PDF et de visualiseurs de PDF dans .NET MAUI à l'aide d'IronPDF :
La dernière version de Visual Studio
.NET Framework 6 ou 7
Paquets MAUI installés dans Visual Studio
L'une des meilleures façons d'installer IronPDF dans un nouveau projet est d'utiliser la console NuGet Package Manager dans Visual Studio. Cette méthode d'installation d'IronPDF présente certains avantages.
Tout d'abord, ouvrez la console du gestionnaire de paquets en allant dans Tools > NuGet Package Manager > Package Manager Console.
Console de gestion des paquets
Ensuite, tapez la commande suivante :
Install-Package IronPdf
Ceci installera le paquet et toutes ses dépendances comme le dossier assets
.
Installation d'IronPDF
Vous pouvez maintenant commencer à utiliser IronPDF dans votre projet MAUI.
Tout d'abord, créez une mise en page pour trois fonctionnalités d'IronPDF.
Pour la mise en page URL vers PDF, créez une étiquette avec le texte "Entrez l'URL pour convertir le PDF" à l'aide d'un contrôle d'étiquette MAUI .NET. Ensuite, appliquez une disposition en pile horizontale pour disposer le contrôle d'entrée et le bouton horizontalement. Ensuite, placez une ligne après les contrôles pour diviser la section suivante de contrôles.
<Label
Text="Enter URL to Convert PDF"
SemanticProperties.HeadingLevel="Level1"
FontSize="18"
HorizontalOptions="Center"
/>
<HorizontalStackLayout
HorizontalOptions="Center">
<Border Stroke="White"
StrokeThickness="2"
StrokeShape="RoundRectangle 5,5,5,5"
HorizontalOptions="Center">
<Entry
x:Name="URL"
HeightRequest="50"
WidthRequest="300"
HorizontalOptions="Center"
/>
</Border>
<Button
x:Name="urlPDF"
Text="Convert URL to PDF"
Margin="30,0,0,0"
Clicked="UrlToPdf"
HorizontalOptions="Center" />
</HorizontalStackLayout>
<Line Stroke="White" X2="1500" />
Pour la mise en page de la section HTML vers PDF, créez un contrôle Éditeur et un bouton. Le contrôle de l'éditeur sera utilisé pour accepter une chaîne de contenu HTML de la part de l'utilisateur. En outre, ajoutez une ligne de séparation.
<Label
Text="Enter HTML to Convert to PDF"
SemanticProperties.HeadingLevel="Level2"
FontSize="18"
HorizontalOptions="Center" />
<Border
Stroke="White"
StrokeThickness="2"
StrokeShape="RoundRectangle 5,5,5,5"
HorizontalOptions="Center">
<Editor
x:Name="HTML"
HeightRequest="200"
WidthRequest="300"
HorizontalOptions="Center"
/>
</Border>
<Button
x:Name="htmlPDF"
Text="Convert HTML to PDF"
Clicked="HtmlToPdf"
HorizontalOptions="Center" />
<Line Stroke="White" X2="1500" />
Pour les fichiers HTML vers PDF, ajoutez un seul bouton. Ce bouton permet de convertir un fichier HTML en document PDF à l'aide d'IronPDF.
<Label
Text="Convert HTML file to PDF"
SemanticProperties.HeadingLevel="Level2"
FontSize="18"
HorizontalOptions="Center" />
<Button
x:Name="htmlFilePDF"
Text="Convert HTML file to PDF"
Clicked="FileToPdf"
HorizontalOptions="Center" />
Le code source complet de l'interface MAUI .NET est donné ci-dessous.
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="PDF_Viewer.MainPage">
<ScrollView>
<VerticalStackLayout
Spacing="25"
Padding="30,0"
VerticalOptions="Center">
<Label
Text="Enter URL to Convert PDF"
SemanticProperties.HeadingLevel="Level1"
FontSize="18"
HorizontalOptions="Center"
/>
<HorizontalStackLayout
HorizontalOptions="Center">
<Border Stroke="White"
StrokeThickness="2"
StrokeShape="RoundRectangle 5,5,5,5"
HorizontalOptions="Center">
<Entry
x:Name="URL"
HeightRequest="50"
WidthRequest="300"
HorizontalOptions="Center"
/>
</Border>
<Button
x:Name="urlPDF"
Text="Convert URL to PDF"
Margin="30,0,0,0"
Clicked="UrlToPdf"
HorizontalOptions="Center" />
</HorizontalStackLayout>
<Line Stroke="White" X2="1500" />
<Label
Text="Enter HTML to Convert to PDF"
SemanticProperties.HeadingLevel="Level2"
FontSize="18"
HorizontalOptions="Center" />
<Border
Stroke="White"
StrokeThickness="2"
StrokeShape="RoundRectangle 5,5,5,5"
HorizontalOptions="Center">
<Editor
x:Name="HTML"
HeightRequest="200"
WidthRequest="300"
HorizontalOptions="Center"
/>
</Border>
<Button
x:Name="htmlPDF"
Text="Convert HTML to PDF"
Clicked="HtmlToPdf"
HorizontalOptions="Center" />
<Line Stroke="White" X2="1500" />
<Label
Text="Convert HTML file to PDF"
SemanticProperties.HeadingLevel="Level2"
FontSize="18"
HorizontalOptions="Center" />
<Button
x:Name="htmlFilePDF"
Text="Convert HTML file to PDF"
Clicked="FileToPdf"
HorizontalOptions="Center" />
</VerticalStackLayout>
</ScrollView>
</ContentPage>
.NET MAUI ne dispose d'aucune fonction prédéfinie permettant d'enregistrer des fichiers dans la mémoire locale. Il est donc nécessaire d'écrire le code nous-mêmes. Pour créer la fonctionnalité de sauvegarde et de visualisation, une classe partielle nommée SaveService
est créée avec une fonction vide partielle nommée SaveAndView
avec trois paramètres : le nom du fichier, le type de contenu du fichier, et le flux de mémoire pour écrire le fichier.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace PDF_Viewer
{
public partial class SaveService
{
public partial void SaveAndView(string filename, string contentType, MemoryStream stream);
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace PDF_Viewer
{
public partial class SaveService
{
public partial void SaveAndView(string filename, string contentType, MemoryStream stream);
}
}
Imports System
Imports System.Collections.Generic
Imports System.Linq
Imports System.Text
Imports System.Threading.Tasks
Namespace PDF_Viewer
Partial Public Class SaveService
Public Partial Private Sub SaveAndView(ByVal filename As String, ByVal contentType As String, ByVal stream As MemoryStream)
End Sub
End Class
End Namespace
La fonctionnalité d'enregistrement et de visualisation devra être mise en œuvre pour chaque plateforme qui a l'intention de prendre en charge les éléments suivants(par exemple pour Android, macOS et/ou Windows). Pour la plateforme Windows, créez un fichier nommé "SaveWindows.cs" et implémentez la méthode partielle SaveAndView
:
using Windows.Storage;
using Windows.Storage.Pickers;
using Windows.Storage.Streams;
using Windows.UI.Popups;
namespace PDF_Viewer
{
public partial class SaveService
{
public async partial void SaveAndView(string filename, string contentType, MemoryStream stream)
{
StorageFile stFile;
string extension = Path.GetExtension(filename);
//Gets process windows handle to open the dialog in application process.
IntPtr windowHandle = System.Diagnostics.Process.GetCurrentProcess().MainWindowHandle;
if (!Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.Phone.UI.Input.HardwareButtons"))
{
//Creates file save picker to save a file.
FileSavePicker savePicker = new FileSavePicker();
savePicker.DefaultFileExtension = ".pdf";
savePicker.SuggestedFileName = filename;
//Saves the file as PDF file.
savePicker.FileTypeChoices.Add("PDF", new List<string>() { ".pdf" });
WinRT.Interop.InitializeWithWindow.Initialize(savePicker, windowHandle);
stFile = await savePicker.PickSaveFileAsync();
}
else
{
StorageFolder local = ApplicationData.Current.LocalFolder;
stFile = await local.CreateFileAsync(filename, CreationCollisionOption.ReplaceExisting);
}
if (stFile != null)
{
using (IRandomAccessStream zipStream = await stFile.OpenAsync(FileAccessMode.ReadWrite))
{
//Writes compressed data from memory to file.
using Stream outstream = zipStream.AsStreamForWrite();
outstream.SetLength(0);
//Saves the stream as file.
byte [] buffer = stream.ToArray();
outstream.Write(buffer, 0, buffer.Length);
outstream.Flush();
}
//Create message dialog box.
MessageDialog msgDialog = new("Do you want to view the document?", "File has been created successfully");
UICommand yesCmd = new("Yes");
msgDialog.Commands.Add(yesCmd);
UICommand noCmd = new("No");
msgDialog.Commands.Add(noCmd);
WinRT.Interop.InitializeWithWindow.Initialize(msgDialog, windowHandle);
//Showing a dialog box.
IUICommand cmd = await msgDialog.ShowAsync();
if (cmd.Label == yesCmd.Label)
{
//Launch the saved file.
await Windows.System.Launcher.LaunchFileAsync(stFile);
}
}
}
}
}
using Windows.Storage;
using Windows.Storage.Pickers;
using Windows.Storage.Streams;
using Windows.UI.Popups;
namespace PDF_Viewer
{
public partial class SaveService
{
public async partial void SaveAndView(string filename, string contentType, MemoryStream stream)
{
StorageFile stFile;
string extension = Path.GetExtension(filename);
//Gets process windows handle to open the dialog in application process.
IntPtr windowHandle = System.Diagnostics.Process.GetCurrentProcess().MainWindowHandle;
if (!Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.Phone.UI.Input.HardwareButtons"))
{
//Creates file save picker to save a file.
FileSavePicker savePicker = new FileSavePicker();
savePicker.DefaultFileExtension = ".pdf";
savePicker.SuggestedFileName = filename;
//Saves the file as PDF file.
savePicker.FileTypeChoices.Add("PDF", new List<string>() { ".pdf" });
WinRT.Interop.InitializeWithWindow.Initialize(savePicker, windowHandle);
stFile = await savePicker.PickSaveFileAsync();
}
else
{
StorageFolder local = ApplicationData.Current.LocalFolder;
stFile = await local.CreateFileAsync(filename, CreationCollisionOption.ReplaceExisting);
}
if (stFile != null)
{
using (IRandomAccessStream zipStream = await stFile.OpenAsync(FileAccessMode.ReadWrite))
{
//Writes compressed data from memory to file.
using Stream outstream = zipStream.AsStreamForWrite();
outstream.SetLength(0);
//Saves the stream as file.
byte [] buffer = stream.ToArray();
outstream.Write(buffer, 0, buffer.Length);
outstream.Flush();
}
//Create message dialog box.
MessageDialog msgDialog = new("Do you want to view the document?", "File has been created successfully");
UICommand yesCmd = new("Yes");
msgDialog.Commands.Add(yesCmd);
UICommand noCmd = new("No");
msgDialog.Commands.Add(noCmd);
WinRT.Interop.InitializeWithWindow.Initialize(msgDialog, windowHandle);
//Showing a dialog box.
IUICommand cmd = await msgDialog.ShowAsync();
if (cmd.Label == yesCmd.Label)
{
//Launch the saved file.
await Windows.System.Launcher.LaunchFileAsync(stFile);
}
}
}
}
}
Imports Windows.Storage
Imports Windows.Storage.Pickers
Imports Windows.Storage.Streams
Imports Windows.UI.Popups
Namespace PDF_Viewer
Partial Public Class SaveService
Public Async Sub SaveAndView(ByVal filename As String, ByVal contentType As String, ByVal stream As MemoryStream)
Dim stFile As StorageFile
Dim extension As String = Path.GetExtension(filename)
'Gets process windows handle to open the dialog in application process.
Dim windowHandle As IntPtr = System.Diagnostics.Process.GetCurrentProcess().MainWindowHandle
If Not Windows.Foundation.Metadata.ApiInformation.IsTypePresent("Windows.Phone.UI.Input.HardwareButtons") Then
'Creates file save picker to save a file.
Dim savePicker As New FileSavePicker()
savePicker.DefaultFileExtension = ".pdf"
savePicker.SuggestedFileName = filename
'Saves the file as PDF file.
savePicker.FileTypeChoices.Add("PDF", New List(Of String)() From {".pdf"})
WinRT.Interop.InitializeWithWindow.Initialize(savePicker, windowHandle)
stFile = Await savePicker.PickSaveFileAsync()
Else
Dim local As StorageFolder = ApplicationData.Current.LocalFolder
stFile = Await local.CreateFileAsync(filename, CreationCollisionOption.ReplaceExisting)
End If
If stFile IsNot Nothing Then
Using zipStream As IRandomAccessStream = Await stFile.OpenAsync(FileAccessMode.ReadWrite)
'Writes compressed data from memory to file.
Using outstream As Stream = zipStream.AsStreamForWrite()
outstream.SetLength(0)
'Saves the stream as file.
Dim buffer() As Byte = stream.ToArray()
outstream.Write(buffer, 0, buffer.Length)
outstream.Flush()
End Using
End Using
'Create message dialog box.
Dim msgDialog As New MessageDialog("Do you want to view the document?", "File has been created successfully")
Dim yesCmd As New UICommand("Yes")
msgDialog.Commands.Add(yesCmd)
Dim noCmd As New UICommand("No")
msgDialog.Commands.Add(noCmd)
WinRT.Interop.InitializeWithWindow.Initialize(msgDialog, windowHandle)
'Showing a dialog box.
Dim cmd As IUICommand = Await msgDialog.ShowAsync()
If cmd.Label = yesCmd.Label Then
'Launch the saved file.
Await Windows.System.Launcher.LaunchFileAsync(stFile)
End If
End If
End Sub
End Class
End Namespace
Pour Android et macOS, vous devez créer des fichiers séparés avec des implémentations SaveAndView
comparables. Vous pouvez obtenir un exemple de fonctionnement à partir de cette pageMAUI PDF Viewer GitHub Repo.
Il est maintenant temps d'écrire le code pour les fonctionnalités PDF. Commençons par la fonctionnalité URL vers PDF.
Créer une fonction UrlToPdf
pour la fonctionnalité URL vers PDF. À l'intérieur de la fonction, instanciez leChromePdfRenderer
et utiliser l'objetRenderUrlAsPdf
(RenderUrlAsPdf) pour convertir les URL en documents PDF. La fonction RenderUrlAsPdf
récupère les données de l'URL depuis le serveur web et les traite pour les convertir en document PDF. En paramètres, passez le texte dans le contrôle d'entrée URL, créez un objet de la classe SaveService
et utilisez la fonction SaveAndView
. Dans les paramètres de la fonction SaveAndView
, passez le flux du fichier PDF généré.
La fonction SaveAndView
permet d'enregistrer les fichiers dans un chemin personnalisé et offre la possibilité de visualiser les fichiers PDF. Enfin, affichez une boîte d'alerte contenant des informations sur la création du fichier PDF. Si un utilisateur tente de créer un fichier PDF avec un contrôle d'entrée vide, une boîte d'alerte s'affiche avec un message d'erreur et un avertissement.
private void UrlToPdf(object sender, EventArgs e)
{
if (URL.Text != null)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf(URL.Text.Trim());
SaveService saveService = new SaveService();
saveService.SaveAndView("URLtoPDF.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from URL Created!", "OK");
}
else
{
DisplayAlert("Error", "Field can't be empty! \nPlease enter URL!", "OK");
}
}
private void UrlToPdf(object sender, EventArgs e)
{
if (URL.Text != null)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderUrlAsPdf(URL.Text.Trim());
SaveService saveService = new SaveService();
saveService.SaveAndView("URLtoPDF.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from URL Created!", "OK");
}
else
{
DisplayAlert("Error", "Field can't be empty! \nPlease enter URL!", "OK");
}
}
Imports Microsoft.VisualBasic
Private Sub UrlToPdf(ByVal sender As Object, ByVal e As EventArgs)
If URL.Text IsNot Nothing Then
Dim renderer = New IronPdf.ChromePdfRenderer()
Dim pdf = renderer.RenderUrlAsPdf(URL.Text.Trim())
Dim saveService As New SaveService()
saveService.SaveAndView("URLtoPDF.pdf", "application/pdf", pdf.Stream)
DisplayAlert("Success", "PDF from URL Created!", "OK")
Else
DisplayAlert("Error", "Field can't be empty! " & vbLf & "Please enter URL!", "OK")
End If
End Sub
Pour convertir le HTML en PDF, créez la fonction HtmlToPdf
et utilisez la fonctionRenderHtmlAsPdf
(RenduHtmlAsPdf) fonction. Utilisez le texte du contrôle Editor et passez-le dans les paramètres de la fonction RenderHtmlAsPdf
. Comme pour la fonction précédente, utilisez la fonction SaveAndView
pour activer la fonctionnalité de visualisation du fichier PDF après l'avoir enregistré.
private void HtmlToPdf(object sender, EventArgs e)
{
if (HTML.Text != null)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(HTML.Text);
SaveService saveService = new SaveService();
saveService.SaveAndView("IronPDF HTML string.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from HTML Created!", "OK");
}
else
{
DisplayAlert("Error", "Field can't be empty! \nPlease enter valid HTML!", "OK");
}
}
private void HtmlToPdf(object sender, EventArgs e)
{
if (HTML.Text != null)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(HTML.Text);
SaveService saveService = new SaveService();
saveService.SaveAndView("IronPDF HTML string.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from HTML Created!", "OK");
}
else
{
DisplayAlert("Error", "Field can't be empty! \nPlease enter valid HTML!", "OK");
}
}
Imports Microsoft.VisualBasic
Private Sub HtmlToPdf(ByVal sender As Object, ByVal e As EventArgs)
If HTML.Text IsNot Nothing Then
Dim renderer = New IronPdf.ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(HTML.Text)
Dim saveService As New SaveService()
saveService.SaveAndView("IronPDF HTML string.pdf", "application/pdf", pdf.Stream)
DisplayAlert("Success", "PDF from HTML Created!", "OK")
Else
DisplayAlert("Error", "Field can't be empty! " & vbLf & "Please enter valid HTML!", "OK")
End If
End Sub
Créez la fonction FileToPdf
pour convertir les fichiers HTML en fichiers PDF, utilisez la fonctionRenderHtmlFileAsPdf
(Rendre le fichier HTML sous forme de fichier PDF) et transmet le chemin d'accès au fichier HTML en tant que paramètre. Il convertit tout le contenu HTML en PDF et enregistre le fichier de sortie.
private void FileToPdf(object sender, EventArgs e)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderHtmlFileAsPdf(@"C:\Users\Administrator\Desktop\index.html");
SaveService saveService = new SaveService();
saveService.SaveAndView("HTML File to PDF.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from File Created!", "OK");
}
private void FileToPdf(object sender, EventArgs e)
{
var renderer = new IronPdf.ChromePdfRenderer();
var pdf = renderer.RenderHtmlFileAsPdf(@"C:\Users\Administrator\Desktop\index.html");
SaveService saveService = new SaveService();
saveService.SaveAndView("HTML File to PDF.pdf", "application/pdf", pdf.Stream);
DisplayAlert("Success", "PDF from File Created!", "OK");
}
Private Sub FileToPdf(ByVal sender As Object, ByVal e As EventArgs)
Dim renderer = New IronPdf.ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlFileAsPdf("C:\Users\Administrator\Desktop\index.html")
Dim saveService As New SaveService()
saveService.SaveAndView("HTML File to PDF.pdf", "application/pdf", pdf.Stream)
DisplayAlert("Success", "PDF from File Created!", "OK")
End Sub
Après l'exécution du projet, le résultat sera le suivant.
Sortie
Inscrivez l'URL du site web de Microsoft dans cette section et cliquez sur le bouton.
URL to PDF (en anglais)
Après avoir créé le fichier PDF, il affiche une boîte de dialogue pour enregistrer le fichier sur la destination personnalisée.
Enregistrer le fichier
Après avoir enregistré le fichier, cette fenêtre contextuelle s'affiche et offre la possibilité de sélectionner le visualiseur PDF pour afficher le fichier PDF.
PDF Viewer Popup
IronPDF convertit l'URL en PDF de manière remarquable. Il préserve toutes les couleurs et les images dans leur forme et leur format d'origine.
PDF Viewer Popup
La même procédure doit être suivie pour toutes les autres fonctionnalités. Consultez ce documentIronPDF en Blazor Blog Post pour en savoir plus sur le travail d'IronPDF dans Blazor.
Apprenez à convertir une page MAUI en XAML en un document PDF en visitant "Comment convertir XAML en PDF dans MAUI".
Ce tutoriel a utilisé IronPDF dans l'application .NET MAUI pour créer un fichier PDF et une visionneuse PDF. Le MAUI .NET est un outil formidable pour créer des applications multiplateformes avec une base de code unique. IronPDF permet de créer et de personnaliser facilement des fichiers PDF dans n'importe quelle application .NET. IronPDF est entièrement compatible avec la plate-forme MAUI .NET.
IronPDF est gratuit pour le développement. Vous pouvez obtenir unclé d'essai gratuite pour tester IronPDF en production. Pour plus d'informations sur IronPDF et ses capacités, veuillez consulter le site web de l'entrepriseSite officiel d'IronPDF.
9 produits de l'API .NET pour vos documents de bureau