Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente |
3_composition:illustrations:inclure_une_image:inclure_un_fichier_pdf2 [2021/12/06 12:09] – Début de la traduction. yannick.tanguy | 3_composition:illustrations:inclure_une_image:inclure_un_fichier_pdf2 [2022/09/23 16:44] (Version actuelle) – Suppression d'espace inutile dbitouze |
---|
====== Comment insérer des images avec “pdfLaTeX”? ====== | ====== Comment insérer des images avec “pdfLaTeX”? ====== |
| |
Le programme ''[[1_generalites/glossaire/qu_est_ce_que_pdftex|pdfTeX]]'' lui-même dispose d'une gamme assez large de formats qu'il peut incorporer directement dans son flux PDF de sortie : | ===== Les formats acceptés par défaut ===== |
| |
| Le programme ''[[1_generalites/glossaire/qu_est_ce_que_pdftex|pdfTeX]]'' dispose d'une gamme assez large de formats qu'il peut incorporer directement dans son flux PDF de sortie : |
* JPEG (fichiers ''jpg'') pour les photographies et images similaires ; | * JPEG (fichiers ''jpg'') pour les photographies et images similaires ; |
* PNG pour les images bitmap artificielles ; | * PNG pour les images bitmap artificielles ; |
Les anciennes versions de ''pdfTeX'' (antérieures à la version 1.10a) prenaient en charge le format TIFF (fichiers ''tif'') comme alternative aux fichiers PNG. Mieux vaut ne pas compter sur cette fonctionnalité, même si vous utilisez une version suffisamment ancienne de ''pdfTeX''. | Les anciennes versions de ''pdfTeX'' (antérieures à la version 1.10a) prenaient en charge le format TIFF (fichiers ''tif'') comme alternative aux fichiers PNG. Mieux vaut ne pas compter sur cette fonctionnalité, même si vous utilisez une version suffisamment ancienne de ''pdfTeX''. |
| |
FIXME //Traduire.// | En plus des formats « natifs », la configuration standard de l'extension [[ctanpkg>graphicx]] provoque le chargement des commandes de l'extension [[ctanpkg>pdf-mps-supp]] de [[https://www.ctan.org/author/hagen|Hans Hagen]] : ces commandes sont capables de traduire la sortie de MetaPost en PDF à la volée. Dès lors, la sortie MetaPost (fichiers ''mps'') peut également être incluse dans les documents compliés avec ''pdfLaTeX''. |
| |
In addition to the "native" formats, the standard pdfLaTeX [[ctanpkg>graphics|graphics]] package setup causes Hans Hagen's ''supp-pdf'' macros to be loaded: these macros are capable of translating the output of MetaPost to PDF "on the fly"; thus MetaPost output (''mps'' files) may also be included in pdfLaTeX documents. | ===== Le format Postscript encapsulé (EPS) ===== |
| |
The commonest problem users encounter, when switching from TeX, is that there is no straightforward way to include EPS files : since pdfTeX is its own "driver", and since it contains no means of converting PostScript to PDF, there's no direct way the job can be done. | Le problème le plus couramment rencontré par les utilisateurs est qu'il n'y a pas de moyen simple pour inclure des fichiers [[5_fichiers/postscript/postscript_encapsule|EPS]], ces derniers étant largement utilisés historiquement. Puisque ''pdfTeX'' ne contient en effet aucun moyen de convertir PostScript en PDF. |
| |
The simple solution is to convert the EPS to an appropriate PDF file. The ''epstopdf'' program will do this: it's available either as a Windows executable or as a Perl script to run on Unix and other similar systems. A LaTeX package, [[ctanpkg>epstopdf|epstopdf]], can be used to generate the requisite PDF files "on the fly"; this is convenient, but requires that you suppress one of TeX's security checks: don't allow its use in files from sources you don't entirely trust. | ==== Avec le programme “epstopdf” ==== |
| |
The package [[ctanpkg>pst-pdf|pst-pdf]] permits other things than "mere" graphics files in its argument. [[ctanpkg>Pst-pdf|Pst-pdf]] operates (the authors suggest) "like BibTeX" --- you process your file using pdfLaTeX, then use LaTeX, ''dvips'' and ''ps2pdf'' in succession, to produce a secondary file to input to your next pdfLaTeX run. (Scripts are provided to ease the production of the secondary file.) | La solution classique consiste à convertir le fichier EPS en un fichier PDF approprié. Le programme ''epstopdf'' traite ce point et est disponible soit en tant qu'exécutable Windows, soit en tant que script Perl pour s'exécuter sur Unix et d'autres systèmes similaires. L'extension [[ctanpkg>epstopdf]] peut être utilisée pour générer les fichiers PDF requis à la volée. Si ce principe est bien pratique, il nécessite toutefois que vous supprimiez un des contrôles de sécurité de <latex>\TeX</latex> : n'autorisez donc pas son utilisation avec des fichiers provenant de sources en lesquelles vous n'avez pas entièrement confiance. |
| |
A further extension is [[ctanpkg>auto-pst-pdf|auto-pst-pdf]], which generates PDF (essentially) transparently, by spawning a job to process output such as [[ctanpkg>pst-pdf|pst-pdf]] uses. If your pdfLaTeX installation doesn't automatically allow it --- see [[FAQ-spawnprog|spawning a process]] --- then you need to start pdfLaTeX with : | ==== Avec les extensions “pst-pdf” et “auto-pst-pdf” ==== |
| |
| L'extension [[ctanpkg>pst-pdf]] vous permet d'aller un peu plus loin avec des éléments Postscript. Elle fonctionne un peu comme ''BibTeX'' : vous compilez votre fichier en utilisant ''pdfLaTeX'', puis vous utilisez <latex>\LaTeX</latex>, ''dvips'' et ''ps2pdf'' successivement pour produire un fichier secondaire à saisir pour votre prochaine exécution de ''pdfLaTeX''. Des scripts sont fournis pour faciliter la production du fichier secondaire. |
| |
| Pour sa part, l'extension [[ctanpkg>auto-pst-pdf]] génère un PDF de manière transparente, en générant une tâche pour traiter les sorties comme [[ctanpkg>pst-pdf|pst-pdf]] le fait. Si votre installation de ''pdfLaTeX'' ne le permet pas automatiquement --- voir la question « [[2_programmation/compilation/write18|Comment lancer un sous-processus pendant la compilation ?]] » --- vous devez alors exécuter ''pdfLaTeX'' avec l'instruction suivante (en changeant le nom du ''fichier.tex'') : |
| |
<code latex> | <code latex> |
pdflatex -shell-escape <file> | pdflatex -shell-escape fichier.tex |
</code> | </code> |
| |
for complete "automation". | ==== Avec le programme “purifyeps” ==== |
| |
| Une solution alternative consiste à utiliser ''purifyeps'', un script Perl qui utilise ''pstoedit'' et MetaPost pour convertir votre fichier EPS en « quelque chose qui ressemble au PostScript encapsulé issu de MetaPost » et peut donc être inclus directement. Malheureusement, ''purifyeps'' ne fonctionne pas pour tous les fichiers EPS. |
| |
An alternative solution is to use ''purifyeps'', a Perl script which uses the good offices of ''pstoedit'' and of MetaPost to convert your Encapsulated PostScript to "Something that looks like the encapsulated PostScript that comes out of MetaPost", and can therefore be included directly. Sadly, ''purifyeps'' doesn't work for all ''eps'' files. | ==== Autres solutions ==== |
| |
Good coverage of the problem is to be found in Herbert Voß's [[http://pstricks.tug.org/main.cgi?file=pdf/pdfoutput|PDF support page]], which is targeted at the use of [[ctanpkg>pstricks|pstricks]] in pdfLaTeX, and also covers the [[ctanpkg>pstricks|pstricks]]-specific package [[ctanpkg>pdftricks|pdftricks]]. A recent alternative (not covered in Herbert Voß's page) is [[ctanpkg>pdftricks2|pdftricks2]], which offers similar facilities to [[ctanpkg>pdftricks|pdftricks]], but with some useful variations. | Une large description de ce sujet est présentée dans la [[http://pstricks.tug.org/main.cgi?file=pdf/pdfoutput|page traitant des PDF]] de [[https://www.ctan.org/author/voss|Herbert Voß]] qui évoque l'utilisation de [[ctanpkg>pstricks]] avec ''pdfLaTeX'' ainsi que l'extension [[ctanpkg>pdftricks]]. Une alternative récente (non couverte dans la page d'Herbert Voß) est l'extension [[ctanpkg>pdftricks2]] qui offre des fonctionnalités similaires à [[ctanpkg>pdftricks|pdftricks]] avec quelques variantes utiles. |
| |
----- | ----- |