• No results found

2 User Interface

N/A
N/A
Protected

Academic year: 2022

Share "2 User Interface"

Copied!
54
0
0

Full text

(1)

The incgraph package

Manual for version 1.2.0 (2021/10/20)

Thomas F. Sturm1

https://www.ctan.org/pkg/incgraph https://github.com/T-F-S/incgraph

Abstract

incgraph provides tools for including graphics on full paper size. The graphics can be centered for a given paper format or the paper may be resized to the graphics dimensions. The main use case for the packageincgraphis to transform one or many scans or taken pictures to a PDF document. It can also be applied for full paper size LATEX created graphics. The packageincgraphprovides a tool box with basic macros and a convenience user interface which wraps the well-knownincludegraphics. Also, bookmarking is especially supported.

Contents

1 Introduction 4

1.1 Motivation . . . 4

1.2 Loading the Package . . . 4

2 User Interface 5 2.1 Inclusion Macros for External Graphics . . . 5

2.2 Inclusion Macro for Internal Graphics . . . 6

2.3 (Global) Option Setting . . . 6

3 Option Keys 7 3.1 Paper (Media) Size . . . 7

3.2 Graphics Inclusion . . . 10

3.3 Hypertargets, Labels, and Bookmarks . . . 12

3.4 Borders . . . 14

3.5 Map and Match . . . 15

3.6 Overlays . . . 16

3.7 Miscellaneous . . . 17

(2)

5.5 Map and Match Commands . . . 49 5.6 Zero Filling Commands . . . 50

References 51

Index 52

(3)
(4)

1 Introduction

1.1 Motivation

The main purpose of this package is to include one or more graphics on full paper size. This means that a graphic is either centered on a blank page presumable of the given document paper size or the page is resized to the dimensions of the graphic. For the graphics, JPG files or PDF files or other supported formats may be used by inclusion. Alternatively, the graphics (or whatever) can be produced by LATEX code. An important use case for the package incgraphis to transform one or many scans or taken pictures to a PDF document. Optionally, the included graphics can be commented with bookmarks for the resulting PDF document.

The well-known graphicxpackage [1] allows the inclusion of several types of external graphics files. The convenience user interface of incgraphdescribed in Section 2 relies on this package and adds assistance for the described purpose. Note that the package is designed for and tested with pdflatex to produce PDF directly. Also, the package is intended to harmonize with lualatex. Some features like the paper resizing may not be applicable for other work-flows.

Many of the features of the convenience user interface can be used directly with various basic macros. These are collected and described as a ’basic tool box’ in Section 5.

If this package does not aid your intended purpose, you may take a look at thepdfpagespackage [2] which also supports the insertion of external multi-page PDF documents.

1.2 Loading the Package

incgraphis loaded in the usual manner in the preamble:

\usepackage{incgraph}

The package incgraphloads the package pgfkeys[4]. If no options are given, it also loads the packages pgf,pgffor[4], the package graphicx[1], and the packagebookmark[3].

• The option nopgfprevents the loading ofpgf andpgffor.

The opposite option pgfresets to loading the packages.

• The option nographicxprevents the loading ofgraphicx.

The opposite option graphicxresets to loading the package.

• The option nobookmarkprevents the loading ofbookmark.

The opposite option bookmarkresets to loading the package.

So, the minimal package loading is done with the following:

\usepackage[nopgf,nographicx,nobookmark]{incgraph}

Note that you can always load the mentioned packages yourself. This is intended to avoid possible option clashes the easy way.

(5)

2 User Interface

2.1 Inclusion Macros for External Graphics

The macros of this section rely on the\includegraphicscommand from the packagegraphicx [1].

\incgraph[⟨options⟩][⟨graphics options⟩]{⟨file name⟩}

The picture file with the given ⟨file name⟩ is included in the center of a separate page.

Depending on the⟨options⟩, this page keeps the document size or is resized to the graphics dimensions. The applicable⟨options⟩are listed in Section3. If⟨graphics options⟩are given, these are added to the options for the underlying \includegraphics command. See the documentation ofgraphicx [1] for a list of applicable⟨graphics options⟩.

Example 1: The hand-drawn example (centered); see page 18

\incgraph[paper=current,label={exacenter},overlay page number at bottom, bookmark={The hand-drawn example (centered)}]{example.jpg}

Example 2: The hand-drawn example (resized page); see page 19

\incgraph[paper=graphics,label={exaresized},

bookmark={The hand-drawn example (resized page)}]{example.jpg}

Example 3: The hand-drawn example (rotated and oversized); see page 20

\incgraph[paper=current,label={exarotated},target=oversized, bookmark={The hand-drawn example (rotated and oversized)}]%

[angle=30,scale=3]{example.jpg}

\incmultigraph[⟨options⟩][⟨graphics options⟩]{⟨file name pattern⟩}{⟨list⟩}

All picture files matching the given ⟨file name pattern⟩ where some parts are substituted by elements of the ⟨list⟩ are included in the center of a separate page. Depending on the

⟨options⟩, the pages keep the document size or are resized to the graphics dimensions. The applicable⟨options⟩ are listed in Section3. If⟨graphics options⟩are given, these are added to the options for the underlying \includegraphics command. See the documentation of graphicx[1] for a list of applicable⟨graphics options⟩.

The ⟨list⟩ may contain any construction allowed for the\foreachstatement [4], especially a list of numbers. The elements of the list can be used inside the ⟨file name pattern⟩ with the following macros:

\n: The current element of the list (may be a number).

\ni: The position of the current element inside the list, i. e. \nicounts from 1 to the

(6)

2.2 Inclusion Macro for Internal Graphics

\begin{inctext}[⟨options⟩]

⟨environment content⟩

\end{inctext}

The environment content is included in the center of a separate page. Depending on the

⟨options⟩, this page keeps the document size or is resized to the content dimensions. The applicable⟨options⟩ are listed in Section3.

Example 5: Some text on a shrunk paper; see page 24

\begin{inctext}[paper=graphics,label={inctext1},bookmark={A huge ABC}]

\Huge ABC

\end{inctext}

Example 6: A tikzpicture as text content; see page 25

