%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % Documentation for the TikZbricks package % A package to draw bricks with tikz % Maintained by samcarter % % Project repository and bug tracker: % https://github.com/samcarter/TikZbricks % % 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 \tikzbrick{}s package} \subtitle{Drawing bricks with \TikZ} \author{% \texorpdfstring{ \begin{tikzpicture} \brick[color=blue]{4}{2} \end{tikzpicture}\\[0.8em] \texttt{samcarter}\\ \url{https://github.com/samcarter/TikZbricks}\\ \url{https://www.ctan.org/pkg/tikzbricks} }{samcarter}} \date{Version v0.6 \textendash{} 2024/12/16} \usepackage[ themecolor=samred ]{\jobname-settings} \colorlet{red}{samred} \colorlet{blue}{samlblue} \colorlet{orange}{samorange} \colorlet{teal}{samteal} \usepackage{tikzbricks} % customisation %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \setlength{\footheight}{50pt} \pagestyle{scrheadings} \pgfmathsetseed{10} \cfoot{% \pgfmathsetmacro{\R}{rnd}% \pgfmathsetmacro{\G}{rnd}% \pgfmathsetmacro{\B}{rnd}% \definecolor{randomcol}{rgb}{\R,\G,\B}% \begin{tikzpicture}[scale=0.5] \brick[color=randomcol]{\thepage}{1} \end{tikzpicture} } \begin{document} \maketitle \thispagestyle{scrheadings} \section{Introduction} \label{intro} The idea for the \tikzbrick{}s package was born at the \href{https://tug.org/tug2021/}{TUG'21 conference}, at which one of the interviewees, John Hammersley, had a very cool collection of brick models in the background (\href{https://www.youtube.com/watch?v=-9_Iy5Fqr4E}{link to video}). The package allows to draw bricks with \TikZ. The user can modify their colour, shape and change the viewpoint. Internally the \href{https://ctan.org/pkg/tikz-3dplot}{tikz-3dplot} package is used for the 3D rendering. The package is included in both \texlive and \miktex and available from \CTAN (\url{https://ctan.org/pkg/tikzbricks}). The development version of this package is located on github at \url{https://github.com/samcarter/TikZbricks}. If you have any problems, ideas or other feedback, please make constructive use of its bug tracker. 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 \href{https://www.latex-project.org/lppl.txt}{LaTeX project public licence, version 1.3c or later}. \section{Basic usage} An individual \tikzbrick can be drawn with \begin{tcblisting}{title={\tikzbrick}} \begin{tikzpicture} \brick{4}{2} \end{tikzpicture} \end{tcblisting} in which the first argument specifies the length of the block and the second argument its width. In addition to this basic block, the user can customise the block via the following optional arguments (the value in parenthesis denotes the default value): \begin{tcblisting}{title={Brick colour (red)}} \begin{tikzpicture} \brick[color=blue]{1}{3} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Front colour (color!60)}} \begin{tikzpicture} \brick[frontcolor=blue]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Top colour (color!40)}} \begin{tikzpicture} \brick[topcolor=blue]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Side colour (color)}} \begin{tikzpicture} \brick[sidecolor=blue]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Stud colour (color)}} \begin{tikzpicture} \brick[studcolor=blue]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Brick height (1.3)}} \begin{tikzpicture} \brick[brickheight=0.3]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Brick length (1)}} \begin{tikzpicture} \brick[bricklength=1.5]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Brick width (1)}} \begin{tikzpicture} \brick[brickwidth=2]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Stud radius (0.35)}} \begin{tikzpicture} \brick[studradius=0.2]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Stud height (0.3)}} \begin{tikzpicture} \brick[studheight=0.6]{2}{1} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Stud text ()}} \begin{tikzpicture} \brick[studtext={TikZ}]{2}{3} \end{tikzpicture} \end{tcblisting} \begin{tcblisting}{title={Brick text ()}} \begin{tikzpicture} \brick[bricktext={TikZ}]{2}{3} \end{tikzpicture} \end{tcblisting} All the above options are also available as package options to change the value for the whole document. The default colour can for example be specified like this: \begin{tcolorbox}[title={Package options ()}] \begin{samcode} \documentclass{standalone} \usepackage[color=blue]{tikzbricks} \begin{document} \begin{tikzpicture} \brick{3}{2} \end{tikzpicture} \end{document} \end{samcode} \tcblower \makeatletter \def\brick@default@color{blue} \makeatother \begin{tikzpicture} \brick{3}{2} \end{tikzpicture} \end{tcolorbox} To change the viewpoint, one can make use of the fact, that the \texttt{tikz-3dplot} package is used internally. By default, the \tikzbrick{}s package uses \saminline|\tdplotsetmaincoords{70}{160}|, but this can be adjusted as desired: \begin{tcblisting}{title={Viewpoint}} \tdplotsetmaincoords{70}{110} \begin{tikzpicture} \brick{4}{2} \end{tikzpicture} \end{tcblisting} Caveat: don't move away too far from the default viewpoint, otherwise the correct rendering of the brick is not guaranteed. In addition to these \tikzbrick specific options, one can also use all normal Ti\emph{k}Z options: \begin{tcblisting}{title={Ti\emph{k}Z options}} \begin{tikzpicture} \brick[scale=1.5]{1}{1} \brick[xshift=3cm]{2}{2} \end{tikzpicture} \end{tcblisting} \section{Wall building} So what to do with the \tikzbrick{}s? Like with any other building blocks, they are made to build things. Using the \saminline|wall| environment one can place \saminline|\wallbrick| besides each other. Due to the perspective and order of drawing, the wall is build from bottom to top and from right to left. To leave gaps or change into another layer, one can add to the \saminline|brickx|, \saminline|bricky| and \saminline|brickz| counters. Inside the \saminline|wall| environment one can use \saminline|\newrow| as a shortcut to go one row up and back to the start at the right hand side. \begin{tcblisting}{title={Wall building}} \begin{wall} \wallbrick[color=blue]{2}{1} \wallbrick[color=red]{1}{1} \addtocounter{brickx}{1} \wallbrick[color=orange]{1}{1} \newrow \addtocounter{brickx}{1}{1} \wallbrick[color=teal]{4}{1} \end{wall} \end{tcblisting} \section{img2bricks (by @Scott Pakin)} To make creating large structures easier, \href{https://github.com/spakin}{Scott Pakin} contributed the \saminline|img2bricks| python script, which converts image into \tikzbrick{}s. The script can be downloaded from \url{https://github.com/samcarter/TikZbricks/blob/main/img2bricks}. The script can be executed with python: \begin{tcolorbox}[righthand width=0cm,title={Usage}] \begin{samcode} python3 img2bricks image.png \end{samcode} \end{tcolorbox} Additional options are \begin{tcolorbox}[righthand width=0cm,title={Options}] \begin{samcode} -h, --help show an help message --output LATEX-FILE, -o LATEX-FILE name of output file --depth DEPTH depth of each brick --widths NUM[,NUM] comma-separated list of allowable brick widths \end{samcode} \end{tcolorbox} When preparing an image to convert into \tikzbrick{}s: \begin{itemize} \item consider using an image with transparent background so some of the edges of the bricks will be visible instead of just a solid wall \item image formats like .png are best suitable to avoid artefacts from image compression \item consider using small images with not too many pixels. Otherwise the resulting \tikzbrick wall gets very large and might not be compilable (Lua\TeX{} is a bit more lenient, but can't do wonders, either) \end{itemize} \section{Example} One example inspired by the documentation of the \href{https://www.ctan.org/pkg/pxpic}{pxpic package}: \begin{tcblisting}{ title={Brick Duck}, text above listing, sidebyside=false, breakable, righthand width=0cm, } \begin{wall}[scale=0.5] \addtocounter{brickx}{3} \wallbrick[color=yellow!80!orange]{6}{2} \newrow \addtocounter{brickx}{2} \wallbrick[color=yellow!80!orange]{8}{2} \newrow \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{3}{2} \addtocounter{brickx}{4} \wallbrick[color=yellow!80!orange]{3}{2} \newrow \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{2}{2} \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{4}{2} \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{3}{2} \newrow \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{8}{2} \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{2}{2} \newrow \addtocounter{brickx}{2} \wallbrick[color=yellow!80!orange]{11}{2} \newrow \addtocounter{brickx}{3} \wallbrick[color=yellow!80!orange]{7}{2} \addtocounter{brickx}{1} \wallbrick[color=yellow!80!orange]{2}{2} \newrow \addtocounter{brickx}{1} \wallbrick[color=orange]{3}{2} \wallbrick[color=yellow!80!orange]{3}{2} \addtocounter{brickx}{5} \wallbrick[color=yellow!80!orange]{1}{2} \newrow \wallbrick[color=orange]{3}{2} \wallbrick[color=yellow!80!orange]{5}{2} \newrow \addtocounter{brickx}{2} \wallbrick[color=orange]{1}{2} \wallbrick[color=yellow!80!orange]{1}{2} \wallbrick[color=black]{1}{2} \wallbrick[color=yellow!80!orange]{3}{2} \newrow \addtocounter{brickx}{2} \wallbrick[color=yellow!80!orange]{6}{2} \newrow \addtocounter{brickx}{3} \wallbrick[color=yellow!80!orange]{4}{2} \end{wall} \end{tcblisting} \end{document}