% MULTIBOX.STY - a style option to provide multiple boxes in pictures % ============ % Author: Brian HAMILTON KELLY, Royal Military College of Science, % Shrivenham, SWINDON, SN6 8LA, United Kingdom % Date: 13 October 1988 % % This style file option provides two new commands for use in the picture % environment: % % \multimake(x,y)(dx,dy){n}(w,h)[]{Text_1}{Text_2}...{Text_n} % \multiframe(x,y)(dx,dy){n}(w,h)[]{Text_1}{Text_2}...{Text_n} % % These commands set the n texts Text_1..Text_n inside a \makebox or % \framebox respectively. The first box has its lower-left corner at (x,y), % and successive boxes are located at (x+dx,y+dy),..,(x+(n-1)dx,y+(n-1)dy). % Each box has width and height determined by (w,h), and the optional % box placement parameter is applied to all the generated texts % \newtoks\multi@rg \def\multiframe{\let\@putitem=\@iframepicbox \multib@x} \def\multimake{\let\@putitem=\@imakepicbox \multib@x} \def\multib@x(#1,#2)(#3,#4)#5(#6,#7){\@xdim=#1\unitlength \@ydim=#2\unitlength \def\@dxdim{#3} \def\@dydim{#4} \@multicnt=#5 \def\@Xsize{#6} \def\@Ysize{#7} \@ifnextchar [{\imultib@x}{\imultib@x[]} } % The liberal use of % at the ends of lines is to prevent the ingestion of % superfluous spaces which would otherwise upset the horizontal positioning % of the boxes. \def\imultib@x[#1]{\@killglue\relax \def\p@sarg{#1}% \d@multi } % We need the expanded definition of \i@putitem because \@imakepicbox DOESN'T % expand its #3 argument (the optional text placement bit). However, it can % only recognize the letters b, t, l and r in this position, so \p@sarg is no % use. Therefore we expand the arguments, producing an appropriate call. \def\d@multi{% \ifnum\@multicnt > 0 \def\next@rg##1{% \multi@rg={{##1}}% Assign the next argument of original text to \multi@rg \edef\@iputitem{% \noexpand\@putitem(\@Xsize,\@Ysize)[\p@sarg]{\the\multi@rg}% }% \raise\@ydim\hbox to \z@{\kern \@xdim \@iputitem\hss}% \advance\@xdim by \@dxdim\unitlength \advance\@ydim by \@dydim\unitlength \advance\@multicnt by \m@ne \d@multi}% End of (re-)definition of \next@rg \else \let\next@rg=\ignorespaces \fi % Now execute \next@rg; \next@rg % This will read the text, set it and then call \d@multi recursively }