Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
2_composition:texte:paragraphes:encadrer_du_texte [2018/12/09 11:51]
jejust
2_composition:texte:paragraphes:encadrer_du_texte [2021/02/06 23:23] (Version actuelle)
jejust Ajout de deux exemples pour "tcolorbox". Réorganisation des sections.
Ligne 1: Ligne 1:
-====== Comment encadrer du texte? ======+====== Comment encadrer du texte ? ======
  
 +===== Avec la commande de base \fbox =====
  
-$\Reponse$ ​ Une solution consiste à définir un tableau d'​une ​seule cellule.+La commande ''​\fbox'' met son argument dans une boîte (comme ''​\parbox''​) puis dessine un cadre autour :
  
 +<WRAP column 40ex>
 +<code latex>
 +Je souhaite \fbox{encadrer} un mot
 +dans un paragraphe.
 +</​code>​
 +</​WRAP>​
 +<WRAP column 30ex>
 +<​latexdoc>​
 +\documentclass{article}
 +\usepackage[width=9cm,​height=1cm]{geometry}
 +\pagestyle{empty}
 +\begin{document}
 +Je souhaite \fbox{encadrer} un mot dans un paragraphe.
 +\end{document}
 +</​latexdoc>​
 +</​WRAP>​
 +<WRAP clear />
 +
 +Mais attention : tout le texte passé à la commande va se retrouver sur une seule ligne, sans coupure de mot possible !
  
-$\Reponse$ ​ On peut aussi utiliser:+Pour encadrer tout un paragraphe, une solution est de le placer dans un environnement ''​minipage'' ​:
  
 +<WRAP column 40ex>
 <code latex> <code latex>
-\fbox{ +\fbox{% 
-\begin{minipage}{0.7\textwidth} +\begin{minipage}{0.75\textwidth} 
-   Texte...+   Je souhaite encadrer tout un 
 +   ​paragraphe,​ sur plusieurs lignes.
 \end{minipage} \end{minipage}
 } }
 </​code>​ </​code>​
 +</​WRAP>​
 +<WRAP column 30ex>
 +<​latexdoc>​
 +\documentclass{article}
 +\usepackage[width=9cm,​height=7cm]{geometry}
 +\usepackage{microtype}
 +\pagestyle{empty}
 +\begin{document}
  
 +\fbox{%
 +\begin{minipage}{0.75\textwidth}
 +   Je souhaite encadrer tout un
 +   ​paragraphe,​ sur plusieurs lignes.
 +\end{minipage}
 +}
  
 +\end{document}
 +</​latexdoc>​
 +</​WRAP>​
 +<WRAP clear/>
  
-$\Reponse$ ​ On peut également se définir son propre environnement:+La commande ​\fbox est soumise à quelques paramètres : par exemple, l'​épaisseur du trait et l'​espace entre le texte et le trait est défini respectivement par les longueurs ''​\fboxrule''​ et ''​\fnboxsep'' ​:
  
