Convertir EPUB en XPS en C#
Dans cet article, vous trouverez des informations sur la manière de convertir EPUB en XPS et sur l’utilisation des paramètres XpsSaveOptions et ICreateStreamProvider.
Convertisseur EPUB en ligne
Vous pouvez vérifier la fonctionnalité de l’API Aspose.HTML for .NET et convertir des EPUB en temps réel. Veuillez charger un fichier EPUB à partir du système de fichiers local, sélectionnez le format de sortie et exécutez l’exemple. Dans l’exemple, les options d’enregistrement sont définies par défaut. Vous recevrez immédiatement le résultat sous la forme d’un fichier séparé.
Si vous souhaitez convertir EPUB en XPS par programme, veuillez consulter les exemples de code C# suivants.
EPUB vers XPS en deux lignes de code
Les méthodes statiques de la classe Converter sont principalement utilisées comme moyen le plus simple de convertir un fichier EPUB dans différents formats. Vous pouvez convertir EPUB en XPS dans votre application C# en deux lignes de code !
1// Convert EPUB to XPS using C#
2
3// Open an existing EPUB file for reading
4using FileStream stream = File.OpenRead(DataDir + "input.epub");
5
6// Invoke the ConvertEPUB() method to convert EPUB to XPS
7Converter.ConvertEPUB(stream, new XpsSaveOptions(), Path.Combine(OutputDir, "convert-by-two-lines.xps"));
Convertir EPUB en XPS
Pour convertir EPUB en XPS, vous devez suivre quelques étapes :
- Ouvrir un fichier EPUB existant. Dans l’exemple, nous utilisons la méthode OpenRead() de la classe System.IO.FileStream pour ouvrir et lire un fichier EPUB à partir du système de fichiers au chemin spécifié.
- Créer une instance de XpsSaveOptions.
- Utilisez la méthode ConvertEPUB() de la classe Converter pour enregistrer un EPUB en tant que fichier XPS. Vous devez transmettre le flux du fichier EPUB, les options XpsSaveOptions et le chemin du fichier de sortie à la méthode ConvertEPUB() pour convertir l’EPUB en XPS.
L’extrait de code C# suivant montre comment convertir un EPUB en XPS à l’aide d’Aspose.HTML for .NET.
1// Convert EPUB to XPS in C#
2
3// Open an existing EPUB file for reading
4using FileStream stream = File.OpenRead(DataDir + "input.epub");
5
6// Prepare a path to save the converted file
7string savePath = Path.Combine(OutputDir, "input-output.xps");
8
9// Create an instance of XpsSaveOptions
10XpsSaveOptions options = new XpsSaveOptions();
11
12// Call the ConvertEPUB() method to convert EPUB to XPS
13Converter.ConvertEPUB(stream, options, savePath);
Vous pouvez télécharger les exemples complets et les fichiers de données sur GitHub.
Sauvegarder les options
Avec Aspose.HTML, vous pouvez convertir EPUB au format XPS de manière programmatique en contrôlant totalement un large éventail de paramètres de conversion. l’utilisation de XpsSaveOptions vous permet de régler le processus de rendu ; vous pouvez spécifier la taille de la page, les marges, les feuilles de style CSS, etc.
Property | Description |
---|---|
PageSetup | This property gets a page setup object and uses it for configuration output page-set. |
Css | Gets a CssOptions object which is used for configuration of CSS properties processing. |
BackgroundColor | This property sets the color that will fill the background of every page. By default, this property is Transparent. |
HorizontalResolution | Sets horizontal resolution for output images in pixels per inch. The default value is 300 dpi. |
VerticalResolution | Sets vertical resolution for output images in pixels per inch. The default value is 300 dpi. |
Pour en savoir plus sur XpsSaveOptions, veuillez lire l’article Convertisseurs à réglage fin.
Convertir EPUB en XPS à l’aide de XpsSaveOptions
Aspose.HTML permet de convertir un EPUB en XPS en utilisant des options d’enregistrement par défaut ou personnalisées. Vous devez suivre quelques étapes :
- Ouvrir un fichier EPUB existant.
- Créez un nouvel objet XpsSaveOptions et spécifiez les options de sauvegarde requises.
- Utilisez la méthode ConvertEPUB() pour enregistrer un EPUB en tant que fichier XPS. Vous devez transmettre le flux du fichier EPUB, les options XpsSaveOptions et le chemin du fichier de sortie à la méthode ConvertEPUB () pour la conversion EPUB vers XPS.
L’exemple suivant montre comment utiliser XpsSaveOptions et créer un fichier XPS avec des options d’enregistrement personnalisées :
1// Convert EPUB to XPS in C# with custom settings
2
3// Open an existing EPUB file for reading
4using FileStream stream = File.OpenRead(DataDir + "input.epub");
5
6// Prepare a path to save the converted file
7string savePath = Path.Combine(OutputDir, "input-options.xps");
8
9// Create an instance of XpsSaveOptions. Set up the page-size and change the background color to LightGray
10XpsSaveOptions options = new XpsSaveOptions()
11{
12 PageSetup =
13 {
14 AnyPage = new Page()
15 {
16 Size = new Aspose.Html.Drawing.Size(Length.FromPixels(500), Length.FromPixels(500))
17 }
18 },
19 BackgroundColor = System.Drawing.Color.LightGray
20};
21
22// Call the ConvertEPUB() method to convert EPUB to XPS
23Converter.ConvertEPUB(stream, options, savePath);
Dans l’exemple, nous utilisons la méthode OpenRead() de la classe System.IO.FileStream pour ouvrir et lire les fichiers source à partir du système de fichiers au chemin spécifié. Le constructeur
XpsSaveOptions() initialise une instance de la classe XpsSaveOptions qui est transmise à la méthode ConvertEPUB(). La méthode ConvertEPUB() prend le stream
, les options
, le chemin du fichier de sortie savePath
et effectue l’opération de conversion. La classe XpsSaveOptions fournit de nombreuses propriétés qui vous donnent un contrôle total sur un large éventail de paramètres et améliorent le processus de conversion EPUB vers XPS.
Dans l’exemple, nous utilisons :
- la propriété
BackgroundColor
qui spécifie la couleur dans laquelle l’arrière-plan sera rempli. La couleur d’arrière-plan par défaut estTransparent
; - propriété
PageSetup
qui spécifie la page size en pixels.
Aspose.HTML for .NET fournit différents types de formats de sortie pour les opérations de rendu. Certains de ces formats produisent un seul fichier de sortie (par exemple PDF, XPS), d’autres créent plusieurs fichiers (formats d’image JPG, PNG, etc.)
Fournisseurs de flux de sortie
S’il est nécessaire d’enregistrer des fichiers dans un espace de stockage distant (par exemple, un nuage, une base de données, etc.), vous pouvez mettre en œuvre l’interface ICreateStreamProvider afin de contrôler manuellement le processus de création de fichiers. Cette interface est conçue comme un objet de rappel pour créer un flux au début du document/de la page (en fonction du format de sortie) et libérer le flux créé au début après le rendu du document/de la page.
L’exemple ci-dessous montre comment mettre en œuvre et utiliser votre propre MemoryStreamProvider dans l’application :
1// Implement a custom MemoryStream provider for advanced control over HTML rendering output streams
2
3class MemoryStreamProvider : Aspose.Html.IO.ICreateStreamProvider
4{
5 // List of MemoryStream objects created during the document rendering
6 public List<MemoryStream> Streams { get; } = new List<MemoryStream>();
7
8 public Stream GetStream(string name, string extension)
9 {
10 // This method is called when only one output stream is required, for instance for XPS, PDF or TIFF formats
11 MemoryStream result = new MemoryStream();
12 Streams.Add(result);
13 return result;
14 }
15
16 public Stream GetStream(string name, string extension, int page)
17 {
18 // This method is called when the creation of multiple output streams are required. For instance, during the rendering HTML to list of image files (JPG, PNG, etc.)
19 MemoryStream result = new MemoryStream();
20 Streams.Add(result);
21 return result;
22 }
23
24 public void ReleaseStream(Stream stream)
25 {
26 // Here you can release the stream filled with data and, for instance, flush it to the hard-drive
27 }
28
29 public void Dispose()
30 {
31 // Releasing resources
32 foreach (MemoryStream stream in Streams)
33 stream.Dispose();
34 }
35}
1// Convert EPUB to XPS in C# using memory stream
2
3// Create an instance of MemoryStreamProvider
4using MemoryStreamProvider streamProvider = new MemoryStreamProvider();
5
6// Open an existing EPUB file for reading
7using FileStream stream = File.OpenRead(DataDir + "input.epub");
8
9// Prepare a path to save the converted file
10string savePath = Path.Combine(OutputDir, "stream-provider.xps");
11
12// Convert EPUB to XPS by using the MemoryStreamProvider class
13Converter.ConvertEPUB(stream, new XpsSaveOptions(), streamProvider);
14
15// Get access to the memory stream that contains the result data
16MemoryStream memory = streamProvider.Streams.First();
17memory.Seek(0, SeekOrigin.Begin);
18
19// Flush the result data to the output file
20using (FileStream fs = File.Create(savePath))
21{
22 memory.CopyTo(fs);
23}
La méthode ConvertEPUB(Stream
, XpsSaveOptions
, ICreateStreamProvider
) prend la source de conversion, les options, et l’instance de MemoryStreamProvider, qui sera utilisée pour obtenir un flux de sortie, et effectue l’opération de conversion.
Aspose.HTML propose un Convertisseur EPUB en XPS gratuit en ligne qui convertit les fichiers EPUB en fichiers XPS avec une grande qualité, facilement et rapidement. Il suffit de télécharger, de convertir vos fichiers et d’obtenir des résultats en quelques secondes !