User's Guide To The PGF Package, Version 0.65: Till Tantau November 4, 2004
User's Guide To The PGF Package, Version 0.65: Till Tantau November 4, 2004
User's Guide To The PGF Package, Version 0.65: Till Tantau November 4, 2004
65
http://latex-beamer.sourceforge.net
Till Tantau
[email protected]
November 4, 2004
Contents
1 Introduction 1
1.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2 Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Installing Prebundled Packages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3.1 Temporary Installation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3.2 Installation in a texmf Tree . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.4 Quick Start . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.5 Gallery . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
3 Using Nodes 22
3.1 Node Creation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
3.2 Coordinates Relative to Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
3.3 Connecting Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
3.4 Placing Labels on Node Connections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
1 Introduction
1.1 Overview
This user’s guide explains the functionality of the pgf package. pgf stands for ‘portable graphics format’. It
is a TEX macro package that allows you to create graphics in your TEX documents using a special pgfpicture
environment and special macros for drawing lines, curves, rectangles, and many other kind of graphic objects.
Its usage closely resembles the pstricks package or the normal picture environment of LATEX.
Although pgf is less powerful than pstricks, it has the advantage that it can generate both PostScript
output and pdf output from the same file. The pgf package works together both with dvips and pdftex.
In particular, packages that rely on pdftex or pdflatex (like some packages for creating presentations) can
be used together with pgf.
1
The package consists of the core style pgf.sty and a number of extension styles that are build on top of
it. Currently, the documented ones are
• pgfarrows.sty, used to draw a large variety of arrows.
• pgfnodes.sty, used to draw nodes in diagrams and to connect them in a convenient way.
• pgfshade.sty, used to create shadings (also called gradients).
In order to use pgf you will have to include the command
\usepackage{pgf}
at the beginning of your main TEX file. If you also wish to use the extensions, you also have to include them.
For example, you will typically use the following command:
\usepackage{pgf,pgfarrows,pgfnodes}
In this guide you will find the descriptions of all “public” commands provided by the pgf package. In
each such description, the described command, environment or option is printed in red. Text shown in green
is optional and can be left out. Note that (currently) many commands take arguments in square brackets
that are not optional. In some future version of pgf it will possible to omit these optional arguments.
1.2 Installation
To use pgf, you just need to put all files with the ending .sty of the pgf package in a directory that is read
by TEX. You need to have the package xcolor installed, version 2.00 or higher. To uninstall pgf, simply
remove these files once more. Unfortunately, there are different ways of making TEX “aware” of files. Which
way you should choose depends on how permanently you intend to use it.
For MiKTEX, you need the packages called pgf and xcolor.
.:/home/tantau/pgf:
Naturally, if the TEXINPUTS variable is already defined differently, you should add the directories to the
list. Do not forget to place a colon at the end (corresponding to an empty path), which will include all
standard directories.
2
• The root texmf tree, which is usually located at /usr/share/, c:\texmf\, or
c:\Program Files\TeXLive\texmf\.
• The local texmf tree, which is usually located at /usr/local/share/, c:\localtexmf\, or
c:\Program Files\TeXLive\texmf-local\.
• Your personal texmf tree, which is located in your home directory.
You should install the packages either in the local tree or in your personal tree, depending on whether
you have write access to the local tree. Installation in the root tree can cause problems, since an update of
the whole TEX installation will replace this whole tree.
Inside whatever texmf directory you have chosen, create the sub-sub-sub-directory texmf/tex/latex/pgf
and place all files in it. Then rebuild TEX’s filename database. This done by running the command texhash
or mktexlsr (they are the same). In MikTeX, there is a menu option to do this.
If you want to be really tidy, you can place the documentation in the directory texmf/doc/latex/pgf.
For a more detailed explanation of the standard installation process of packages, you might wish to
consult http://www.ctan.org/installationadvice/. However, note that the pgf package does not come
with a .ins file (simply skip that part).
\begin{pgfpicture}{0cm}{0cm}{5cm}{2cm}
% (0cm,0cm) is the lower left corner,
% (5cm,2cm) is the upper right corner.
\pgfrect[stroke]{\pgfpoint{0cm}{0cm}}{\pgfpoint{2cm}{10pt}}
% Paint a rectangle (stroke it, do not fill it)
% The lower left corner is at (0cm,0cm)
% The rectangle is 2cm wide and 10pt high.
\pgfcircle[fill]{\pgfpoint{3cm}{1cm}}{10pt}
% Paint a filled circle
% The center is at (3cm,1cm)
% The radius is 10pt
\end{pgfpicture}
The \pgfpoint command is used to specify a point. It is often more convenient to use the command
pgfxy instead, which lets you specify a point in terms of multiples of a x-vector and a y-vector. They are
predefined to \pgfpoint{1cm}{0cm} and \pgfpoint{0cm}{1cm}, but you can change these settings.
\begin{pgfpicture}{0cm}{0cm}{5cm}{1.25cm}
\pgfline{\pgfxy(0,0)}{\pgfxy(1,1)}
% Draws a line from (0cm,0cm) to (1cm,1cm)
% Command \pgfline{\pgfpoint{0cm}{0cm}}{\pgfpoint{1cm}{1cm}}
% would have the same effect.
\pgfline{\pgfxy(1,1)}{\pgfxy(2,1)}
\pgfline{\pgfxy(2,1)}{\pgfxy(3,0)}
\pgfline{\pgfxy(3,0)}{\pgfxy(4,0)}
3
\pgfline{\pgfxy(4,0)}{\pgfxy(5,1)}
\end{pgfpicture}
You can put text into a picture using the \pgfbox command.
x
Hi! R ∞ xd
0
\begin{pgfpicture}{0cm}{0cm}{5cm}{2cm}
\pgfputat{\pgfxy(1,1)}{\pgfbox[center,center]{Hi!}}
% pgfputat places something at a certain position
% pgfbox shows the text ‘hi!’. The horizontal alignment
% is centered (other options: left, right). The vertical
% alignment is also centered (other options: top, bottom,
% base).
\pgfcircle[stroke]{\pgfxy(1,1)}{0.5cm}
\pgfsetendarrow{\pgfarrowto}
% In the following, all lines will end with an arrow that looks like
% the arrow of TeX’s \to command
\pgfline{\pgfxy(1.5,1)}{\pgfxy(2.2,1)}
\pgfputat{\pgfxy(3,1)}{
\begin{pgfrotateby}{\pgfdegree{30}}
% You can rotate things like this
\pgfbox[center,center]{$\int_0^\infty xdx$}
\end{pgfrotateby}}
\pgfcircle[stroke]{\pgfxy(3,1)}{0.75cm}
\end{pgfpicture}
In order to draw curves and complicated lines, you can use the commands pgfmoveto, pgflineto, and
pgfcurveto. To actually draw or fill the painted area, you use pgfstroke or pgffill.
\begin{pgfpicture}{0cm}{0cm}{5cm}{2cm}
\pgfmoveto{\pgfxy(0,1)}
\pgfcurveto{\pgfxy(1,0.5)}{\pgfxy(1,1.5)}{\pgfxy(2,1)}
\pgfstroke
\pgfsetdash{{3pt}{3pt}}{0pt}
\pgfmoveto{\pgfxy(0,1)}
\pgflineto{\pgfxy(1,0.5)}
\pgflineto{\pgfxy(1,1.5)}
\pgflineto{\pgfxy(2,1)}
\pgfstroke
\pgfmoveto{\pgfxy(3,1)}
\pgfcurveto{\pgfxy(3,0)}{\pgfxy(4,0)}{\pgfxy(4,1)}
\pgfcurveto{\pgfxy(4,2)}{\pgfxy(3,2)}{\pgfxy(3,1)}
\pgfclosepath
\pgffill
\end{pgfpicture}
1.5 Gallery
In the following, a number of figures are shown that have been created using pgf. Please see the source
code for how they are created.
4
PSPACE-hard
PSPACE
NLINSPACE = CSL
DLINSPACE
CFL
0
11
∗ ∗ ∗ ∈ ∈ ∈
/ ∗ ∗ ∗ ∗ ∗ ∗
000
110
00
1
10
1
∗ ∗ ∗ ∗ ∗ ∗ ∈
/ ∈
/ ∈ ∗ ∗ ∗
000 00 1
1 10 110
∈ ∈
/ ∈
w5
0
w3 ‘∈ B’ w4 ‘∈ A’ w2 w5
0
w2 ‘∈ A’ w3 ‘∈ A’, ‘∈ B’ w4 ‘∈ A’, ‘∈ B’
0 0 1
w1 ‘∈ A’ w1 ‘∈ A’
5
qv
y
z
{00, 10, 11}
x
q= 0
, 1
q6v,6w
1 0 y
start z
{00, 11} {00, 01, 10}
x
x qw
x
y
z
{00, 01, 11}
z
z
x
q2 y q3
u
1 v
1 {0, 1} {0, 2}
q1
start x
{0, 1} y
q4
u
0
v
0 {0, 1}
6
\end{pgfpicture}
Inside a picture, you can create nested scopes using pgfscope. Changes made inside a pgfscope are
undone when the scope ends.
\begin{pgfscope}
henvironment contentsi
\end{pgfscope}
All changes made inside a scope are local to that scope.
Example:
\begin{pgfpicture}{0cm}{0cm}{5cm}{0.75cm}
\pgfxyline(0,0)(5,0)
\begin{pgfscope}
\pgfsetlinewidth{2pt}
\pgfxyline(0,0.25)(5,0.25)
\end{pgfscope}
\pgfxyline(0,0.5)(5,0.5)
\end{pgfpicture}
\pgforigin
Yields the origin.
Example: \pgmoveto{\pgforigin}
\pgfpolar{hdegreei}{hradiusi}
Yields a point location given in polar coordinates.
Example: \pgfmoveto{\pgfpolar{30}{1cm}}
\pgfdirection{hdirection stringi}
Returns the degree that corresponds to the direction. Allowed values for hdirection stringi are n[orth],
s[south], e[east], w[est], ne, nw, se, and sw.
Example: \pgfmoveto{\pgfpolar{\pgfdirection{n}}{1cm}}
\pgfextractx{hdimensioni}{hpointi}
Sets the TEX-hdimensioni to the x-coordinate of the point.
Example:
\newdimen\mydim
\pgfextractx{\mydim}{\pgfpoint{2cm}{4pt}}
% \mydim is now 2cm
7
\pgfextracty{hdimensioni}{hpointi}
Like \pgfextractx, except for the y-coordinate.
Coordinates can also be specified as multiples of an x-vector and a y-vector. Normally, the x-vector
points one centimeter in the x-direction and the y-vector points one centimeter in the y-direction, but using
the commands pgfsetxvec and pgfsetyvec they can be changed.
It is also possible to specify a point as a multiple of three vectors, the x-, y-, and z-vector. This is useful
for creating simple three dimensional graphics.
\pgfxy(hsx i,hsy i)
Yields a point that is situated at sx times the x-vector plus sy times the y-vector.
Example: \pgfline{\pgfxy(0,0)}{\pgfxy(1,1)}
\pgfxyz(hsx i,hsy i,hsz i)
Yields a point that is situated at sx times the x-vector plus sy times the y-vector plus sz times the
z-vector.
Example:
\pgfsetendarrow{\pgfarrowto}
\pgfline{\pgfxyz(0,0,0)}{\pgfxyz(0,0,1)}
\pgfline{\pgfxyz(0,0,0)}{\pgfxyz(0,1,0)}
\pgfline{\pgfxyz(0,0,0)}{\pgfxyz(1,0,0)}
\pgfsetxvec{hpointi}
A point that replaces the current x-vector. The commands \pgfsetyvec and \pgfsetzvec are defined
the same way.
Example:
\pgfsetxvec{\pgfpoint{2cm}{0cm}}
\pgfline{\pgfxy(0,0)}{\pgfxy(1,1)}
% Same as \pgfline{\pgforigin}{\pgfpoint{2cm}{1cm}}
8
\pgfcorner[hdirectioni]{hfirst pointi}{hsecond pointi}
Image the rectangle whose corners are hfirst pointi and second hsecond pointi. If you specify se as
hdirectioni you will get the south-east (or lower left) corner of this rectangle. Similarly, ne, nw, and sw
yield the other three corners. If you specify s for south, you get the middle of the lower side of the
rectangle. Similarly for the other three directions n, e, and w.
Example:
\pgfmoveto{\pgfcorner[sw]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[nw]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[ne]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[e]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[s]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[w]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgflineto{\pgfcorner[n]{\pgfpoint{2cm}{4pt}}{\pgfpoint{3cm}{2cm}}}
\pgfstroke
\begin{pgftranslate}{hnew origini}
henvironment contentsi
\end{pgftranslate}
Makes hnew origini the new origin within the scope of the environment.
Example:
\begin{pgftranslate}{\pgfpoint{0cm}{1cm}}
\pgfline{\pgforigin}{\pgfxy(1,0)}
\end{pgftranslate}
\pgftranslateto{hnew origini}
Makes the parameter the new origin.
Example:
\pgftranslateto{\pgfpoint{0cm}{1cm}}
\pgfline{\pgforigin}{\pgfxy(1,0)}
\pgfputat{han origini}{hcommandsi}
Executes the commands after having translated the origin to the given location.
Example: \pgfputat{\pgfxy(1,0)}{\pgfbox[center,center]{Hello world}}
9
\end{pgfmagnify}
Magnifies everything within the environment by the given factors.
Example:
\begin{pgfmagnify}{2}{2}
\pgfline{\pgforigin}{\pgfxy(1,0)}
\end{pgfmagnify}
(2, 0)
\pgfmoveto{\pgforigin}
\pgfcurveto{\pgfxy(1,1)}{\pgfxy(2,1)}{\pgfxy(2,0)}
\pgfstroke
\pgfclosepath
Connects the current point to the point where the current path started.
\pgfzerocircle{hradiusi}
Appends a circle around the origin of the given radius to the current path.
Example: \pgfzerocircle{1cm}
\pgfzeroellipse{haxis vector 1 i}{haxis vector 2 i}
Appends an ellipse with the given axis vectors centered at the origin to the current path.
Example:
\pgfzeroellipse{\pgfxy(0.5,0.5)}{\pgfxy(-0.75,0.75)}
\pgfstroke
\pgfline{\pgforigin}{\pgfxy(0.5,0.5)}
\pgfline{\pgforigin}{\pgfxy(-0.75,0.75)}
10
The basic drawing commands also come in ‘quick’ versions. These versions get plain numbers as input
that represent TEX points. These commands are executed much quicker than the normal commands. They
are useful if you need to do construct very long or numerous paths.
\pgfqmoveto{hx bpi}{hy bpi}
Makes the given point the current point. The real numbers given are interpreted as TEX “big points,”
which are a 1/72th of an inch (as opposed to TEX points, which are a 1/72.27th of an inch).
Example: \pgfqmoveto{10}{20}
\pgfqlineto{hx bpi}{hy bpi}
Extends the path by a straight line from the current point to the parameter point. The parameter point
is then made the current point.
Example:
\pgfqmoveto{0}{0}
\pgfqlineto{100}{100}
\pgfstroke
\pgfqstroke
Like \pgfstroke, except that no arrows are drawn.
\pgfclosestroke
Closes the current path and then draws it.
Example:
\pgfmoveto{\pgforigin}
\pgflineto{\pgfxy(1,1)}
\pgflineto{\pgfxy(0,1)}
\pgfclosestroke
\pgffill
Closes the current path, if necessary, and then fill the area with the current color.
Example:
\pgfmoveto{\pgforigin}
\pgflineto{\pgfxy(1,1)}
\pgfstroke
11
\pgfeofill
Same as \pgffill, except that the even-odd rule is used.
\pgffillstroke
Strokes the current path, the closes the current path, if necessary, and then fills the area with the current
color.
\pgfeofillstroke
Same as \pgffillstroke, except that the even-odd rule is used.
\pgfsetlinewidth{hline widthi}
Sets the line width for subsequent stroking commands to hline widthi. A dimension of 0pt corresponds
to the thinnest drawable line. On high resolution printers these will be impossible to see.
Example: \pgfsetlinewidth{3pt}
\pgfsetdash{{0.5cm}{0.5cm}{0.1cm}{0.2cm}}{0cm}
\pgfxyline(0,1)(5,1)
\pgfsetdash{{0.5cm}{0.5cm}{0.1cm}{0.2cm}}{0.1cm}
\pgfxyline(0,0.9)(5,0.9)
\pgfsetdash{{0.5cm}{0.5cm}{0.1cm}{0.2cm}}{0.2cm}
\pgfxyline(0,0.8)(5,0.8)
\pgfsetbuttcap
Set a butt line cap for subsequent stroking commands.
\pgfsetroundcap
Set a round line cap for subsequent stroking commands.
\pgfsetrectcap
Set a rectangular line cap for subsequent stroking commands.
\pgfsetbeveljoin
Set a bevel line join for subsequent stroking commands.
\pgfsetroundjoin
Set a round line join for subsequent stroking commands.
\pgfsetmiterjoin
Set a miter line join for subsequent stroking commands.
\pgfsetmiterlimit{hmiter limiti}
Sets the miter limit for subsequent stroking commands. See the pdf manual for details on what the
miter limit is.
Example: \pgfsetmiterlimit{3pt}
12
2.6 Clipping
Paths can also be used to clip subsequent drawings. Executing the clip operator intersects the current
clipping area with the area specified by the path. There is no way of enlarging the clipping area once more.
However, if a clipping operations is done inside a pgfscope environment, the end of the scope restores the
original clipping area.
\pgfclip
Closes the current path and intersect it with the current clipping path to form a new clipping path.
Example:
\pgfmoveto{\pgfxy(0,0)}
\pgflineto{\pgfxy(0,1)}
\pgflineto{\pgfxy(1,0)}
\pgfclip
\pgfcircle[fill]{\pgfxy(0.25,0.25)}{14pt}
\pgfstrokeclip
Stroke the current path, then close it, and intersect it with the current clipping path to form a new
clipping path.
Example:
\pgfmoveto{\pgfxy(0,0)}
\pgflineto{\pgfxy(0,1)}
\pgflineto{\pgfxy(1,0)}
\pgfstrokeclip
\pgfcircle[fill]{\pgfxy(0.25,0.25)}{14pt}
\pgfclosestrokeclip
Close the current path, strokes it, and intersect it with the current clipping path to form a new clipping
path.
Example:
\pgfmoveto{\pgfxy(0,0)}
\pgflineto{\pgfxy(0,1)}
\pgflineto{\pgfxy(1,0)}
\pgfclosestrokeclip
\pgfcircle[fill]{\pgfxy(0.25,0.25)}{14pt}
\pgffillclip
Closes the current path, fills it, and intersect it with the current clipping path to form a new clipping
path.
\pgffillstrokeclip
Closes the current path, fills it, strokes it, and intersect it with the current clipping path to form a new
clipping path.
13
2.7 Shape and Line Drawing
There are several commands that make drawing shapes and lines easier. However, in principle these could
be implemented using the path construction and stroking and filling commands introduced above.
\pgfline{hstart pointi}{hend pointi}
Draws a line from hstart pointi to hend pointi. This command is equivalent to constructing a path from
the start to the end point and then stroking it.
Example: \pgfline{\pgfxy(0,0)}{\pgfxy(1,1)}
\pgfxyline(hx1 i,hy1 i),(hx2 i,hy2 i)
Like the \pgfline command, except the start and end points are given in xy-coordinates.
Example: \pgfxyline(0,0)(1,1)
\pgfcurve{hstart pointi}{hsupport point 1 i}{hsupport point 2 i}{hend pointi}
Draws a curve from the start to the end point with given support points.
Example: \pgfcurve{\pgfxy(0,0)}{\pgfxy(0,1)}{\pgfxy(1,1)}{\pgfxy(1,0)}
\pgfxycurve(hx1 i,hy1 i),(hx01 i,hy10 i),(hx02 i,hy20 i),(hx2 i,hy2 i)
Like the \pgfcurve command, except that all points are given in xy-coordinates.
Example: \pgfxycurve(0,0)(0,1)(1,1)(1,0)
\pgfrect[hdrawing typei]{hlower left corner i}{hheight/width vector i}
Draws a rectangle. The hdrawing typei can be stroke, fill, fillstroke, or clip.
Example:
% Draw a filled rectangle with corners (2,2) and (3,3)
\pgfrect[fill]{\pgfxy(2,2)}{\pgfxy(1,1)}
Example:
\pgfsetlinewidth{0.8pt}
\pgfgrid[step={\pgfpoint{1cm}{1cm}}]{\pgfxy(-.3,-.3)}{\pgfxy(3.3,2.3)}{}
\pgfsetlinewidth{0.4pt}
\pgfgrid[stepx=0.1cm,stepy=0.1cm]{\pgfxy(-.15,-.15)}{\pgfxy(3.15,2.15)}
14
2.8 Image Inclusion
The pgf package offers an abstraction of the image inclusion process, but you can still use the usual image
inclusion facilities of the graphics package. The main reason why you might wish to use pgf’s image
inclusion instead is that file extensions are added automatically, depending on whether .pdf or .dvi is
requested (this is important for packages that must work with both).
The general approach to including an image is the following: First, you use \pgfdeclareimage to declare
the image. This must be done prior to the first use of the image. Once you have declared an image, you can
insert it into the text using \pgfuseimage. The advantage of this two-phase approach is that, at least for
pdf, the image data will only be included once in the file. This can drastically reduce the file size if you use
an image repeatedly, for example in an overlay. However, there is also a command called \pgfimage that
declares and then immediately uses the image.
\pgfdeclareimage[hoptionsi]{himage namei}{hfilenamei}
Declares an image, but does not paint anything. To draw the image, use \pgfuseimage{himage namei}.
The hfilenamei may not have an extension. For pdf, the extensions .pdf, .jpg, and .png will auto-
matically tried. For PostScript, the extensions .eps, .epsi, and .ps will be tried.
The following options are possible:
• height=hdimensioni sets the height of the image. If the width is not specified simultaneously, the
aspect ratio of the image is kept.
• width=hdimensioni sets the width of the image. If the height is not specified simultaneously, the
aspect ratio of the image is kept.
• page=hpage number i selects a given page number from a multipage document. Specifying this
option will have the following effect: first, pgf tries to find a file named
hfilenamei.pagehpage number i.hextensioni
If such a file is found, it will be used instead of the originally specified filename. If not, pgf inserts
the image stored in hfilenamei.hextensioni and if a recent version of pdflatex is used, only the
selected page is inserted. For older versions of pdflatex and for dvips the complete document is
inserted and a warning is printed.
• interpolate=htrue or falsei selects whether the image should “smoothed” when zoomed. False
by default.
• mask=hmask namei selects a transparency mask. The mask must previously be declared using
\pgfdeclaremask (see below). This option only has an effect for pdf. Not all viewers support
masking.
Example:
\pgfdeclareimage[interpolate=true,height=1cm]{image1}{pgf-tu-logo}
\pgfdeclareimage[interpolate=true,width=1cm,height=1cm]{image2}{pgf-tu-logo}
\pgfdeclareimage[interpolate=true,height=1cm]{image3}{pgf-tu-logo}
\pgfuseimage{himage namei}
Inserts a previously declared image into the text. If you wish to use it in a picture environment, you
should put a \pgfbox around it.
If the macro \pgfalternateextension expands to some nonempty halternate extensioni, pgf will first
try to use the image names himage namei.halternate extensioni. If this image is not defined, pgf will
next check whether halternate extensioni contains a ! character. If so, everythings up to this exclamation
mark and including it is deleted from halternate extensioni and the pgf again tries to use the image
himage namei.halternate extensioni. This is repeated until halternate extensioni no longer contains a
!. Then the original image is used.
The xxcolor package sets the alternate extension to the current color mixin.
Example:
\begin{pgfpictureboxed}{0cm}{0cm}{7cm}{2.1cm}
\pgfputat{\pgfxy(1,1)}{\pgfbox[left,base]{\pgfuseimage{image1}}}
\pgfputat{\pgfxy(3,1)}{\pgfbox[left,base]{\pgfuseimage{image2}}}
15
\pgfputat{\pgfxy(5,1)}{\pgfbox[left,base]{\pgfuseimage{image3}}}
\pgfrect[stroke]{\pgfxy(1,1)}{\pgfxy(1,1)}
\pgfrect[stroke]{\pgfxy(3,1)}{\pgfxy(1,1)}
\pgfrect[stroke]{\pgfxy(5,1)}{\pgfxy(1,1)}
\pgfputat{\pgfxy(1,0)}{\pgfbox[left,base]{Some text.}}
\end{pgfpictureboxed}
Some text.
The following example demonstrates the effect of using \pgfuseimage inside a color mixin environment.
\pgfdeclareimage[interpolate=true,height=1cm]{image1.!25!white}{pgf-tu-logo.25}
\pgfdeclareimage[interpolate=true,width=1cm,height=1cm]{image2.!25!white}{pgf-tu-logo.25}
\pgfdeclareimage[interpolate=true,height=1cm]{image3.!25!white}{pgf-tu-logo.25}
\begin{colormixin}{25!white}
\begin{pgfpictureboxed}{0cm}{0cm}{7cm}{2.1cm}
\pgfputat{\pgfxy(1,1)}{\pgfbox[left,base]{\pgfuseimage{image1}}}
... % as above
\end{pgfpictureboxed}
\end{colormixin}
Some text.
\pgfalternateextension
You should redefine this command to install a different alternate extension.
Example: \def\pgfalternateextension{!25!white}
\pgfimage[hoptionsi]{hfilenamei}
Declares the image under the name pgflastimage and immediately uses it. You can “save” the image
for later usage by invoking \pgfaliasimage on pgflastimage.
Example:
\begin{pgfpictureboxed}{0cm}{0.9cm}{7cm}{2.1cm}
\pgfputat{\pgfxy(1,1)}{\pgfbox[left,base]
{\pgfimage[interpolate=true,width=1cm,height=1cm]{pgf-tu-logo}}}
\pgfputat{\pgfxy(3,1)}{\pgfbox[left,base]
{\pgfimage[interpolate=true,width=1cm]{pgf-tu-logo}}}
\pgfputat{\pgfxy(5,1)}{\pgfbox[left,base]
{\pgfimage[interpolate=true,height=1cm]{pgf-tu-logo}}}
\pgfrect[stroke]{\pgfxy(1,1)}{\pgfxy(1,1)}
\pgfrect[stroke]{\pgfxy(3,1)}{\pgfxy(1,1)}
\pgfrect[stroke]{\pgfxy(5,1)}{\pgfxy(1,1)}
\end{pgfpictureboxed}
16
\pgfdeclaremask[hoptionsi]{hmask namei}{hfilenamei}
Declares a transparency mask named hmask namei (called a soft mask in the pdf specification). This
mask is read from the file hfilenamei. This file should contain a grayscale image that is as large as
the actual image. A white pixel in the mask will correspond to “transparent,” a black pixel to “solid,”
and grey values correspond to intermediate values. The maks must have a single “color channel.” This
means that the maks must be a “real” grayscale image, not an rgb-image in which all rgb-triples
happen to have the same components.
You can only mask images the are in a “pixel format.” These are .jpg and .png. You cannot mask
.pdf images in this way. Also, again, the mask file and the image file have to have the same size.
The following options may be given:
• matte={hcolor componentsi} sets the so-called matte of the actual image (strangely, this has to be
specified together with the mask, not with the image itself). The matte is the color that has been
used to preblend the image. For example, if the image has been preblended with a red background,
then hcolor componentsi should be set to {1 0 0}. The default is {1 1 1}, which is white in the
rgb model.
The matte is specified in terms of the parent’s image color space. Thus, if the parent is a grayscale
image, the matte has to be set to {1}.
Example:
% Draw a large colorful background
\pgfdeclarehorizontalshading{colorful}{5cm}{color(0cm)=(red);
color(2cm)=(green); color(4cm)=(blue); color(6cm)=(red);
color(8cm)=(green); color(10cm)=(blue); color(12cm)=(red);
color(14cm)=(green); color(16cm)=(blue)}
\hbox{\pgfuseshading{colorful}\hskip-16cm\hskip1cm
\pgfimage[height=4cm]{pgf-apple}\hskip1cm
\pgfimage[height=4cm]{pgf-apple.mask}\hskip1cm
\pgfdeclaremask{mymask}{pgf-apple.mask}
\pgfimage[mask=mymask,height=4cm,interpolate=true]{pgf-apple}}
To speedup the compilation, you may wish to use the following class option:
\usepackage[draft]{pgf}
In draft mode boxes showing the image name replace the images. It is checked whether the image files
exist, but they are not read. If either height or width is not given, 1cm is used instead.
17
\pgfbox[hhorizontal alignmenti,hvertical alignmenti]{hTEX texti}
Draws the given text with the given alignment at the origin. Allowed alignments are left, center, and
right horizontally; and bottom, base (the base line of the text), center, and top vertically.
Example:
\pgfxyline(3,1)(12.5,1)
\pgfputat{\pgfxy(3,1)}{\pgfbox[left,bottom]{lovely bottom}}
\pgfputat{\pgfxy(5.5,1)}{\pgfbox[left,base]{lovely base}}
\pgfputat{\pgfxy(8,1)}{\pgfbox[left,center]{lovely center}}
\pgfputat{\pgfxy(10.5,1)}{\pgfbox[left,top]{lovely top}}
\pgfsetstartarrow{harrow typei}
Henceforth, the specified harrow typei is added to all stroked lines and curves. This does not apply
to lines constructed using quick commands or lines that are stroked using \pgfqstroke. The allowed
arrow types are listed below.
Example:
\pgfsetstartarrow{\pgfarrowto}
\pgfsetendarrow{\pgfarrowsingle}
\pgfxycurve(0,0.25)(0.5,0.5)(1,0)(1.5,0.25)
\pgfsetendarrow{harrow typei}
Like \pgfsetstartarrow, except that the type of arrow at the end is specified.
\pgfclearstartarrow
Clears the setting for the start arrows.
\pgfclearendarrow
Clears the setting for the end arrows.
The arrow types are explained below. Some arrow types take a parameter that govern its size.
18
\pgfarrowlargepointed{6pt}
\pgfarrowtriangle{4pt}
\pgfarrowcirvle{4pt}
\pgfarrowdiamond
\pgfarrowdot
\pgfarrowpointed
\pgfarrowround
\pgfarrowsquare
\pgfarrowbar
\pgfarrowsingle
\pgfarrowto
You can build more complicated arrow types by applying the following modifiers.
\pgfarrowswap{harrow typei}
Yields an arrow type that has a swapped direction.
Example:
\pgfarrowswap{\pgfarrowsquare}
\pgfarrowswap{\pgfarrowbar}
\pgfarrowswap{\pgfarrowsingle}
\pgfarrowswap{\pgfarrowto}
\pgfarrowdouble{harrow typei}
Yields an arrow type that doubles the given arrow.
Example:
\pgfarrowdouble{\pgfarrowsquare}
\pgfarrowdouble{\pgfarrowbar}
\pgfarrowdouble{\pgfarrowsingle}
\pgfarrowdouble{\pgfarrowto}
\pgfarrowtriple{harrow typei}
Yields an arrow type that triples the given arrow.
Example:
\pgfarrowtriple{\pgfarrowsquare}
\pgfarrowtriple{\pgfarrowbar}
\pgfarrowtriple{\pgfarrowsingle}
\pgfarrowtriple{\pgfarrowto}
\pgfarrowcombineloose{\pgfarrowbar}{\pgfarrowdot}
\pgfarrowcombine{\pgfarrowswap{\pgfarrowsingle}}{\pgfarrowsingle}
\pgfarrowcombine{\pgfarrowsquare}{\pgfarrowround}
\pgfarrowcombine{\pgfarrowto}{\pgfarrowsingle}
19
2.11 Placing Labels on Lines
Two commands can be used to place labels on lines.
\pgfxyline(0,0)(5,2)
\pgfputat
{\pgflabel{.5}{\pgfxy(0,0)}{\pgfxy(5,2)}{1pt}}
{\pgfcircle[stroke]{\pgforigin}{5pt}}
\pgfputat{\pgflabel{.75}{\pgfxy(0,0)}{\pgfxy(5,2)}{5pt}}{\pgfbox[center,base]{Hi!}}
\pgfxyline(0,0)(5,2)
\pgfputlabelrotated{.5}{\pgfxy(0,0)}{\pgfxy(5,2)}{1pt}
{\pgfcircle[stroke]{\pgforigin}{5pt}}
\pgfputlabelrotated{.75}{\pgfxy(0,0)}{\pgfxy(5,2)}{5pt}{\pgfbox[center,base]{Hi!}}
2.12 Shadings
The package pgfshade can be used to create shadings. A shading is an area in which the color changes
smoothly between different colors. Note that you need a recent version of pdflatex for the shadings to work
in pdf. Note also that ghostview may do a poor job at displaying shadings when doing anti-aliasing.
Similarly to an image, a shading must first be declared before it can be used. Also similarly to an image,
a shading is put into a TEX-box. Hence, in order to include a shading in a pgfpicture, you have to place
it in a \pgfbox.
There are three kinds of shadings: horizontal, vertical, and radial shadings. However, you can rotate
and clip shadings like any other graphics object, which allows you to create more complicated shadings.
Horizontal shadings could be created by rotating a vertical shading by 90 degrees, but explicit commands
for creating both horizontal and vertical shadings are included for convenience.
Once you have declared a shading, you can insert it into text using the command \pgfuseshading.
A horizontal shading is a horizontal bar of a certain height whose color changes smoothly. You must at
least specify the colors at the left and at the right end of the bar, but you can also add color specifications
for points in the middle. For example, suppose you which to create a bar that is red at the left end, green
in the middle, and blue at the end. Suppose you would like the bar to be 4cm long. This could be specified
as follows:
rgb(0cm)=(1,0,0); rgb(2cm)=(0,1,0); rgb(4cm)=(0,0,1)
This line means that at 0cm (the left end) of the bar, the color should be red, which has red-green-blue (rgb)
components (1,0,0). At 2cm, the bar should be green, and at 4cm it should be blue. Instead of rgb, you can
currently also specify gray as color model, in which case only one value is needed, or color, in which case
20
you must provide the name of a color in round brackets. In a color specification the individual specifications
must be separated using a semicolon, which may be followed by a whitespace (like a space or a newline).
Individual specifications must be given in increasing order.
\pgfdeclarehorizontalshading{myshading}{1cm}%
{rgb(0cm)=(1,0,0); color(2cm)=(green); color(4cm)=(blue)}
\pgfuseshading{myshading}
The effect of the hcolor listi, which is a comma-separated list of colors, is the following: Normally, when
this list is empty, once a shading is declared it becomes “frozen.” This means that even if you change a
color that was used in the declaration of the shading later on, the shading will not change. By specifying
a hcolor listi you can specify that the shading should be recalculated whenever one of the colors listed in
the list changes (this includes effects like color mixins). Thus, when you specify a hcolor listi, whenever
the shading is used, pgf first converts the colors in the list to rgb triples using the current values of
the colors and taking any mixins and blendings into account. If the resulting rgb triples have not yet
been used, a new shading is internally created and used. Note that if the option hcolor listi is used,
then no shading is created until the first use of \pgfuseshading. In particular, the colors mentioned in
the shading need not be defined when the declaration is given.
When a shading is recalculated because of a change in the colors mentioned in hcolor listi, the complete
shading is recalculated. Thus even colors not mentioned in the list will be used with their current values,
not with the values they had upon declaration.
Example:
\pgfdeclarehorizontalshading[mycolor]{myshading}{1cm}{rgb(0cm)=(1,0,0); color(2cm)=(mycolor)}
\colorlet{mycolor}{green}
\pgfuseshading{myshading}
\colorlet{mycolor}{blue}
\pgfuseshading{myshading}
\pgfdeclareverticalshading{myshading}{5cm}%
{rgb(0cm)=(1,0,0); rgb(1.5cm)=(0,1,0); rgb(2cm)=(0,0,1)}
\pgfuseshading{myshading}
21
such that the given center now has the color specified for 0cm. The effect of color list is the same as for
horizontal shadings.
Example:
\pgfdeclareradialshading{sphere}{\pgfpoint{0.5cm}{0.5cm}}%
{rgb(0.3cm)=(0.9,0,0);
rgb(0.7cm)=(0.7,0,0);
rgb(1cm)=(0.5,0,0);
rgb(1.05cm)=(1,1,1)}
\pgfuseshading{sphere}
\pgfuseshading{hshading namei}
Inserts a previously declared shading into the text. If you wish to use it in a pgfpicture environment,
you should put a \pgfbox around it. Like \pgfuseimage, alternate extensions are tried before the
actual shading is used.
Example:
\pgfputat{\pgfxy(1,1)}{\pgfbox[center,center]{\pgfuseshading{myshading}}}
3 Using Nodes
The package pgfnodes allows you to draw all sorts of graphs in a convenient way. You draw them by first
defining nodes. Once you have defined a node, you can connect nodes using lines or curves. The advantage of
using nodes is that if, later on, you decide to move a node slightly, all connecting lines ‘follow’ automatically.
\pgfnodecircle{Node1}[stroke]{\pgfxy(1,1)}{0.5cm}
\pgfnodecircle{Node2}[virtual]{\pgfxy(3,0.5)}{0.25cm}
\pgfnodecircle{Node3}[fill]{\pgfxy(5,1)}{0.25cm}
\pgfnodeconnline{Node1}{Node2}
\pgfnodeconnline{Node2}{Node3}
22
\pgfnoderect{hnode namei}[hdrawing typei]{hcenter i}{hwidth/height vector i}
Creates a rectangular node with the width and height that is centered at the given position.
Example:
\pgfnoderect{Node1}[fill]{\pgfxy(1,1)}{\pgfxy(1,0.5)}
\pgfnodecircle{Node2}[virtual]{\pgfxy(3,0.5)}{0.25cm}
\pgfnoderect{Node3}[stroke]{\pgfxy(5,1)}{\pgfxy(2,1)}
\pgfnodeconnline{Node1}{Node2}
\pgfnodeconnline{Node2}{Node3}
Hi! You
There
\pgfnodebox{Node1}[stroke]{\pgfxy(1,1)}{Hi!}{2pt}{2pt}
\pgfnodebox{Node2}[virtual]{\pgfxy(3,0.5)}{There}{2pt}{2pt}
\pgfnodebox{Node3}[stroke]{\pgfxy(5,1)}{You}{10pt}{0pt}
\pgfnodeconnline{Node1}{Node2}
\pgfnodeconnline{Node2}{Node3}
\pgfnodecircle{Node1}[stroke]{\pgfxy(1,0.5)}{0.25cm}
\pgfnodecircle{Node2}[stroke]
{\pgfrelative{\pgfxy(1,0)}{\pgfnodecenter{Node1}}}{0.25cm}
\pgfnodecircle{Node3}[stroke]
{\pgfrelative{\pgfxy(1,0)}{\pgfnodecenter{Node2}}}{0.25cm}
\pgfnodecircle{Node4}[stroke]
{\pgfrelative{\pgfxy(1,0)}{\pgfnodecenter{Node3}}}{0.25cm}
hello world
\pgfnodebox{Node1}[stroke]{\pgfxy(1,0.5)}{hello world}{2pt}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{0}{5pt}}{2pt}
23
\pgfcircle[fill]{\pgfnodeborder{Node1}{10}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{20}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{30}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{40}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{50}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeborder{Node1}{60}{5pt}}{2pt}
\pgfcircle[fill]{\pgfnodeconnstart[5pt]{Node1}{Node2}}{2pt}
\pgfcircle[fill]{\pgfnodeconnstart[10pt]{Node1}{Node3}}{2pt}
\pgfcircle[fill]{\pgfnodeconnstart[15pt]{Node1}{Node4}}{2pt}
hello world 2
\pgfnodebox{Node1}[stroke]{\pgfxy(1,0.5)}{hello world}{2pt}{2pt}
\pgfnodebox{Node2}[stroke]{\pgfxy(4,.5)}{2}{2pt}{2pt}
\pgfnodesetsepstart{0pt}
\pgfnodesetsepend{5pt}
\pgfsetendarrow{\pgfarrowto}
\pgfnodeconnline{Node1}{Node2}
\pgfnodebox{Node1}[stroke]{\pgfxy(1,0.5)}{hello}{2pt}{2pt}
24
\pgfnodebox{Node2}[stroke]{\pgfxy(4,.5)}{world}{2pt}{2pt}
\pgfnodebox{Node3}[stroke]{\pgfxy(7,.5)}{lovely}{2pt}{2pt}
\pgfnodeconncurve{Node1}{Node2}{0}{90}{1cm}{1cm}
\pgfnodeconncurve{Node1}{Node2}{0}{90}{1cm}{1.5cm}
\pgfnodeconncurve{Node1}{Node2}{0}{90}{1cm}{2cm}
\pgfnodeconncurve{Node1}{Node2}{0}{90}{1cm}{2.5cm}
\pgfnodeconncurve{Node2}{Node3}{-10}{80}{1cm}{1cm}
\pgfnodeconncurve{Node2}{Node3}{-20}{70}{1cm}{1cm}
\pgfnodeconncurve{Node2}{Node3}{-30}{60}{1cm}{1cm}
\pgfnodeconncurve{Node2}{Node3}{-40}{50}{1cm}{1cm}
Hi! world
hello
\pgfnodebox{Node1}[stroke]{\pgfxy(1,0.5)}{hello}{2pt}{2pt}
\pgfnodebox{Node2}[stroke]{\pgfxy(5,1.5)}{world}{2pt}{2pt}
\pgfnodeconnline{Node1}{Node2}
\pgfnodelabel{Node1}{Node2}[0.5][5pt]{\pgfcircle[stroke]{\pgforigin}{5pt}}
\pgfnodelabel{Node1}{Node2}[0.75][5pt]{\pgfbox[center,base]{Hi!}}
Hi! world
hello
\pgfnodebox{Node1}[stroke]{\pgfxy(1,0.5)}{hello}{2pt}{2pt}
\pgfnodebox{Node2}[stroke]{\pgfxy(5,1.5)}{world}{2pt}{2pt}
\pgfnodeconnline{Node1}{Node2}
\pgfnodelabelrotated{Node1}{Node2}[0.5][5pt]{\pgfcircle[stroke]{\pgforigin}{5pt}}
\pgfnodelabelrotated{Node1}{Node2}[0.75][5pt]{\pgfbox[center,base]{Hi!}}
\begin{colormixin}{hmix-in specificationi}
henvironment contentsi
25
\end{colormixin}
The mix-in specification is applied to all colors inside the environment. At the beginning of the environ-
ment, the mix-in is applied to the current color, i. e., the color that was in effect before the environment
started. A mix-in specification is a number between 0 and 100 followed by an exclamation mark and a
color name. When a \color command is encountered inside a mix-in environment, the number states
what percentage of the desired color should be used. The rest is “filled up” with the color given in the
mix-in specification. Thus, a mix-in specification like 90!blue will mix in 10% of blue into everything,
whereas 25!white will make everything nearly white.
Example:
\color{red}Red text,%
\begin{colormixin}{25!white}
washed-out red text,
\color{blue} washed-out blue text,
\begin{colormixin}{25!black}
dark washed-out blue text,
\color{green} dark washed-out green text,%
\end{colormixin}
back to washed-out blue text,%
\end{colormixin}
and back to red.
Red text, washed-out red text, washed-out blue text, dark washed-out blue text, dark washed-out green
text, back to washed-out blue text, and back to red.
Note that the environment only changes colors that have been installed using the standard LATEX \color
command. In particular, the colors in images are not changed. There is, however, some support offered by
the commands \pgfuseimage and \pgfuseshading. If the first command is invoked inside a colormixin
environment with the parameter, say, 50!black on an image with the name foo, the command will first check
whether there is also a defined image with the name foo.!50!black. If so, this image is used instead. This
allows you to provide a different image for this case. If you nest colormixin environments, the different mix-
ins are appended as a comma-separated list. For example, inside the inner environment of the above example,
\pgfuseimage{foo} would first check whether there exists an image named foo.!50!white!25!black.
\colorcurrentmixin
Expands to the current accumulated mix-in. Each nesting of a colormixin adds a mix-in to this list.
Example:
\begin{colormixin}{25!white}
\colorcurrentmixin is now ‘‘25!white’’
\begin{colormixin}{75!black}
\colorcurrentmixin is now ‘‘75!black!25!white’’
\begin{colormixin}{50!white}
\colorcurrentmixin is now ‘‘50!white!75!black!25!white’’
\end{colormixin}
\end{colormixin}
\end{colormixin}
26