-<file latex fmpage.sty+<WRAP column 40ex> 
-\newsavebox{\fmbox} +<​code ​latex> 
-\newenvironment{fmpage}[1] +Je souhaite ​\fbox{encadrerun mot 
-    {\begin{lrbox}{\fmbox}\begin{minipage}{#​1}} +dans un paragraphe.
-    {\end{minipage}\end{lrbox}\fbox{\usebox{\fmbox}}+
-<​file>​+
  
 +{% Cette paire d'​accolades permet
 + % que la modification n'ait
 + % qu'un effet local.
 + ​\setlength{\fboxrule}{2pt}
 + Je souhaite \fbox{encadrer} un mot
 + dans un paragraphe.
 +}
  
-Utilisation de l'​environnement définit par ''​fmpage.sty'':​+{% 
 + ​\setlength{\fboxsep}{1.5ex} 
 + Je souhaite \fbox{encadrer} un mot 
 + dans un paragraphe. 
 +
 +</​code>​ 
 +</​WRAP>​ 
 +<WRAP column 30ex> 
 +<​latexdoc>​ 
 +\documentclass{article} 
 +\usepackage[width=9cm,​height=7cm]{geometry} 
 +\pagestyle{empty} 
 +\begin{document}
  
 +Je souhaite \fbox{encadrer} un mot
 +dans un paragraphe.
 +
 +{% Cette paire d'​accolades permet
 + % que la modification n'ait
 + % qu'un effet local.
 + ​\setlength{\fboxrule}{2pt}
 + Je souhaite \fbox{encadrer} un mot
 + dans un paragraphe.
 +}
 +
 +{%
 + ​\setlength{\fboxsep}{1.5ex}
 + Je souhaite \fbox{encadrer} un mot
 + dans un paragraphe.
 +}
 +
 +\end{document}
 +</​latexdoc>​
 +</​WRAP>​
 +<WRAP clear/>
 +
 +===== Avec l'​environnement tabular =====
 +
 +Avoir du texte encadré revient à avoir un tableaau avec une unique cellule :
 +
 +<WRAP column 40ex>
 <code latex> <code latex>
-\input{faq.fmpage.sty} +\begin{tabular}{|p{5cm}|
-\begin{fmpage}{3cm+\hline 
-   Texte à encadrer dans une boîte ne +On ne dirait ​pas, mais il s'​agit 
-   dépassant ​pas 3 centimètres de large+ici d'un tableau\\ 
-\end{fmpage}+\hline 
 +\end{tabular}
 </​code>​ </​code>​
 +</​WRAP>​
 +<WRAP column 30ex>
 +<​latexdoc>​
 +\documentclass{article}
 +\usepackage[width=9cm,​height=7cm]{geometry}
 +\pagestyle{empty}
 +\begin{document}
  
 +\begin{tabular}{|p{5cm}|}
 +\hline
 +On ne dirait pas, mais il s'agit ici d'un tableau. \\
 +\hline
 +\end{tabular}
  
 +\end{document}
 +</​latexdoc>​
 +</​WRAP>​
 +<WRAP clear/>
  
-$\Reponse$ ​ Il existe également le package [[ctanpkg>​fancybox|fancybox]],​ disponible sur +===== Exemples avancés avec d'autres extensions =====
-https://​www.ctan.org/​macros/​latex/​contrib/​seminar/​inputs/,​ qui définit +
-des fonctions telles que ''​\shadowbox'',​ ''​\doublebox'',​ ''​\ovalbox'',​ etc.+
  
 +Les méthodes ci-dessous fournissent des cadres d'​apparence très classique.
 +D'​autres extensions dessinent des cadres adaptés à des documents
 +au look plus moderne, avec couleurs et icônes.
  
 +Certaines extensions permettent également d'​encadrer des pages entières,
 +ou des blocs de texte s'​étendant sur plusieurs pages.
 +
 +==== L'​extension fancybox ====
 +
 +L'​extension [[ctanpkg>​fancybox]] définit des commandes telles que ''​\shadowbox'',​ ''​\doublebox''​ et ''​\ovalbox'',​ qui fonctionnent de la même manière que ''​\fbox''​ ci-dessus :
 +
 +<WRAP column 40ex>
 <code latex> <code latex>
 +\usepackage{fancybox}
 +
 \shadowbox{Texte ombré.} \shadowbox{Texte ombré.}
 \doublebox{Texte doublement encadré.} \doublebox{Texte doublement encadré.}
Ligne 50: Ligne 162:
   aux coins arrondis.}   aux coins arrondis.}
 </​code>​ </​code>​
 +</​WRAP>​
 +<WRAP column 30ex>
 +<​latexdoc>​
 +\documentclass{article}
 +\usepackage[width=9cm,​height=7cm]{geometry}
 +\usepackage{fancybox}
 +\pagestyle{empty}
 +\begin{document}
  
 +\shadowbox{Texte ombré.}
 +\smallskip
  
 +\doublebox{Texte doublement encadré.}
 +\smallskip
  
-$\Reponse$ ​ Le package [[ctanpkg>​boxedminipage|boxedminipage]] est un vieux style <latex>\LaTeX</latex>2.09 +\ovalbox{Texte dans un cadre 
-disponible sur https://​www.ctan.org/​macros/​latex209/​contrib/​misc/​.+  aux coins arrondis.} 
 +\end{document} 
 +</latexdoc> 
 +</WRAP
 +<WRAP clear />
  
 +==== L'​extension awesomebox ====
  
-$\Reponse$ ​ Voir également le package ​[[ctanpkg>​hhflxbox|hhflxbox]] disponible sur +L'​extension ​[[ctanpkg>​awesomebox]] ne dessine pas de cadres à proprement parler, 
-https://​www.ctan.org/​usergrps/​uktug/​baskervi/​5_5/​. +mais peut mettre en valeur un bloc de texte avec une icône et un filet coloré:
-ftp://​ftp.fdn.fr/​pub/​not-on-CTAN/​macros/​latex/​contrib/​hh/​.+
  
 +<WRAP column 45ex>
 +<code latex>
 +\documentclass{article}
 +  \usepackage{awesomebox}
  
-$\Reponse$ ​ Le package [[ctanpkg>​niceframe|niceframe]] permet de +\begin{document}
-définir des cadres pleine page.+
  
 +\notebox{Notez bien ceci!}
 +\smallskip
  
-$\Reponse$ ​ Pour encadrer un texte pouvant s'​étendre sur plusieurs pageson +\importantbox{Lisez bien ce paragraphe 
-peut utiliser l'​environnement ''​breakbox''​ du package [[ctanpkg>boites|boites]].+avant de passer à la suite de ce document 
 +sinonvous risquez de perdre votre temps 
 +en considérations inutiles!} 
 +\end{document} 
 +</code> 
 +</​WRAP>​ 
 +<WRAP column 30ex> 
 +<​latexdoc>​ 
 +\documentclass{article} 
 +  \usepackage[width=9cm,​height=7cm]{geometry} 
 +  \usepackage{awesomebox} 
 +  \pagestyle{empty}
  
-Le package [[ctanpkg>​boitesexemples|boitesexemples]] définit les +\begin{document}
-environnements ''​boiteepaisseavecuntitre'',​ ''​boitenumeroteeavecunedoublebarre'',​ +
-''​boiteavecunelignequiondulesurlecote''​ et ''​boitecoloriee''​ qui +
-proposent différentes méthodes d'​encadrement.+
  
-  * ''​bkcounttrue''​ les lignes sont numérotées ; +\notebox{Notez bien ceci!} 
-  * ''​bkcountfalse''​ elles ne le sont pas (défaut).+\smallskip
  
-On peut emboîter ces environnements.+\importantbox{Lisez bien ce paragraphe 
 +avant de passer à la suite de ce document 
 +sinon, vous risquez de perdre votre temps 
 +en considérations inutiles!} 
 +\smallskip
  
 +\end{document}
 +</​latexdoc>​
 +</​WRAP>​
 +<WRAP clear/>
  
 +[[ctanpkg>​awesomebox|Awesomebox]] a cinq dessins de base,
 +utilisables sous forme d'une commande ou d'un environnement:​
  
-{{htmlmetatags>​metatag-keywords=(LaTeX) +^ Pour... ​  ^ Commande ​ ^ Environnement ​ ^ Exemple ​ ^ 
-metatag-og:​title=(Comment encadrer du texte?)+| Une note  | ''​\notebox''​ | ''​\begin{noteblock}''​...''​\end{noteblock}'' ​ | <​latexdoc>​\documentclass[6pt]{extarticle}\usepackage{awesomebox}\pagestyle{empty}\begin{document}\notebox{Marcel se couche de bonne heure.}\end{document}</​latexdoc> ​ | 
 +| Une suggestion ​ | ''​\tipbox''​ | ''​\begin{tipblock}''​...''​\end{tipblock}'' ​ | <​latexdoc>​\documentclass[6pt]{extarticle}\usepackage{awesomebox}\pagestyle{empty}\begin{document}\tipbox{Marcel se couche de bonne heure.}\end{document}</​latexdoc> ​ | 
 +| Un avertissement ​ | ''​\warningbox''​ | ''​\begin{warningblock}''​...''​\end{warningblock}'' ​ | <​latexdoc>​\documentclass[6pt]{extarticle}\usepackage{awesomebox}\pagestyle{empty}\begin{document}\warningbox{Marcel se couche de bonne heure.}\end{document}</​latexdoc> ​ | 
 +| Une mise en garde  | ''​\cautionbox''​ | ''​\begin{cautionblock}''​...''​\end{cautionblock}'' ​ | <​latexdoc>​\documentclass[6pt]{extarticle}\usepackage{awesomebox}\pagestyle{empty}\begin{document}\cautionbox{Marcel se couche de bonne heure.}\end{document}</​latexdoc> ​ | 
 +| Une remarque importante ​ | ''​\importantbox''​ | ''​\begin{importantblock}''​...''​\end{importantblock}'' ​ | <​latexdoc>​\documentclass[6pt]{extarticle}\usepackage{awesomebox}\pagestyle{empty}\begin{document}\importantbox{Marcel se couche de bonne heure.}\end{document}</​latexdoc> ​ | 
 + 
 +<note tip> 
 +Il est également très facile de définir vos propres boîtes avec la commande 
 +''​\awesomebox''​. Les icônes peuvent être choisies parmi celles de l'​extension 
 +[[ctanpkg>​fontawesome5]],​ et vous pouvez mettre des filets horizontaux avant 
 +et/ou après votre bloc de texte: 
 +<WRAP clear /> 
 + 
 +<code latex> 
 +\documentclass{article} 
 +  \usepackage{awesomebox} 
 + 
 +\begin{document} 
 + 
 +\awesomebox[white][\abShortLine]{0pt}{\faGrinBeam[regular]}{pink}{Ceci va vous rendre heureux\dots} 
 + 
 +\end{document} 
 +</​code>​ 
 +</​note>​ 
 + 
 + 
 +==== L'​extension tcolorbox ==== 
 + 
 +L'​extension [[ctanpkg>​tcolorbox]] utilise [[ctanpkg>​tikz|TikZ/​PGF]] 
 +pour dessiner ses cadres. 
 +Si vous avez l'​habitude de Ti//k//Z, vous apprécierez la syntaxe clefs-valeurs 
 +qui permet de paramétrer finement l'​apparence des cadres (couleurs, formes, 
 +structures...). 
 + 
 +À cause de ses possibilités de configuration immenses, [[texdoc>​tcolorbox|sa documentation]] 
 +fait plus de 500 pages (en anglais). 
 +Mais les deux exemples ci-dessous montrent qu'il n'est vraiment pas compliqué 
 +de dessiner des cadres déjà adaptés à pas mal de circonstances,​ 
 +et les nombreuses illustrations de la documentation devraient vous aider à aller plus loin: 
 + 
 +<WRAP column 50ex> 
 +<code latex> 
 +\documentclass{article} 
 +  \usepackage{tcolorbox} 
 + 
 +\begin{document} 
 + 
 +\begin{tcolorbox} 
 +Le cadre par défaut 
 +\end{tcolorbox} 
 +\smallskip 
 + 
 +\begin{tcolorbox}[colback=red!5!white,​ 
 +                  colframe=red!75!black,​ 
 +                  title=Cadre sexy 
 +                 ] 
 +Un autre cadre \textbf{plus coloré}, séparé 
 +en deux parties, et portant un titre. 
 +\tcblower 
 +Demain, \textit{j'​enlève le bas}. 
 +\end{tcolorbox} 
 + 
 +\end{document} 
 +</​code>​ 
 +</​WRAP>​ 
 +<WRAP column 40ex> 
 +<​latexdoc>​ 
 +\documentclass{article} 
 +  \usepackage[width=6cm,​height=6cm]{geometry} 
 +  \usepackage{microtype} 
 +  \usepackage[french]{babel} 
 +  \usepackage{tcolorbox} 
 +  \pagestyle{empty} 
 + 
 +\begin{document} 
 + 
 +\begin{tcolorbox} 
 +Le cadre par défaut 
 +\end{tcolorbox} 
 +\smallskip 
 + 
 +\begin{tcolorbox}[colback=red!5!white,​ 
 +                  colframe=red!75!black,​ 
 +                  title=Cadre sexy 
 +                 ] 
 +Un autre cadre \textbf{plus coloré}, séparé 
 +en deux parties, et portant un titre. 
 +\tcblower 
 +Demain, \textit{j'​enlève le bas}. 
 +\end{tcolorbox} 
 + 
 +\end{document} 
 +</​latexdoc>​ 
 +</​WRAP>​ 
 +<WRAP clear /> 
 + 
 + 
 +==== L'​extension boites ==== 
 + 
 +Pour encadrer un texte pouvant s'​étendre sur plusieurs pages, on peut utiliser l'​environnement ''​breakbox''​ 
 +de l'​extension [[ctanpkg>​boites]]. Cette extension définit également, par le biais du fichier 
 +''​boites_exemples.sty''​ (à charger car [[ctanpkg>​boites]] ne le précharge pas), 
 +des environnements qui proposent différentes méthodes d'​encadrement : 
 +  * ''​boiteepaisseavecuntitre''​ ; 
 +  * ''​boitenumeroteeavecunedoublebarre''​ ; 
 +  * ''​boiteavecunelignequiondulesurlecote''​ ; 
 +  * et ''​boitecoloriee''​. 
 + 
 +Ces environnements peuvent tous être modifiés par deux commandes ​  : 
 +  * ''​bkcounttrue''​ qui numérote les lignes de ces boîtes ; 
 +  * ''​bkcountfalse''​ qui ne les numérote plus (option par défaut). 
 + 
 +Il est également possible d'​emboîter ces environnements. 
 + 
 + 
 + 
 +==== L'​extension niceframe ==== 
 + 
 +L'​extension [[ctanpkg>​niceframe]] permet de définir des cadres pleine page. 
 + 
 +FIXME Détailler [[ctanpkg>​nieframe]]. 
 + 
 +==== L'​extension boxedminipage ==== 
 + 
 +L'​extension [[ctanpkg>​boxedminipage]] correspond à un vieux style <​latex>​\LaTeX</​latex>​ 2.09 qui a été actualisé. 
 + 
 +FIXME Détailler [[ctanpkg>​boxedminipage]]. 
 + 
 +==== L'​extension bclogo ==== 
 + 
 +FIXME Détailler [[ctanpkg>​bclogo]]. 
 + 
 + 
 +===== Avec des environnements « faits maison » ===== 
 + 
 +Les extensions présentées ci-dessus sont évidemment bien plus plus puissantes 
 +mais, à titre pédagogique,​ voici un exemple d'​environnement « fait main » 
 +pour encadrer des paragraphes de texte : 
 + 
 +<file latex fmpage.sty>​ 
 +\newsavebox{\fmbox} 
 +\newenvironment{fmpage}[1] 
 +    {\begin{lrbox}{\fmbox}\begin{minipage}{#​1}} 
 +    {\end{minipage}\end{lrbox}\fbox{\usebox{\fmbox}}} 
 +</​file>​ 
 + 
 +Et voici un exemple d'​utilisation de ce fichier : 
 + 
 +<WRAP column 40ex> 
 +<code latex> 
 +\input{fmpage.sty} 
 + 
 +\begin{fmpage}{3cm} 
 +   Texte à encadrer dans une boîte 
 +   ne dépassant pas 3 centimètres 
 +   de large. 
 +\end{fmpage} 
 +</​code>​ 
 +</​WRAP>​ 
 +<WRAP column 30x> 
 +<​latexdoc>​ 
 +\documentclass{article} 
 +\usepackage[width=6cm,​height=7cm]{geometry} 
 +\pagestyle{empty} 
 + 
 +\newsavebox{\fmbox} 
 +\newenvironment{fmpage}[1] 
 +    {\begin{lrbox}{\fmbox}\begin{minipage}{#​1}} 
 +    {\end{minipage}\end{lrbox}\fbox{\usebox{\fmbox}}} 
 + 
 +\begin{document} 
 + 
 +\begin{fmpage}{3cm} 
 +   Texte à encadrer dans une boîte 
 +   ne dépassant pas 3 centimètres 
 +   de large. 
 +\end{fmpage} 
 + 
 +\end{document} 
 +</​latexdoc>​ 
 +</​WRAP>​ 
 +<WRAP clear/>​ 
 + 
 +{{htmlmetatags>​metatag-keywords=(LaTeX,entourer du texte,​mettre un cadre,​dessiner un cadre,​dessiner des filets
 +metatag-og:​title=(Comment encadrer du texte)
 metatag-og:​site_name=(FAQ LaTeX francophone) metatag-og:​site_name=(FAQ LaTeX francophone)
 }} }}
- 
2_composition/texte/paragraphes/encadrer_du_texte.1544352712.txt.gz · Dernière modification: 2018/12/09 11:51 par jejust
CC Attribution-Share Alike 4.0 International
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0