LaTeX vers l'image | Aspose.TeX pour .NET
Aspose.TeX pour .NET nous permet de convertir des fichiers LaTeX vers un certain nombre de formats d’images raster.
Comment convertir LaTeX en PNG
Examinons en détail le code en C# fournissant le moyen le plus simple de convertir LaTeX au format PNG.
1// Create conversion options for Object LaTeX format upon Object TeX engine extension.
2TeXOptions options = TeXOptions.ConsoleAppOptions(TeXConfig.ObjectLaTeX);
3// Specify a file system working directory for the output.
4options.OutputWorkingDirectory = new OutputFileSystemDirectory(RunExamples.OutputDirectory);
5// Initialize the options for saving in PNG format.
6options.SaveOptions = new PngSaveOptions();
7// Run LaTeX to PNG conversion.
8new TeXJob(Path.Combine(RunExamples.InputDirectory, "hello-world.ltx"), new ImageDevice(), options).Run();
Ainsi, la première chose que nous devons faire (enfin, parfois pas la toute première) est de créer une instance de la classe TeXOptions. La seule méthode statique qui fait cela est ConsoleAppOptions(), alors ne soyons pas intrigués par la signification de son nom. La méthode prend l’ instance ObjectLaTeX de la classe TeXConfig, qui convient parfaitement à la conversion d’un fichier LaTeX. Cette configuration indique au moteur Object TeX de charger le format Object LaTeX et d’être prêt à accepter le fichier LaTeX. Le format Object LaTeX n’est en fait que le format LaTeX, sauf qu’il utilise des primitives spécifiques à Object TeX pour configurer les métriques de la page.
La première des options requises est OutputWorkingDirectory qui définit l’espace, ou la zone, où la sortie TeX sera écrite. Ici sont les détails sur le concept de répertoire de sortie dans Aspose.TeX pour .NET. Dans cet exemple, nous utilisons la classe OutputFileSystemDirectory, qui nous permet d’écrire la sortie dans le répertoire ou dossier spécifié.
La deuxième option est une instance de classe SaveOptions qui contrôlera la transformation du modèle objet au format cible. Puisque nous convertissons LaTeX en PNG, c’est l’instance de classe PngSaveOptions, qui nous permet de spécifier la résolution des images de sortie.
Ensuite, nous devons créer une instance de la classe TeXJob. Voulant convertir un fichier LaTeX stocké dans le système de fichiers, nous utilisons cette version du constructeur. Nous devons spécifier le chemin complet du fichier. Sinon, le moteur le recherchera dans le répertoire courant (qui est CurrentDirectory) et ne le trouvera probablement pas. Néanmoins, l’extension .tex peut être omise. Le moteur l’ajoutera automatiquement. Le deuxième argument du constructeur est une instance de classe Device. Puisque nous convertissons LaTeX en PNG, il s’agit d’une instance de classe ImageDevice, et ceci est commun à tous les formats d’image pris en charge. Comme dernier argument, nous passons les options de conversion récemment préparées.
Il ne reste plus qu’à exécuter le travail.
Que l’exécution ait réussi ou non, le premier résultat que nous verrons sera la sortie du terminal. Si l’exécution a réussi, cela ressemblera à ceci :
1This is ObjectTeX, Version 3.1415926-1.0 (Aspose.TeX 21.8)
2entering extended mode
3
4(<input_directory>\hello-world.ltx
5LaTeX2e <2011/06/27>
6(article.cls
7Document Class: article 2007/10/19 v1.4h Standard LaTeX document class
8(size10.clo))
9No file hello-world.aux.
10[1]
11(<output_directory>\hello-world.aux) )
12Output written on hello-world.png (1 page).
13Transcript written on hello-world.log.
Nous retrouverons d’autres “fruits” du travail du moteur dans le dossier que nous avons spécifié comme répertoire de sortie. Il s’agira du fichier de transcription et, le voici !, du ou des fichiers image PNG de sortie principaux.
Une autre façon d’écrire le(s) fichier(s) PNG de sortie principal
Il existe une autre façon d’obtenir des données d’image sous forme de tableau de tableaux d’octets, chaque tableau de la deuxième dimension représente les données d’image d’une page distincte.
1// Create conversion options instance.
2...
3// Initialize the options for saving in PNG format.
4PngSaveOptions pngSaveOptions = new PngSaveOptions();
5pngSaveOptions.DeviceWritesImages = false;
6options.SaveOptions = pngSaveOptions;
7// Create the image device.
8ImageDevice device = new ImageDevice();
9// Run LaTeX to PNG conversion.
10new TeXJob(Path.Combine(RunExamples.InputDirectory, "hello-world.ltx"), device, options).Run();
11
12// Save pages file by file.
13for (int i = 0; i < device.Result.Length; i++)
14{
15 using (Stream fs = File.Open(Path.Combine(RunExamples.OutputDirectory, $"page-{i + 1}.png"), FileMode.Create))
16 fs.Write(device.Result[i], 0, device.Result[i].Length);
17}
Le(s) fichier(s) “page-n.png” seront écrits dans n’importe quel chemin que nous spécifions. Contrairement à Sortie PDF, ils dupliqueront les fichiers PNG de sortie écrits dans le répertoire de sortie.
À propos des options de saisie
Dans le cas où notre fichier d’entrée principal nécessite des dépendances, par exemple des packages, qui ne sont pas inclus dans le système LaTeX de base et les packages pris en charge, nous DEVONS définir l’option
RequiredInputDirectory de la même manière que nous définissons
OutputWorkingDirectory. option et placez les dépendances dans ce répertoire. Les dépendances peuvent être arbitrairement organisées en sous-répertoires. Dans le cas où nous avons nos propres fichiers à inclure tout au long du processus de composition, par exemple des fichiers graphiques externes, nous DEVONS également définir le
InputWorkingDirectory en utilisant le chemin d’accès à l’emplacement où ces fichiers sont collectés. Nous pouvons également placer le fichier d’entrée principal quelque part dans le répertoire d’entrée et spécifier le chemin relatif dans la méthode run()
(ou ne spécifier aucun chemin si le fichier d’entrée principal est à la racine).
Ici sont les détails sur le concept de répertoire d’entrée dans Aspose.TeX pour .NET et les implémentations fournies.
D’autres options de travail TeX sont discutées ici.
Vous pouvez également consulter la conversion gratuite LaTeX vers PNG application Web construite sur la base de Aspose.TeX pour l’API .NET.
Ci-dessous, nous discutons de la conversion de LaTeX vers d’autres formats d’image raster pris en charge sans entrer dans les détails car il n’y a en réalité aucun détail. La seule différence réside dans le type de la propriété SaveOptions dans les options de conversion.
Comment convertir LaTeX en JPG
1// Create conversion options instance.
2...
3// Initialize the options for saving in JPEG format.
4options.SaveOptions = new JpegSaveOptions();
Vous pouvez également consulter la conversion gratuite LaTeX vers JPG application Web construite sur la base de Aspose.TeX pour l’API .NET.
Comment convertir LaTeX en TIFF
1// Create conversion options instance.
2...
3// Initialize the options for saving in TIFF format.
4options.SaveOptions = new TiffSaveOptions();
Vous pouvez également consulter la conversion gratuite LaTeX vers TIFF application Web construite sur la base de Aspose.TeX pour l’API .NET.
Comment convertir LaTeX en BMP
1// Create conversion options instance.
2...
3// Initialize the options for saving in BMP format.
4options.SaveOptions = new BmpSaveOptions();
Vous pouvez également consulter la conversion gratuite LaTeX vers BMP application Web construite sur la base de Aspose.TeX pour l’API .NET.
Comment convertir LaTeX en SVG
Et encore un autre format cible pris en charge est SVG. Scalable Vector Graphics (SVG) est un format d’image vectorielle basé sur XML permettant de définir des graphiques bidimensionnels, prenant en charge l’interactivité et l’animation.
Les images SVG sont définies dans un format graphique vectoriel et stockées dans des fichiers texte XML. Les images SVG peuvent ainsi être redimensionnées sans perte de qualité, et les fichiers SVG peuvent être recherchés, indexés, scriptés et compressés. Les fichiers texte XML peuvent être créés et modifiés avec des éditeurs de texte ou des éditeurs de graphiques vectoriels, et sont rendus par les navigateurs Web les plus utilisés.
Il existe la bibliothèque Aspose.SVG qui fournit diverses fonctionnalités liées à SVG. Ceux-ci incluent la création, le chargement, l’édition et la conversion de documents SVG.
La conversion LaTeX en SVG est également aussi simple que la conversion aux formats d’image raster, sauf que les SaveOptions DOIVENT être définies sur une instance de classe SvgSaveOptions, et le périphérique DOIT être remplacé par une instance de la classe SvgDevice.
1// Create conversion options for Object LaTeX format upon Object TeX engine extension.
2TeXOptions options = TeXOptions.ConsoleAppOptions(TeXConfig.ObjectLaTeX);
3// Specify a file system working directory for the output.
4options.OutputWorkingDirectory = new OutputFileSystemDirectory(RunExamples.OutputDirectory);
5// Initialize the options for saving in SVG format.
6options.SaveOptions = new SvgSaveOptions();
7// Run LaTeX to SVG conversion.
8new TeXJob(Path.Combine(RunExamples.InputDirectory, "hello-world.ltx"), new PdfDevice(), options).Run();
Vous pouvez également consulter la conversion gratuite LaTeX vers SVG application Web construite sur la base de Aspose.TeX pour l’API .NET.