%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Documentation for the tikzlings package % A package to bring cute little animals and other beings into tikz % Maintained by samcarter % % Project repository and bug tracker: % https://github.com/samcarter/tikzlings % % Released under the LaTeX Project Public License v1.3c or later % See https://www.latex-project.org/lppl.txt % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % arara: latexmk \documentclass{scrartcl} % meta %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \title{The \texorpdfstring{\tikzlings}{tikzlings} package} \subtitle{drawing animals and beings in \TikZ} \author{% \texorpdfstring{ \begin{tikzpicture} \penguin \end{tikzpicture}\\[0.8em] \texttt{samcarter}\\ \url{https://github.com/samcarter/tikzlings}\\ \url{https://www.ctan.org/pkg/tikzlings} }{samcarter}} \date{Version v2.2 \textendash{} 2025/01/05} \usepackage[ themecolor=samviolet ]{\jobname-settings} \selectcolormodel{rgb} \colorlet{blue}{samlblue} % packages %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \usepackage{tikzlings} \usepackage{bearwear} \usetikzlibrary{3d} \usetikzlibrary{tikzlings} % including commented lines from the .sty files %%%%%%%%%%%%%%%%%%%%%% % thanks to Phelype Oleinik https://topanswers.xyz/tex?q=1861#a2092 \ExplSyntaxOn \makeatletter \iow_new:N \l__tikzlings_iow \tl_new:N \l__tikzlings_file_name_tl \NewDocumentCommand \CommentInput { m } { \tikzlings_comment_input:n {#1} } \cs_new_protected:Npn \tikzlings_comment_input:n #1 { \file_get_full_name:nNTF {#1} \l__tikzlings_file_name_tl { \__tikzlings_comment_input: } { \msg_error:nnn { tikzlings } { file-not-found } {#1} } } \msg_new:nnn { tikzlings } { file-not-found } { File~'#1'~not~found. } \cs_new_protected:Npn \__tikzlings_comment_input: { \group_begin: \cctab_select:N \c_other_cctab \int_set:Nn \tex_endlinechar:D { `\^^M } \use:x { \tex_everyeof:D { \exp_not:N \q_nil \char_generate:nn { 13 } { 13 } } } \char_set_active_eq:NN \^^M \__tikzlings_process_line:w \char_set_catcode_active:N \^^M \iow_open:Nn \l__tikzlings_iow { \c_sys_jobname_str . cif } % cif => comment input file \exp_after:wN \__tikzlings_process_line:w \tex_input:D { \l__tikzlings_file_name_tl } \iow_close:N \l__tikzlings_iow \group_end: \declare@file@substitution { \l__tikzlings_file_name_tl } { \c_sys_jobname_str . cif } \input { \l__tikzlings_file_name_tl } \undeclare@file@substitution { \l__tikzlings_file_name_tl } } \group_begin: \char_set_catcode_active:N \^^M \char_set_active_eq:NN \^^M \scan_stop: \cs_new_protected:Npx \__tikzlings_process_line:w #1 ^^M { \exp_not:N \__tikzlings_parse_line:w ^^M #1 ^^M \c_percent_str \s_stop } \cs_set_protected:Npn \__tikzlings_tmp:w #1 { \cs_new_protected:Npn \__tikzlings_parse_line:w ##1 ^^M #1 ##2 \s_stop { \tl_if_empty:nTF {##1} { \peek_charcode_remove:NTF #1 { \__tikzlings_ignore_line:w } { \__tikzlings_output_line:w } ##2 \s_stop ^^M } { \tl_set:Nx \l_tmpa_tl { \tl_tail:n {##1} } \tl_if_eq:NNF \l_tmpa_tl \q_nil { ^^M } } } \cs_new_protected:Npn \__tikzlings_output_line:w ##1 ^^M #1 \s_stop { \iow_now:Nn \l__tikzlings_iow {##1} } \cs_new_protected:Npn \__tikzlings_ignore_line:w ##1 \s_stop { } } \exp_args:No \__tikzlings_tmp:w { \c_percent_str } \group_end: \makeatother \ExplSyntaxOff % customisation %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \deftocheading{toc}{}% \setcounter{tocdepth}{1} \newcommand*\gobbleentrynumber[1]{} \newcommand*\mytocformat[1]{#1} \newcommand*\mytocpageformat[1]{#1} \makeatletter \RedeclareSectionCommand[ toclinefill=\hyper@linkstart{link}{\Hy@tocdestname}\TOCLineLeaderFill\hyper@linkend, tocnumwidth=0pt, tocentrynumberformat=\gobbleentrynumber, tocentryformat=\mytocformat, tocpagenumberformat=\mytocpageformat, tocbeforeskip=0.8ex plus 1pt minus 1pt ]{section} \renewcommand{\sectionlinesformat}[4]{% \Ifstr{#1}{section}{% \parbox[t]{\linewidth}{% \raggedsection\@hangfrom{\hskip #2#3}{#4}\par% \kern-.75\ht\strutbox\rule{\linewidth}{.8pt}% }% }{% \@hangfrom{\hskip #2#3}{#4}}% } \makeatother \renewcommand*{\subsectionformat}{} \renewcommand*{\sectionformat}{} \pgfmathsetseed{2} \setlength{\footheight}{50pt} \cfoot{\thepage} \cfoot{% \begin{tikzpicture}[scale=0.5] \tikzling[signpost={\thepage}] \end{tikzpicture} } \pagestyle{scrheadings} \tcbset{% tikz lower, height plus=3cm, } \newcommand{\coatihookbackground}{\path (-1.63,0.1) rectangle (1.63,2.26);} \newcommand{\mousehookbackground}{\path (-1.6,0.1) rectangle (0.905, 2.17);} \newcommand{\cathookbackground}{\path (-1.6,0.1) rectangle (0.905, 2.17);} \begin{document} \maketitle \thispagestyle{scrheadings} \section*{Introduction} \label{intro} The \tikzlings are a collection of little animals (and beings) drawn in \TikZ. It is the next evolutionary phase of the \tikzmarmots package extending it with further animals (and beings) and also adding the ability to natively use many of the accessories known from the \tikzducks package. This package is work in progress, therefore I would be happy to hear your feedback and ideas how to improve the package. The head version of the source code can be found on \url{github.com/samcarter/tikzlings}, including a bug tracker -- please make constructive use of it! If you seek any other assistance (not bug reports/feature requests), I suggest asking a question at \url{topanswers.xyz/tex}. A more stable package version can be found on \CTAN (\url{https://www.ctan.org/pkg/tikzlings}) and is included in both \miktex and \texlive as \tikzlings. \subsection*{Acknowledgements} I'd like to thank the friendly and helpful community of \TeX{} users for their suggestions, feedback and help to create this package and find a suitable name for it. As a thank you all the \tikzlings have a name which is in some way or another connected to the users of \TeX{}. \subsection*{License} Copyright \raisebox{0.2em}{\tiny\fontfamily{cmr}\selectfont\textcopyright} \texttt{samcarter}. Permission is granted to copy, distribute and\slash or modify this software under the terms of the LaTeX project public licence, version 1.3c or later \url{https://www.latex-project.org/lppl.txt}. \clearpage \section*{The \tikzlings} The \tikzlings package is a collection of packages. It can either be loaded as a whole with \saminline|\usepackage{tikzlings}| or the subpackages containing the individual animals (and beings) can be used separately, e.g.\ by loading \saminline|\usepackage{tikzlings-marmots}|. The basic usage is the same for all animals (and beings). Inside a \saminline|tikzpicture|, the \tikzlings can be added via \saminline|\|. For example \begin{tcblisting}{title={Basic Ti\emph{k}Zling}} \marmot \end{tcblisting} will produce a marmot. All usual \TikZ and \saminline|pgf| keys can be passed as optional argument to change the appearance. For example scaling and rotating the \tikzlings can be done by \begin{tcblisting}{title={Ti\emph{k}Zling with options}} \penguin[rotate=30,scale=0.5] \end{tcblisting} In addition to the standard options provided by \TikZ each \tikzlings also comes with some additional options which are listed in the following sections. If these additional options consist of multiple words they are available both with and without spaces, for example \saminline|askphil| and \saminline|ask phil| will be treated as the same. To make customisation of the \tikzlings easier, some hooks are provided, which can be redefined by the user in order to add commands at specific layers: \begin{itemize} \item \saminline|\hookbackground| \item \saminline|\hookbelly| \item \saminline|\hookbody| \item \saminline|\hookforeground| \end{itemize} With regard to the individual components of the \tikzlings, they are located in the following z order: \begingroup \centering \begin{tikzpicture}[scale=0.95] \newcommand{\planewidth}{2.6} \newcommand{\planeheight}{3.4} \newcommand{\planes}{\fill[gray!20!white,opacity=0.9] (-\planewidth,-0.1) rectangle (\planewidth,\planeheight);} \newcommand{\hooks}{\draw[themecolor, rounded corners=3pt, line width=1pt] (-\planewidth,-0.1) rectangle (\planewidth,\planeheight);} \newcounter{layer} \setcounter{layer}{0} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \hooks \node[font=\footnotesize\ttfamily,rotate=45] at (0,0.1) {background}; \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \planes \newcommand{\rhinohookbelly}{ \pgfsetfillopacity{0} \pgfsetstrokeopacity{0} } \rhino \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \hooks \node[font=\footnotesize\ttfamily,rotate=45] at (0,0.1) {belly}; \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \planes \newcommand{\rhinohookbackground}{ \pgfsetfillopacity{0} \pgfsetstrokeopacity{0} } \newcommand{\rhinohookbelly}{ \pgfsetfillopacity{1} \pgfsetstrokeopacity{1} } \rhino \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \hooks \node[font=\footnotesize\ttfamily,rotate=45] at (0,0.1) {body}; \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \planes \thing[magichat,magicwand] \end{scope} \addtocounter{layer}{1} \begin{scope}[canvas is zy plane at x=\thelayer*1.8] \hooks \node[font=\footnotesize\ttfamily,rotate=45] at (0,0.1) {foreground}; \end{scope} \end{tikzpicture} \par \endgroup {\raggedright In addition, the hooks \saminline|\tikzlinghookbackground|, \saminline|\tikzlinghookbelly|,\newline \saminline|\tikzlinghookbody| and \saminline|\tikzlinghookforeground| are available and will effect all\newline \tikzlings.} A short example how the hooks can be used: \begin{tcblisting}{title={Hooks}} \newcommand{\mousehookbelly}{% \fill[red!80!black] (0.55, 1.35) -- (0.65, 0.3) -- (-0.65, 0.3) -- (-0.55, 1.35) -- (0.0, 0.9) -- cycle; } \mouse \end{tcblisting} Another way to use the \tikzlings is the \TikZ library of the same name. By loading this library, all macros from the normal package can be used. In addition the \TikZ library also defines the \tikzlings as \saminline|pic|'s: \begin{tcolorbox}[title={Ti\emph{k}z library and \texttt{\textbackslash pic}}] \begin{samcode} \documentclass{standalone} \usepackage{tikz} \usetikzlibrary{tikzlings} \begin{document} \begin{tikzpicture} \path (1,0) pic{bear} (2,1) pic[ coati/body=blue, scale=0.5 ]{coati} (3,2) pic[ thing/hat=red ]{penguin}; \end{tikzpicture} \end{document} \end{samcode} \tcblower \begin{tikzpicture} \path (1,0) pic{bear} (2,1) pic[ coati/body=blue, scale=0.5 ]{coati} (3,2) pic[ thing/hat=red!80!black ]{penguin}; \end{tikzpicture} \end{tcolorbox} \clearpage \subsection*{List of all \tikzlings:} \begingroup \hypersetup{hidelinks,linktoc=all} \tableofcontents \endgroup \makeatletter \tikzlings@clistMapInlineNn{\tikzlings@packages@clist}{% \CommentInput{tikzlings-#1.sty}} \makeatother %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Random Tikzling % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \clearpage \section[Ti\emph{k}Zling]{Rani, the Ti\emph{k}Zling} \emph{The full name of this Ti\emph{k}Zling is ``Random'', but everybody just calls them ``Rani''} \subsection{Package name} \begin{tcolorbox}[lower separated=false, lefthand width=.8\linewidth,title={Package usage}] \vspace*{0.5cm} \saminline|\usepackage{tikzlings}| \vspace*{0.5cm} \end{tcolorbox} \subsection{Basic Usage} \begin{tcblisting}{title={Basic Ti\emph{k}Zling}} \tikzling \end{tcblisting} \subsection{Options} Options common for all \tikzlings are supported for the \saminline|\tikzling|. These are the ability to change the body colour \begin{tcblisting}{title={Body colour}} \tikzling[body=blue] \end{tcblisting} to view the \tikzlings from behind \begin{tcblisting}{title={Back view}} \tikzling[back] \end{tcblisting} and the \saminline|3D| key, which will make the Ti\emph{k}Zlings 3-dimensional: \begin{tcblisting}{title={3D view}} \tikzling[3D] \end{tcblisting} And finally the \saminline|contour| key will only draw the outlines: \begin{tcblisting}{title={Contours}} \tikzling[contour=black] \end{tcblisting} If an option of a specific Ti\emph{k}Zling is used (for example \saminline|sleeping|, which only the koala and sloth can do) this option will only work for these \tikzlings. For all other \tikzlings, the option will be silently ignored. In addition all usual \TikZ and \saminline|pgf| keys can be used in the optional argument as well as the accessories presented in the following section. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Accessories % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \clearpage \section{Accessories} To customise the \tikzlings the package provides a number of accessories which can be added to all the \tikzlings simply by adding the respective keyword as optional argument: \begin{tcblisting}{title={Basic usage}} \bear[ hat ] \end{tcblisting} For most of these items, the colour can be customised: \begin{tcblisting}{title={Customisation}} \koala[ crown=orange!50!yellow ] \end{tcblisting} Unfortunately it is very difficult to create accessories that will fit all the different shapes of the \tikzlings. Therefore it is also possible to add them separately as optional argument of the \saminline|\thing| macro, which allows more control of their size and placement: \begin{tcblisting}{title={Further customisation}} \owl \thing[ tophat, scale=1.5, yshift=-0.6cm, xshift=-0.05cm ] \end{tcblisting} A list of all available accessories is given below. For completeness the default colours for each key are shown, but actually it is unnecessary unless it should be changed. In case more than one key is shown, all but the first are optional. \subsection{Hats} \begin{tcblisting}{title={Hat}} \penguin[ hat=blue!40!black ] \end{tcblisting} \begin{tcblisting}{title={Top hat}} \snowman[ tophat=black!90!white ] \end{tcblisting} \begin{tcblisting}{title={Beret}} \mouse[ beret=black ] \end{tcblisting} \begin{tcblisting}{title={Strawhat}} \anteater[ strawhat=blue, ribbon=black ] \end{tcblisting} \begin{tcblisting}{title={Harlequin hat}} \coati[ harlequin=blue, niuqelrah=red ] \end{tcblisting} \begin{tcblisting}{title={Witch hat}} \cat[ witch=gray ] \end{tcblisting} \begin{tcblisting}{title={Magic hat}} \bear[ magichat=violet, magicstars=yellow!80!brown ] \end{tcblisting} \begin{tcblisting}{title={Crown}} \sheep[ crown=yellow!90!orange ] \end{tcblisting} \begin{tcblisting}{title={Queen crown}} \bat[ queencrown=yellow ] \end{tcblisting} \begin{tcblisting}{title={King crown}} \marmot[ kingcrown=gray ] \end{tcblisting} \begin{tcblisting}{title={Santa hat}} \mouse[ santa=red!80!black ] \end{tcblisting} \begin{tcblisting}{title={Chefs hat}} \bear[ chef=gray!20!white ] \end{tcblisting} \begin{tcblisting}{title={Graduate cap}} \wolf[ graduate=black, tassel=red ] \end{tcblisting} \begin{tcblisting}{title={Alien antennas}} \penguin[ alien=green ] \end{tcblisting} \begin{tcblisting}{title={Sombrero}} \marmot[ sombrero=orange!70!yellow, sombreroa= green!70!blue, sombrerob= red, sombreroc= blue ] \end{tcblisting} \subsection{Communication} \begin{tcblisting}{title={Book}} \coati[ book={\tiny\TeX}, bookcolour=brown ] \end{tcblisting} \begin{tcblisting}{title={Sign post}} \pig[ signpost={\TeX}, signcolour= brown!50!black, signback=green!40!black ] \end{tcblisting} \begin{tcblisting}{title={Speech bubble}} \bear[ speech={\TeX}, bubblecolour=gray!30!white ] \end{tcblisting} \begin{tcblisting}{title={Thinking bubble}} \penguin[ think={\TeX}, bubblecolour=gray!30!white ] \end{tcblisting} \subsection{Food} \begin{tcblisting}{title={Pizza}} \koala[ pizza ] \end{tcblisting} \begin{tcblisting}{title={Cheese}} \mouse[ cheese=yellow!30!orange!60!white ] \end{tcblisting} \begin{tcblisting}{title={Baguette}} \bug[ baguette=brown ] \end{tcblisting} \begin{tcblisting}{title={Cake}} \moles[ cake=violet ] \end{tcblisting} \begin{tcblisting}{title={Ice cream}} \marmot[ icecream=brown!60!gray, flavoura=brown!50!black, flavourb=white!70!brown, flavourc=red!50!white ] \end{tcblisting} \begin{tcblisting}{title={Milk shake}} \penguin[ milkshake=red!20!white ] \end{tcblisting} \begin{tcblisting}{title={wine}} \owl[ wine=red!70!black ] \end{tcblisting} \begin{tcblisting}{title={Cocktail}} \bear[ cocktail ] \end{tcblisting} \begin{tcblisting}{title={Banana}} \ape[ banana=yellow!80!orange ] \end{tcblisting} \subsection{Sports} \begin{tcblisting}{title={Cricket bat}} \coati[ cricket=brown ] \end{tcblisting} \begin{tcblisting}{title={Hockey stick}} \bug[ hockey=brown ] \end{tcblisting} \begin{tcblisting}{title={Football}} \elephant[ football=white ] \end{tcblisting} \subsection{Other items} \begin{tcblisting}{title={Crystal ball}} \meerkat[ crystalball=cyan ] \end{tcblisting} \begin{tcblisting}{title={Magic wand}} \bear[ magicwand ] \end{tcblisting} \begin{tcblisting}{title={Rolling pin}} \coati[ rollingpin=brown ] \end{tcblisting} \begin{tcblisting}{title={Light sabre}} \penguin[ lightsaber=green ] \end{tcblisting} \begin{tcblisting}{title={Torch}} \snowman[ torch=gray ] \end{tcblisting} \begin{tcblisting}{title={Basket}} \mouse[ basket=brown!70!gray ] \end{tcblisting} \begin{tcblisting}{title={Easter Basket}} \sloth[ easter=brown!70!gray, egga=blue, eggb=green, eggc=red ] \end{tcblisting} \begin{tcblisting}{title={Crozier}} \koala[ crozier=brown ] \end{tcblisting} \begin{tcblisting}{title={Shovel}} \snowman[ shovel=gray ] \end{tcblisting} \begin{tcblisting}{title={Pick axe}} \penguin[ pickaxe=gray ] \end{tcblisting} \begin{tcblisting}{title={Straw broom}} \bug[ strawbroom=brown!50!white, strawbroomstick=brown, strawbroomribbon=red!50!black ] \end{tcblisting} \begin{tcblisting}{title={broom}} \chicken[ broom=brown, broomstick=gray!50!black ] \end{tcblisting} \begin{tcblisting}{title={Open umbrella}} \rhino[ umbrella=cyan ] \end{tcblisting} \begin{tcblisting}{title={Closed umbrella}} \marmot[ umbrellaclosed=cyan ] \end{tcblisting} \begin{tcblisting}{title={Handbag}} \mouse[ handbag=red!70!black ] \end{tcblisting} \begin{tcblisting}{title={Stick with leaf}} \ape[ stick=brown!50!black, leaf=green!70!red ] \end{tcblisting} \subsection{Random accessories} Given the number of available accessories, it can be hard to decide which ones to use. Luckily, one does not need to decide and pick random accessories instead. There are two macros for this purpose, \saminline|\randomhead| and \saminline|\randomaccessories|, which will choose a random headpiece and a random other accessories, respectively. Please note, that one needs to initialise these macros with \saminline|\shufflethings| to generate the random accessories. \begin{tcblisting}{title={Random accessories}} \shufflethings \coati[ \randomhead, \randomaccessories ] \end{tcblisting} \end{document}