\begin{inctext}[paper=a6,landscape,label={inctext2},bookmark={Graph}, overlay page number at bottom=8mm]

\begin{tikzpicture}[zustand/.style={circle,fill=Gold,draw},scale=2]

\draw node[zustand] (s0) {$s_0$}

+(30:3cm) node[zustand] (s1) {$s_1$}

++(-30:3cm) node[zustand] (s2) {$s_2$}

+(30:3cm) node[zustand] (s3) {$s_3$};

\path[very thick,-latex]

(s0) edge node[above left] {a} (s1) edge node[below left] {b} (s2)

(s1) edge[out=-120,in=120] node[left] {b} (s2) edge node[above right] {a} (s3)

(s2) edge[out=60,in=-60] node[right] {a} (s1) edge node[below right] {b} (s3);

\end{tikzpicture}

\end{inctext}

2.3 (Global) Option Setting

\igrset{⟨options⟩}

Sets options for\incgraphP. 5,\incmultigraphP. 5, andinctextinside the current TEX group. For example, the options/igr/paperP. 7and/igr/zerofillP. 17may be defined for the whole document by this:

\igrset{paper=current,zerofill=3}

(7)

3 Option Keys

3.1 Paper (Media) Size

/igr/currentpaper (no value)

The paper size keeps unchanged at the current size except if/igr/landscape is used. The current paper size has not to be the document paper size. See page 18 for the output of Example 1 on page 5.

/igr/documentpaper (no value)

The paper size is set to the initial document paper size.

/igr/graphicspaper (no value, initially set)

The paper is resized to the dimensions of the included image. The/igr/landscapeoption is ignored for this paper. See page19 for the output of Example 2on page 5.

/igr/paper size=⟨width⟩:⟨height⟩ (no default)

The paper is resized to the given ⟨width⟩ and ⟨height⟩.

/igr/paper=⟨name⟩ (no default)

The paper size is chosen according to the given⟨name⟩. Feasible values for the⟨name⟩ are current, document, graphics,a0, a1, a2,a3,a4, a5, a6,a7, a8, a9,a10, b0,b1,b2, b3, b4, b5,b6,b7, b8,b9,b10,c0, c1, c2,c3, c4, c5,c6, c7, c8,c9, c10,d0, d1, d2,d3, d4, d5,d6,d7,executive,letter,legal,ledger.

/igr/landscape (no value)

If set the width and height of the chosen paper are switched. Note that this turns the paper by 90 degrees but the contents of the paper is not turned.

/igr/portrait (no value, initially set)

Disables the /igr/landscapemode.

/igr/a0paper (no value)

The paper size is set to 841mm×1189mm.

/igr/a1paper (no value)

The paper size is set to 594mm×841mm.

/igr/a2paper (no value)

The paper size is set to 420mm×594mm.

/igr/a3paper (no value)

The paper size is set to 297mm×420mm.

/igr/a4paper (no value)

The paper size is set to 210mm×297mm.

(8)

The paper size is set to 37mm× 52mm.

/igr/a10paper (no value)

The paper size is set to 26mm× 37mm.

/igr/b0paper (no value)

The paper size is set to 1000mm×1414mm.

/igr/b1paper (no value)

The paper size is set to 707mm×1000mm.

/igr/b2paper (no value)

The paper size is set to 500mm×707mm.

/igr/b3paper (no value)

The paper size is set to 353mm×500mm.

/igr/b4paper (no value)

The paper size is set to 250mm×353mm.

/igr/b5paper (no value)

The paper size is set to 176mm×250mm.

/igr/b6paper (no value)

The paper size is set to 125mm×176mm.

/igr/b7paper (no value)

The paper size is set to 88mm× 125mm.

/igr/b8paper (no value)

The paper size is set to 62mm× 88mm.

/igr/b9paper (no value)

The paper size is set to 44mm× 62mm.

/igr/b10paper (no value)

The paper size is set to 31mm× 44mm.

/igr/c0paper (no value)

The paper size is set to 917mm×1297mm.

/igr/c1paper (no value)

The paper size is set to 648mm×917mm.

/igr/c2paper (no value)

The paper size is set to 648mm×917mm.

/igr/c3paper (no value)

The paper size is set to 324mm×458mm.

/igr/c4paper (no value)

The paper size is set to 229mm×324mm.

(9)

/igr/c8paper (no value) The paper size is set to 57mm× 81mm.

/igr/c9paper (no value)

The paper size is set to 40mm× 57mm.

/igr/c10paper (no value)

The paper size is set to 28mm× 40mm.

/igr/d0paper (no value)

The paper size is set to 771mm×1091mm.

/igr/d1paper (no value)

The paper size is set to 545mm×771mm.

/igr/d2paper (no value)

The paper size is set to 385mm×545mm.

/igr/d3paper (no value)

The paper size is set to 272mm×385mm.

/igr/d4paper (no value)

The paper size is set to 192mm×272mm.

/igr/d5paper (no value)

The paper size is set to 136mm×192mm.

/igr/d6paper (no value)

The paper size is set to 96mm× 136mm.

/igr/d7paper (no value)

The paper size is set to 68mm× 96mm.

/igr/executivepaper (no value)

The paper size is set to 7.25in×10.5in.

/igr/letterpaper (no value)

The paper size is set to 8.5in×11in.

/igr/legalpaper (no value)

The paper size is set to 8.5in×14in.

/igr/ledgerpaper (no value)

The paper size is set to 17in× 11in.

/igr/center (no value, deprecated)

An alias for/igr/currentpaperP. 7.

(10)

3.2 Graphics Inclusion

/igr/options={⟨graphics options⟩} (no default, initially empty) The⟨graphics options⟩are applied to the underlying\includegraphicscommand. See the documentation ofgraphicx [1] for a list of applicable⟨graphics options⟩.

Example 7: A resized image; see page 26

\igrset{options={width=10cm,height=10cm}, paper=graphics, overlay page number at top=5mm

}

\incgraph[bookmark={A resized image}, label={exagraphresize}]%

{exaimage-0037.png}

/igr/options add={⟨graphics options⟩} (no default, initially empty) The ⟨graphics options⟩ are added to the current list of options for the underlying

\includegraphics command.

