Packages in The Graphics' Bundle: D. P. Carlisle The L TEX3 Project 2005/11/14
Packages in The Graphics' Bundle: D. P. Carlisle The L TEX3 Project 2005/11/14
Packages in The Graphics' Bundle: D. P. Carlisle The L TEX3 Project 2005/11/14
D. P. Carlisle
A The L TEX3 Project
2005/11/14
Contents
1 Introduction 2 Driver support 3 Colour 3.1 Package Options . 3.2 Dening Colours . 3.3 Using Colours . . . 3.4 Named Colours . . 3.5 Page Colour . . . . 3.6 Box Backgrounds . 3.7 Possible Problems 4 The 4.1 4.2 4.3 4.4 4.5 4.6 4.7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 2 3 4 4 5 6 6 6 7 7 7 8 9 9 13 15 15 16 16 16 16 17
Graphics packages Package Options . . . . . . . . . . . . . . . Rotation . . . . . . . . . . . . . . . . . . . . Scaling . . . . . . . . . . . . . . . . . . . . . Including Graphics Files . . . . . . . . . . . Other commands in the graphics package . . Global setting of keys . . . . . . . . . . . . Compatibility between graphics and graphicx packages . . . . . . . . . . . . . . . . . . . . . . . . in . . . . . . . .
Introduction
This document serves as a user-manual for the packages color, graphics, and graphicx. Further documentation may be obtained by processing the source (dtx) les of the individual packages.
Driver support
All these packages rely on features that are not in TEX itself. These features must be supplied by the driver used to print the dvi le. Unfortunately not all drivers support the same features, and even the internal method of accessing these extensions varies between drivers. Consequently all these packages take options such as dvips to specify which driver is being used. You should to set up a site default for these options, for the driver that you normally use. Suppose that you wish for the color package to always default to use specials for the PostScript driver, dvipsone. In that case create a le color.cfg containing the line: \ExecuteOptions{dvipsone} Normally you will want an identical le graphics.cfg to set a similar default for the graphics packages. The following driver options are declared in the packages. dvips, xdvi, dvipdf, dvipdfm, dvipdfmx, pdftex, dvipsone, dviwindo, emtex, dviwin, pctexps, pctexwin, pctexhp, pctex32, truetex, tcidvi, vtex, oztex, textures, xetex
A Note that the L TEX Team does not maintain these drivers; we merely provide a way for a particular driver to work with the graphics packages.
If you use a driver that is not in the list above you may add an option for that driver by putting the appropriate \DeclareOption line into graphics.cfg and color.cfg, before making it the default option with \ExecuteOptions, as described above. For example to add the option dvi2ps for the original Unix dvi to ps driver, and to make that the default, you just need conguration les looking like:
\DeclareOption{dvi2ps}{\def\Gin@driver{dvi2ps.def}} \ExecuteOptions{dvi2ps}
There is a suitable dvi2ps.def le in the standard distribution. It is not enabled by default as it is not well tested as the driver is no longer available to me. The following driver les are similarly distributed but not enabled by default. 2
dvi2ps, dvialw, dvilaser, dvitops, psprint, pubps, ln Most of these driver les are generated from the source le drivers.dtx. That le has the sources for other versions (for example older versions of dvips and textures) which are not generated by default. Dierent TEX systems support dierent drivers and the drivers are usually maintained by the developers of the TEX variants or post-processors. Hence they are always linked to some program and since the TEX distributors decide which programs they support, it is up to them to make sure the necessary drivers are included with their distribution. The graphics bundle contains the installation le graphics-drivers.ins which can be used to extract drivers from drivers.dtx but we cannot guarantee that these are up to date. Not all of the aforementioned drivers are available in drivers.dtx (some like pdftex and dvipdfm can be found on CTAN). If you use a driver that is not covered by any of these possibilities, you may try to write a .def le by analogy with one of the existing ones, and then specify a suitable option in graphics.cfg and color.cfg, as for the above example of dvi2ps.
Colour
The colour support is built around the idea of a system of Colour Models. The Colour models supported by a driver vary, but typically include rgb Red Green Blue: A comma separated list of three numbers between 0 and 1, giving the components of the colour. cmyk Cyan Magenta Yellow [K]Black: A comma separated list of four numbers between 0 and 1, giving the components of the colour according to the additive model used in most printers. gray Grey scale: a single number between 0 and 1. named Colours accessed by name, e.g. JungleGreen. Not all drivers support this model. The names must either be known to the driver or added using commands described in color.dtx. Some drivers support an extended form of the named model in which an intensity of the colour may also be specied, so JungleGreen, 0.5 would denote that colour at half strength. Note that the named model is really just given as an example of a colour model that takes names rather than a numeric specication. Other options may be provided locally that provide dierent colour models, eg pantone (An industry standard set of colours), x11 (Colour names from the X Window System), etc. The standard distribution does not currently have such models, but the 3
named model could be used as an example of how to dene a new colour model. The names used in the named model are those suggested by Jim Hafner in his colordvi and foiltex packages, and implemented originally in the color.pro header le for the dvips driver.
3.1
Package Options
Most of the options to the color package just specify a driver, e.g., dvips, as discussed in section 2. One special option for the color package that is of interest is monochrome. If this option is selected the colour commands are all disabled so that they do not generate errors, but do not generate colour either. This is useful if previewing with a previewer that can not produce colour. Three other package options control the use of the named model. The dvips driver (by default) pre-denes 68 colour names. The dvips option normally makes these names available in the named colour model. If you do not want these names to be declared in this model (Saving TEX some memory) you may give the nodvipsnames option. Conversely, if you are using another driver, you may wish to add these names to the named model for that driver (especially if you are processing a document originally produced on dvips). In this case you could use the dvipsnames option. Lastly the usenames option makes all names in the named model directly available, as described below.
3.2
Dening Colours
The colours black, white, red, green, blue, cyan, magenta, yellow should be predened, but should you wish to mix your own colours use the \definecolor command.
\definecolor{ name }{ model }{ colour specication }
This denes name as a colour which can be used in later colour commands. For example
\definecolor{light-blue}{rgb}{0.8,0.85,1} \definecolor{mygrey}{gray}{0.75}
Now light-blue and mygrey may be used in addition to the predened colours above.
3.3
3.3.1
Using Colours
Using predened colours
The syntax for colour changes is designed to mimic font changes. The basic syntax is:
\color{ name }
This is a declaration, like \bfseries It changes the current colour to name until the end of the current group or environment. An alternative command syntax is to use a command form that takes the text to be coloured as an argument. This is similar to the font commands such as \textbf:
\textcolor{ name }{ text }
So the above is essentially equivalent to {\color{ name }text }. 3.3.2 Using colour specications directly
Normally one would predeclare all the colours used in a package, or in the document preamble, but sometimes it is convenient to directly use a colour without naming it rst. To achieve this \color (and all the other colour commands) take an optional argument specifying the model. If this is used then the mandatory argument takes a colour specication instead of a name . For example: \color[rgb]{1,0.2,0.3} would directly select that colour. This is particularly useful for accessing the named model: \color[named]{BrickRed} selects the dvips colour BrickRed. Rather than repeatedly use [named] you may use \definecolor to provide convenient aliases: \definecolor{myred}{named}{WildStrawberry} . . . \color{myred} . . . Alternatively if you are happy to use the existing names from the named model, you may use the usenames package option, which eectively calls \definecolor on every colour in the named model, thus allowing \color{WildStrawberry} in addition to \color[named]{WildStrawbery}.
3.4
Named Colours
Using the named colour model has certain advantages over using other colour models. Firstly as the dvi le contains a request for a colour by name, the actual mix of primary colours used to obtain the requested colour can be tuned to the characteristics of a particular printer. In the dvips driver the meanings of the colour names are dened in the header le color.pro. Users are encouraged to produce dierent versions of this le for any printers they use. By this means the same dvi le should produce colours of similar appearance when printed on printers with dierent colour characteristics. Secondly, apart from the so called process colours that are produced by mixing primary colours during the print process, one may want to use spot or custom colours. Here a particular colour name does not refer to a mix of primaries, but to a particular ink. The parts of the document using this colour will be printed separately using this named ink colour.
3.5
Page Colour
The background colour of the whole page can be set using \pagecolor. This takes the same argument forms as \color but sets the background colour for the current and all subsequent pages. It is a global declaration, so you need to use \pagecolor{white} to get back to normal.
3.6
Box Backgrounds
Two commands similar to \fbox produce boxes with the backgrounds shaded an appropriate colour.
\colorbox{ name }{ text } \colorbox[ model ]{ specication }{ text } \fcolorbox{ name1 }{ name2 }{ text } \fcolorbox[ model ]{ specication1 }{ specication2 }{ text }
The former produces a box coloured with name like this . The latter is similar but puts a frame of colour name1 around the box coloured name2. These commands use the \fbox parameters \fboxrule and \fboxsep to determine the thickness of the rule, and the size of the shaded area.
3.7
Possible Problems
TEX was not designed with colour in mind, and producing colours requires a lot of help from the driver program. Thus, depending on the driver, some or all features of the color package may not be available. Some drivers do not maintain a special colour stack. These drivers are likely to get confused if you nest colour changes, or use colours in oating environments. Some drivers do not maintain colours over a page break, so that if the page breaks in the middle of a coloured paragraph, the last part of the text will incorrectly be printed in black. There is a dierent type of problem that will occur for all drivers. Due to certain technical diculties1 , it is possible that at points where the colour changes, the spacing is aected. For this reason the monochrome option does not completely disable the colour commands, it redenes them to write to the log le. This will have the same eects on spacing, so you can produce monochrome drafts of your document, at least knowing that the nal spacing is being shown.
There are two graphics packages: graphics The standard graphics package. graphicx The extended or enhanced graphics package. The two dier only in the format of optional arguments for the commands dened. The command names, and the mandatory arguments are the same for the two packages.
4.1
Package Options
As discussed in section 2, the graphics packages share the same driver options as the color package. As for colour you should set up a site-default in a le, graphics.cfg, containing the line (for dvips): \ExecuteOptions{dvips} The graphics packages have some other options for controlling how many of the features to enable:
1 At least two causes: 1) The presence of a \special whatsit prevents \addvspace seeing space on the current vertical list, so causing it to incorrectly add extra vertical space. 2) A whatsit as the rst item in a \vtop moves the reference point of the box.
draft suppress all the special features. In particular graphics les are not included (but they are still read for size info) just the lename is printed in a box of the correct size. nal The opposite of draft. Useful to over-ride a global draft option specied in the \documentclass command. hiderotate Do not show rotated text (presumably because the previewer can not rotate). hidescale Do not show scaled text (presumably because the previewer can not scale). hiresbb Look for size specications in %%HiResBoundingBox lines rather than standard %%BoundingBox lines. demo Instead of inserting an image le \includegraphics draws a 150 pt by 100 pt rectangle unless other dimensions are specied manually.
New feature 1996/10/29 New feature 2006/02/20
4.2
Rotation
graphics: \rotatebox{ angle }{ text } graphicx: \rotatebox[ key val list ]{ angle }{ text }
This puts text in a box, like \mbox, but rotates the box through angle degrees, his like t . The standard version always rotates around the reference point of the box, but the keyval version takes the following keys:
origin= label x= dimen y= dimen units= number
So you may specify both x and y, which give the coordinate of the centre of rotation relative to the reference point of the box, eg [x=2mm, y=5mm]. Alternatively, for the most common points, one may use origin with a label containing one or two of the following: lrctbB (B denotes the baseline, as for PSTricks). . . . to the eects For example, compare a default rotation of 180 . . . gained by using the origin key: [origin = c] rotates about the centre of the box,. . . ... [origin = tr] rotates about the top right hand corner. . . The units key allows a change from the default units of degrees anti-clockwise. Give the number of units in one full anti-clockwise rotation. For example: [units = -360] species degrees clockwise. [units= 6.283185] species radians. 8 Like This Like This Like This ...
4.3
4.3.1
Scaling
Scaling by scale factor
Again this is basically like \mbox but scales the text. If v-scale is not specied it defaults to h-scale. If it is specied the text is distorted as the horizontal and vertical stretches are dierent, Like This.
\reflectbox{ text }
Scale text so that the width is h-length. If ! is used as either length argument, the other argument is used to determine a scale factor that is used in both directions. Normally v-length refers to the height of the box, but in the star A form, it refers to the height + depth. As normal for L TEX 2 box length arguments, \height, \width, \totalheight, \depth may be used to refer to the original size of the box. \resizebox{1in}{\height}{Some text}: Some text \resizebox{1in}{!}{Some text}:
Some text
4.4
The functions for graphics inclusion try to give the same user syntax for including any kind of graphics le that can be understood by the driver. This relies on the le having an extension that identies the le type. The driver options will dene a collection of le extensions that the driver can handle, although this list may be extended using the declarations described below. If the les extension is unknown to the driver, the system may try a default le type. The PostScript driver les set this default to be eps (PostScript), but this behaviour may be customised if other defaults are required.
graphics: \includegraphics*[ llx,lly ][ urx,ury ]{ le } graphicx: \includegraphics*[ key val list ]{ le }
If * is present, then the graphic is clipped to the size specied. If * is omitted, then any part of the graphic that is outside the specied bounding box will over-print the surrounding text. If the optional arguments are omitted, then the size of the graphic will be determined by reading an external le as described below. graphics version If [ urx,ury ] is present, then it should specify the coordinates of the top right corner of the image, as a pair of TEX dimensions. If the units are omitted they default to bp. So [1in,1in] and [72,72] are equivalent. If only one optional argument appears, the lower left corner of the image is assumed to be at [0,0]. Otherwise [ llx,lly ] may be used to specify the coordinates of this point. graphicx version Here the star form is just for compatibility with the standard version. It just adds clip to the list of keys specied. (Also, for increased compatibility, if two optional arguments are used, the standard version of \includegraphics is always used, even if the graphicx package is loaded.) The allowed keys are listed below. bb The argument should be four dimensions, separated by spaces. These denote the Bounding Box of the printed region within the le. bbllx,bblly,bburx,bbury Set the bounding box. Mainly for compatibility with older packages. Specifying bbllx=a,bblly=b,bburx=c,bbury=d is equivalent to specifying bb = a b c d. natwidth,natheight Again an alternative to bb. natheight=h,natwidth=w is equivalent to bb = 0 0 h w. hiresbb Boolean valued key. If set to true (just specifying hiresbb is equivalent to hiresbb=true) then TEX will look for %%HiResBoundingBox lines rather than %%BoundingBox. It may be set to false to overrule a default setting of true set by the hiresbb package option. viewport The viewport key takes four arguments, just like bb. However in this case the values are taken relative to the origin specied by the bounding box in the le. So to view the 1in square in the bottom left hand corner of the area specied by the bounding box, use the argument viewport=0 0 72 72. trim Similar to viewport, but here the four lengths specify the amount to remove or add to each side. trim= 1 2 3 4 crops the picture by 1bp at the left, 2bp at the bottom, 3bp on the right and 4bp at the top. angle Rotation angle.
New feature 1996/10/29
10
origin Origin for rotation. See the documentation of \rotatebox. width Required width. The graphic is scaled to this width. height Required height. The graphic is scaled to this height. totalheight Specify the total height (height + depth) of the gure. This will dier from the height if rotation has occurred. In particular if the gure has been rotated by 90 then it will have zero height but large depth. keepaspectratio Boolean valued key like clip. If set to true then specifying both width and height (or totalheight) does not distort the gure but scales such that neither of the specied dimensions is exceeded. scale Scale factor. clip Either true or false (or no value, which is equivalent to true). Clip the graphic to the bounding box. draft a boolean valued key, like clip. Locally switches to draft mode. type Specify the graphics type. ext Specify the le extension. This should only be used in conjunction with type. read Specify the le extension of the read le. This should only be used in conjunction with type. command Specify any command to be applied to the le. This should only be used in conjunction with type. For the keys specifying the original size (i.e,, the bounding box, trim and viewport keys) the units can be omitted, in which case bp (i.e., PostScript points) are assumed. The rst seven keys specify the original size of the image. This size needs to be specied in the case that the le can not be read by TEX, or it contains an incorrect size BoundingBox specication. bbllx. . . \bbury are mainly for compatibility for older packages. bbllx=a, bblly=b, bburx=c, bbury=d is equivalent to bb = a b c d. natheight and natwidth are just shorthands for setting the lower left coordinate to 0 0 and the upper right coordinate to the specied width and height. The next few keys specify any scaling or rotation to be applied to the image. To get these eects using the standard package, the \includegraphics call must be placed inside the argument of a \rotatebox or \scalebox command.
11
The keys are read left-to-right, so [angle=90, height=1in] means rotate by 90 degrees, and then scale to a height of 1in. [height=1in, angle=90] would result in a nal width of 1in. If the calc package is also loaded the lengths may use calc syntax, for instance to specify a width of 2 cm less than the text width: [width=\textwidth-2cm]. TEX leaves the space specied either in the le, or in the optional arguments. If any part of the image is actually outside this area, it will by default overprint the surrounding text. If the star form is used, or clip specied, any part of the image outside this area will not be printed. The last four keys suppress the parsing of the lename. If they are used, the main le argument should not have the le extension. They correspond to the arguments of \DeclareGraphicsRule described below. To see the eect that the various options have consider the le a.ps. This le contains the bounding box specication
%%BoundingBox:100 100 172 172
That is, the printed region consists of a one-inch square, 100 pt in from the bottom and left hand edges of the paper. In all the following examples the input will be of the form
left---\fbox{\includegraphics{a}}---right
left
A
A
right
left
right
left
right 12
left
graphics: \scalebox{0.5}{\includegraphics{a}} and draft option. graphicx: \includegraphics[scale=.5, draft]{a} a.ps left right
right
4.5
\graphicspath{ dir-list }
This optional declaration may be used to specify a list of directories in which to A search for graphics les. The format is the same as for the L TEX 2 primitive \input@path. A list of directories, each in a {} group (even if there is only one in the list). For example: \graphicspath{{eps/}{tiff/}} would cause the system to look in the subdirectories eps and tiff of the current directory. This is unix syntax, on a Mac it would be: \graphicspath{{:eps:}{:tiff:}} Note the diering conventions, an initial : is needed on Macintosh systems to denote the current folder, whereas on unix an initial / would denote the top level root directory. The default setting of this path is \input@path that is: graphics les will be found wherever TEX les are found.
\DeclareGraphicsExtensions{ ext-list }
This species the behaviour of the system when no le extension is specied in the argument to \includegraphics. { ext-list } should be a comma separated list of le extensions. (White space is ignored between the entries.) A le name is produced by appending one extension from the list. If a le is found, the system acts as if that extension had been specied. If not, the next extension in ext-list is tried. Note that if the extension is not specied in the \includegraphics comA mand, the graphics le must exist at the time L TEX is run, as the existence of the le is used to determine which extension from the list to choose. However if a le extension is specied, e.g. \includegraphics{a.ps} instead of A \includegraphics{a}, then the graphics le need not exist at the time L TEX 13
is used. (In particular it may be created on the y by the command specied A in the \DeclareGraphicsRule command described below.) L TEX does however need to be able to determine the size of the image so this size must be specied A in arguments, or the read le must exist at the time L TEX is used.
\DeclareGraphicsRule{ ext }{ type }{ read-le }{ command }
Any number of these declarations can be made. They determine how the system behaves when a le with extension ext is specied. (The extension may be specied explicitly or, if the argument to \includegraphics does not have an extension, it may be a default extension from the ext-list specied with \DeclareGraphicsExtensions.) ext the le extension for which this rule applies. As a special case, ext may be given as * to denote the default behaviour for all undeclared extensions (see the example below). type is the type of le involved. All les of the same type will be input with the same internal command (which must be dened in a driver le). For example les with extensions ps, eps, ps.gz may all be classed as type eps. read-le determines the extension of the le that should be read to determine size information. It may be the same as ext but it may be dierent, for example .ps.gz les are not readable easily by TEX, so you may want to put the bounding box information in a separate le with extension .ps.bb. If read-le is empty, {}, then the system will not try to locate an external le for size info, and the size must be specied in the arguments of \includegraphics. If the driver le species a procedure for reading size les for type, that will be used, otherwise the procedure for reading eps les will be used. Thus the size of bitmap les may be specied in a le with a PostScript style %%BoundingBox line, if no other specic format is available. As a special case * may be used to denote the same extension as the graphic le. This is mainly of use in conjunction with using * as the extension, as in that case the particular graphic extension is not known. For example
\DeclareGraphicsRule{*}{eps}{*}{}
This would declare a default rule, such that all unknown extensions would be treated as EPS les, and the graphic le would be read for a BoundingBox comment. command is usually empty, but if non empty it is used in place of the lename in the \special. Within this argument, #1 may be used to denote the lename. Thus using the dvips driver, one may use \DeclareGraphicsRule{.ps.gz}{eps}{.ps.bb}{zcat #1} the nal argument causes dvips to use the zcat command to unzip the le before inserting it into the PostScript output. 14
A Note that L TEX will nd the graphics le by searching along TEXINPUTS (and possibly other places, as specied with \graphicspath) however it may be that the command you specify in this argument can not nd such les unless they are in the current directory. On some systems it may be possible to modify A the command so that it will nd any les that L TEX can nd. For example on newer web2c TEX releases on unix, one may modify the above command so that the last argument is: {zcat kpsewhich -n latex tex #1} which incantation causes the kpsewhich program to nd the le, by searching A along L TEXs path, and then pass the full path name to the zcat program so that it can uncompress the le. Any such uses are very system dependent, and would best be placed in a graphics.cfg le, thus keeping the document itself portable.
4.6
Most of the keyval keys used in the graphicx package may also be set using the command \setkeys provided by the keyval package. For instance, suppose you wanted all the les to be included in the current document to be scaled to 75% of the width of the lines of text, then one could issue the following command: \setkeys{Gin}{width=0.75\textwidth} Here Gin is the name used for the keyval keys associated with Graphics inclusion. All following \includegraphics commands (within the same group or environment) will act as if [width=0.75\textwidth] had been specied, in addition to any other key settings actually given in the optional argument. Similarly to make all \rotatebox arguments take an argument in radians, one just needs to specify: \setkeys{Grot}{units=6.28318}
4.7
For a document author, there are not really any problems of compatibility between the two packages. You just choose the interface that you personally prefer, and then use the appropriate package. For a package or class writer the situation is slightly dierent. Suppose that you are writing a letter class that needs to print a company logo as part of the letterhead. As the author of the class you may want to give the users the possibility of using either interface in their letters (should they need to include any further graphics into the letter body). In this case the class should load the graphics package (not graphicx, as this would commit any users of the class to the keyval interface). 15
The logo should be included with \includegraphics either with no optional argument (if the correct size information is in the le) or both optional arguments otherwise. Do not use the one optional argument form, as the meaning of this argument would change (and generate errors) if the user were to load graphicx as well as your class.
5
5.1
This is a small package essentially a wrapper around the graphicx package, dening a command \psfig which has the syntax \psfig{file=xxx,...} rather than \includegraphics[...]{xxx}. It also has a few more commands to make it slightly more compatible with the A old L TEX 2.09 style of the same name.
5.2
Trig
The trig package is not intended to be used directly in documents. It calculates sine, cosine and tangent trigonometric functions. These are used to calculate the space taken up by a rotated box. This package is also used by the fontinst program which converts PostScript les to a form usable by TEX.
A As well as being used as a L TEX package, the macros may be extracted with the A docstrip options plain,package. In this case the L TEX package declarations are omitted from the le, and the macros may be directly used as part of another macro le (they work with any format based on plain TEX.)
5.3
Keyval
The keyval package is intended to be used by other packages. It provides a generic way of setting keys as used by the graphicx package, and splitting up the comma separated lists of key = value pairs. Like the trig package, these macros may be extracted and used as part of another A macro le, based on plain TEX, as well as the standard use as a L TEX package. By default an undeclared key will generate an error. If however the option unknownkeysallowed is used, then unknown keys will be silently ignored (leaving a message in the log le). This option is also accepted by the graphicx package.
16
5.4
Lscape
The lscape package requires and takes the same options as the graphics package. It denes a landscape environment within which page bodies are rotated through 90 degrees. The page head and foot are not aected, they appear in the standard (portrait) position.
17