% !TeX TXS-program:compile = txs:///arara % arara: pdflatex: {shell: yes, synctex: no, interaction: batchmode} % arara: pdflatex: {shell: yes, synctex: no, interaction: batchmode} if found('log', '(undefined references|Please rerun|Rerun to get)') \documentclass[french,11pt,a4paper]{article} \usepackage[utf8]{inputenc} \usepackage[T1]{fontenc} \RequirePackage[upright]{fourier} \RequirePackage{mathtools} \RequirePackage{amsmath,amssymb,amstext} \RequirePackage[scaled=0.875]{helvet} \renewcommand\ttdefault{lmtt} \RequirePackage[scaled=0.925]{cabin} % sf %\usepackage{DejaVuSerif} %\usepackage[scale=1.1]{inconsolata} \usepackage[pastableur]{customenvs} \usepackage{tabularx} \usepackage{soul} %\usepackage{codehigh} \usepackage{fontawesome5} \usepackage{lipsum} \usepackage{fancyvrb} \usepackage{fancyhdr} \fancyhf{} \renewcommand{\headrulewidth}{0pt} \lfoot{\sffamily\small [customenvs]} \cfoot{\sffamily\small - \thepage{} -} \rfoot{\hyperlink{matoc}{\small\faArrowAltCircleUp[regular]}} \usepackage{hologo} \providecommand\tikzlogo{Ti\textit{k}Z} \providecommand\TeXLive{\TeX{}Live\xspace} \providecommand\PSTricks{\textsf{PSTricks}\xspace} \let\pstricks\PSTricks \let\TikZ\tikzlogo \usepackage{hyperref} \urlstyle{same} \hypersetup{pdfborder=0 0 0} \usepackage[margin=1.5cm]{geometry} \setlength{\parindent}{0pt} \def\TPversion{0.1.7} \def\TPdate{03 juin 2024} \usepackage{tcolorbox} \tcbuselibrary{listingsutf8} \newtcblisting{DemoCode}[1]{% enhanced,width=0.95\linewidth,center,% bicolor,size=title,% colback=cyan!5!white,% colbacklower=cyan!1!white,% colframe=cyan!75!black,% listing options={% breaklines=true,% breakatwhitespace=true,% style=tcblatex,basicstyle=\small\ttfamily,% tabsize=4,% commentstyle={\itshape\color{gray}}, keywordstyle={\color{blue}},% classoffset=0,% keywords={usepackage,displaystyle,frac,infty,begin,end,lipsum,centering,par,baselineskip,item,bullet,int,color,NewDocumentCommand},% alsoletter={-},% keywordstyle={\color{blue}},% classoffset=1,% alsoletter={-},% morekeywords={center,justify,\LstDeuxNiv,\LstTroisNiv,\LstQuatreNiv,\NoticeDeuxNiv,\NoticeTroisNiv,\NoticeQuatreNiv,\DeuxNivBatterie,\TroisNivBatterie,\QuatreNivBatterie,\DeuxNivSmiley,\TroisNivSmiley,\QuatreNivSmiley,\vcenterfa,\faIcon},% keywordstyle={\color{violet}},% classoffset=2,% alsoletter={-},% morekeywords={\ReponsesQCM,MultiCols,\CreerListeItems,\ListeChoixItems,\TableauCompetences,\CrayonDeCompetences,\StyleEnvtExo,\StyleEnvtExoDefaut,\TitreExo,\ipsum,EnvSMS,\SMSrec,\SMSenv,BoiteSimple,\SujetTitreExo,\CircledNumber,\AffVignette,\BoiteArrondie,\ChangerDisplaySkip,\celcouleur,\celfusion,\lignetxt,\colonnetxt,\celnumbreak,\celtxt},% keywordstyle={\color{green!50!black}},% classoffset=3,% morekeywords={Largeur,Filets,EspacesCL,NbCols,Labels,PoliceLabels,EspaceLabels,Swap,Type,CoeffEspVert,EpTrait,Alea,LargeurNivs,Niveaux,NoticeNiveaux,Titre,PolTitre,PolNotice,PolComp,LigneSep,CouleurNotice,CouleurNiveaux,CouleurFond,Note,Notice,PoliceCateg,PoliceBloc,Couleurs,LargeurBloc,Echelle,NoirBlanc,Libelle,EpTrait,Police,Type,ComplementTitre,Titre,CodeDebut,Couleur,EchelleImage,Decoration,Trait,Avatar,AffAvatar,NoirBlanc,CouleurE,CouleurR,CouleurFond,Hauteur,Largeur,PoliceTxt,CouleurTitre,AlignH,bg,txt,bthick,bcol,raise,Type,EspH,Fond,Texte,Style,Dense,Avant,AvantS,Apres,ApresS,Global,align,width},% keywordstyle={\color{orange}} },% #1 } \sethlcolor{lightgray!25} \NewDocumentCommand\MontreCode{ m }{% \hl{\vphantom{\texttt{pf}}\texttt{#1}}% } \usepackage{babel} \begin{document} \pagestyle{fancy} \thispagestyle{empty} \begin{center} \begin{minipage}{0.75\linewidth} \begin{tcolorbox}[colframe=yellow,colback=yellow!15] \begin{center} \renewcommand\arraystretch{1.25} \begin{tabular}{c} {\Huge \texttt{customenvs [fr]}}\\ \\ {\Large Quelques environnements classiques,} \\ {\Large légèrement modifiés, et basés} \\ {\Large sur des environnements existants.} \\ \end{tabular} \renewcommand\arraystretch{1} \medskip {\small \texttt{Version \TPversion{} -- \TPdate}} \end{center} \end{tcolorbox} \end{minipage} \end{center} \vspace*{1mm} \begin{center} \begin{tabular}{c} \texttt{Cédric Pierquet}\\ {\ttfamily c pierquet -- at -- outlook . fr}\\ \texttt{\url{https://github.com/cpierquet/customenvs}} \end{tabular} \end{center} \vspace*{5mm} %\hrule % %\vspace*{2mm} % %{\centering Le nom du package vient de \textsf{ENVironnemenTS ALTernatifs}, avec le suffixe \textsf{FRançais}.\par} % %\vspace*{2mm} % %\hrule % %\vspace*{1cm} \hrule \phantomsection \hypertarget{matoc}{} \tableofcontents \vspace*{5mm} \hrule \pagebreak \section{Historique} \verb|v0.1.7|~:~~~~Possibilité de créer des vignettes \textsf{perso} \verb|v0.1.6|~:~~~~Patch \textsf{displayskip} + Patches \textsf{pas-tableur} \verb|v0.1.5|~:~~~~La librairie \texttt{babel} de \TikZ\ n'est plus chargée \verb|v0.1.5|~:~~~~Vignettes + Numéros encerclés + Création de boîtes 'simples' \verb|v0.1.4|~:~~~~Commande pour du texte dans une boîte arrondie, de hauteur 'figée' + 'Chat' SMS \verb|v0.1.3|~:~~~~Environnement/commande pour des exercices, avec personnalisation(s) \verb|v0.1.2|~:~~~~Crayon de compétences \verb|v0.1.1|~:~~~~Tableaux de compétences \verb|v0.1.0|~:~~~~Version initiale \pagebreak \section{Le package customenvs} \subsection{Idée} L'idée est de proposer des commandes ou environnements classiques avec quelques éléments de personnalisation (via des \textsf{clés} francisées), comme : \begin{itemize} %\item modifier localement l'\textit{alignement vertical} d'éléments sans jambage ; \item \textit{centrer} avec gestion des espacements autour ; \item écrire en \textit{multi-colonnes} avec gestion des espacements autour ; \item mettre en forme des réponses à des \textit{QCM} ; \item créer une liste avec \textit{choix des items} (de manière aléatoire ou par saisie directe) ; \item créer un tableau de \textit{compétences}. \end{itemize} \smallskip L'idée globale est de proposer des environnements clé en main, avec personnalisations \textit{explicites}, sans forcément avoir besoin de \textit{se pencher sur le code}, mais il est évident qu'il existe d'autres solutions pour l'utilisateur qui souhaite réellement contrôler son rendu. \smallskip Il est ici essentiellement question de gérer les espacements, donc on peut citer comme autres solutions possibles : \begin{itemize} \item l'utilisation de \MontreCode{\textbackslash vspace} ou de \MontreCode{\textbackslash setlength} ; \item le package \MontreCode{spacingtricks}. \end{itemize} \subsection{Chargement} Le package se charge dans le préambule, via \MontreCode{\textbackslash usepackage\{customenvs\}}. Les packages chargés sont : \begin{itemize} \item \MontreCode{xstring}, \MontreCode{simplekv}, \MontreCode{listofitems}, \MontreCode{randomlist} et \MontreCode{xintexpr} ; \item \MontreCode{enumitem} ; \item \MontreCode{multicol} ; \item \MontreCode{tabularray} ; \item \MontreCode{xcolor} ; \item \MontreCode{fontawesome5} ; \item \MontreCode{tikz} avec les librairies \MontreCode{decorations.pathmorphing,positioning,shapes.misc,calc}. \end{itemize} À noter que, pour des raisons de compatibilité (ou d'incompatibilité), les packages \MontreCode{enumitem}/\MontreCode{multicol}/\MontreCode{tabularray}/\MontreCode{xcolor}/\MontreCode{fontawesome5} peuvent ne pas être chargés par \MontreCode{customenvs} (auxquels cas l'utilisateur devra les avoir chargés pour faire fonctionner certains environnements) via les options : \begin{itemize} \item \MontreCode{$\mathtt{\langle}$nonenum$\mathtt{\rangle}$} ; \item \MontreCode{$\mathtt{\langle}$nonmulticol$\mathtt{\rangle}$} ; \item \MontreCode{$\mathtt{\langle}$nontblr$\mathtt{\rangle}$} ; \item \MontreCode{$\mathtt{\langle}$nonxcolor$\mathtt{\rangle}$} ; \item \MontreCode{$\mathtt{\langle}$nonfa$\mathtt{\rangle}$}. \end{itemize} \begin{DemoCode}{listing only} %chargement avec tous les packages \usepackage{customenvs} %chargement avec options(s) pour ne pas charger certains packages \usepackage[option(s)]{customenvs} \end{DemoCode} \newpage \section{Présentation de réponses à un QCM} \subsection{Principe} L'idée est de proposer une environnement prêt à l'emploi pour présenter, grâce à \MontreCode{tabularray} (et non pas à \MontreCode{multicols}) qui est donc à charger, les réponses à une question type QCM, données en colonnes. \smallskip Il est possible de spécifier 2, 3 ou 4 réponses, et dans le cas de 4 réponses il est possible de spécifier 1 ou 2 colonnes. \begin{DemoCode}{listing only} \ReponsesQCM[options]{liste reponses} \end{DemoCode} Les \MontreCode{options} disponibles sont : \begin{itemize} \item \MontreCode{Largeur} pour spécifier la largeur du tableau, \MontreCode{0.99\textbackslash linewidth} par défaut ; \item \MontreCode{Filets} pour afficher les filets, \MontreCode{false} par défaut ; \item \MontreCode{EspacesCL} pour les espacements Colonnes/Lignes, sous la forme \MontreCode{col/lign} ou \MontreCode{globale}, et valant \MontreCode{6pt/2pt} par défaut ; \item \MontreCode{NbCols} pour forcer le passage à 2 colonnes dans le cas de 4 réponses, \MontreCode{4} par défaut ; \item \MontreCode{Labels} pour spécifier le formatage des labels, avec \MontreCode{a.} par défaut ; \begin{itemize} \item pouvant faire intervenir \MontreCode{a} pour \textit{numéroter} \MontreCode{a b c d} ; \item pouvant faire intervenir \MontreCode{A} pour \textit{numéroter} \MontreCode{A B C D} ; \item pouvant faire intervenir \MontreCode{1} pour \textit{numéroter} \MontreCode{1 2 3 4} ; \end{itemize} \item \MontreCode{PoliceLabels} pour la police des labels, \MontreCode{\textbackslash bfseries} par défaut ; \item \MontreCode{EspaceLabels} pour gérer l'espacement entre le label et la réponse, et valant \MontreCode{\textbackslash kern5pt} par défaut ; \item \MontreCode{Swap} pour afficher les (4) réponses en mode 2 colonnes sous la forme ACBD ou ABCD, et valant \MontreCode{false} par défaut. \end{itemize} La liste des réponses est à donner sous la forme \MontreCode{answA § answB § ...} Les options spécifiques, optionnelles et entre \MontreCode{<...>}, sont pour le dernier argument. \subsection{Exemples} \begin{DemoCode}{} %sortie par defaut \ReponsesQCM{Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[Filets]{Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[Filets,Labels=(1.),EspaceLabels={~~~}]{Réponse A § Réponse B § Réponse C} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[Labels={A.},PoliceLabels={\color{red}\bfseries}]% {Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[NbCols=4,Labels={A.},PoliceLabels={\color{red}\bfseries}]% {Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[NbCols=2,Labels={A.},PoliceLabels={\color{red}\bfseries}]% {Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[NbCols=2,Swap,Labels={A.},PoliceLabels={\color{red}\bfseries}]% {Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[Filets,NbCols=2,EspacesCL=6pt/10pt]% {Réponse A § Réponse B § Réponse C § Réponse D} \end{DemoCode} \begin{DemoCode}{} \ReponsesQCM[Largeur=10cm,NbCols=2,Filets]% {$\displaystyle\frac1x$ § $1+\displaystyle\frac1x$ § $-2x^2+5$ § $-\infty$} \end{DemoCode} \pagebreak \section{Environnement Centrage} \subsection{Principe} L'idée est de proposer un environnement, basé sur \MontreCode{center}, avec une gestion plus fine des espacements avant et après. Le fait est qu'un environnement \MontreCode{center} génère des espacements (parfois) un peu trop grands autour (on peut également utiliser \MontreCode{\textbackslash centering} ou \MontreCode{\textbackslash centered} du package \MontreCode{spacingtricks}), et donc il s'agit ici de garder l'architecture \textit{environnement} et proposant des solutions pour modifier les espacements. \begin{DemoCode}{listing only} \begin{Centrage}[options] %corps \end{Centrage} \end{DemoCode} Les \MontreCode{options} disponibles sont : \begin{itemize} \item \MontreCode{Avant} pour spécifier l'espacement avant l'environnement, \MontreCode{0.33\textbackslash baselineskip} par défaut ; \item \MontreCode{Apres} pour spécifier l'espacement après l'environnement, \MontreCode{0.33\textbackslash baselineskip} par défaut. \end{itemize} À noter que les espacements peuvent être donnés de manière absolue, ou via des dimensions existantes. \subsection{Exemples} \begin{DemoCode}{} %environnement center, par défaut \lipsum[1][1-3] \begin{center} \lipsum[1][1] \end{center} \lipsum[1][1-2] \end{DemoCode} \begin{DemoCode}{} %centering \lipsum[1][1-3]\par {\centering\lipsum[1][1]\par} \lipsum[1][1-2] \end{DemoCode} \begin{DemoCode}{} %environnement Centrage, par défaut \lipsum[1][1-3] \begin{Centrage} \lipsum[1][1] \end{Centrage} \lipsum[1][1-2] \end{DemoCode} \begin{DemoCode}{} %environnement Centrage, personnalisé \lipsum[1][1-3] \begin{Centrage}[Avant=0pt,Apres=0pt] \lipsum[1][1] \end{Centrage} \lipsum[1][1-2] \end{DemoCode} \begin{DemoCode}{} %environnement Centrage, avec des listes \lipsum[2][3] \begin{itemize} \item \lipsum[1][1] \item \lipsum[1][2] \end{itemize} \begin{Centrage}[Avant=-0.25\baselineskip] \lipsum[1][1] \end{Centrage} \lipsum[1][1-2] \end{DemoCode} \pagebreak \section{Environnement multi-colonnes} \subsection{Principe} L'idée est de proposer un environnement basé sur \MontreCode{multicols} (donc le package \MontreCode{multicol} est à charger), pour lequel les espacements avant et après peuvent être personnalisés. C'est la longueur \MontreCode{\textbackslash multicolsep}, qui vaut \MontreCode{12pt plus 4pt minus 3pt} par défaut, qui gère ces espacements. \smallskip L'idée est donc de proposer une environnement \textit{simplifié} intégrant une modification de cette longueur. Il sera également possible de créer automatiquement un environnement multi-colonnes combiné avec une liste d'énumération (avec \MontreCode{enumitem} chargé, par exemple) ! De plus, si le multi-colonnes est destiné à accueillir une liste, les items seront correctement alignés avec une liste sans multi-colonnes. \begin{DemoCode}{listing only} \begin{MultiCols}[options](nbcols) %corps \end{MutiCols} \end{DemoCode} Les \MontreCode{options} disponibles sont : \begin{itemize} \item \MontreCode{Type} pour spécifier le type d'environnement qui sera inclus en multi-colonnes, et valant \MontreCode{texte} par défaut ; \hfill{}à choisir parmi \MontreCode{texte / enum / item} \item \MontreCode{CoeffEspVert} pour spécifier le coefficient à appliquer à la longueur par défaut, et valant \MontreCode{0.5} par défaut ; \hfill{}à choisir parmi \MontreCode{0 / 0.25 / 0.33 / 0.5 / 0.66 / 0.75 / 1 / 1.25} \item \MontreCode{EpTrait} pour l'épaisseur éventuelle du trait de séparation, et valant \MontreCode{0pt} par défaut. \end{itemize} Le nombre de colonnes, obligatoire, est à donner entre \MontreCode{(...)}. L'argument optionnel et entre \MontreCode{<...>} est passé à l'environnement \MontreCode{enumitem} ou \MontreCode{itemize} si spécifié. \subsection{Exemples} \begin{DemoCode}{} %par défaut \lipsum[1][1-2] \begin{MultiCols}(2) \lipsum[2] \end{MultiCols} \lipsum[1][3-4] \end{DemoCode} \begin{DemoCode}{} %espacement réduit + filet \lipsum[1][1-2] \begin{MultiCols}[CoeffEspVert=0.25,EpTrait=1pt](3) \lipsum[2] \end{MultiCols} \lipsum[1][3-4] \end{DemoCode} \begin{DemoCode}{} %type enumitem \begin{enumerate} \item \lipsum[1][1-2] \begin{MultiCols}[Type=enum](4) \item bla \item bla \item bla \item bla \end{MultiCols} \item \lipsum[1][3-4] \begin{MultiCols}[Type=item](3) \item bla \item bla \item bla \end{MultiCols} \end{enumerate} \lipsum[3][1] \end{DemoCode} \pagebreak \section{Énumération avec choix des items, parmi une liste} \subsection{Principe et fonctionnement} L'idée est ici de : \begin{itemize} \item créer une liste d'items qui servira de base pour le(s) choix ; \item afficher la liste avec choix des items, de manière aléatoire ou par items choisis \end{itemize} À noter que l'environnement \MontreCode{MultiCols} du package peut être utilisé comme environnement de listes ! \begin{DemoCode}{listing only} \CreerListeItems{liste}{macro}{nomliste} \end{DemoCode} \begin{DemoCode}{listing only} \ListeChoixItems[clés]{macro}{nomliste}(numéros) \end{DemoCode} Les \MontreCode{clés} disponibles sont : \begin{itemize} \item \MontreCode{Type} pour spécifier le type d'environnement, et valant \MontreCode{enum} par défaut ; \hfill{}à choisir parmi \MontreCode{enum} \MontreCode{item} ou \MontreCode{MultiCols/Type/NbCols} \item \MontreCode{Alea} pour forcer un affichage aléatoire, \MontreCode{false} par défaut. \end{itemize} Le deuxième argument, obligatoire et entre \MontreCode{\{...\}} est la macro créée précédemment. Le troisième argument, obligatoire et entre \MontreCode{\{...\}} est le nom de la liste créée précédemment. Le quatrième argument, obligatoire et entre \MontreCode{(...)} permet de spécifier : \begin{itemize} \item le nombre d'items à afficher en mode \MontreCode{Alea=true} ; \item les items à afficher, sous la forme \MontreCode{num1,num2,...}. \end{itemize} Le dernier argument, optionnel et entre \MontreCode{<...>} correspond à des options spécifiques à passer à l'environnement de liste \MontreCode{enumitem} créé. \medskip À noter que des contrôles sont effectués lors de l'appel aux macros pour : \begin{itemize} \item vérifier que la liste n'existe pas déjà (pour la macro de création) ; \item vérifier que la liste existe déjà (pour la macro d'affichage des items). \end{itemize} \subsection{Exemples} \begin{DemoCode}{listing only} %création de la liste ListeItems, avec la macro \malisteditems \CreerListeItems% {Réponse A,Réponse B,Réponse C,Réponse D,Réponse E,Réponse F,Réponse G,Réponse H}% {\malisteditems}{ListeItems} \end{DemoCode} \CreerListeItems{Réponse A,Réponse B,Réponse C,Réponse D,Réponse E,Réponse F,Réponse G,Réponse H}{\malisteditems}{ListeItems} \begin{DemoCode}{} %affichage d'items aléatoires \ListeChoixItems[Alea]{\malisteditems}{ListeItems}(5) \end{DemoCode} \begin{DemoCode}{} %affichage de certains items \ListeChoixItems{\malisteditems}{ListeItems}(1,4,3,8,2) \end{DemoCode} \begin{DemoCode}{listing only} %création de la liste ListeItemsB, avec la macro \malisteditemsb \CreerListeItems% {{$\int_0^1 x^2 dx$},{$\int_0^1 x^3 dx$},{$\int_0^1 x^4 dx$},...}% {\malisteditemsb}{ListeItemsB} \end{DemoCode} \CreerListeItems{{$\int_0^1 x^2 dx$},{$\int_0^1 x^3 dx$},{$\int_0^1 x^4 dx$},{$\int_0^1 x^5 dx$},{$\int_0^1 x^6 dx$},{$\int_0^1 x^7 dx$},{$\int_0^1 x^8 dx$}}{\malisteditemsb}{ListeItemsB} \begin{DemoCode}{} %affichage d'items aléatoires, via MultiCols \ListeChoixItems[Alea,Type={MultiCols/enum/2}]{\malisteditemsb}{ListeItemsB}(4) \end{DemoCode} \begin{DemoCode}{} %affichage de certains items \ListeChoixItems[Type=item]{\malisteditemsb}{ListeItemsB}(7,2,1,5,3) \end{DemoCode} \pagebreak \section{Tableau de compétences} \subsection{Principe et fonctionnement} L'idée est de proposer un environnement pour créer un tableau de compétences, via 2/3/4 niveaux : \begin{itemize} \item basé sur \MontreCode{tblr}, qui doit donc être chargé (par défaut il l'est) ; \item basé sur \MontreCode{xcolor}, qui doit donc être chargé (par défaut il l'est) ; \item avec personnalisations possibles. \end{itemize} Si \MontreCode{xcolor} est déjà chargé, avec des options particulières, le package peut ne pas le charger, grâce à l'option \MontreCode{nonxcolor}. \begin{DemoCode}{listing only} \TableauCompetences[clés]{listecompétences} \end{DemoCode} \begin{DemoCode}{} \TableauCompetences{Compétence A § Compétence B} \end{DemoCode} \subsection{Éléments prédéfinis} Pour simplifier la saisie de certains paramètres, certaines macros ont été définies en interne, et pourront être utilisées, ou redéfinies si besoin. \begin{DemoCode}{listing only} %patch fa vcenter \NewDocumentCommand{\vcenterfa}{ O{} m }{$\vcenter{\hbox{\faIcon[#1]{#2}}}$} %labelnote \def\LabelNoteComp{Note} %listeniveaux \def\LstDeuxNiv{NA § A} \def\LstTroisNiv{NA § ECA § A} \def\LstQuatreNiv{NA § PA § ECA § A} %noticeniveaux \def\NoticeDeuxNiv{Non acquis § Acquis} \def\NoticeTroisNiv{Non acquis § En cours d'acquis. § Acquis} \def\NoticeQuatreNiv{Non acquis § Part. acquis § En cours d'acquis. § Acquis} \end{DemoCode} \begin{DemoCode}{text only} Niveaux par \og batterie \fg : \MontreCode{\textbackslash DeuxNivBatterie} : \DeuxNivBatterie\\ \MontreCode{\textbackslash TroisNivBatterie} : \TroisNivBatterie \\ \MontreCode{\textbackslash QuatreNivBatterie} : \QuatreNivBatterie\\ Niveaux par \og smiley \fg : \MontreCode{\textbackslash DeuxNivSmiley} : \DeuxNivSmiley\\ \MontreCode{\textbackslash TroisNivSmiley} : \TroisNivSmiley\\ \MontreCode{\textbackslash QuatreNivSmiley} : \QuatreNivSmiley \end{DemoCode} \pagebreak Les \MontreCode{clés} disponibles sont : \begin{itemize} \item \MontreCode{Largeur} : largeur globale du tableau ; \MontreCode{0.95\textbackslash linewidth} par défaut \item \MontreCode{LargeurNivs} : largeur des colonnes Niv + Note (séparées par \MontreCode{§}) ; \MontreCode{0.75cm § 1.25cm} par défaut \item \MontreCode{Niveaux} : liste des niveaux (séparés par \MontreCode{§}) ; \MontreCode{NA § ECA § A} par défaut \item \MontreCode{NoticeNiveaux} : notice des niveaux (séparés par \MontreCode{§}) ; \MontreCode{Non acquis § En cours d'acquisition § Acquis} par défaut ; \item \MontreCode{Titre} : titre du tableau ; \MontreCode{DS01} par défaut \item \MontreCode{PolTitre} : police de la 1\up{ere} ligne ; \MontreCode{\textbackslash small\textbackslash sffamily\textbackslash bfseries} par défaut \item \MontreCode{PolNotice} : police de la notice (dernière ligne) ; \MontreCode{\textbackslash small\textbackslash sffamily\textbackslash bfseries} par défaut \item \MontreCode{PolComp} : police des lignes des compétences ; \MontreCode{\textbackslash small\textbackslash sffamily} par défaut \item \MontreCode{LigneSep} : séparation entre les lignes ; \MontreCode{2pt} par défaut \item \MontreCode{CouleurNotice} : couleur de la notice ; \MontreCode{black} par défaut \item \MontreCode{CouleurNiveaux} : couleur de la première ligne ; \MontreCode{black} par défaut \item \MontreCode{CouleurFond} : fond de la première ligne; \MontreCode{lightgray!25} par défaut \item \MontreCode{Note} : booléen pour afficher la colonne note ; \MontreCode{true} par défaut \item \MontreCode{Notice} : booléen pour afficher la ligne notice; \MontreCode{true} par défaut. \end{itemize} L'argument, obligatoire et entre \MontreCode{\{...\}} est la liste des compétences, sous la forme \MontreCode{Comp A § Comp B § ...}. À noter que les clés \MontreCode{Niveaux} et \MontreCode{NoticeNiveaux} doivent avoir le même nombre d'éléments. \subsection{Exemples} \begin{DemoCode}{} %Note + Notice \TableauCompetences{Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \begin{DemoCode}{} %- Note + Notice \TableauCompetences[Note=false]{Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \begin{DemoCode}{} %Note - Notice \TableauCompetences[Notice=false]{Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \begin{DemoCode}{} %- Note - Notice \TableauCompetences[Note=false,Notice=false]{Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \begin{DemoCode}{} %Personnalisations \TableauCompetences[Titre=Eval n°01,Niveaux=\TroisNivBatterie]{Utiliser le compas § Utiliser l'équerre}\par \TableauCompetences[Titre={},Niveaux=\TroisNivSmiley]{Utiliser le compas § Utiliser l'équerre}\par \TableauCompetences[Largeur=10cm,Notice=false,Titre={},Niveaux=\TroisNivSmiley]{Utiliser le compas § Utiliser l'équerre}\par \end{DemoCode} \begin{DemoCode}{} %deux niveaux \TableauCompetences[Niveaux=\LstDeuxNiv,NoticeNiveaux=\NoticeDeuxNiv]{Utiliser le compas § Utiliser l'équerre}\par \TableauCompetences[Largeur=10cm,Titre={},Niveaux=\DeuxNivBatterie, NoticeNiveaux=\NoticeDeuxNiv]{Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \pagebreak \begin{DemoCode}{} %quatre niveaux, personnalisation 'complète' \def\LabelNoteComp{Appréc.} \TableauCompetences[% Largeur=14cm,% LargeurNivs={1cm§3.5cm},% Niveaux={N0§N1§N2§N3}, NoticeNiveaux={Très bof§Bof§Moyen§Bien}, CouleurNotice=orange,% CouleurNiveaux=blue,% PolTitre=\large\ttfamily\itshape\bfseries ]% {Utiliser la règle § Utiliser le compas § Utiliser l'équerre} \end{DemoCode} \pagebreak \section{Crayon de compétences} \subsection{Principe et fonctionnement} L'idée est de proposer un environnement pour créer un \textit{crayon} de compétences, basé sur \MontreCode{TikZ}. Le code (en licence CC-BY-SA 4.0) est largement inspiré du fil : \hfill{\footnotesize \url{https://tex.stackexchange.com/questions/504092/replicating-a-fancy-bordered-text-style-in-latex/504145#504145}}\hfill~ \begin{DemoCode}{listing only} \CrayonDeCompetences[clés]{listecompétences} \end{DemoCode} \begin{DemoCode}{} \CrayonDeCompetences{Chercher/Compétence 1\\Compétence 2,Modéliser/Compétence 1\\Compétence 2} \end{DemoCode} La forme générale est fixée, et seuls quelques éléments de personnalisation(s) sont modifiables. \subsection{La commande} Les \MontreCode{clés} disponibles, à donner entre \MontreCode{[...]}, sont : \begin{itemize} \item \MontreCode{PoliceCateg} : police des catégories ; \MontreCode{\textbackslash bfseries\textbackslash sffamily} par défaut \item \MontreCode{PoliceBloc} : police des compétences ; \MontreCode{\textbackslash small\textbackslash ttfamily} par défaut \item \MontreCode{Couleurs} : liste des couleurs de catégories, sous la forme \MontreCode{FondCatég1/PoliceCatég1,FondCatég2/PoliceCatég2,...} (Si \MontreCode{PolicCatég} est absent, \MontreCode{black} est utilisé par défaut) \item \MontreCode{LargeurBloc} : largeur des blocs \textit{texte} ; \MontreCode{5cm} par défaut ; \item \MontreCode{Echelle} : échelle globale du schéma ; \MontreCode{1} par défaut \item \MontreCode{NoirBlanc} : booléen pour un affichage N\&B. \MontreCode{false} par défaut. \end{itemize} L'argument optionnel, et entre \MontreCode{<...>}, permet de spécifier des options à la figure \MontreCode{TikZ} (comme une rotation, un alignement, etc) \smallskip L'argument, obligatoire et entre \MontreCode{\{...\}} est la liste des catégories/compétences, sous la forme \MontreCode{Catég1/ListeCompétences1,Catég2/ListeCompétences2,...}. \begin{DemoCode}{} \CrayonDeCompetences[Largeur=3cm,Couleurs=teal/white]{% DS01/Compétence 1\\Compétence 2 } \end{DemoCode} \subsection{Exemples} \begin{DemoCode}{} %Sortie par défaut \CrayonDeCompetences{% Chercher/Compétence 1\\Compétence 2, Modéliser/Compétence 1\\Compétence 2, Représenter/Compétence 1, Calculer/Compétence 1\\Compétence 2\\Compétence 3 } \end{DemoCode} \begin{DemoCode}{} \CrayonDeCompetences[Echelle=0.75,LargeurBloc=3cm]% {Chercher/Compétence 1\\Compétence 2, Modéliser/{Compétence 1\\Compétence 2},Raisonner/{Compétence 1\\Compétence 2}} \end{DemoCode} \begin{DemoCode}{} \CrayonDeCompetences[Echelle=0.5]% {Chercher/Compétence 1\\Compétence 2,Modéliser/{Compétence 1\\Compétence 2}} \end{DemoCode} \begin{DemoCode}{} \CrayonDeCompetences[Echelle=0.75,NoirBlanc]% {Chercher/Compétence 1\\Compétence 2,Modéliser/{Compétence 1\\Compétence 2}}% \hspace{1cm} \CrayonDeCompetences[Echelle=0.75,NoirBlanc]% {Chercher/Compétence 1\\Compétence 2,Modéliser/{Compétence 1\\Compétence 2}} \hspace{1cm} \CrayonDeCompetences[Echelle=0.75,NoirBlanc,Largeur,LargeurBloc=3cm]% {Chercher/Compétence 1\\Compétence 2,Modéliser/{Compétence 1\\Compétence 2}} \end{DemoCode} \pagebreak \section{Fenêtre type conversation instantanée} \subsection{Principe et fonctionnement} L'idée est de proposer un environnement pour créer une fenêtre type \textit{conversation instantanée}, basée sur \MontreCode{tcolorbox}. \begin{DemoCode}{listing only} \begin{EnvSMS}[Clés]{nom} \SMSrec(*){heure}{msg} \SMSenv(*){heure}{msg} \end{EnvSMS} \end{DemoCode} \begin{DemoCode}{} \begin{EnvSMS}{\LaTeX} \SMSrec{19:23}{Salut !} \SMSenv{19:23}{Salut!\\ Comment ça va~?} \end{EnvSMS} \end{DemoCode} La forme générale est fixée, et seuls quelques éléments de personnalisation(s) sont modifiables. \subsection{L'environnement} Les \MontreCode{clés} disponibles pour l'environnement, à donner entre \MontreCode{[...]}, sont : \begin{itemize} \item \MontreCode{Hauteur} : hauteur de la fenêtre (automatique ou spécifique) ; \MontreCode{auto} par défaut \item \MontreCode{Largeur} : largeur de la fenêtre (un minimum de 5 cm est conseillé) ; \MontreCode{7cm} par défaut \item \MontreCode{Marge} : marge (G ou D) pour les bulles \MontreCode{1.5cm} par défaut \item \MontreCode{Couleur} : couleur \textit{principale} (bandeau) ; \MontreCode{teal!75!cyan!75!white} par défaut ; \item \MontreCode{CouleurFond} : couleur du fond ; \MontreCode{lightgray!5} par défaut \item \MontreCode{CouleurR} : couleur des bulles de réception ; \MontreCode{lime!25} par défaut \item \MontreCode{CouleurE} : couleur des bulles d'envoi ; \MontreCode{teal!5} par défaut \item \MontreCode{TxtEcrire} : texte dans la zone d'envoi ; \MontreCode{Écrire} par défaut \item \MontreCode{PoliceTxt} : police des textes ; \MontreCode{\textbackslash normalfont} par défaut \item \MontreCode{Avatar} : avatar du contact ; \MontreCode{\textbackslash faAddressCard} par défaut \item \MontreCode{AffAvatar} : booléen pour ajouter l'avatar aux bulles de réception ; \MontreCode{false} par défaut \item \MontreCode{NoirBlanc} : booléen pour forcer un affichage N\&B. \MontreCode{false} par défaut \end{itemize} L'argument, obligatoire et entre \MontreCode{\{...\}}, est le nom du contact à afficher. \subsection{Les commandes de création des bulles} En ce qui concerne les commandes de création des bulles, \MontreCode{\textbackslash SMSrec} et \MontreCode{\textbackslash SMSenv} : \begin{itemize} \item la version \textit{étoilée} n'affiche pas les \textit{coches} de \textit{bonne réception} ; \item le premier argument obligatoire est l'heure à afficher ; \item le deuxième argument obligatoire est le message à afficher (y compris multi-lignes). \end{itemize} \subsection{Exemples} \begin{DemoCode}{} %avec une image personnelle \begin{EnvSMS}% [Largeur=5cm,Hauteur=13cm,AffAvatar,Avatar=Image/avatar]{CP} \SMSrec{19:23}{Salut !} \SMSenv{19:23}{Salut!\\ Comment ça va~?} \SMSrec{19:25}{Je n'arrive pas à un truc en maths\ldots} \SMSenv{19:26}{Tu veux un coup de main ??} \SMSrec{19:28}{Oui, faut qu'je calcule $\int_{0}^{1} x^2e^{-x}\,dx$\ldots} \SMSenv*{19:30}{Je m'en occupe !!} \end{EnvSMS} \end{DemoCode} \begin{DemoCode}{} \begin{EnvSMS}% [Largeur=8cm,PoliceTxt=\sffamily,NoirBlanc]{CP} \SMSrec{19:23}{Salut !} \SMSenv{19:23}{Salut!\\ Comment ça va~?} \SMSrec{19:25}{Je n'arrive pas à un truc en maths\ldots} \SMSenv{19:26}{Tu veux un coup de main ??} \SMSrec{19:28}{Oui, faut que je calcule $\mathsf{\int_{0}^{1} x^2e^{-x}\,dx}$\ldots} \SMSenv*{19:30}{Je m'en occupe !!} \end{EnvSMS} \end{DemoCode} \pagebreak \section{Titre d'exercices} \subsection{Principe et définition du style global} L'idée est de proposer une commande ou un environnement pour afficher, \textit{facilement}, un \textit{titre} pour les exercices d'une évaluation ou d'une fiche d'exercices. \smallskip Les éléments personnalisables sont : \begin{itemize} \item le libellé via la clé \MontreCode{[Libelle]}, qui vaut \MontreCode{Exercice~} par défaut ; \item la couleur via la clé \MontreCode{[Couleur]}, qui vaut \MontreCode{blue!50!black} par défaut ; \item la police via la clé \MontreCode{[Police]}, qui vaut \MontreCode{\textbackslash bfseries\textbackslash LARGE\textbackslash sffamily} par défaut ; \item l'épaisseur du trait (éventuel) via la clé \MontreCode{[EpTrait]}, qui vaut \MontreCode{1.1pt} par défaut. \end{itemize} L'utilisateur peut personnaliser \textit{globalement} les éléments précédents, les styles seront dans ce cas propagés à tous les environnements ou à toutes les commandes créant les titres. \begin{DemoCode}{listing only} %personnalisation(s) \StyleEnvtExo[clés] %paramètres par défaut \StyleEnvtExoDefaut \end{DemoCode} Une fois les styles \textit{choisis}, il suffit d'utiliser la commande d'environnement ou la commande \textit{directe} : \begin{DemoCode}{} %exo1, environnement par défaut \begin{EnvtExo} Ceci est un exercice\ldots \end{EnvtExo} \end{DemoCode} \begin{DemoCode}{} %exo2, macro par défaut \TitreExo Ceci est un exercice\ldots \end{DemoCode} \subsection{Options de personnalisations} Hormis le style global, il est possible de modifier/ajouter certains éléments : \begin{itemize} \item le trait peut être défini : \begin{itemize} \item plein (par défaut) ; \item en pointillés, via \texttt{dotfill} ; \item en \textit{dashillés}, via le package \texttt{dashrulex} ; \end{itemize} \item un complément de titre peut être rajouté ; \item une décoration peut être rajoutée en fin de ligne : \begin{itemize} \item des points, sous la forme \texttt{(xx points)} ; \item une image, via \texttt{graphicx}, dont la hauteur est adaptée à la hauteur de la ligne en cours ; \item une icône, via \texttt{fontawesome5}, dont la hauteur est adaptée à la hauteur de la ligne en cours ; \item un petit chronomètre, via \texttt{pictochrono}, dont la hauteur est adaptée à la hauteur de la ligne en cours ; \item une ceinture colorée, via \texttt{coloredbelts}, dont la hauteur est adaptée à la hauteur de la ligne en cours ; \end{itemize} \item le compteur (nommé \MontreCode{numeroexo}) peut être désactivé et \textit{adpaté} via les commandes classiques de compteurs. \end{itemize} \pagebreak Les \MontreCode{clés} disponibles, à donner entre \MontreCode{[...]}, sont : \begin{itemize} \item \MontreCode{Type} : type de libellés, parmi \MontreCode{Classique} (défaut) ou \MontreCode{Perso/titrepersonnalisé} \item \MontreCode{ComplementTitre} : complément pour la titre, après le numéro (attention aux espaces) ; \item \MontreCode{CodeDebut} : code \LaTeX\ qui sera \textit{rajouté} entre le titre et l'énoncé ; \item \MontreCode{EchelleImage} : pour modifier ponctuellement l'image de décoration ; \item \MontreCode{Compteur} : booléen pour activer/désactiver (\MontreCode{true} par défaut) le compteur (non affiché et non incrémenté) ; \item \MontreCode{Decoration} : choix de la décoration parmi : \begin{itemize} \item \MontreCode{Icone/...} := afficher l'icône \MontreCode{...} à la fin de la ligne ; \item \MontreCode{Image/...} := afficher l'image \MontreCode{...} à la fin de la ligne ; \item \MontreCode{Ceinture/...} := afficher la ceinture couleur \MontreCode{...} à la fin de la ligne ; \item \MontreCode{Chrono/...} := afficher le chrono de durée \MontreCode{...} à la fin de la ligne ; \item \MontreCode{Points/...} := afficher les points \MontreCode{(... points)} à la fin de la ligne ; \end{itemize} \item \MontreCode{Trait} : choix du trait parmi : \begin{itemize} \item \MontreCode{plein} := un trait plain (par défaut) ; \item \MontreCode{non} := aucun trait ; \item \MontreCode{pointilles} := pointilles (\texttt{\textbackslash dotfill}) ; \item \MontreCode{dashilles} := pointilles \textit{dash} (\texttt{\textbackslash hdashrule}). \end{itemize} \end{itemize} \subsection{Exemples} Les exemples suivants ont été obtenus via un document externe (fourni avec le package), du fait du chargement de packages spécifiques. Le code proposé utilise l'environnement, mais la commande simple est complètement compatible également ! \smallskip {\footnotesize\faExclamationTriangle} Les petites \textit{images} ne sont pas incluses dans le package, elles sont là pour illustrer l'utilisation d'images personnelles. \begin{DemoCode}{listing only} \documentclass[a5paper,11pt]{article} \usepackage[margin=1cm]{geometry} \usepackage{customenvs} %facultatif, pour les décorations \usepackage{graphicx} \usepackage{dashrulex} \usepackage{coloredbelts} \usepackage{pictochrono} %mise en page \usepackage{ipsum} \setlength{\parindent}{0pt} \end{DemoCode} \pagebreak \begin{DemoCode}{listing only} \begin{EnvtExo}%exo1 \ipsum \end{EnvtExo} \begin{EnvtExo}[Trait=pointilles]%exo2 \ipsum \end{EnvtExo} \begin{EnvtExo}[Trait=dashilles]%exo3 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Icone/\faPython]%exo4 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Ceinture/rouge]%exo5 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Chrono/20]%exo6 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Image/goku_ssj4]%exo7 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Image/sseiya_shura]%exo8 \ipsum \end{EnvtExo} \begin{EnvtExo}[Decoration=Points/7]%exo9 \ipsum \end{EnvtExo} \begin{EnvtExo}[Type=Perso/{Titre perso }]%exo10 \ipsum \end{EnvtExo} \StyleEnvtExo[Couleur=red,Police=\bfseries\ttfamily,EpTrait=2pt,Libelle={Exercice n°}] \begin{EnvtExo}[Decoration=Icone/\faAddressBook]%exo11 \ipsum \end{EnvtExo} \begin{EnvtExo}[Type=Perso/{Titre perso },Decoration=Chrono/25,Couleur=red,Trait=dashilles]%exo12 \ipsum \end{EnvtExo} \StyleEnvtExoDefaut \begin{EnvtExo}% [Type=Perso/{Titre perso~},Decoration=Image/goku_ssj4,Trait=non,Compteur=false]%exo13 \ipsum \end{EnvtExo} \TitreExo[Type=Perso/{Annexe Exercice 3},Compteur=false,Decoration=Image/sseiya_aiolos]%exo14 \ipsum \end{DemoCode} \pagebreak \begin{DemoCode}{} \includegraphics{envtexo_exemples.pdf} \end{DemoCode} \pagebreak \section{Boîtes divers} \subsection{Introduction} L'idée est de proposer (modestement) des commandes, basées sur \MontreCode{tcolorbox}, pour, avec un style prédéfini : \begin{itemize} \item créer des boîtes de présentation ; \item créer des titres de sujets d'examens, par exemple ; \item créer des titres d'exercices, pour des sujets d'examens par exemple ; \item créer des numéros encadrés ; \item créer de vignettes. \end{itemize} \subsection{Boîtes de présentation} \begin{DemoCode}{listing only} \begin{BoiteSimple}[couleur]{titre} ... \end{BoiteSimple} \end{DemoCode} \begin{DemoCode}{} \begin{BoiteSimple}[red]{Propriété} Si M est la matrice d'adjacence d'un graphe simple orienté de sommets $A_1$, $A_2$, \dots, $A_n$, le nombre de chemins de longueur $p$ d'un sommet $A_i$ à un sommet $A_j$ est le nombre situé ligne $i$ et colonne $j$ dans la matrice $M^p$. \end{BoiteSimple} \end{DemoCode} \begin{DemoCode}{} \begin{BoiteSimple}[blue]{Propriété} Si M est la matrice d'adjacence d'un graphe simple orienté de sommets $A_1$, $A_2$, \dots, $A_n$, le nombre de chemins de longueur $p$ d'un sommet $A_i$ à un sommet $A_j$ est le nombre situé ligne $i$ et colonne $j$ dans la matrice $M^p$. \end{BoiteSimple} \end{DemoCode} \subsection{Titres de sujets d'examens, titres d'exercices} \begin{DemoCode}{listing only} \begin{TitreSujet}[Couleur=...,AlignH=...]{titre onglet} ... \end{TitreSujet} \end{DemoCode} \begin{DemoCode}{} \begin{TitreSujet}[Couleur=red!50!black]{SUJET} Métropole, SIO, 16 Mai 2024 \end{TitreSujet} \end{DemoCode} \begin{DemoCode}{} \begin{TitreSujet}[Couleur=teal,AlignH=center]{CORRIGÉ} Baccalauréat Centres étrangers Groupe 1\\ 14 mars 2023 \end{TitreSujet} \end{DemoCode} \begin{DemoCode}{listing only} \SujetTitreExo[couleur]{titre} \end{DemoCode} \begin{DemoCode}{} \SujetTitreExo{Exercice 4 (5 points)} \SujetTitreExo[olive]{Exercice 1 [Matrices]\dotfill(5 points)} \end{DemoCode} \subsection{Numéros encerclés} \begin{DemoCode}{listing only} \CircledNumber[bg=...,txt=...,bthick=...,bcol=...,raise=true/false]% {nombre}{noeud tikz} \end{DemoCode} \begin{DemoCode}{} En ligne \CircledNumber{1} avec texte après. \end{DemoCode} \begin{DemoCode}{} {\bfseries\sffamily\Huge En ligne (\CircledNumber[bthick=0.25mm,bcol=red,bg=cyan!25,txt=darkgray]{7}) avec texte après} \end{DemoCode} \begin{DemoCode}{} {\Large En ligne \CircledNumber[raise=false,bthick=0.5mm,bcol=cyan,bg=cyan!25,txt=orange]{4} avec texte après} \end{DemoCode} \begin{DemoCode}{} \begin{enumerate}[label={\CircledNumber[raise=false]{\arabic*}}] \item A \item B \item C \end{enumerate} \end{DemoCode} \subsection{Vignettes} \begin{DemoCode}{listing only} \AffVignette(*)[Type=...,Couleur=...,Police=...]{texte} % la version étoilée active le \NoAutoSpacing \end{DemoCode} \begin{DemoCode}{} %vignette de base \AffVignette{test} ou \AffVignette[Couleur=magenta]{test} \end{DemoCode} \begin{DemoCode}{} %vignette type algo \AffVignette[Type=algo]{test} ou \AffVignette[Type=algo,Couleur=teal]{Renvoyer} \end{DemoCode} \begin{DemoCode}{} %vignette type python, classique \AffVignette[Type=py]{test} ou \AffVignette[Type=py,Couleur=lime]{return} %vignette type python, avec piton (et lualatex) %\AffVignette[Type=pypit]{from math import sqrt} %vignette type python, avec piton et pyluatex (et lualatex + shell-escape) %\AffVignette[Type=pyl,Couleur=blue]{1+4/5} \end{DemoCode} \begin{DemoCode}{} %vignette type graphique \AffVignette[Type=grph]{fonction} ou \AffVignette[Couleur=olive,Type=grph]{intersection} \end{DemoCode} \begin{DemoCode}{} %vignette type MPM \AffVignette[Type=mpm]{marge} ou \AffVignette[Type=mpm,Couleur=orange]{chemin} \end{DemoCode} \begin{DemoCode}{} %vignette type xcas \AffVignette[Type=xcas]{calcul formel} ou \AffVignette[Type=xcas,Couleur=brown]{calcul formel} \end{DemoCode} \begin{DemoCode}{} %vignette type shell \AffVignette[Type=shell,Couleur=red!50!orange]{fenêtre cmd} \end{DemoCode} \begin{DemoCode}{} %vignette type LaTeX \AffVignette[Type=tex]{code LaTeX} \end{DemoCode} \begin{DemoCode}{} %vignette type tableur \AffVignette[Type=sheet,Couleur=green!50!black,Police=\footnotesize\sffamily] {cellule A3} \end{DemoCode} \begin{DemoCode}{} %vignette type tableur \AffVignette[Type=perso/CRYPT,Couleur=blue!50!teal,Echelle=0.5] {vignette personnalisée} \end{DemoCode} \begin{DemoCode}{} %création d'une macro personnelle \NewDocumentCommand\VignetteTableur{ m }{% \AffVignette*[Type=sheet,Couleur=green!50!black,Police=\footnotesize\sffamily] {#1} } On se place dans la plage \VignetteTableur{A3:B5} pour... \end{DemoCode} \subsection{Boîte arrondie} \begin{DemoCode}{listing only} \BoiteArrondie[Fond=...,Texte=...,EspH=...,Style=...]{texte}[noeud tikz] \end{DemoCode} \begin{DemoCode}{} On lance le logiciel \BoiteArrondie[Fond=cyan!33,Texte=violet,EspH=2mm,Style=rect]{situé sur le bureau} en cliquant \BoiteArrondie[Fond=lightgray!25,Texte=darkgray]{droit}. \end{DemoCode} \pagebreak \section{Patchs divers} \subsection{Gérer l'espacement vertical du mode hors-ligne} L'idée est de proposer une commande, à insérer dans le préambule, pour \textit{patcher} l'espacement vertical proposé par les environnements mathématiques hors-ligne. \begin{DemoCode}{listing only} ... \ChangerDisplaySkip[clés] ... \begin{document} \end{DemoCode} Les \MontreCode{clés} disponibles, à donner entre \MontreCode{[...]}, sont : \begin{itemize} \item \MontreCode{Avant=...} : modification de l'espacement avant ; \item \MontreCode{AvantS=...} : modification de l'espacement avant (version \textit{short}) ; \item \MontreCode{Apres=...} : modification de l'espacement après ; \item \MontreCode{ApresS=...} : modification de l'espacement après (version \textit{short}) ; \item \MontreCode{Global=...} : modification globale de \textbf{tous} les espacements ; \item \MontreCode{Dense} : booléen pour modification globale en \MontreCode{0.33\textbackslash baselineskip}. \end{itemize} \subsection{Quelques ajouts au package pas-tableur} L'idée est de proposer quelques commandes complémentaires pour le package \textsf{pas-tableur}, de Stéphane Pasquet (\url{https://ctan.org/pkg/pas-tableur}), en respectant autant que faire se peut la syntaxe du package (voir la documentation pour de plus amples informations). \smallskip Le package \textsf{pas-tableur} n'est pas chargé par défaut, mais il peut l'être grâce à l'option \MontreCode{[pastableur]}. \smallskip Les \textit{ajouts} disponibles sont : \begin{itemize} \item colorer/griser une case, via \MontreCode{\textbackslash celcouleur} ; \item fusionner des celules, via \MontreCode{\textbackslash celfusion} ; \item \textit{casser la numérotation} avec des pointillés, via \MontreCode{\textbackslash celnumbreak} ; \item remplir (partiellement ou non) une ligne, via \MontreCode{\textbackslash lignetxt} ; \item remplir (partiellement ou non) une colonne, via \MontreCode{\textbackslash colonnetxt}. \end{itemize} \begin{DemoCode}{listing only} %chargement du package \usepackage[pastableur]{customenvs} %griser une cellule \celcouleur[couleur]{col-lig} %fusionner des cellules \celfusion[options pas-tableur]{col-lig}{col-lig}{label} %pointillés dans la numérotation \celnumbreak{num ligne pointillés}{début numéro suite}{fin numéro suite} %remplir ligne \lignetxt(*)[options pas-tableur]{num ligne}{liste des cellules} %remplir colonne \colonnetxt(*)[options pas-tableur]{num colonne}{liste des cellules} \end{DemoCode} \pagebreak L'exemple suivant illustre les différentes commandes proposées dans ce package. \begin{DemoCode}{} \begin{tikzpicture}{} \tableur*[10]{A/2.5cm,B/2.5cm,C/2.5cm,D/2.5cm,E/2.5cm,F/2.5cm} %ligne n°1 \celtxt*[align=center]{A}{1}{$n$} \celfusion[align=center]{B-1}{C-1}{$M_n$} \celfusion[align=center]{D-1}{E-1}{$S_n$} \celtxt*[align=center]{F}{1}{$d_n$} % %Ligne2/3/4 \celcouleur{A-2} \lignetxt*[align=center]{2}<2>{$x_n$,$y_n$,5,$n$,$n$} %à partir de la colonne n°2 \lignetxt*[align=center]{3}{0,0,0,5,0,5} \lignetxt*[align=center]{4}{1,1,0,5,1,4.12310563}% \celnumbreak{8}{27}{28} %colonneA \colonnetxt*[align=center]{A}<5>{2,3,4,\dots,24,25} %à partir de la ligne n°5 \end{tikzpicture} \end{DemoCode} \end{document}