% !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,a4paper,11pt]{article}
\usepackage[margin=2cm,includefoot]{geometry}
\def\TPversion{0.1.5}
\def\TPdate{22 mai 2025}
\usepackage[utf8]{inputenc}
\usepackage[T1]{fontenc}
\usepackage{amsmath,amssymb}
\usepackage{tikz3d-fr}
\usepackage{awesomebox}
\usepackage{fontawesome5}
\usepackage{footnote}
\makesavenoteenv{tabular}
\usepackage{enumitem}
\usepackage{tabularray}
\UseTblrLibrary{diagbox}
\usepackage{fancyvrb}
\usepackage{fancyhdr}
\fancyhf{}
\renewcommand{\headrulewidth}{0pt}
\lfoot{\sffamily\small [tikz3d-fr]}
\cfoot{\sffamily\small - \thepage{} -}
\rfoot{\hyperlink{matoc}{\small\faArrowAltCircleUp[regular]}}

%\usepackage{hvlogos}
\usepackage{hologo}
\providecommand\tikzlogo{Ti\textit{k}Z}
\providecommand\TeXLive{\TeX{}Live\xspace}
\providecommand\PSTricks{\textsf{PSTricks}\xspace}
\let\pstricks\PSTricks
\let\TikZ\tikzlogo
\newcommand\TableauDocumentation{%
       \begin{tblr}{width=\linewidth,colspec={X[c]X[c]X[c]X[c]X[c]X[c]},cells={font=\sffamily}}
               {\LARGE \LaTeX} & & & & &\\
               & {\LARGE \hologo{pdfLaTeX}} & & & & \\
               & & {\LARGE \hologo{LuaLaTeX}} & & & \\
               & & & {\LARGE \TikZ} & & \\
               & & & & {\LARGE \TeXLive} & \\
               & & & & & {\LARGE \hologo{MiKTeX}} \\
       \end{tblr}
}

\usepackage{hyperref}
\urlstyle{same}
\hypersetup{pdfborder=0 0 0}
\setlength{\parindent}{0pt}
\definecolor{LightGray}{gray}{0.9}

\usepackage{babel}
\AddThinSpaceBeforeFootnotes
\FrenchFootnotes