/igr/include command=⟨macro⟩ (default and initially \includegraphics) Replaces the internally used \includegraphics command by the given ⟨macro⟩. Note that⟨macro⟩ has to have the same signature as\includegraphics, i. e. it has to take two arguments where the first argument is optional.

/igr/existence check=⟨macro⟩ (no default)

Replaces the internally used \IfFileExists(in truth \file_if_exist:nTF) command by the given ⟨macro⟩. Note that ⟨macro⟩ has to have the same signature as\IfFileExists, i. e. it has to take three arguments.

N2021-10-16 /igr/no existence check (no value)

/igr/fail on not found (no value)

Omits any existence checks by the package, i.e. the underlying\includegraphicsis called directly any may stop the compilation with an error if the included file does not exist.

Both options are equal, but the newer/igr/no existence checkis considered to be more comprehensible.

/igr/ignore on not found (no value, initially set)

Not existing included files are ignored without warning. This is the default setting and is intended to be used with fragmentary file lists.

(11)

N2021-10-16 /igr/ignore on not found with extensions={⟨extension list⟩} (initially unset)

N2021-10-16 /igr/ignore on not found with extensions*={⟨extension list⟩} (initially unset) Tests, if the included file with an addedextension exists and performs the inclusion on ex- istence. Otherwise, included files are ignored without warning. Testedextensions are taken from the optional comma separated⟨extension list⟩or (exclusively) from the configured list from /igr/extensionsand friends (only, if ⟨extension list⟩ is not given).

/igr/ignore on not found with extensions* also tests, if the included file without addedextension exists and takes it on existence.

Note that if a file is included with a given extension, this extension is not replaced by the listed extension, but prolonged with it.

These options are intended for mixed file lists, e.g. .jpg and .png, or unkown type file lists. Note that if you know the (singular) extension of your files, you are encouraged to use/igr/ignore on not foundP. 10 instead for performance reasons.

\incmultigraph[ignore on not found with extensions={.jpg,.png}]{myfile\n}{1,...,100}

% includes e.g. `myfile1.jpg`, `myfile2.png`, `myfile42.jpg`, ...

\incmultigraph[ignore on not found with extensions={.jpg,.png}]{myfile\n.xy}{1,...,100}

% includes e.g. `myfile1.xy.jpg`, `myfile2.xy.png`, `myfile42.xy.jpg`, ...

\incgraph[ignore on not found with extensions={.jpg,.png}]{myfile}

% tests `myfile.jpg` and `myfile.png` for existence (and inclusion)

\incgraph[ignore on not found with extensions*={.jpg,.png}]{myfile}

% tests `myfile`, `myfile.jpg`, and `myfile.png` for existence (and inclusion)

\incmultigraph[ignore on not found with extensions]{myfile\n}{1,...,100}

% includes files with extensions given by /igr/extensions

N2021-10-16 /igr/extensions={⟨extension list⟩} (initially .jpg,.png)

Specifies a comma separated⟨extension list⟩ to be used in combination with /igr/ignore on not found with extensions.

N2021-10-16 /igr/extensions add={⟨extension list⟩} (initially unset)

Adds a comma separated⟨extension list⟩to an already defined list from/igr/extensions.

N2021-10-16 /igr/extensions from graphics (initially unset)

Takes the list of extensions from\DeclareGraphicsExtensionsof thegraphics[1] package as setup for/igr/extensions. While this looks like the most comfortable options, this can significantely increase compilation time when used for fragmentary file lists, because every non-existing file from the file list will induce a lot of existence checks. Also note that this options uses internals fromgraphicsand is not guaranteed to work with future versions of graphics.

(12)

3.3 Hypertargets, Labels, and Bookmarks

/igr/hyper (no value, initially set)

An automated hyper target is set to the current image. The hyper target is placed at the top left corner of the page. It is used internally, when a bookmark is added.

/igr/no hyper (no value)

No automated hyper target is set to the current image. Use this option, if the package bookmarkis not included.

/igr/target=⟨anchor⟩ (no default)

The next hypertarget destination value is set to⟨anchor⟩instead of an automatically created value. This may be used for hyperlinks.

\hyperlink{oversized}{This is linked to the oversized example (click me)}.

The target value '|oversized|' was defined in Example~\ref{exarotated.listing}, see page~\pageref{exarotated.listing}.

This is linked to the oversized example (click me). The target value ’oversized’ was defined in Example3, see page5.

(13)

/igr/label=⟨text⟩ (no default, initially empty) Adds a LATEX label to the included image.

/igr/bookmark=⟨text⟩ (no default, initially empty)

Adds a PDF bookmark with the given ⟨text⟩ to the current image.

/igr/bookmark options={⟨bookmark options⟩} (no default, initially empty) Sets the options for a bookmark. See the documentation of bookmark [3] for a list of applicable⟨bookmark options⟩.

Example 8: Bookmark options; see page 27

% not every PDF reader will show the effect!

\igrset{bookmark options={bold,color={red}},currentpaper}

\incgraph[bookmark={This ugly image again!},label={exabookmark}]%

{example.jpg}

/igr/bookmark heading=⟨text⟩ (no default, initially empty) For\incmultigraphP. 5, an additional bookmark with the given⟨text⟩is set as a heading before the images are included.

Example 9: A series of pictures; see from page 28

\incmultigraph[zerofill=4,currentpaper, bookmark heading={A series of pictures}, bookmark heading options={level=subsection},

bookmark={\nt},bookmark options={level=subsubsection}, overlay page number at bottom,

label={exaheading.\n}]{exaimage-\nn.png}{1,...,150}

/igr/bookmark heading options={⟨bookmark options⟩} (no default, initially empty) Sets the options for a/igr/bookmark heading. See the documentation ofbookmark[3] for a list of applicable ⟨bookmark options⟩.

(14)

3.4 Borders

The following settings enlarge or shrink the picture box, if /igr/graphicspaperP. 7 is used.

For other paper settings, the result will be just a certain shift of the picture box since the enlarged box will be centered on the paper.

N2015-03-12 /igr/left border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the left hand side.

N2015-03-12 /igr/bottom border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the bottom.

N2015-03-12 /igr/right border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the right hand side.

N2015-03-12 /igr/top border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the top.

