LaTeX all'immagine | Aspose.TeX per Python
Aspose.TeX per Python ci fornisce la capacità di convertire i file in LaTeX in vari formati di immagini raster.
Convertire il LaTeX in PNG
Ora, esaminiamo il codice Python che offre l’approccio più semplice alla conversione del formato di LaTeX in PNG in profondità.
1# Create conversion options for Object LaTeX format upon Object TeX engine extension.
2options = TeXOptions.console_app_options(TeXConfig.object_latex)
3# Specify a file system working directory for the output.
4options.output_working_directory = OutputFileSystemDirectory(Util.output_directory)
5# Initialize the options for saving in PNG format.
6options.save_options = PngSaveOptions()
7
8# Run LaTeX to PNG conversion.
9TeXJob(path.join(Util.input_directory, "hello-world.ltx"), ImageDevice(True), options).run()
Per cominciare, dobbiamo creare un’istanza della classe texoptions usando il metodo Console_app_options(). Non preoccuparti del nome, è solo il metodo statico che crea l’istanza. Questo metodo prende l’istanza Object_Latex della classe TexConfig, che è perfetta per convertire un file latex. Questa configurazione imposta il motore Object Tex per caricare il formato Object Latex ed essere pronto a elaborare il file Latex. Il formato di LaTeX oggetto è essenzialmente lo stesso del formato latex, ma utilizza oggetto tex primitive specifiche per definire le metriche di pagina.
La prima delle opzioni necessarie è output_working_directory, che specifica la posizione in cui verrà salvato l’output Tex. Se interessato, puoi conoscere ulteriori informazioni sul concetto di directory di output in Aspose.TeX per python. In questo esempio particolare, utilizziamo la classe OutputFilesystemDirectory per scrivere l’output su una directory o una cartella specifica.
La seconda opzione è un’istanza della classe SaveOptions, che è responsabile della gestione della conversione dal modello a oggetti al formato desiderato. In questo caso, dal momento che stiamo convertendo il LaTeX in PNG, utilizziamo l’istanza di classe PNGSaveOptions, che ci consente di specificare la risoluzione delle immagini di output.
Successivamente, creiamo un’istanza della classe
Texjob. In questo caso, dal momento che vogliamo convertire un file LaTeX memorizzato nel file system, utilizziamo
questa versione del costruttore. Dobbiamo fornire l’intero percorso al file, altrimenti il motore lo cercherà nella directory corrente (che è la directory di lavoro dello script) e potrebbe non trovarlo. Tuttavia, l’estensione .tex
può essere omessa poiché il motore lo aggiungerà automaticamente. Il secondo argomento del costruttore è un’istanza della classe
dispositivo. Dal momento che stiamo convertendo il LaTeX in PNG, è un’istanza di classe
imagevice, che è comune a tutti i formati di immagine supportati. Infine, passiamo le opzioni di conversione preparate come ultimo argomento.
Ora, tutto ciò che rimane è correre il lavoro.
Dopo che il lavoro è stato eseguito, indipendentemente dal suo successo o fallimento, il primo output che incontreremo è l’output del terminale. Nel caso di una corsa riuscita, l’output assomigliarà a quanto segue:
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.
I risultati del lavoro del motore sono disponibili nella directory di output che abbiamo specificato. Ciò includerà il file di trascrizione e, soprattutto, i principali file di immagine PNG di output.
Un modo alternativo per scrivere i file PNG di output principale
Esiste un metodo alternativo per ottenere i dati dell’immagine come array di array di byte, in cui ciascun array nella seconda dimensione rappresenta i dati dell’immagine per una pagina separata.
1# Create conversion options for Object LaTeX format upon Object TeX engine extension.
2options = TeXOptions.console_app_options(TeXConfig.object_latex)
3# Specify a file system working directory for the output.
4options.output_working_directory = OutputFileSystemDirectory(Util.output_directory)
5# Initialize the options for saving in PNG format.
6so = PngSaveOptions()
7so.device_writes_images = False # Run LaTeX to PNG conversion.
8options.save_options = so
9device = ImageDevice(True)
10TeXJob(path.join(Util.input_directory, "hello-world.ltx"), device, options).run()
11
12# Save pages file by file.
13for i in range(len(device.result)):
14 with open(path.join(Util.output_directory, f"page-{(i + 1)}" + ".png"), "wb") as fs:
15 fs.write(device.result[i][0:len(device.result[i])])
I file “Page-N.Png” possono essere scritti su qualsiasi percorso specificato. A differenza di PDF output, questi file PNG duplicheranno i file PNG di output scritti nella directory di output.
Per quanto riguarda le opzioni di input
Se il nostro file di input principale richiede dipendenze, come pacchetti che non sono inclusi nel sistema di base in LaTeX o pacchetti supportati, è necessario impostare l’opzione
Recome_input_directory in modo simile a come impostiamo l’opzione * output_working_directory * e posizionare le dipendenze in quella directory. Le dipendenze possono essere organizzate nelle sottodirectory se necessario. Se abbiamo i nostri file da includere nel processo di composizione, come i file grafici esterni, dobbiamo anche impostare
input_working_directory nella posizione in cui tali file sono archiviati. Possiamo anche posizionare il file di input principale all’interno della directory di input e specificare il percorso relativo nel metodo run()
o specificare alcun percorso se il file di input principale è nella directory di root. Ci sono anche maggiori dettagli sul
concetto di directory di input in aspose.tex e le implementazioni fornite descritte.
Impara anche le altre opzioni di lavoro di Tex qui.
Puoi anche esplorare la conversione gratuita Web App per la conversione da lattoce a PNG, che viene sviluppata utilizzando Aspose.TeX per API .NET.
Di seguito, spiegheremo brevemente la conversione del LaTeX ad altri formati di immagini raster supportati, senza immergersi in troppi dettagli in quanto non vi sono differenze significative. L’unica variazione risiede nel tipo di proprietà Save_options nelle opzioni di conversione.
Convertire il LaTeX in jpg
1# Create conversion options instance.
2...
3# Initialize the options for saving in JPEG format.
4options.save_options = JpegSaveOptions()
Puoi anche esplorare la conversione gratuita app Web per LaTeX a jpg, che viene sviluppata utilizzando Aspose.TeX per .NET API.
Convertire il LaTeX in TIFF
1# Create conversion options instance.
2...
3# Initialize the options for saving in TIFF format.
4options.save_options = TiffSaveOptions()
Puoi anche esplorare la conversione gratuita app Web per LaTeX-tiff, che viene sviluppata utilizzando Aspose.TeX per .NET API.
Convertire il LaTeX in BMP
1# Create conversion options instance.
2...
3# Initialize the options for saving in BMP format.
4options.save_options = BmpSaveOptions()
Puoi anche esplorare la conversione gratuita app Web per LaTeX-a-BMP, che viene sviluppata utilizzando Aspose.TeX per .NET API.
Convertire il LaTeX in SVG
Un altro formato target supportato è svg. Scalable Vector Graphics (SVG) è un formato di immagine vettoriale basato su XML che viene utilizzato per definire la grafica bidimensionale. Supporta l’interattività e l’animazione.
Le immagini SVG sono archiviate in file di testo XML e definite in un formato grafico vettoriale. Ciò significa che le immagini svg possono essere ridimensionate senza perdere la qualità e i file svg stessi possono essere cercati, indicizzati, scritti e compressi. I file di testo XML possono essere creati e modificati utilizzando editor di testo o redattori di grafica vettoriale e possono essere resi dai browser Web più comunemente usati.
L’API Aspose.svg offre una gamma di funzionalità per lavorare con svg, come la creazione, il caricamento, la modifica e la conversione di documenti svg.
La conversione del LaTeX in SVG è semplice quanto la conversione in formati di immagini raster, con l’unica differenza è che i Save_options devono essere impostati su un’istanza della classe SVGSaveOptions e il dispositivo deve essere modificato in un’istanza della classe SvgDevice.
1# Create conversion options for Object LaTeX format upon Object TeX engine extension.
2options = TeXOptions.console_app_options(TeXConfig.object_latex)
3# Specify a file system working directory for the output.
4options.output_working_directory = OutputFileSystemDirectory(Util.output_directory)
5# Initialize the options for saving in SVG format.
6options.save_options = SvgSaveOptions()
7# Run LaTeX to SVG conversion.
8TeXJob(path.join(Util.input_directory, "hello-world.ltx"), SvgDevice(), options).run()
Puoi anche esplorare la conversione gratuita app Web per la latex-a-SVG, che viene sviluppata utilizzando Aspose.TeX per .NET API.