Plan 9 from Bell Labs’s /usr/web/sources/contrib/steve/root/sys/lib/texmf/doc/metapost/grdemo.ms

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


.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.


Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to webmaster@9p.io.