N2015-03-12 /igr/horizontal border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the left hand side and the right hand side.

N2015-03-12 /igr/vertical border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at the top and bottom.

N2015-03-12 /igr/border=⟨length⟩ (no default, initially0pt)

Adds a space of ⟨length⟩ at all four sides.

(15)

3.5 Map and Match

/igr/set matches={⟨list⟩} (no default, initially empty) The⟨list⟩ is a comma separated list of⟨key⟩=⟨value⟩ pairs. For every pair, the given⟨key⟩

is mapped to the given ⟨value⟩. Later, this ⟨value⟩ can be retrieved by /igr/if match code,/igr/if match set, and /igr/if match set bookmark.

\igrset{set matches={

foo = bar,

1 = A very red image,

37 = A not so centered number, 123 = A greenish example}}

/igr/if match code={⟨key⟩}{⟨then⟩}{⟨else⟩} (no default) If the ⟨key⟩ was defined by /igr/set matches, \igrsetmatchvalueP. 49, or

\igrsetmatchesP. 49, the corresponding value is put in the macro \igrmatchvalue and the⟨then⟩ code is executed. If the⟨key⟩ is unknown, the⟨else⟩code is executed.

/igr/if match set={⟨key⟩}{⟨then⟩}{⟨else⟩} (no default) If the ⟨key⟩ was defined by /igr/set matches, \igrsetmatchvalueP. 49, or

\igrsetmatchesP. 49, the corresponding value is put in the macro \igrmatchvalue and \igrset{⟨then⟩}is executed. If the⟨key⟩ is unknown,\igrset{⟨else⟩}is executed.

/igr/if match set bookmark={⟨key⟩}{⟨then⟩}{⟨else⟩} (no default) If the ⟨key⟩ was defined by /igr/set matches, \igrsetmatchvalueP. 49, or

\igrsetmatchesP. 49, the corresponding value is put in the macro \igrmatchvalue and the current PDF bookmark is set to⟨then⟩. If the ⟨key⟩ is unknown, the current PDF bookmark is set to⟨else⟩.

Example 10: Map and match example; see from page 31

\incmultigraph[zerofill=4,paper=graphics, bookmark heading={Map and match example}, bookmark heading options={level=subsection}, bookmark options={level=subsubsection},

if match set bookmark={\n}{\igrmatchvalue\ (\n)}{\nt}, overlay page number at bottom,

label={examatch.\n}]{exaimage-\nn.png}{1,...,150}

/igr/disable match (no value, initially set)

Disables the statements by /igr/if match code, /igr/if match set, and /igr/if match set bookmark.

(16)

3.6 Overlays

/igr/overlay={⟨tikz code⟩} (no default, initially unset) Introduces arbitrary ⟨tikz code⟩ to be drawn over the included image. Note that the TikZ package [4] has to be loaded separately. To support positioning inside the picture, two tikz nodes named box and page are defined. box takes the dimensions of the included image and page takes the dimensions of the image or of the page depending on the usage of /igr/paperP. 7.

Example 11: Overlay; see page 34

\igrset{bookmark options={level=subsection}, paper=current}

\incgraph[bookmark={Picture with overlay},label={overlay}, overlay={

\node[draw=red,line width=3pt,fill=red,fill opacity=0.1, minimum width=14cm,circle] (circ) at (page.center) {};

\node[fill=blue!5!white,below right,text width=4cm] (A) at ([xshift=1cm,yshift=-1cm]page.north west)

{This included image is overlayed with |tikz| code.};

\node[fill=green!10!white,above,text width=7cm] (B) at ([yshift=2cm]page.south)

{Image Name: \nt\\Page number: \thepage\\

Example~\ref{overlay.listing} on page~\pageref{overlay.listing}};

\draw[line width=2pt,->] (A)--(circ);

\draw[line width=2pt,green!50!black,dashed]

(box.south west)--(box.south east);

\draw[line width=2pt,->,green!50!black] (B)--(box.south);

}]{example.jpg}

/igr/overlay page number at=⟨position⟩ (no default, initially unset) Overlays the page number at the giventikz ⟨position⟩.

/igr/overlay page number at bottom=⟨length⟩ (default1.5cm) Overlays the page number at⟨length⟩above the bottom edge of the paper. See Example1 on page 5 and the result on page18.

/igr/overlay page number at top=⟨length⟩ (default1.5cm) Overlays the page number at ⟨length⟩ below the top edge of the paper. See Example 7 on page10 and the result on page 26.

N2021-10-11 /igr/overlay page number options={⟨tikz options⟩} (no default, initially fill opacity=0.35,draw opacity=0.5,text opacity=1,inner xsep=1em, rounded corners,fill=white,draw=black) Defines the TikZ node style for drawing the page number with one of the options above, e.g. /igr/overlay page number at

/igr/no overlay (no value, initially set)

Removes the overlay setting.

(17)

3.7 Miscellaneous

/igr/pagestyle=⟨page style⟩ (no default, initiallyempty) Sets the ⟨page style⟩ for the included graphics.

/igr/zerofill=⟨digits⟩ (no default, initially0)

For \incmultigraphP. 5, the current number element is filled up with leading zeros until the⟨digits⟩ count is reached. If⟨digits⟩ is 0 or 1, nothing is added. A⟨digits⟩ value greater than 10 is treated as 10 which is the maximum number of possible digits. The result is accessible as \nn, see \incmultigraphP. 5. Note thatzerofill should be set to 0 if the list elements in\incmultigraphP. 5 are not numbers.

(18)
(19)
(20)
(21)
(22)
(23)
(24)
(25)

s1

(26)

26

(27)
(28)
(29)
(30)
(31)
(32)
(33)
(34)

This included image is overlayed with tikz code.

(35)

4 Examples

4.1 Including some Scans to Standard Paper

In this scenario, we have some scans (or images from whatever source) which should be combined to a PDF document for our paperless office. The paper size of the PDF document is set to a standard paper (here: letter size) to allow the document to be printed.

The following Example 12 is a complete template for such a document. Here, the images example.jpg,exaimage-0001.png,exaimage-0037.png, andexaimage-0123.pngare used for the resulting document. All included images are automatically bookmarked with the page number and the file name of the source image.