\usepackage[most]{tcolorbox}
\usetikzlibrary{calc}
\usepackage{minted2}
\tcbuselibrary{minted}
\NewTCBListing{PresCodeTex}{ O{cyan} m }{%
       enhanced,width=0.93\linewidth,flush right,boxrule=0.75pt,colframe=#1!85!black,%
       sharp corners,top=0mm,bottom=0mm,left=0.4em,right=5mm,%
       before skip=\baselineskip,after skip=\baselineskip,%
       colback=white,
       fontupper=\footnotesize,fontlower=\footnotesize,%
       watermark text={\faCode},watermark opacity=0.25,watermark zoom=0.50,%
       title={{\scriptsize\faCode} Code \LaTeX},
       lefttitle=0.4em,
       fonttitle=\bfseries\footnotesize\sffamily,colbacktitle=darkgray!50!#1,%
       listing engine=minted,minted style=colorful,minted language=tex,
       minted options={tabsize=4,fontsize=\footnotesize,autogobble,breaklines=true},
       #2,%
       overlay={\draw[#1!85!black] ($(frame.north west)+(-0.035\linewidth,-0.025\linewidth)$) node[scale=1.66] {\faCode} ;}
}

\NewTCBListing{PresCode}{ O{cyan} m }{%
       enhanced,width=0.93\linewidth,flush right,boxrule=0.75pt,colframe=#1!85!black,%
       sharp corners,top=0mm,bottom=0mm,left=0.4em,right=5mm,%
       before skip=\baselineskip,after skip=\baselineskip,%
       colback=white,
       fontupper=\footnotesize,fontlower=\footnotesize,%
       watermark text={\faCogs},watermark opacity=0.25,watermark zoom=0.50,%
       title={{\scriptsize\faCogs} Code \LaTeX{} et sortie \LaTeX},
       lefttitle=0.4em,
       fonttitle=\bfseries\footnotesize\sffamily,colbacktitle=darkgray!50!#1,%
       listing engine=minted,minted style=colorful,minted language=tex,
       minted options={tabsize=4,fontsize=\footnotesize,autogobble,breaklines=true},
       #2,%
       overlay={%
               \draw[#1!85!black] ($(frame.north west)+(-0.035\linewidth,-0.025\linewidth)$) node[scale=1.66] {\faCode} ;
               \draw[#1!85!black] ($(segmentation.west)+(-0.035\linewidth,-0.025\linewidth)$) node[scale=1.66] {\faFilePdf} ;

       }
}

\NewTCBListing{PresCodeSortie}{ O{cyan} m }{%
       enhanced,width=0.93\linewidth,flush right,boxrule=0.75pt,colframe=#1!85!black,%
       sharp corners,top=0mm,bottom=0mm,left=0.4em,right=5mm,%
       before skip=\baselineskip,after skip=\baselineskip,%
       colback=white,
       fontupper=\footnotesize,fontlower=\footnotesize,%
       watermark text={\faFilePdf},watermark opacity=0.25,watermark zoom=0.50,%
       title={{\scriptsize\faFilePdf} Sortie \LaTeX},
       lefttitle=0.4em,
       fonttitle=\bfseries\footnotesize\sffamily,colbacktitle=darkgray!50!#1,%
       listing engine=minted,minted style=colorful,minted language=tex,
       minted options={tabsize=4,fontsize=\footnotesize,autogobble,breaklines=true},
       #2,%
       overlay={\draw[#1!85!black] ($(frame.north west)+(-0.035\linewidth,-0.025\linewidth)$) node[scale=1.66] {\faFilePdf} ;}
}

\NewTCBListing{PresentationCode}{ O{blue} m }{%
       sharp corners=downhill,enhanced,arc=12pt,skin=bicolor,%
       colback=#1!1!white,colframe=#1!75!black,colbacklower=white,%
       attach boxed title to top right={yshift=-\tcboxedtitleheight},title=Code \LaTeX,%
       boxed title style={%
               colframe=#1!75!black,colback=#1!15!white,%
               ,sharp corners=downhill,arc=12pt,%
       },%
       top=\baselineskip,%
       fonttitle=\color{#1!90!black}\itshape\ttfamily\footnotesize,%
       listing engine=minted,minted style=colorful,
       minted language=tex,minted options={tabsize=4,fontsize=\small,autogobble},
       #2
}

\tcbset{vignettes/.style={%
       nobeforeafter,box align=base,boxsep=0pt,enhanced,sharp corners=all,rounded corners=southeast,%
       boxrule=0.75pt,left=7pt,right=1pt,top=0pt,bottom=0.25pt,%
       }
}

\tcbset{vignetteMaJ/.style={%
       fontupper={\vphantom{pf}\footnotesize\ttfamily},
       vignettes,colframe=ForestGreen!50!black,coltitle=white,colback=purple!25,%
       overlay={\begin{tcbclipinterior}%
                       \fill[fill=purple!75]($(interior.south west)$) rectangle node[rotate=90]{\tiny \sffamily{\textcolor{Black}{\scalebox{0.85}[0.75]{\textbf{MàJ}}}}} ($(interior.north west)+(5pt,0pt)$);%
       \end{tcbclipinterior}}
       }
}

\newcommand\Cle[1]{{\bfseries\sffamily\textlangle #1\textrangle}}
\newcommand\cmaj[1]{\tcbox[vignetteMaJ]{#1}\xspace}

\begin{document}

\setlength{\aweboxleftmargin}{0.07\linewidth}
\setlength{\aweboxcontentwidth}{0.93\linewidth}
\setlength{\aweboxvskip}{8pt}

\pagestyle{fancy}

\thispagestyle{empty}

\vspace{2cm}

\begin{center}
       \begin{minipage}{0.75\linewidth}
       \begin{tcolorbox}[colframe=yellow,colback=yellow!15]
               \begin{center}
                       \begin{tabular}{c}
                               {\Huge \texttt{tikz3d-fr}}\\
                               \\
                               {\LARGE Quelques commandes (fr) pour} \\
                               \\
                               {\LARGE un peu de 3D avec \TikZ.} \\
                       \end{tabular}

                       \bigskip

                       {\small \texttt{Version \TPversion{} -- \TPdate}}
               \end{center}
       \end{tcolorbox}
\end{minipage}
\end{center}

\begin{center}
       \begin{tabular}{c}
       \texttt{Cédric Pierquet}\\
       {\ttfamily c pierquet -- at -- outlook . fr}\\
       \texttt{\url{https://forge.apps.education.fr/pierquetcedric/packages-latex}}
\end{tabular}
\end{center}

\vspace{0.25cm}

{$\blacktriangleright$~~Un environnement avec déclaration des unités.}

\smallskip

{$\blacktriangleright$~~Une commande pour afficher un pavé, avec personnalisations.}

\smallskip

{$\blacktriangleright$~~Deux commandes pour afficher des empilements de \og petits cubes \fg.}

\vspace{1cm}

\begin{center}
       \begin{tcolorbox}[enhanced,colframe=cyan,colback=cyan!2,center,width=0.95\linewidth,drop fuzzy shadow=lightgray]
       \begin{EnvTikzEspace}
               \PaveTikzTriDim[Cube,Largeur=2.5,AffLabel,Couleur=blue!50!black,CouleurSommets=red]
       \end{EnvTikzEspace}

       \vspace*{-2cm}

       \hfill\BlocPetitsCubes[violet]{1,2,3,4,5 / 0,2,1,1,3 / 0,2,1,1,2 / 1,1,1,1,1}\hfill~

       \vspace*{-2cm}

       \def\listecouleursdes{red!25,blue!25,yellow!25,orange!25,green!25}\TirageAleaDesTriDim[EspaceH=-2mm]{5}
       \hfill
       \begin{EmpilementCubes}
               \PlaquePetitsCubes[cyan/red/green/yellow]{ 3111-1-4 / 233123 / 2-1112 }
               \PlaquePetitsCubes[cyan/red]{ 111 / -21 }
               \PlaquePetitsCubes[cyan/red/green]{ 3-2 }
       \end{EmpilementCubes}
       \end{tcolorbox}
\end{center}

\vspace{0.5cm}

%\hfill{}\textit{Merci à Denis Bitouzé et à Gilles Le Bourhis pour leurs retours et idées !}

\smallskip

\vfill

\hrule

\medskip

\TableauDocumentation

\medskip

\hrule

\medskip

\newpage

\phantomsection
\hypertarget{matoc}{}

\tableofcontents

\pagebreak

\part{Historique}

\verb|v0.1.5|~:~~~~Bugfix

\verb|v0.1.4|~:~~~~Bugfix

\verb|v0.1.3|~:~~~~Affichage de dés en 3d (avec aléatoire possible)

\verb|v0.1.2|~:~~~~Option pour l'épaisseur des traits + \textsf{[line join=round]} pour les cubes

\verb|v0.1.1|~:~~~~Tracé des segments individuels avec l'option \textsf{[line cap=round]}

\verb|v0.1.0|~:~~~~Version initiale

\pagebreak

\part{Introduction}

\section{Le package tikz3d-fr}

\subsection{Introduction}

\begin{noteblock}
Le package propose des commandes basiques -- et francisées -- pour travailler sur des figures simples en 3D, à l'aide de \TikZ{} en utilisant des coordonnées tridimensionnelles :

\begin{itemize}
       \item un environnement avec gestion des unités $x/y/z$ ;
       \item une commande pour tracer et personnaliser un cube ;
       \item des commandes pour créer/afficher/nommer des points de l'espace ;
       \item des commandes pour tracer un ou plusieurs segments ;
       \item des commandes et un environnement pour travailler sur des \textit{empilements} de cubes ;
       \item des commandes pour représenter des dés en perspective (avec aléatoire possible).
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{noteblock}

\begin{importantblock}
Il existe d'autres solutions pour travailler avec de la 3D en \LaTeX, comme par exemple les packages \textsf{ProfCollege}\footnotemark\footnotetext{\url{https://www.ctan.org/pkg/profcollege}} (de Christophe Poulain, qui utilise \hologo{MetaPost}, et qui est certainement beaucoup plus performant) ou \textsf{pst-ob3d}\footnotemark\footnotetext{\url{https://www.ctan.org/pkg/pst-ob3d}} (de Herbert Voß et Denis Girou, qui utilise \pstricks).

\smallskip

L'idée est de proposer une utilisation des capacités (natives) 3D de \TikZ, en proposant des commandes \textit{simplifiées} et \textit{francisées} pour des figures simples (tétraèdres, cubes, pyramides, pavés) utilisées fréquemment dans des exercices de géométrie dans l'espace dans l'enseignement secondaires en France.
\end{importantblock}

\subsection{Chargement du package, packages utilisés}

\begin{importantblock}
Le package se charge, de manière classique, dans le préambule.

Il n'existe pas d'option pour le package, et \texttt{xcolor} n'est pas chargé.
\end{importantblock}

\begin{PresCodeTex}{listing only}
\usepackage{tikz3d-fr}
\end{PresCodeTex}

\begin{noteblock}
\textsf{tikz3d-fr} charge les packages suivantes :

\begin{itemize}
       \item \texttt{tikz}, \texttt{xstring}, \texttt{xintexpr}, \texttt{simplekv} et \texttt{xinttools} et \texttt{listofitems}, \texttt{tikz-3dplot} et \texttt{randomlist}  ;
       \item la librairie \texttt{\textit{tikz}.calc}.
\end{itemize}

Il est compatible avec les compilations usuelles en \textsf{latex}, \textsf{pdflatex}, \textsf{lualatex} ou \textsf{xelatex}.
\end{noteblock}

\vfill~

\pagebreak

\part{Environnement 3D et commandes de base}

\section{Création de l'environnement}

\subsection{Commande}

\begin{cautionblock}
L'environnement dédié à la création de figures en 3D avec \TikZ{} est \texttt{EnvTikzEspace}.

Il permet de définir les unités et \textit{angles} des différents axes.
\end{cautionblock}

\begin{PresCodeTex}{listing only}
\begin{EnvTikzEspace}[Clés]<options tikz>
       %commandes
\end{EnvTikzEspace}
\end{PresCodeTex}

\subsection{Clés et options}

\begin{tipblock}
Le premier argument, optionnel et entre \texttt{[...]} propose les \Cle{clés} suivantes :

\begin{itemize}
       \item \Cle{UniteX}, à donner sous la forme \Cle{\{angle\string:longueur\}} pour le vecteur de base $\vec{\imath}$ ;

       \hfill{}défaut : \Cle{\{-15\string:1cm\}},%
       \item \Cle{UniteY}, à donner sous la forme \Cle{\{angle\string:longueur\}} pour le vecteur de base $\vec{\jmath}$ ;

       \hfill{}défaut : \Cle{\{20\string:0.65cm\}}
       \item \Cle{UniteZ}, à donner sous la forme \Cle{\{angle\string:longueur\}} pour le vecteur de base $\vec{k}$ ;

       \hfill{}défaut : \Cle{\{90\string:1cm\}}
       \item Le booléen \Cle{VueClassique} pour un affichage en perspective habituelle.\hfill~défaut : \Cle{false}
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{tipblock}

\begin{tipblock}
Le second argument, optionnel et entre \texttt{<...>} est quant à lui relatif à des arguments à passer à l'environnement \TikZ{} créé, comme par exemple un alignement vertical, etc
\end{tipblock}

\begin{PresCode}{}
\begin{EnvTikzEspace}
       \draw[->,>=latex] (0,0,0)--(1,0,0) node[right] {$\vec{\imath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,1,0) node[right] {$\vec{\jmath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,0,1) node[above] {$\vec{k}$} ;
\end{EnvTikzEspace}
\end{PresCode}

\begin{PresCode}{}
\begin{EnvTikzEspace}[UniteX={-145:1.25cm},UniteY={0:1.75cm},UniteZ={90:1.75cm}]
       \draw[->,>=latex] (0,0,0)--(1,0,0) node[right] {$\vec{\imath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,1,0) node[right] {$\vec{\jmath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,0,1) node[above] {$\vec{k}$} ;
\end{EnvTikzEspace}
\end{PresCode}

\begin{PresCode}{}
\begin{EnvTikzEspace}[VueClassique]
       \draw[->,>=latex] (0,0,0)--(1,0,0) node[right] {$\vec{\imath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,1,0) node[right] {$\vec{\jmath}$} ;
       \draw[->,>=latex] (0,0,0)--(0,0,1) node[above] {$\vec{k}$} ;
\end{EnvTikzEspace}
\end{PresCode}

\begin{noteblock}
Une fois l'environnement, via son \textit{repère}, est créé, toute commande en \TikZ{} est utilisable avec les coordonnées \texttt{(x,y,z)} ou bien les \texttt{scope} avec les \texttt{canva}.
\end{noteblock}

\begin{PresCode}{}
\begin{EnvTikzEspace}[UniteX={-145:0.575cm},UniteY={0:0.7cm},UniteZ={90:0.7cm}]
       \filldraw[red] (2,4,3) circle[radius=1pt] ; \draw[red] (0,0,0) -- (2,4,3) ;
       \draw[thin,->,>=latex] (0,0,0)--(3,0,0) ;
       \draw[thin,->,>=latex] (0,0,0)--(0,5,0) ;
       \draw[thin,->,>=latex] (0,0,0)--(0,0,4) ;
       \draw[->,>=latex] (0,0,0)--(1,0,0) ;
       \draw[->,>=latex] (0,0,0)--(0,1,0) ;
       \draw[->,>=latex] (0,0,0)--(0,0,1) ;
       \draw[dashed] (0,0,3)--(2,4,3)--(2,4,0)--(0,0,0) (2,4,0)--(2,0,0) (2,4,0)--(0,4,0) ;
\end{EnvTikzEspace}
\end{PresCode}

\pagebreak

\section{Points et segments}

\subsection{Commandes}

\begin{cautionblock}
Les commandes \textit{simplifiées} et \textit{francisées} disponibles sont :

\begin{itemize}
       \item \texttt{\textbackslash PlacePointEspace} pour placer un point dans l'espace ;
       \item \texttt{\textbackslash PlacePointsEspace} pour placer des points dans l'espace ;
       \item \texttt{\textbackslash MarquePointEspace} pour marquer (matérialiser) un point dans l'espace ;
       \item \texttt{\textbackslash MarquePointsEspace} pour marquer (matérialiser) un point dans l'espace ;
       \item \texttt{\textbackslash TraceSegmentEspace} pour tracer un segment dans l'espace ;
       \item \texttt{\textbackslash TraceSegmentsEspace} pour tracer des segments dans l'espace.
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{cautionblock}

\begin{PresCodeTex}{listing only}
\begin{EnvTikzEspace}[Clés]<options tikz>
       %créer/placer/nommer un point
       \PlacePointEspace(*)[clés]{nœud}{coordonnées}<label>
       %créer/placer/nommer plusieurs points
       \PlacePointsEspace(*)[clés]{liste}
       %marquer un point
       \MarquePointEspace[clés]{point}
       %marquer plusieurs points
       \MarquePointsEspace[clés]{liste}
       %tracer un segment
       \TraceSegmentEspace[clés](point)(point)
       %tracer plusieurs segments
       \TraceSegmentsEspace[clés]{liste}
\end{EnvTikzEspace}
\end{PresCodeTex}

\subsection{Clés, options et arguments}

\begin{tipblock}
Les versions étoilées désactivent l'affichage des labels des points.

\smallskip

L'argument optionnel et entre \texttt{[...]} propose les \Cle{clés} suivantes (communes ou spécifiques) :

\begin{itemize}
       \item \Cle{PosLabel} pour préciser la position (francisée) du label pour les points ; \hfill{}défaut : \Cle{b}
       \item \Cle{StyleMarque} parmi \Cle{x/o} pour spécifier le style de la marque des points ;

       \hfill{}défaut : \Cle{o}
       \item \Cle{TailleMarque} pour spécifier la taille de la marque des points (disque ou croix) ;

       \hfill{}défaut : \Cle{2pt}
       \item \Cle{Couleur} pour paramétrer la couleur.\hfill{}défaut : \Cle{black}
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{tipblock}

\begin{tipblock}
Les positions pour les labels des points sont \textit{francisées} :

\begin{itemize}
       \item \Cle{b} : \texttt{bas}
       \item \Cle{h} : \texttt{haut}
       \item \Cle{g} : \texttt{gauche}
       \item \Cle{d} : \texttt{droite}
       \item \Cle{hg} : \texttt{haut gauche}
       \item \ldots
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{tipblock}

\begin{tipblock}
De manière un peu plus spécifique :

\begin{itemize}
       \item le \texttt{<label>} pour la commande \texttt{\textbackslash PlacePointEspace} est optionnel, et est identique à \texttt{\{nœud\}} ;
       \item la \texttt{\{liste\}} pour la commande \texttt{\textbackslash PlacePointsEspace} est à donner -- par exemple -- sous la forme \texttt{A/0,0,0/bg B/5,2,1/hd} ;
       \item la \texttt{\{liste\}} pour la commande \texttt{\textbackslash TraceSegmentsEspace} est à donner -- par exemple -- sous la forme \texttt{A/B A/C A/D B/D} ;
       \item les \texttt{[clés]} pour les segments correspondent aux options en langage \TikZ.
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{tipblock}

\begin{PresCode}{}
\begin{EnvTikzEspace}[VueClassique]
       %placement des points avec labels
       \PlacePointsEspace[Couleur=red]{A/0,0,0/bg B/4,0,0/bd C/4,4,0/hd D/0,4,0/hg E/0,0,4/bg F/4,0,4/bd G/4,4,4/hd H/0,4,4/hg}
       %segments pointillés
       \TraceSegmentsEspace[thick,dashed,purple]{A/D D/C D/H}
       %segments pleins
       \TraceSegmentsEspace[thick,blue]{A/B B/C C/G G/H H/E E/A E/F B/F F/G}
       %Marques points
       \MarquePointsEspace[Couleur=orange]{A,B,C,D,E,F,G,H}
\end{EnvTikzEspace}
\end{PresCode}

\pagebreak

\section{Pavés}

\subsection{Commandes}

\begin{cautionblock}
La commande \textit{simplifiée} et \textit{francisée} pour afficher un pavé (ou un cube !) est la commande \texttt{\textbackslash PaveTikzTriDim}.
\end{cautionblock}

\begin{PresCodeTex}{listing only}
\begin{EnvTikzEspace}[Clés]<options tikz>
       \PaveTikzTriDim[clés]
\end{EnvTikzEspace}
\end{PresCodeTex}

\begin{PresCode}{}
\begin{EnvTikzEspace}[VueClassique]
       \PaveTikzTriDim
\end{EnvTikzEspace}
\hspace{1cm}
\begin{EnvTikzEspace}
       \PaveTikzTriDim
\end{EnvTikzEspace}
\end{PresCode}

\subsection{Clés et options}

\begin{tipblock}
Quelques \Cle{clés} sont disponibles pour cette commande :

\begin{itemize}
       \item \Cle{Largeur} : largeur du pavé ;\hfill{}défaut \Cle{2}
       \item \Cle{Profondeur} : profondeur du pavé ;\hfill{}défaut \Cle{1}
       \item \Cle{Hauteur} : hauteur du pavé ;\hfill{}défaut \Cle{1.25}
       \item \Cle{Sommets} : liste des sommets (avec délimiteur § !) ;\hfill{}défaut \Cle{A§B§C§D§E§F§G§H}
       \item \Cle{Math} : booléen pour forcer le mode math des sommets ;\hfill{}défaut \Cle{false}
       \item \Cle{Epaisseur} : épaisseur des arêtes (en \textit{langage simplifié} \TikZ) ;\hfill{}défaut \Cle{thick}
       \item \Cle{AffLabel} : booléen pour afficher les noms des sommets ;\hfill{}défaut \Cle{false}
       \item \Cle{Plein} : booléen pour ne pas afficher les arêtes \textit{invisibles} ;\hfill{}défaut \Cle{false}
       \item \Cle{Cube} : booléen pour préciser qu'il s'agit d'un cube (seule \Cle{Largeur} est util(isé)e) ;

       \hfill{}défaut \Cle{false}
       \item \Cle{Couleur} : couleur des arêtes ; \hfill{}défaut \Cle{black}

       \item \Cle{CouleurSommets} : couleur des sommets.\hfill{}défaut \Cle{black}
\end{itemize}
\vspace*{-\baselineskip}\leavevmode
\end{tipblock}

\pagebreak

\begin{PresCode}{}
\begin{EnvTikzEspace}
       \PaveTikzTriDim[Cube,Largeur=3,Couleur=red,CouleurSommets=blue,AffLabel]
\end{EnvTikzEspace}
\end{PresCode}

\begin{PresCode}{}
\begin{EnvTikzEspace}[VueClassique]<scale=2>
       \PaveTikzTriDim[Largeur=3,Profondeur=4,Hauteur=2,Plein,Couleur=gray,AffLabel, CouleurSommets=gray]
\end{EnvTikzEspace}
\end{PresCode}

\newpage

\part{Empilements de cubes}

\section{Environnement dédié}

\begin{cautionblock}
L'environnement dédié à la création de figures type \textit{empilement de cubes} est\ldots{} \texttt{EmpilementCubes}.

Il existe deux manières de définir les empilements :

\begin{itemize}
       \item en travaillant par \textit{plaques} verticales de l'arrière vers l'avant ;
       \item en travaillant par les \textit{hauteurs} des colonnes, de l'arrière vers l'avant \textbf{et} de gauche à droite.
\end{itemize}

L'unité de base des cubes est fixée au départ à $0{,}5$\,cm.
\end{cautionblock}

\begin{importantblock}
Les axes (et de ce fait la vue proposée !) sont fixés, non modifiables, donc cette partie est beaucoup moins performante que ce propose le package \textsf{ProfCollege} avec sa commande \texttt{\textbackslash VueCubes} !
\end{importantblock}

\begin{PresCodeTex}{listing only}
\begin{EmpilementCubes}[échelle]<options tikz>
       %commandes
\end{EmpilementCubes}
\end{PresCodeTex}

\section{Création par \textit{plaques}}

\subsection{Commandes}

\begin{cautionblock}
La commande pour créer une plaque \textit{verticale} est \texttt{\textbackslash PlaquePetitsCubes}, avec la contrainte de créer la \textit{figure} de l'arrière vers l'avant.

Il existe également la commande \texttt{\textbackslash PlaqueVide} pour \textit{passer} une ligne.
\end{cautionblock}

\begin{PresCodeTex}{listing only}
\begin{EmpilementCubes}[échelle]<options tikz>
       \PlaquePetitsCubes[couleur(s)]{empilement}[épaisseur traits]
       \PlaqueVide[nb]
\end{EmpilementCubes}
\end{PresCodeTex}

\begin{importantblock}
Les plaques créées sont affichées l'une \textit{devant} l'autre, et elles sont -- par défaut -- collées les unes aux autres.
\end{importantblock}

\subsection{Options et arguments}

\begin{tipblock}
Le premier argument, optionnel et entre \texttt{[...]} permet de spécifier une couleur (\texttt{cyan} par défaut) ou une liste de couleurs qui seront utilisées pour la création des plaques :

\begin{itemize}
       \item soit une couleur unique, qui sera \textit{codée} par \texttt{1} pour la création des cubes ;
       \item soit plusieurs couleurs, sous la forme \texttt{couleur1/couleur2/couleur3/...} qui seront codées par \texttt{1}, \texttt{2}, \ldots{} pour la création des cubes.
\end{itemize}

Le second argument, obligatoire et entre \texttt{\{...\}} est quant à lui la liste, des lignes à construire, avec comme ordres :

\begin{itemize}
       \item du bas vers le haut (caractère de séparation \texttt{/}) ;
       \item de la gauche vers la droite (caractère de séparation \texttt{,}) ;
       \item un \texttt{-} code un \textit{trou}, et un numéro code une couleur (comme définie(s) précédemment).
\end{itemize}

Le dernier argument, optionnel et entre \texttt{[...]} permet de spécifier une dimension pour les tracés (\texttt{0.2pt} par défaut).

\medskip

Cette manière permet de créer des plaques avec couleurs \textit{individuelles} et des \textit{trous} éventuels.
\end{tipblock}

\begin{PresCode}{}
\begin{EmpilementCubes}
       %plaque
       %de bas en haut : couleurs VBRB-B-J / RVVBRV / J-BBBR
       \PlaquePetitsCubes[cyan/red/green/yellow]{ 3121-1-4 / 233123 / 4-1112 }
\end{EmpilementCubes}
\end{PresCode}

\begin{PresCode}{}
\begin{EmpilementCubes}
       %plaque n°1 (fond)
       \PlaquePetitsCubes{ 1111 / 1111 }[0.4pt]
       \PlaqueVide[2]
       %plaque n°2
       \PlaquePetitsCubes[cyan/red]{ 111- / -211  }[0.4pt]
       \PlaqueVide[2]
       %plaque n°3 (devant)
       \PlaquePetitsCubes{ 1111 / ---1 }[0.4pt]
\end{EmpilementCubes}
\end{PresCode}

\begin{PresCode}{}
\begin{EmpilementCubes}
       %plaque n°1 (fond)
       \PlaquePetitsCubes{ 1111 / 1111 }
       %plaque n°2
       \PlaquePetitsCubes[cyan/red]{ 111- / -211  }
       %plaque n°3 (devant)
       \PlaquePetitsCubes{ 1111 / ---1 }
\end{EmpilementCubes}
\end{PresCode}


\begin{PresCode}{}
\begin{EmpilementCubes}[1.75]
       \PlaquePetitsCubes[cyan/red/green/yellow]{ 3111-1-4 / 233123 / 2-1112 }[1pt]
       \PlaquePetitsCubes[cyan/red]{ 111 / -21 }[1pt]
       \PlaquePetitsCubes[cyan/red/green]{ 3-2 }[1pt]
\end{EmpilementCubes}
\end{PresCode}

\pagebreak

\section{Création par \textit{hauteurs}}

\subsection{Commande}

\begin{tipblock}
L'idée, reprise du package \textsf{ProfCollege}\footnotemark\footnotetext{\url{https://www.ctan.org/pkg/profcollege}} permet d'afficher une empilement de cubes (monochromes, et sans trou) en précisant -- grâce à un système de \textit{grille} -- les hauteurs des colonnes.

La commande qui permet de réaliser cet empilement est \texttt{\textbackslash BlocPetitsCubes}.
\end{tipblock}

\begin{PresCodeTex}{listing only}
%création dans un environnement dédié
\begin{EmpilementCubes}[échelle]<options tikz>
       \BlocPetitsCubes*[couleur]{grille des hauteurs}[epaisseur traits]
\end{EmpilementCubes}
\end{PresCodeTex}

\begin{PresCodeTex}{listing only}
%création autonome
\BlocPetitsCubes[couleur]{grille des hauteurs}[epaisseur traits]
\end{PresCodeTex}

\begin{cautionblock}
Le support de la grille des hauteurs est donc à donner sous forme \textit{rectangulaire}, en respectant un nombre \textit{homogène} de colonnes par ligne !
\end{cautionblock}

\begin{importantblock}
Voici une grille permettant d’anticiper la création d'un assemblage (en spécifiant les hauteurs) :

\begin{center}
       \begin{EnvTikzEspace}[UniteX={-22:1cm},UniteY={22:1cm}]
               \foreach \x in {0,...,4} {\draw[semithick] (\x,-0.2,0)--++(0,5.4,0) ;}
               \foreach \y in {0,...,5} {\draw[semithick] (-0.2,\y,0)--++(4.4,0,0) ;}
               \foreach \y/\n in {0.5/1,1.5/2,2.5/3,3.5/4,4.5/5}
                       {\draw (0.5,\y,0) node[font=\small\sffamily] {\n} ;}
               \foreach \y/\n in {0.5/0,1.5/2,2.5/1,3.5/1,4.5/3}
                       {\draw (1.5,\y,0) node[font=\small\sffamily] {\n} ;}
               \foreach \y/\n in {0.5/0,1.5/2,2.5/1,3.5/1,4.5/2}
                       {\draw (2.5,\y,0) node[font=\small\sffamily] {\n} ;}
               \foreach \y/\n in {0.5/1,1.5/1,2.5/1,3.5/1,4.5/1}
                       {\draw (3.5,\y,0) node[font=\small\sffamily] {\n} ;}
       \end{EnvTikzEspace}
\end{center}
\end{importantblock}

\subsection{Options et arguments}

\begin{tipblock}
Le premier argument, optionnel et entre \texttt{[...]} permet de spécifier une couleur (\texttt{cyan} par défaut).

Le second argument, obligatoire et entre \texttt{\{...\}} est quant à lui la liste des hauteurs, comme présentée précédemment :

\begin{itemize}
       \item le caractère de séparation des \textit{plaques} est le \texttt{/} ;
       \item pour chaque plaque, le caractère de séparation des colonnes est le \texttt{,}.
\end{itemize}

Le dernier argument, optionnel et entre \texttt{[...]} permet de spécifier une dimension pour les tracés (\texttt{0.2pt} par défaut).
\end{tipblock}

\begin{importantblock}
Par exemple, la \textit{grille} associée à l'empilement précédent est :

\smallskip

\hfill\texttt{1,2,3,4,5 / 0,2,1,1,3 / 0,2,1,1,2 / 1,1,1,1,1}\hfill~
\end{importantblock}

\vfill~

\begin{PresCode}{}
\begin{EmpilementCubes}
       \BlocPetitsCubes*{1,2,3,4,5}
\end{EmpilementCubes}
\end{PresCode}

\begin{PresCode}{}
%commande autonome, taille par défaut
\BlocPetitsCubes{1,2,3,4,5 / 0,2,1,1,3 / 0,2,1,1,2 / 1,1,1,1,1}
\end{PresCode}

\begin{PresCode}{}
\begin{EmpilementCubes}[2]
       \BlocPetitsCubes*[violet]{1,2,3,4,5 / 0,2,1,1,3 / 0,2,1,1,2 / 1,1,1,1,1}[0.8pt]
\end{EmpilementCubes}
\end{PresCode}

\newpage

\part{Dés à jouer, en 3D}

\section{Fonctionnement global}

\begin{tipblock}
L'idée est de proposer des commandes pour travailler avec des dés, en 3D, avec possibilité de les \textit{lancer} de manière aléatoire.

\smallskip

La commande peut être autonome pour afficher dé par dé, mais elle peut être également à intégrer dans un environnement \texttt{tikzpicture}.
\end{tipblock}

\begin{importantblock}
Par défaut, les dés ont une hauteur proche de 1~cm (sans la perspective).

\smallskip

L'orientation est \textit{globalement} fixée, mais il est possible (dans une certaine mesure) de pivoter les dés (suivants les angles $\theta$ et $\phi$ des coordonnées sphériques).

\smallskip

Il est également possible de spécifier un \textit{angle de vue}, droite ou gauche.
\end{importantblock}


\begin{PresCodeTex}{listing only}
%affichage indépendant
\DeTriDim[clés]{numéro(s)}
\end{PresCodeTex}

\begin{PresCodeTex}{listing only}
%affichage dans un environnement
\begin{tikzpicture}
       \DeTriDim*[clés]{numéro(s)}
\end{tikzpicture}
\end{PresCodeTex}

\begin{PresCodeTex}{listing only}
%tirages aléatoires
\TirageAleaDesTriDim[clés]{tirages}
\end{PresCodeTex}

\begin{PresCode}{}
\DeTriDim{6/2}~\DeTriDim{1/5}~\DeTriDim{6/4}~\DeTriDim{3/2}
\end{PresCode}

\begin{PresCode}{}
\begin{tikzpicture}
       %\tdplotsetmaincoords{70}{110}
       \DeTriDim*[Echelle=2]{6/2}
       \DeTriDim*[Echelle=2,Origine={(2,-0.2)}]{6/5}
       \DeTriDim*[Echelle=2,Origine={(4,-0.4)},]{6/3}
       \DeTriDim*[Echelle=2,Origine={(6,-0.6)},Hasard]{}
\end{tikzpicture}
\end{PresCode}

\begin{PresCode}{}
\TirageAleaDesTriDim[Vue=G,Yams,Echelle=3,Couleurs={red!25,blue!25,yellow!25}]{3}
\end{PresCode}

\section{Influence des paramètres}

\subsection{Clés et options}

\begin{tipblock}
Quelques \Cle{clés} sont disponibles pour cette commande (elles ne sont pas toutes utilisées par les toutes les commandes) :

\begin{itemize}
       \item \Cle{Echelle} : échelle pour modifier la taille ;\hfill{}défaut \Cle{1}
       \item \Cle{Couleur} : couleur (individuelle) ;\hfill{}défaut \Cle{lightgray!25}
       \item \Cle{CouleurPoints} : couleurs des points ;\hfill{}défaut \Cle{black}
       \item \Cle{Phi} : angle $\phi$ de la perpective ;\hfill{}défaut \Cle{110}
       \item \Cle{Theta} : angle $\theta$ de la perpective ;\hfill{}défaut \Cle{70}
       \item \Cle{Vue} : vue de la perspective (\texttt{D/G}) ;\hfill{}défaut \Cle{D}
       \item \Cle{Hasard} : booléen pour un tirage aléatoire ;\hfill{}défaut \Cle{false}
       \item \Cle{Origine} : origine du dé pour la version \texttt{tikzpicture} ;
       \item en ce qui concerne les clés spécifiques au tirage :
       \begin{itemize}
               \item \Cle{EspaceH} : espace horizontal entre les dés ;\hfill{}défaut \Cle{0mm}
               \item \Cle{Couleurs} : liste des couleurs pour les dés ;\hfill{}défaut \Cle{lightgray!25}
               \item \Cle{Yams} : booléen pour forcer un affichage en ligne.\hfill{}défaut \Cle{false}
       \end{itemize}
\end{itemize}

Hormis dans le cas où \texttt{Harsard=true}, l'argument obligatoire, pour l'affichage unique, est à donner sous la forme \texttt{face de devant/face du dessus} (l'autre face visible est déterminée automatiquement).
\end{tipblock}

\subsection{Exemples}

\begin{PresCode}{}
\TirageAleaDesTriDim[EspaceH=-2mm]{5}

\TirageAleaDesTriDim[EspaceH=1mm,Echelle=2,Couleurs=darkgray,CouleurPoints=white]{5}
\end{PresCode}

\begin{PresCode}{}
\def\listecouleursdes{red!25,blue!25,yellow!25,orange!25,green!25}

\TirageAleaDesTriDim[Yams,Couleurs=brown!10]{10}

\TirageAleaDesTriDim[Yams,Echelle=2,Couleurs=\listecouleursdes,CouleurPoints=magenta]{5}

\TirageAleaDesTriDim[Vue=G,Yams,Echelle=3,Couleurs=\listecouleursdes]{3}
\end{PresCode}

\subsection{Angles de rotation}

\begin{cautionblock}
Les paramètres $\theta$ et $\phi$ peuvent être modifiés, en fonction du rendu souhaité.

Mais comme toutes les faces ne sont pas traitées (du fait de la perspective), il est conseillé de rester dans une \textit{fenêtre classique}.
\end{cautionblock}

\begin{tipblock}
Vue \texttt{D} :

\begin{tblr}{hlines,vlines,colspec={*{5}{Q[m,c]}}}
       \diagbox{$\phi$}{$\theta$} & 60 & \textbf{70} & 80 & 85 \\
       95 & \DeTriDim[Hasard,Theta=60,Phi=95]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=70,Phi=95]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=80,Phi=95]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=85,Phi=95]<baseline=0pt>{} \\
       100 & \DeTriDim[Hasard,Theta=60,Phi=100]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=70,Phi=100]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=80,Phi=100]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=85,Phi=100]<baseline=0pt>{} \\
       \textbf{110} & \DeTriDim[Hasard,Theta=60,Phi=95]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=70,Phi=110,Couleur=red!25]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=80,Phi=110]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=85,Phi=110]<baseline=0pt>{} \\
       120 & \DeTriDim[Hasard,Theta=60,Phi=120]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=70,Phi=120]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=80,Phi=120]<baseline=0pt>{} & \DeTriDim[Hasard,Theta=85,Phi=120]<baseline=0pt>{} \\
\end{tblr}
\end{tipblock}

\begin{tipblock}
Vue \texttt{G} :

\begin{tblr}{hlines,vlines,colspec={*{5}{Q[m,c]}}}
       \diagbox{$\phi$}{$\theta$} & 60 & \textbf{70} & 80 & 85 \\
       95 & \DeTriDim[Vue=G,Hasard,Theta=60,Phi=95]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=70,Phi=95]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=80,Phi=95]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=85,Phi=95]<baseline=0pt>{} \\
       100 & \DeTriDim[Vue=G,Hasard,Theta=60,Phi=100]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=70,Phi=100]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=80,Phi=100]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=85,Phi=100]<baseline=0pt>{} \\
       \textbf{110} & \DeTriDim[Vue=G,Hasard,Theta=60,Phi=95]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=70,Phi=110,Couleur=red!25]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=80,Phi=110]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=85,Phi=110]<baseline=0pt>{} \\
       120 & \DeTriDim[Vue=G,Hasard,Theta=60,Phi=120]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=70,Phi=120]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=80,Phi=120]<baseline=0pt>{} & \DeTriDim[Vue=G,Hasard,Theta=85,Phi=120]<baseline=0pt>{} \\
\end{tblr}
\end{tipblock}


\end{document}