% Copyright 2019 by Till Tantau % % This file may be distributed and/or modified % % 1. under the LaTeX Project Public License and/or % 2. under the GNU Free Documentation License. % % See the file doc/generic/pgf/licenses/LICENSE for more details. \section[Hierarchical Structures: Package, Environments, Scopes, and Text] {Hierarchical Structures:\\ Package, Environments, Scopes, and Text} \subsection{Overview} \pgfname\ uses two kinds of hierarchical structuring: First, the package itself is structured hierarchically, consisting of different packages that are built on top of each other. Second, \pgfname\ allows you to structure your graphics hierarchically using environments and scopes. \subsubsection{The Hierarchical Structure of the Package} The \pgfname\ system consists of several layers: % \begin{description} \item[System layer.] The lowest layer is called the \emph{system layer}, though it might also be called ``driver layer'' or perhaps ``backend layer''. Its job is to provide an abstraction of the details of which driver is used to transform the |.dvi| file. The system layer is implemented by the package |pgfsys|, which will load appropriate driver files as needed. The system layer is documented in Part~\ref{part-system}. \item[Basic layer.] The basic layer is loaded by the package |pgfcore| and subsequent use of the command |\usepgfmodule| to load additional modules of the basic layer. The basic layer is documented in the present part. \item[Frontend layer.] The frontend layer is not loaded by a single package. Rather, different packages, like \tikzname\ or \textsc{pgfpict2e}, are different frontends to the basic layer. The \tikzname\ frontend is documented in Part~\ref{part-tikz}. \end{description} Each layer will automatically load the necessary files of the layers below it. In addition to the packages of these layers, there are also some library packages. These packages provide additional definitions of things like new arrow tips or new plot handlers. The library packages are documented in Part~\ref{part-libraries}. \subsubsection{The Hierarchical Structure of Graphics} Graphics in \pgfname\ are typically structured hierarchically. Hierarchical structuring can be used to identify groups of graphical elements that are to be treated ``in the same way''. For example, you might group together a number of paths, all of which are to be drawn in red. Then, when you decide later on that you like them to be drawn in, say, blue, all you have to do is to change the color once. The general mechanism underlying hierarchical structuring is known as \emph{scoping} in computer science. The idea is that all changes to the general ``state'' of the graphic that are done inside a scope are local to that scope. So, if you change the color inside a scope, this does not affect the color used outside the scope. Likewise, when you change the line width in a scope, the line width outside is not changed, and so on. There are different ways of starting and ending scopes of graphic parameters. Unfortunately, these scopes are sometimes ``in conflict'' with each other and it is sometimes not immediately clear which scopes apply. In essence, the following scoping mechanisms are available: % \begin{enumerate} \item The ``outermost'' scope supported by \pgfname\ is the |{pgfpicture}| environment. All changes to the graphic state done inside a |{pgfpicture}| are local to that picture. In general, it is \emph{not} possible to set graphic parameters globally outside any |{pgfpicture}| environments. Thus, you can \emph{not} say |\pgfsetlinewidth{1pt}| at the beginning of your document to have a default line width of one point. Rather, you have to (re)set all graphic parameters inside each |{pgfpicture}|. (If this is too bothersome, try defining some macro that does the job for you.) \item Inside a |{pgfpicture}| you can use a |{pgfscope}| environment to keep changes of the graphic state local to that environment. The effect of commands that change the graphic state are local to the current |{pgfscope}|, but not always to the current \TeX\ group. Thus, if you open a \TeX\ group (some text in curly braces) inside a |{pgfscope}|, and if you change, for example, the dash pattern, the effect of this changed dash pattern will persist till the end of the |{pgfscope}|. Unfortunately, this is not always the case. \emph{Some} graphic parameters only persist till the end of the current \TeX\ group. For example, when you use |\pgfsetarrows| to set the arrow tip inside a \TeX\ group, the effect lasts only till the end of the current \TeX\ group. \item Some graphic parameters are not scoped by |{pgfscope}| but ``already'' by \TeX\ groups. For example, the effect of coordinate transformation commands is always local to the current \TeX\ group. Since every |{pgfscope}| automatically creates a \TeX\ group, all graphic parameters that are local to the current \TeX\ group are also local to the current |{pgfscope}|. \item Some graphic parameters can only be scoped using \TeX\ groups, since in some situations it is not possible to introduce a |{pgfscope}|. For example, a path always has to be completely constructed and used in the same |{pgfscope}|. However, we might wish to have different coordinate transformations apply to different points on the path. In this case, we can use \TeX\ groups to keep the effect local, but we could not use |{pgfscope}|. \item The |\pgftext| command can be used to create a scope in which \TeX\ ``escapes back'' to normal \TeX\ mode. The text passed to the |\pgftext| is ``heavily guarded'' against having any effect on the scope in which it is used. For example, it is possible to use another |{pgfpicture}| environment inside the argument of |\pgftext|. \end{enumerate} Most of the complications can be avoided if you stick to the following rules: % \begin{itemize} \item Give graphic commands only inside |{pgfpicture}| environments. \item Use |{pgfscope}| to structure graphics. \item Do not use \TeX\ groups inside graphics, \emph{except} for keeping the effect of coordinate transformations local. \end{itemize} \subsection{The Hierarchical Structure of the Package} Before we come to the structuring commands provided by \pgfname\ to structure your graphics, let us first have a look at the structure of the package itself. \subsubsection{The Core Package} To use \pgfname, include the following package: \begin{package}{pgfcore} This package loads the complete core of the ``basic layer'' of \pgfname, but not any modules. That is, it will load all of the commands described in the current part of this manual, but it will not load frontends like \tikzname. It will also load the system layer. To load additional modules, use the |\usepgfmodule| command explained below. \end{package} The following package is just a convenience. \begin{package}{pgf} This package loads the |pgfcore| and the two modules |shapes| and |plot|. In \LaTeX, the package takes two options: % \begin{packageoption}{draft} When this option is set, all images will be replaced by empty rectangles. This can speedup compilation. \end{packageoption} \begin{packageoption}{version=\meta{version}} Indicates that the commands of version \meta{version} need to be defined. If you set \meta{version} to |0.65|, then a large bunch of ``compatibility commands'' are loaded. If you set \meta{version} to |0.96|, then these compatibility commands will not be loaded. If this option is not given at all, then the commands of all versions are defined. \end{packageoption} \end{package} \subsubsection{The Modules} \begin{command}{\usepgfmodule\marg{module names}} Once the core has been loaded, you can use this command to load further modules. The modules in the \meta{module names} list should be separated by commas. Instead of curly braces, you can also use square brackets, which is something Con\TeX t users will like. If you try to load a module a second time, nothing will happen. \example |\usepgfmodule{matrix,shapes}| What this command does is to load the file |pgfmodule|\meta{module}|.code.tex| for each \meta{module} in the list of \meta{module names}. Thus, to write your own module, all you need to do is to place a file of the appropriate name somewhere \TeX\ can find it. \LaTeX, plain \TeX, and Con\TeX t users can then use your library. \end{command} The following modules are available for use with |pgfcore|: \todosp{In the meantime there are some more modules. Also mention them here?} % \begin{itemize} \item The |plot| module provides commands for plotting functions. The commands are explained in Section~\ref{section-plots}. \item The |shapes| module provides commands for drawing shapes and nodes. These commands are explained in Section~\ref{section-shapes}. \item The |decorations| module provides commands for adding decorations to paths. These commands are explained in Section~\ref{section-base-decorations}. \item The |matrix| module provides the |\pgfmatrix| command. The commands are documented in Section~\ref{section-base-matrices}. \end{itemize} \subsubsection{The Library Packages} There is a special command for loading library packages. The difference between a library and module is the following: A library just defines additional objects using the basic layer, whereas a module adds completely new functionality. For instance, a |decorations| library defines additional decorations, while a decoration module defines the whole code for handling decorations. \begin{command}{\usepgflibrary\marg{list of libraries}} Use this command to load further libraries. The list of libraries should contain the names of libraries separated by commas. Instead of curly braces, you can also use square brackets. If you try to load a library a second time, nothing will happen. \example |\usepgflibrary{arrows}| This command causes the file |pgflibrary|\meta{library}|.code.tex| to be loaded for each \meta{library} in the \meta{list of libraries}. This means that in order to write your own library file, place a file of the appropriate name somewhere where \TeX\ can find it. \LaTeX, plain \TeX, and Con\TeX t users can then use your library. You should also consider adding a \tikzname\ library that simply includes your \pgfname\ library. \end{command} \subsection{The Hierarchical Structure of the Graphics} \subsubsection{The Main Environment} Most, but not all, commands of the \pgfname\ package must be given within a |{pgfpicture}| environment. The only commands that (must) be given outside are commands having to do with including images (like |\pgfuseimage|) and with inserting complete shadings (like |\pgfuseshading|). However, just to keep life entertaining, the |\pgfshadepath| command must be given \emph{inside} a |{pgfpicture}| environment. \begin{environment}{{pgfpicture}} This environment will insert a \TeX\ box containing the graphic drawn by the \meta{environment contents} at the current position. \medskip \textbf{The size of the bounding box.} The size of the box is determined in the following manner: While \pgfname\ parses the \meta{environment contents}, it keeps track of a bounding box for the graphic. Essentially, this bounding box is the smallest box that contains all coordinates mentioned in the graphics. Some coordinates may be ``mentioned'' by \pgfname\ itself; for example, when you add circle to the current path, the support points of the curve making up the circle are also ``mentioned'' despite the fact that you will not ``see'' them in your code. Once the \meta{environment contents} have been parsed completely, a \TeX\ box is created whose size is the size of the computed bounding box and this box is inserted at the current position. % \begin{codeexample}[] Hello \begin{pgfpicture} \pgfpathrectangle{\pgfpointorigin}{\pgfpoint{2ex}{1ex}} \pgfusepath{stroke} \end{pgfpicture} World! \end{codeexample} Sometimes, you may need more fine-grained control over the size of the bounding box. For example, the computed bounding box may be too large or you intensionally wish the box to be ``too small''. In these cases, you can use the command |\pgfusepath{use as bounding box}|, as described in Section~\ref{section-using-bb}. \medskip \textbf{The baseline of the bounding box.} When the box containing the graphic is inserted into the normal text, the baseline of the graphic is normally at the bottom of the graphic. For this reason, the following two sets of code lines have the same effect, despite the fact that the second graphic uses ``higher'' coordinates than the first: % \begin{codeexample}[] Rectangles \begin{pgfpicture} \pgfpathrectangle{\pgfpointorigin}{\pgfpoint{2ex}{1ex}} \pgfusepath{stroke} \end{pgfpicture} and \begin{pgfpicture} \pgfpathrectangle{\pgfpoint{0ex}{1ex}}{\pgfpoint{2ex}{1ex}} \pgfusepath{stroke} \end{pgfpicture}. \end{codeexample} You can change the baseline using the |\pgfsetbaseline| command, see below. % \begin{codeexample}[] Rectangles \begin{pgfpicture} \pgfpathrectangle{\pgfpointorigin}{\pgfpoint{2ex}{1ex}} \pgfusepath{stroke} \pgfsetbaseline{0pt} \end{pgfpicture} and \begin{pgfpicture} \pgfpathrectangle{\pgfpoint{0ex}{1ex}}{\pgfpoint{2ex}{1ex}} \pgfusepath{stroke} \pgfsetbaseline{0pt} \end{pgfpicture}. \end{codeexample} \medskip \textbf{Including text and images in a picture.} You cannot directly include text and images in a picture. Thus, you should \emph{not} simply write some text in a |{pgfpicture}| or use a command like |\includegraphics| or even |\pgfimage|. In all these cases, you need to place the text inside a |\pgftext| command. This will ``escape back'' to normal \TeX\ mode, see Section~\ref{section-text-command} for details. \medskip \textbf{Remembering a picture position for later reference.} After a picture has been typeset, its position on the page is normally forgotten by \pgfname\ and also by \TeX. This means that is not possible to reference a node in this picture later on. In particular, it is normally impossible to draw lines between nodes in different pictures automatically. In order to make \pgfname\ ``remember'' a picture, the \TeX-if |\ifpgfrememberpicturepositiononpage| should be set to |true|. It is only important that this \TeX-if is |true| at the end of the |{pgfpicture}|-en\-vi\-ron\-ment, so you can switch it on inside the environment. However, you can also just switch it on globally, then the positions of all pictures are remembered. There are several reasons why the remembering is not switched on by default. First, it does not work for all backend drivers (currently, it works only for pdf\TeX). Second, it requires two passes of \TeX\ over the file; on the first pass all positions will be wrong. Third, for every remembered picture a line is added to the |.aux|-file, which may result in a large number of extra lines. Despite all these ``problems'', for documents that are processed with pdf\TeX\ and in which there is only a small number of pictures (less than a hundred or so), you can switch on this option globally, it will not cause any significant slowing of \TeX. \end{environment} \begin{plainenvironment}{{pgfpicture}} The plain \TeX\ version of the environment. Note that in this version, also, a \TeX\ group is created around the environment. \end{plainenvironment} \begin{contextenvironment}{{pgfpicture}} This is the Con\TeX t version of the environment. \end{contextenvironment} {\let\ifpgfrememberpicturepositiononpage=\relax \begin{command}{\ifpgfrememberpicturepositiononpage} Determines whether the position of pictures on the page should be recorded. The value of this \TeX-if at the end of a |{pgfpicture}| environment is important, not the value at the beginning. If this option is set to true of a picture, \pgfname\ will attempt to record the position of the picture on the page. (This attempt will fail with most drivers and when it works, it typically requires two runs of \TeX.) The position is not directly accessible. Rather, the nodes mechanism will use this position if you access a node from another picture. See Sections~\ref{section-cross-pictures-pgf} and~\ref{section-cross-picture-tikz} for more details. \end{command} } \makeatletter \begin{command}{\pgfsetbaseline\marg{dimension}} This command specifies a $y$-coordinate of the picture that should be used as the baseline of the whole picture. When a \pgfname\ picture has been typeset completely, \pgfname\ must decide at which height the baseline of the picture should lie. Normally, the baseline is set to the $y$-coordinate of the bottom of the picture, but it is often desirable to use a different height. % \begin{codeexample}[] Text \begin{pgfpicture} \pgfpathcircle{\pgfpointorigin}{1ex}\pgfusepath{stroke} \end{pgfpicture}, \begin{pgfpicture} \pgfsetbaseline{0pt} \pgfpathcircle{\pgfpointorigin}{1ex}\pgfusepath{stroke} \end{pgfpicture}, \begin{pgfpicture} \pgfsetbaseline{.5ex} \pgfpathcircle{\pgfpointorigin}{1ex}\pgfusepath{stroke} \end{pgfpicture}, \begin{pgfpicture} \pgfsetbaseline{-1ex} \pgfpathcircle{\pgfpointorigin}{1ex}\pgfusepath{stroke} \end{pgfpicture}. \end{codeexample} % \end{command} \begin{command}{\pgfsetbaselinepointnow\marg{point}} This command specifies the baseline indirectly, namely as the $y$-coordinate that the given \meta{point} has when the command is called. \end{command} \begin{command}{\pgfsetbaselinepointlater\marg{point}} This command also specifies the baseline indirectly, but the $y$-coordinate of the given \meta{point} is only computed at the end of the picture. % \begin{codeexample}[] Hello \begin{pgfpicture} \pgfsetbaselinepointlater{\pgfpointanchor{X}{base}} % Note: no shape X, yet \pgfnode{cross out}{center}{world.}{X}{\pgfusepath{stroke}} \end{pgfpicture} \end{codeexample} % \end{command} \subsubsection{Graphic Scope Environments} Inside a |{pgfpicture}| environment you can substructure your picture using the following environment: \begin{environment}{{pgfscope}} All changes to the graphic state done inside this environment are local to the environment. The graphic state includes the following: % \begin{itemize} \item The line width. \item The stroke and fill colors. \item The dash pattern. \item The line join and cap. \item The miter limit. \item The canvas transformation matrix. \item The clipping path. \end{itemize} % Other parameters may also influence how graphics are rendered, but they are \emph{not} part of the graphic state. For example, the arrow tip kind is not part of the graphic state and the effect of commands setting the arrow tip kind are local to the current \TeX\ group, not to the current |{pgfscope}|. However, since |{pgfscope}| starts and ends a \TeX\ group automatically, a |{pgfscope}| can be used to limit the effect of, say, commands that set the arrow tip kind. % \begin{codeexample}[] \begin{pgfpicture} \begin{pgfscope} { \pgfsetlinewidth{2pt} \pgfpathrectangle{\pgfpointorigin}{\pgfpoint{2ex}{2ex}} \pgfusepath{stroke} } \pgfpathrectangle{\pgfpoint{3ex}{0ex}}{\pgfpoint{2ex}{2ex}} \pgfusepath{stroke} \end{pgfscope} \pgfpathrectangle{\pgfpoint{6ex}{0ex}}{\pgfpoint{2ex}{2ex}} \pgfusepath{stroke} \end{pgfpicture} \end{codeexample} \begin{codeexample}[] \begin{pgfpicture} \begin{pgfscope} { \pgfsetarrows{->} \pgfpathmoveto{\pgfpointorigin}\pgfpathlineto{\pgfpoint{2ex}{2ex}} \pgfusepath{stroke} } \pgfpathmoveto{\pgfpoint{3ex}{0ex}}\pgfpathlineto{\pgfpoint{5ex}{2ex}} \pgfusepath{stroke} \end{pgfscope} \pgfpathmoveto{\pgfpoint{6ex}{0ex}}\pgfpathlineto{\pgfpoint{8ex}{2ex}} \pgfusepath{stroke} \end{pgfpicture} \end{codeexample} At the start of the scope, the current path must be empty, that is, you cannot open a scope while constructing a path. It is usually a good idea \emph{not} to introduce \TeX\ groups inside a |{pgfscope}| environment. \end{environment} \begin{plainenvironment}{{pgfscope}} Plain \TeX\ version of the |{pgfscope}| environment. \end{plainenvironment} \begin{contextenvironment}{{pgfscope}} This is the Con\TeX t version of the environment. \end{contextenvironment} The following scopes also encapsulate certain properties of the graphic state. However, they are typically not used directly by the user. \begin{environment}{{pgfinterruptpath}} This environment can be used to temporarily interrupt the construction of the current path. The effect will be that the path currently under construction will be ``stored away'' and restored at the end of the environment. Inside the environment you can construct a new path and do something with it. An example application of this environment is the arrow tip caching. Suppose you ask \pgfname\ to use a specific arrow tip kind. When the arrow tip needs to be rendered for the first time, \pgfname\ will ``cache'' the path that makes up the arrow tip. To do so, it interrupts the current path construction and then protocols the path of the arrow tip. The |{pgfinterruptpath}| environment is used to ensure that this does not interfere with the path to which the arrow tips should be attached. This command does \emph{not} install a |{pgfscope}|. In particular, it does not call any |\pgfsys@| commands at all, which would, indeed, be dangerous in the middle of a path construction. \end{environment} \begin{plainenvironment}{{pgfinterruptpath}} Plain \TeX\ version of the environment. \end{plainenvironment} \begin{contextenvironment}{{pgfinterruptpath}} Con\TeX t version of the environment. \end{contextenvironment} \begin{environment}{{pgfinterruptpicture}} This environment can be used to temporarily interrupt a |{pgfpicture}|. However, the environment is intended only to be used at the beginning and end of a box that is (later) inserted into a |{pgfpicture}| using |\pgfqbox|. You cannot use this environment directly inside a |{pgfpicture}|. % \begin{codeexample}[] \begin{pgfpicture} \pgfpathmoveto{\pgfpoint{0cm}{0cm}} % In the middle of path, now \newbox\mybox \setbox\mybox=\hbox{ \begin{pgfinterruptpicture} Sub-\begin{pgfpicture} % a subpicture \pgfpathmoveto{\pgfpoint{1cm}{0cm}} \pgfpathlineto{\pgfpoint{1cm}{1cm}} \pgfusepath{stroke} \end{pgfpicture}-picture. \end{pgfinterruptpicture} } \pgfqbox{\mybox}% \pgfpathlineto{\pgfpoint{0cm}{1cm}} \pgfusepath{stroke} \end{pgfpicture}\hskip3.9cm \end{codeexample} % \end{environment} \begin{plainenvironment}{{pgfinterruptpicture}} Plain \TeX\ version of the environment. \end{plainenvironment} \begin{contextenvironment}{{pgfinterruptpicture}} Con\TeX t version of the environment. \end{contextenvironment} \begin{environment}{{pgfinterruptboundingbox}} This environment temporarily interrupts the computation of the bounding box and sets up a new bounding box. At the beginning of the environment the old bounding box is saved and an empty bounding box is installed. After the environment the original bounding box is reinstalled as if nothing has happened. \end{environment} \begin{plainenvironment}{{pgfinterruptboundingbox}} Plain \TeX\ version of the environment. \end{plainenvironment} \begin{contextenvironment}{{pgfinterruptboundingbox}} Con\TeX t version of the environment. \end{contextenvironment} \subsubsection{Inserting Text and Images} \label{section-text-command} Often, you may wish to add normal \TeX\ text at a certain point inside a |{pgfpicture}|. You cannot do so ``directly'', that is, you cannot simply write this text inside the |{pgfpicture}| environment. Rather, you must pass the text as an argument to the |\pgftext| command. You must \emph{also} use the |\pgftext| command to insert an image or a shading into a |{pgfpicture}|. \begin{command}{\pgftext\opt{\oarg{options}}\marg{text}} This command will typeset \meta{text} in normal \TeX\ mode and insert the resulting box into the |{pgfpicture}|. The bounding box of the graphic will be updated so that all of the text box is inside. By default, the text box is centered at the origin, but this can be changed either by giving appropriate \meta{options} or by applying an appropriate coordinate transformation beforehand. The \meta{text} may contain verbatim text. (In other words, the \meta{text} ``argument'' is not a normal argument, but is put in a box and some |\aftergroup| hackery is used to find the end of the box.) \pgfname's current (high-level) coordinate transformation is synchronized with the canvas transformation matrix temporarily when the text box is inserted. The effect is that if there is currently a high-level rotation of, say, 30 degrees, the \meta{text} will also be rotated by thirty degrees. If you do not want this effect, you have to (possibly temporarily) reset the high-level transformation matrix. The \meta{options} keys are used with the path |/pgf/text/|. The following keys are defined for this path: % \begin{key}{/pgf/text/left} The key causes the text box to be placed such that its left border is on the origin. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[left] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/right} The key causes the text box to be placed such that its right border is on the origin. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[right] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/top} This key causes the text box to be placed such that its top is on the origin. This option can be used together with the |left| or |right| option. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[top] {lovely}} \end{codeexample} % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[top,right] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/bottom} This key causes the text box to be placed such that its bottom is on the origin. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[bottom] {lovely}} \end{codeexample} % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[bottom,right] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/base} This key causes the text box to be placed such that its baseline is on the origin. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[base] {lovely}} \end{codeexample} % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[base,right] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/at=\meta{point}} Translates the origin (that is, the point where the text is shown) to \meta{point}. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[base,at={\pgfpoint{1cm}{0cm}}] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/x=\meta{dimension}} Translates the origin by \meta{dimension} along the $x$-axis. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[base,x=1cm,y=-0.5cm] {lovely}} \end{codeexample} \end{key} % \begin{key}{/pgf/text/y=\meta{dimension}} This key works like the |x| option. \end{key} % \begin{key}{/pgf/text/rotate=\meta{degree}} Rotates the coordinate system by \meta{degree}. This will also rotate the text box. % \begin{codeexample}[] \tikz{\draw[help lines] (-1,-.5) grid (1,.5); \pgftext[base,x=1cm,y=-0.5cm,rotate=30] {lovely}} \end{codeexample} \end{key} \end{command} \subsection{Object Identifiers} Graphical objects can have an \emph{identifier,} which allows you to reference the object later on. For instance, you could reference the object as the target of a hyperlink (although this capability is not necessarily implemented by drivers) or as the target of an animation; indeed, animations always need an object identifier to identify the to-be-animated object. Attaching an identifier to an object is a two-step process: % \begin{enumerate} \item You call |\pgfuseid{|\meta{id}|}| to choose an id, which is a normal string. \item Next, you call one of several commands like |\pgfidscope| or |\pgftext|, which create an object. This object will have then have the id. \end{enumerate} \subsubsection{Commands for Creating Graphic Objects} The following system level commands create an object with an id: % \begin{enumerate} \item |\pgfsys@begin@idscope|, which creates a graphic scope. \item |\pgfsys@viewboxmeet| or |\pgfsys@viewboxslice|, which create view boxes, \item |\pgfsys@fill|, |\pgfsys@stroke|, and all other path usage command, \item |\pgfsys@hbox| or |\pgfsys@hboxsynced|, which create text boxes, and \item |\pgfsys@animate...|, which create animations. \end{enumerate} These system layer commands are, in turn, called by the following basic layer commands (and, also, by the commands that call them, in turn): % \begin{itemize} \item |\pgfidscope|, which creates an id scope (see below). \item |\pgfviewboxscope|, which creates a view box. \item |\pgfusepath|, which creates a path. \item |\pgftext| and |\pgfnode| and |\pgfmultipartnode|, which create text boxes and nodes, and \item |\pgfanimateattribute|, which creates an animation. \end{itemize} \begin{environment}{{pgfidscope}} Creates a graphic scope that will have the id last used with |\pgfuseid| attached to, provided such an id was set and was not already used with another object. In the latter cases, no graphic scope is created. Thus, if you wish to ensure that a graphic scope is created, you must (additionally) call |\pgfscope| inside or outside the id scope. \end{environment} The Plain\TeX\ and Con\TeX t versions of the environment are: % \begin{plainenvironment}{{pgfidscope}} \end{plainenvironment} \begin{contextenvironment}{{pgfidscope}} \end{contextenvironment} \subsubsection{Settings and Querying Identifiers} In order to attach an identifier to an object, you first use the following command: \begin{command}{\pgfuseid\marg{name}} The \meta{name} is a string by which the object will be referenced (see |\pgfidrefnextuse|). The next time a graphic object is created in the current \TeX\ scope, the name will be attached to it (actually, it will get a system layer identifier attached to it that is automatically created using |\pgfsys@new@id|, the \meta{name} is bound to that identifier and it can be retrieved using |\pgfidrefnextuse|). This holds true only for the next object: If a second object is created, it will not get the name attached to it. This does not mean, however, that you cannot attach the same name to different objects; you just need to call |\pgfuseid| again before each object. Besides the \meta{name} (or, more precisely, besides the system layer identifier it refers to), the current \emph{identifier type} is also important: Actually, a graphic object is not referenced by a system layer identifier, but by the combination of the identifier and a type. You can use the following commands for modifying the type used for the creation of objects: \begin{command}{\pgfusetype\marg{type}} Sets the type used for the referencing of graphic objects for the current scope to \meta{type} or, if \meta{type} starts with a dot, appends \meta{type} to the current type. You use this command with compound graphic objects: Before each part of a graphic object, set the type to an appropriate value. Now, if the object is named using |\pgfuseid|, you can later on access all parts of the compound object using the combination of the \meta{name} used with |\pgfuseid| and the type of the part. As an example, this system is used to give you access to the different parts of a node: When you say |\pgfuseid{mynode}| and then create a node, you can use |mynode| with the empty type to reference the graphics scope that encompasses the whole node, but also |mynode| together with the type |background| to access the background path of the node. In detail, \pgfname\ uses this command to set the following types: % \begin{itemize} \item Inside the command |\pgfviewboxscope|, the type |.view| is used for the view object. \item Inside the command |\pgfmultipartnode|, the type |.behind background| is used for the scope of drawings behind the background. Similarly, |.before background| and |.behind foreground| and finally |.before foreground| are used with the respective parts of a node. \item Also inside a node, |.background| and |.foreground| are used as types of the background and foreground paths, respectively. \item Finally, inside a node, for each text part, the text part's name is used as a type (so |.text| is used for the main part). \end{itemize} In addition, \tikzname\ uses this command in the following situations: % \begin{itemize} \item The type |.path| is used with a named path (named using the |name| key). This is the graphic object you need to reference when you wish to morph a path. \item The type |.path picture| is used with the scope of the optional path picture. \item The type |.path fill| is used with the path used for filling. This is not the same as the normal path in case the path is filled and patterned, for instance. \item The type |.path shade| is used with the path used for shading a path. \end{itemize} \end{command} \begin{command}{\pgfpushtype} Pushes the current type on an internal global stack. The idea is to allow you to temporarily change the current type without having to open a \TeX\ scope. \end{command} \begin{command}{\pgfpoptype} Restores the most recent type from the internal global stack of types. \end{command} \end{command} \begin{command}{\pgfclearid} Clears the current id (and type) for the local scope. \end{command} \begin{command}{\pgfidrefnextuse\marg{macro}\marg{name}} This command assigns a system layer identifier (the identifier returned by |\pgfsys@new@id|) to the \meta{macro}, namely the one that will be used the \emph{next} time |\pgfuseid| is used. You use this command for ``forward referencing''. A typical use case is the following: A key like |whom| for animations uses this command to get the system identifier that will be used for a future object. Then, this identifier can be passed to system layer commands like |\pgfsys@animation@whom|. Note that the ``next'' use need not be on the same page (or there may not even be any use at all), in which case the reference will not refer to any object. \end{command} \begin{command}{\pgfidrefprevuse\marg{macro}\marg{name}} Works like |\pgfidrefnextuse|, only it references the most recent \emph{previous} use of the \meta{name}. As for |\pgfidrefnextuse|, the most recent use need not be on the same page. \end{command} \begin{command}{\pgfaliasid\marg{alias}\marg{name}} Creates an alias of a name inside the current \TeX\ scope. After calling this command, you can use \meta{alias} anywhere where you would normally use \meta{name}. Note that the binding between \meta{alias} and \meta{name} is not kept when |\pgfuseid| is used on the \meta{name} (or the \meta{alias}). \end{command} \begin{command}{\pgfgaliasid\marg{1}\marg{2}} Like |\pgfaliasid|, only the alias is set globally. \end{command} \begin{command}{\pgfifidreferenced\marg{name}\marg{then code}\marg{else code}} If \meta{name} has been referenced, \meta{then code} is executed, otherwise \meta{else code}. \end{command} \subsection{Resource Description Framework Annotations (RDFa)} \label{section-base-rdf} With certain output formats (in particular, with \textsc{svg}) you can insert annotations into the output file following the standard set by the \emph{resource description framework} (known as ``\textsc{rdf}'', please consult the literature on \textsc{rdf} and \textsc{rdf}a for an introduction to resource descriptions and ontologies and their purpose in general). To do so, you call one (or several) of the following commands before you call |\pgfidscope|. The attributes and values you specify using the commands will then be added to the resulting scope (if the driver supports this, which is only the case for \textsc{svg} at the moment). As an example, when you write % \begin{codeexample}[code only] \pgfrdfresource{/fruits/apple} \pgfidscope ... \pgfendidscope \end{codeexample} in the resulting \textsc{svg} file you get % \begin{codeexample}[code only] ... \end{codeexample} Most of the following commands just set a single attribute for the next id scope. In some cases, however, repeated calling of these commands makes sense and causes the passed values to accumulate as in the following example: % \begin{codeexample}[code only] \pgfrdfresource{/fruits/apple} \pgfrdfproperty{http://foo.com/props/juicy} \pgfrdfproperty{http://foo.com/props/green} \pgfidscope ... \pgfendidscope \end{codeexample} Now you get: % \begin{codeexample}[code only] ... \end{codeexample} The following commands ``accumulate'': |\pgfrdfproperty|, |\pgfrdfrel|, |\pgfrdfrev| and also the command |\pgfrdftypeof|. \begin{command}{\pgfrdfabout\marg{text}} Adds the \textsc{rdf} attribute |about="|\meta{text}|"| to the next id scope (please see the \textsc{rdf}a specification for details on the semantics of |about| in the context of the resource description framework). \end{command} The following commands work the same way. \begin{command}{\pgfrdfcontent\marg{text}} \end{command} \begin{command}{\pgfrdfdatatype\marg{text}} \end{command} \begin{command}{\pgfrdfhref\marg{text}} \end{command} \begin{command}{\pgfrdfinlist} \end{command} \begin{command}{\pgfrdfprefix\marg{text}} \end{command} \begin{command}{\pgfrdfproperty\marg{text}} \end{command} \begin{command}{\pgfrdfrel\marg{text}} \end{command} \begin{command}{\pgfrdfresource\marg{text}} \end{command} \begin{command}{\pgfrdfrev\marg{text}} \end{command} \begin{command}{\pgfrdfsrc\marg{text}} \end{command} \begin{command}{\pgfrdftypeof\marg{text}} \end{command} \begin{command}{\pgfrdfvocab\marg{text}} \end{command} \subsection{Error Messages and Warnings} Sometimes, a command inside \pgfname\ may fail. In this case, two commands are useful to communicate with the author: \begin{command}{\pgferror\marg{message}} Stops the processing of the current document and prints out the \meta{message}. In \LaTeX, this will be done using |\PackageError|, otherwise |\errmessage| is used directly. \end{command} \begin{command}{\pgfwarning\marg{message}} Prints the \meta{message} on the output, but does not interrupt the processing. In \LaTeX, this will be done using |\PackageWarning|, otherwise a write to stream $17$ is used. \end{command}