Example 12: incgraph-example-a.tex

\documentclass{article}

\usepackage{incgraph}

\igrset{paper=letter, zerofill=4,

bookmark={Page \theigrpage\ (\nt)}

}

\begin{document}%

\incgraph{example.jpg}

\incmultigraph{exaimage-\nn.png}{1,...,150}

\end{document}

The compiled result of this stand-alone source code is not found in this document but as a separate file in the documentation directory of the package.

(36)

4.2 Creating a Picture Book

For this example, we assume again that a bunch of image files is to be combined to a PDF document. This time, the target document should be read or displayed mainly on computer screens and may never be printed. Therefore, the paper size is set flexible for the current image.

The following Example 13 is a complete template for such a document. All included images are resized to a common width, but this is not necessary. The resulting document is consid- ered as an e-book where the bookmarks are the most important navigation accessory. Single page inclusions with \incgraphP. 5 are bookmarked directly, but multi-page inclusions with

\incmultigraphP. 5 can be bookmarked using the map-and-match feature of the package.

The example shows a mixed usage of the macros. Note that the bookmarks of the multi- page part are matched with the numbers contained in the file names of exaimage-0001.pngto exaimage-0150.png.

Example 13: incgraph-example-b.tex

\documentclass{article}

\usepackage{incgraph,tikz}

\igrset{paper=graphics, zerofill=4,

options={width=18cm},

overlay page number at top=7mm}

\igrsetmatches{ 1 = A very red image, 123 = A greenish example }

\begin{document}

\incgraph[bookmark={Page \theigrpage: My first example}]{example.jpg}

\incmultigraph[if match set bookmark=

{\n}{Page \theigrpage: \igrmatchvalue}{Page \theigrpage}]

{exaimage-\nn.png}{1,...,150}

\end{document}

The compiled result of this stand-alone source code is not found in this document but as a separate file in the documentation directory of the package.

(37)

4.3 Reformatting from Letter to DIN A4 (and vice versa)

In this scenario, we assume to have a PDF document with the ’wrong’ paper size. Here, incgraph-example-a.pdf has the letter format, but A4 paper is needed. incgraph is used to reformat to the desired paper size. Of course, it also works the other way around.

The following Example 14 is a complete template for such a document. The document gets the desired paper size with the /igr/paperP. 7 option. Then, all four pages of the original document are imported to the new paper size. Note that the actual document content itself is not resized because letter and DIN A4 are not so very different. If needed, the content could be shrunk or enlarged easily by adding a scale option for the underlying \includegraphics macro.

Example 14: incgraph-example-c.tex

\documentclass{article}

\usepackage{incgraph}

\begin{document}%

\incmultigraph[paper=a4,

bookmark={Imported page \n\ of \nt}][page=\n]

{incgraph-example-a.pdf}{1,...,4}

\end{document}

The compiled result of this stand-alone source code is not found in this document but as a separate file in the documentation directory of the package.

(38)

4.4 Drawing on Full Paper Size

In the following examples, no external image is included to the document. Instead, the image (or whatever) is created inside the document and put on a separate page which could be resized or take the original document paper size.

In Example15, a tikzpictureis drawn. The whole picture is put inside aninctextP. 6envi- ronment which puts the drawing on a separate page which gets the dimensions of the drawing.

Example 15: Creation of a special text page (resized)

\begin{inctext}[paper=graphics, bookmark=My special text page (resized)]

\begin{tikzpicture}%

\coordinate (A) at (0,0); \coordinate (B) at (16,16);

\path[use as bounding box,top color=Goldenrod!25,bottom color=Navy!25]

(A) rectangle (B);

\coordinate (C) at ([xshift=1cm,yshift=1cm]A);

\coordinate (D) at ([xshift=-1cm,yshift=-1cm]B);

\path (C) -- coordinate (E) (D);

\draw[rounded corners=5mm,very thick,Navy] (C) rectangle (D);

\path (C) |-

node [pos=0.75,fill=white,draw=Navy,very thick,inner sep=3mm]

{My Special Page \thepage} (D);

\node[text width=10cm,align=flush center,font=\Large] at (E) { This is my special page. It takes the dimensions of the underlying

|tikzpicture| as seen in the source code of Example~\ref{fullpaperdrawing1}

on page~\pageref{fullpaperdrawing1}.};

\end{tikzpicture}

\end{inctext}

See the result on the following page.

(39)

My Special Page 39

This is my special page. It takes the

(40)

In Example16, nearly the sametikzpictureis drawn. This time, the current paper size is used which puts the drawing on a separate page but without resizing the paper. To draw seamlessly, the document paper size of 21cm to 29.7cm is used directly inside the tikzpicture.

Example 16: Creation of a special text page (fitted)

\begin{inctext}[paper=current, target=mytarget, bookmark=My special text page (fitted)]

\begin{tikzpicture}%

\coordinate (A) at (0,0); \coordinate (B) at (21,29.7);

\path[use as bounding box,top color=Goldenrod!25,bottom color=Navy!25]

(A) rectangle (B);

\coordinate (C) at ([xshift=1cm,yshift=1cm]A);

\coordinate (D) at ([xshift=-1cm,yshift=-1cm]B);

\path (C) -- coordinate (E) (D);

\draw[rounded corners=5mm,very thick,Navy] (C) rectangle (D);

\path (C) |-

node [pos=0.75,fill=white,draw=Navy,very thick,inner sep=3mm]

{My Special Page \thepage} (D);

\node[text width=10cm,align=flush center,font=\Large] at (E) {

This is my special page. It consumes the whole document paper size with an underlying |tikzpicture| as seen in the source code of

Example~\ref{fullpaperdrawing2} on page~\pageref{fullpaperdrawing2}.};

\end{tikzpicture}

\end{inctext}

See the result on the following page.

(41)

My Special Page 41

This is my special page. It consumes the whole document paper size with an underlying tikzpicture as seen in the source

code of Example 16 on page 40.

(42)

5 Basic Tool Box

In this section, some basic macros of the package are documented. It is assumed that most users will only need the macros from the user interface described in Section 2and Section 3.

5.1 Page Size Commands

The following macros are auxiliary tools which wrap corresponding length registers from pdflatexand lualatex.

