.nr PS 11
.nr VS 13
.TL
MetaPost with groff
.LP
Since MetaPost is a picture-drawing language that outputs PostScript,
it is necessary to use the
.ft CW
-mpspic
.ft
macro package, which is automatically included when \fIgroff\fR
is invoked with the
.ft CW
-Tps
.ft
option to prepare output for PostScript printers or previewers.
.PP
Suppose you have written some figures in MetaPost and placed
the input in a file \f(CWfigures.mp\fR.
Running
.nf
.ft CW
mp -T figures
.ft
.fi
to invoke the MetaPost interpreter produces output files
\f(CWfigures.1\fR, \f(CWfigures.2\fR, .\|.\|.
which can be included in a \fIgroff\fR document via macro calls
such as
.nf
.ft CW
.PSPIC figures.1 width height
.ft
.fi
as explained in the \fIgrops\fR(1) documentation.
Note that the picture gets rescaled if the height and width
in the \f(CW.PSPIC\fR command don't match \fImp\fR's idea of
the picture dimensions.
.PP
For instance,
.PSPIC figs.1 1.5i 1.08i
this figure was derived from a file
.ft CW
figs.mp
.ft
and included at this point by invoking the \f(CW.PSPIC\fR macro
with height 1.08 inches and width 1.5 inches.
.PP
The file
.ft CW
figs.mp
.ft
looks like this:
.nf
.ft CW
.nr PS 9
.nr VS 11
prologues:=1;
input boxes
beginfig(1);
pair shadowshift; shadowshift=(1,-1)*bp;
def drawshadowed(text t) =
forsuffixes $=t:
fill bpath$ shifted shadowshift;
unfill bpath$;
drawboxed($);
endfor
enddef;
boxit.a(btex \\s8A\\s+2 \\(lh a etex);
circleit.b(btex $e sup {i omega t}$ etex rotated 20);
b.w - a.e = (10bp,0);
drawshadowed(a,b);
draw a.e..b.w;
draw bbox currentpicture dashed evenly;
endfig;
.nr PS 11
.nr VS 13
.ft
.fi
.PP
Note that the typesetting commands in the
\f(CWbtex\fR.\|.\|.\f(CWetex\fR blocks in the above example
are processed by
.nf
.ft CW
eqn -d\\$\\$ | troff -Tpost
.ft
.fi
If a different \fItroff\fR pipeline is desired, it can be specified
via the
.ft CW
TROFF
.ft
environment variable. For example,
.nf
.ft CW
TROFF='tbl | eqn -d\\$\\$ | troff -Tpost'
.ft
.fi
adds \fItbl\fR to the pipeline in addition to \fIeqn\fR.
.PP
Macro definitions and such can be added via the standard
\f(CWverbatimtex\fR.\|.\|.\f(CWetex\fR mechanism that adds the
given material to the \fItroff\fR input. Such material should
not generate any output since this would get mixed up with the
next \f(CWbtex\fR.\|.\|.\f(CWetex\fR block. Thus, newlines between
\f(CWverbatimtex\fR and \f(CWetex\fR must be protected with \f(CW\\\fR.
.PP
Unfortunately, typesetting of \f(CWbtex\fR.\|.\|.\f(CWetex\fR blocks
currently doesn't work with \fIgroff\fR and equires a UNIX
\fItroff\fR implementation, because MetaPost's \f(CWdmp\fR
post-processor can't handle \fIgroff\fR's extended font and output
file formats documented in \fIgroff_font\fR(5) and \fIgroff_out\fR(5).
Nevertheless, using \fItroff\fR to prepare figures with MetaPost
and \fIgroff\fR to typeset them may still be a useful combination
if your \fItroff\fR implementation doesn't provide the
.ft CW
-mpictures
.ft
macro packages.
|