N2021-10-12 \igrGetPageSize

Reads the current page dimensions and stores them into the macros \igrPageWidth and

\igrPageHeight.

N2021-10-12 \igrPageWidth

After using \igrGetPageSize, \igrPageWidth contains the current page width. This is

\pdfpagewidth for pdflatex, \pagewidth for lualatex and a choice of \pdfpagewidth or\paperwidthfor other engines.

N2021-10-12 \igrPageHeight

After using \igrGetPageSize, \igrPageHeight contains the current page height. This is

\pdfpageheightforpdflatex,\pageheightforlualatexand a choice of\pdfpageheight or\paperheight for other engines.

N2021-10-12 \igrSetPageSize{⟨width⟩}{⟨height⟩}

Sets the current page dimensions to⟨width⟩and⟨height⟩. In depends on the used engine, if a call to this command has success or not. This should work for pdflatexand lualatex.

5.2 Last Page Commands (Number of Pages)

The following macros are auxiliary tools which wrap corresponding functions from pdflatex and lualatex.

N2021-10-18 \igrGetLastPage{⟨file⟩}

Reads the last page (page count) from the given (PDF-)⟨file⟩ and stores it into the macro

\igrLastPage.

N2021-10-18 \igrLastPage

After using\igrGetLastPage,\igrLastPagecontains the last page of the currently tested file. This is \pdflastximagepages for pdflatex, \lastsavedimageresourcepages for lualatexand simply 1 for other engines.

(43)

5.3 Full Page Commands

\igrpage{⟨text⟩}

The ⟨text⟩ is put on a separate page which is resized to fit the dimensions of the ⟨text⟩.

⟨text⟩ may be single letter, an included picture, or any LATEX code. The page number is stored into\theigrpageand\igrAutoTargetholds a hyper target value for bookmarking.

The style of the separate page is set to the content of the macro \igrpagestyle which defaults to ’empty’ but can be redefined.

\igrcenter{⟨text⟩}

The⟨text⟩is put in the center of a separate page which has the current document dimensions.

⟨text⟩ may be single letter, an included picture or any LATEX code. The page number is stored into\theigrpageand\igrAutoTargetholds a hyper target value for bookmarking.

The style of the separate page is set to the content of the macro \igrpagestyle which defaults to ’empty’ but can be redefined.

\igrcenterfit{⟨width⟩}{⟨height⟩}{⟨text⟩}

The ⟨text⟩ is put in the center of a separate page which is resized to the given⟨width⟩ and

⟨height⟩. ⟨text⟩may be single letter, an included picture or any LATEX code. The page num- ber is stored into \theigrpageand \igrAutoTarget holds a hyper target value for book- marking. The style of the separate page is set to the content of the macro \igrpagestyle which defaults to ’empty’ but can be redefined.

\igrtargetset{⟨anchor⟩}

The next value for \igrAutoTarget is set to ⟨anchor⟩. This can be used for hand-made hyperlinks or bookmarks. An application for igrtargetset is found in Example 16 on page40.

(44)

5.4 Box Commands

\igrboxset{⟨text⟩}

The ⟨text⟩ is put into a TEX box named\igrbox. Additionally, some auxiliary macros are defined:

\igrAutoTarget: unique value for a hyper target.

\igrBoxWidth: width of the\igrbox.

\igrBoxHeight: total height of the\igrbox.

\igrBoxht: height of the \igrbox.

\igrBoxdp: depth of the\igrbox.

\igrboxset{This is an example}

|\igrAutoTarget| = \igrAutoTarget, |\igrBoxWidth| = \igrBoxWidth,

|\igrBoxHeight| = \igrBoxHeight,\\

|\igrBoxht| = \igrBoxht, |\igrBoxdp| = \igrBoxdp;

\igrAutoTarget= igr-31,\igrBoxWidth= 76.42221pt,\igrBoxHeight= 7.95pt,

\igrBoxht= 6.2pt,\igrBoxdp= 1.75pt;

\igrboxcenter

The current content of the \igrbox is put in the center of a separate page which has the current pdfpage dimensions.

The style of the separate page is set to the content of the macro \igrpagestyle which defaults to ’empty’ but can be redefined. Note that a \clearpage or similar has to be inserted before this command.

(45)

\igrboxtikz

The current content of the \igrbox is embedded into a \node command from the tikz package [4] which has to be loaded separately. Also, the bounding box is adjusted to the

\igrbox.

To support positioning inside the picture, twotikz nodes namedboxand pageare defined which both take the dimensions of the \igrbox.

\igrboxset{\includegraphics{example.jpg}}%

\begin{tikzpicture}%

\igrboxtikz%

\draw[blue,very thick] (0,0) rectangle (\igrBoxWidth,\igrBoxHeight);

\draw[red] (0,0) grid (\igrBoxWidth,\igrBoxHeight);

\draw[black] ([xshift=-1cm,yshift=-1cm]page.north east) circle (1cm);

\end{tikzpicture}

The boxing macros can also be used nested (see the result on the following page):

\igrpage{\igrboxset{\includegraphics{example.jpg}}%

\begin{tikzpicture}%

\igrboxtikz%

\draw[blue,very thick] (0,0) rectangle (\igrBoxWidth,\igrBoxHeight);

\draw[red] (0,0) grid (\igrBoxWidth,\igrBoxHeight);

\draw[black] ([xshift=1cm,yshift=-1cm]page.north west) circle (1cm);

\end{tikzpicture}}

(46)
(47)

\igrboxtikzpage

This is an alias for\igrboxtikzP. 45.

\igrboxtikzcenter

The current content of the \igrbox is embedded into a \node command from the tikz package [4] which has to be loaded separately. This node is placed in the center of a bounding box which takes the current page dimensions. Afterwards, \igrBoxWidth and

\igrBoxHeightare redefined to the dimensions of the total page.

To support positioning inside the picture, twotikznodes namedboxandpageare defined.

boxtakes the dimensions of the\igrboxandpagetakes the dimensions of thetikzpicture.

\igrcenter{\igrboxset{\includegraphics{example.jpg}}%

\begin{tikzpicture}%

\igrboxtikzcenter%

\draw[help lines] (0,0) grid (\igrBoxWidth,\igrBoxHeight);

\draw[dashed] (box.south west) rectangle (box.north east);

\draw[very thick,<->] (page.north west)--(box.north west);

\draw[very thick,<->] (page.north east)--(box.north east);

\draw[very thick,<->] (page.south west)--(box.south west);

\draw[very thick,<->] (page.south east)--(box.south east);

\end{tikzpicture}}

See the result on the following page.

(48)
(49)

5.5 Map and Match Commands

\igrsetmatchvalue{⟨key⟩}{⟨value⟩}

The given ⟨key⟩ is mapped to the given ⟨value⟩. Later, this ⟨value⟩ can be retrieved by

\igrifmatch.

\igrsetmatchvalue{my key A}{my value A}

\def\keytester#1{\igrifmatch{#1}{Hurray: '\igrmatchvalue'}{'#1' unknown}}

\keytester{something}\\

\keytester{my key A}

’something’ unknown Hurray: ’my value A’

\igrsetmatches{⟨list⟩}

The ⟨list⟩ is a comma separated list of ⟨key⟩=⟨value⟩ pairs. On every pair, the

\igrsetmatchvalue macro is applied.

\igrsetmatches{my key A = my value A, bar = Shakespeare}

\def\keytester#1{\igrifmatch{#1}{Hurray: '\igrmatchvalue'}{'#1' unknown}}

\keytester{something}\\

\keytester{bar}\\

\keytester{my key A}

’something’ unknown Hurray: ’Shakespeare’

Hurray: ’my value A’

\igrifmatch{⟨key⟩}{⟨then⟩}{⟨else⟩}

If a⟨key⟩was defined by\igrsetmatchvalueor\igrsetmatches, the corresponding value is put in the macro \igrmatchvalue and the ⟨then⟩ code is executed. If the ⟨key⟩ is unknown, the ⟨else⟩code is executed.

\igrsetmatches{1 = January, 2 = February, 3 = March, apr = April}

\def\monthname#1{\igrifmatch{#1}{The name of month #1\ is \igrmatchvalue.}{%

You are kidding.}}

\monthname{1} \monthname{foo} \monthname{2}\\

\monthname{3} \monthname{apr} \monthname{35}

The name of month 1 is January. The name of month foo is bar. The name of month 2 is February.

The name of month 3 is March. The name of month apr is April. You are kidding.

(50)

5.6 Zero Filling Commands

\igrmakezerofill{⟨macro⟩}{⟨digits⟩}

With this command, a new ⟨macro⟩ can be defined which takes a non negative number as parameter. This number is filled up with leading zeros until the ⟨digits⟩ count is reached.

If⟨digits⟩is 0 or 1, nothing is added. A⟨digits⟩value greater than 10 is treated as 10 which is the maximum number of possible digits.

\igrmakezerofill{\myfill}{0}

\myfill{7}, \myfill{12}, \myfill{934}, \myfill{665234}.\\

\igrmakezerofill{\myfill}{3}

\myfill{7}, \myfill{12}, \myfill{934}, \myfill{665234}.\\

\igrmakezerofill{\myfill}{5}

\myfill{7}, \myfill{12}, \myfill{934}, \myfill{665234}.\\

\igrmakezerofill{\myfill}{9}

\myfill{7}, \myfill{12}, \myfill{934}, \myfill{665234}.\\

\igrmakezerofill{\myfill}{30}

\myfill{7}, \myfill{12}, \myfill{934}, \myfill{665234}.

7, 12, 934, 665234.

007, 012, 934, 665234.

00007, 00012, 00934, 665234.

000000007, 000000012, 000000934, 000665234.

0000000007, 0000000012, 0000000934, 0000665234.

\igrmakezerofill{\threedigits}{3}

\threedigits{1}%

\foreach \n in {2,...,100} {, \threedigits{\n}}.

001, 002, 003, 004, 005, 006, 007, 008, 009, 010, 011, 012, 013, 014, 015, 016, 017, 018, 019, 020, 021, 022, 023, 024, 025, 026, 027, 028, 029, 030, 031, 032, 033, 034, 035, 036, 037, 038, 039, 040, 041, 042, 043, 044, 045, 046, 047, 048, 049, 050, 051, 052, 053, 054, 055, 056, 057, 058, 059, 060, 061, 062, 063, 064, 065, 066, 067, 068, 069, 070, 071, 072, 073, 074, 075, 076, 077, 078, 079, 080, 081, 082, 083, 084, 085, 086, 087, 088, 089, 090, 091, 092, 093, 094, 095, 096, 097, 098, 099, 100.

(51)

References

[1] D. P. Carlisle.Packages in the ‘graphics’ bundle. Mar. 5, 2021.

https://mirrors.ctan.org/macros/latex/required/graphics/grfguide.pdf.

[2] Andreas Matthias.The pdfpages Package. Mar. 6, 2021.

https://mirrors.ctan.org/macros/latex/contrib/pdfpages/pdfpages.pdf.

[3] Heiko Oberdiek.The bookmark Package. Nov. 6, 2020.

https://mirrors.ctan.org/macros/latex/contrib/bookmark/bookmark.pdf.

[4] Till Tantau. The TikZ and PGF Packages. Manual for version 3.1.9a. May 15, 2021.

https://mirrors.ctan.org/graphics/pgf/base/doc/pgfmanual.pdf.

(52)

Index

a0paperkey,7 a10paperkey,8 a1paperkey,7 a2paperkey,7 a3paperkey,7 a4paperkey,7 a5paperkey,7 a6paperkey,7 a7paperkey,7 a8paperkey,7 a9paperkey,7

b0paperkey,8 b10paperkey,8 b1paperkey,8 b2paperkey,8 b3paperkey,8 b4paperkey,8 b5paperkey,8 b6paperkey,8 b7paperkey,8 b8paperkey,8 b9paperkey,8 bookmarkkey,13

bookmark headingkey,13

bookmark heading options key,13 bookmark optionskey,13

borderkey,14

bottom borderkey,14

c0paperkey,8 c10paperkey,9 c1paperkey,8 c2paperkey,8 c3paperkey,8 c4paperkey,8 c5paperkey,8 c6paperkey,8 c7paperkey,8 c8paperkey,9 c9paperkey,9 centerkey,9 currentpaperkey,7

d0paperkey,9 d1paperkey,9 d2paperkey,9 d3paperkey,9

executivepaperkey,9 existence checkkey,10 extensions key,11 extensions addkey,11

extensions from graphicskey,11 fail on not foundkey,10

graphicspaperkey,7

horizontal borderkey,14 hyperkey,12

if match codekey,15 if match setkey,15

if match set bookmarkkey,15 ignore on not foundkey,10

ignore on not found with extensionskey, 11

ignore on not found with extensions* key, 11

\igrAutoTarget,43,44

\igrbox,44

\igrboxcenter,44

\igrBoxdp,44

\igrBoxHeight,44

\igrBoxht,44

\igrboxset,44

\igrboxtikz, 45

\igrboxtikzcenter, 47

\igrboxtikzpage,47

\igrBoxWidth,44

\igrcenter,43

\igrcenterfit,43

\igrGetLastPage,42

\igrGetPageSize,42

\igrifmatch, 49

\igrLastPage,42

\igrmakezerofill,50

\igrmatchvalue,49

\igrpage,43

\igrPageHeight,42

\igrpagestyle,43,44

\igrPageWidth,42

\igrset,6

\igrsetmatches,49

\igrsetmatchvalue, 49

\igrSetPageSize,42

(53)

a10paper,8 a1paper,7 a2paper,7 a3paper,7 a4paper,7 a5paper,7 a6paper,7 a7paper,7 a8paper,7 a9paper,7 b0paper,8 b10paper,8 b1paper,8 b2paper,8 b3paper,8 b4paper,8 b5paper,8 b6paper,8 b7paper,8 b8paper,8 b9paper,8 bookmark,13

bookmark heading,13

bookmark heading options, 13 bookmark options,13

border,14

bottom border,14 c0paper,8

c10paper,9 c1paper,8 c2paper,8 c3paper,8 c4paper,8 c5paper,8 c6paper,8 c7paper,8 c8paper,9 c9paper,9 center,9 currentpaper,7 d0paper,9 d1paper,9 d2paper,9 d3paper,9 d4paper,9 d5paper,9

if match code,15 if match set,15

if match set bookmark,15 ignore on not found,10 ignore on not found with extensions, 11

ignore on not found with extensions*,11

include command,10 label,13

landscape,7 ledgerpaper,9 left border,14 legalpaper, 9 letterpaper,9

no existence check,10 no hyper,12

no overlay, 16 options,10 options add,10 overlay,16

overlay page number at,16

overlay page number at bottom, 16 overlay page number at top,16 overlay page number options,16 page,9

pagestyle,17 paper,7 paper size, 7 portrait,7 right border,14 set matches,15 target,12 top border, 14 vertical border,14 zerofill,17

labelkey,13 landscapekey,7 ledgerpaperkey,9 left borderkey,14 legalpaper key,9 letterpaperkey,9

\n,5

\ni,5

(54)

page key,9 pagestylekey,17 paper key,7 paper size key,7 portraitkey,7 right borderkey,14 set matches key,15

targetkey,12

\theigrpage,43 top border key,14 vertical borderkey,14 zerofillkey,17

References

Related documents

disadvantage have special resonance for the Australian Aboriginal community, where the construct, the best interests of the child, has been applied and has resulted in an

Thus, the fieldwork component in social work education is central, under-resourced, vari- able and potentially able to make use of a growing amount of overseas and locally generated

The Swedish school authorities have drawn attention to this work and designated the school ‘the best school in Sweden working for equal value 2008’. Student empowerment, child’s

Socialisation processes proposed in this model which is expected to effect adolescents’ knowledge, attitudes and behaviour towards OTC are communication with family,

The transition field in our \BibSpec example is a dummy field to be used when punctuation or other material must be added at a certain point in the bibliography without regard to

• float: handles floats placed within text; used only when the man and floatsintext options are both specified biblatex package (when loaded by the user in the document preamble)

• float : handles floats placed within text; used only when the man and floatsintext options are both specified biblatex package (when loaded by the user in the document preamble)

Depending on the particular package options that are set and the document class, the appendices environment may change the definition of elements of the sectioning commands

The \n@wsp@cies command creates a command for all the different parameters it gets, which name is of TypeIdenti- fier@Parametername, for example, if the command would

name-options-set = { htikz optioni } (initially empty) This value is passed to the options of the \node the third argument of \bohr is placed in.. name-options-add = { htikz optionsi

The output consists of the two arguments separated by a comma and enclosed in a pair of adjustable-size brackets, with the optional argument placed as a subscript (to denote the

This is sufficient for centered longtables, but for left or right aligned longtables this results in captions moved into the left or right page margin.. To solve this problem

The total ABC contribution to Australian screen drama, combined with approximately $125 million in external funding, delivered up to $244 million in production value to

Approximate linear Hubble law Galactic evolutionary effects Cosmic Background Radiation Stellar structure and evolution?. Big

Sessional Com m ittee on the Environm ent 79.. A strong research and development effort, particularly into the integration of control methods, is essential to the

There are options for centering the document page on the paper sheet, for mounting pages on a physical sheet, for reflect- ing and inverting the whole document or printing

The master file is a BibTEX bibliographic style file containing alternative coding depending on docstrip options!. The options are selected when docstrip is run, either interactively

3.41 The Committee’s Green Paper proposed that Wednesday mornings of sitting weeks be set aside for Committee meetings which, depending on the committees’ needs, would allow up

All options provided to the class (except the ksp-thesis-specific options listed in section 3. The packages ClassicThesis and ArsClassica are loaded, thus applying their layout

Vessel biofouling is a major pathway for the introduction of non-indigenous marine organisms into New Zealand territorial waters, some of which may be harmful

5.15 At the time of Mr C’s requests for access to the NDIS, the NDIA did not have any policy or guideline dealing specifically with incarcerated individuals and access to the NDIS.

The entity or person(s) responsible for the ownership and control of the containment facility includes natural persons, organisations (corporate and non-corporate), Board

existence. In making such an estimate, the Government Printer was requested to take as understood that each author body would have its report printed by the