-
Notifications
You must be signed in to change notification settings - Fork 2
/
colorspace.tex
563 lines (478 loc) · 18.5 KB
/
colorspace.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
%
% Copyright (C) 2015-2019 Javier Bezos http://www.texnia.com
%
% This file may be distributed and/or modified under the conditions of
% the MIT License. A version can be found at the end of this file.
%
% Repository: https://github.com/jbezos/colorspace
%
\documentclass[a4paper]{ltxguide}
\title{\textsf{colorspace}\\\large Version 1.3}
\author{Javier Bezos\\\texttt{http://www.texnia.com}}
\date{2019-03-25}
\raggedright
\parskip=.8ex
\advance\oddsidemargin-.7cm
\advance\textwidth2cm
\addtolength{\textheight}{3.5cm}
\addtolength{\topmargin}{-2cm}
\newif\ifcolorspace
\newif\iftikz
\usepackage{graphicx,bera}
\IfFileExists{colorspace.sty}{%
\usepackage[illuminant=d65]{colorspace}%
\definespotcolor{foo}{BarTone 555 GN}{.8,.2,.5,.3}%
\definespotcolor{foob}{BarTone 666 GN}[rgb]{.8, .2, .4}%
\definespotcolor{foolab}{BarTone 888 LB}[alt=lab]%
{50, -30, -40/1, .20, .15, .07}%
%
\definecolorspace{fooshaded}{mixed}{foo,black}%
\definecolorspace{labshaded}{mixed}{foolab,foob}%
%
\definecolor{sfoo}{fooshaded}{1,0}
\definecolor{sblack}{fooshaded}{0,1}
\definecolorseries{shseries}{fooshaded}{last}{sfoo!40}{sblack}
\colorspacetrue}{}
\IfFileExists{tikz.sty}{%
\catcode`|=12
\usepackage{tikz}%
\catcode`|=\active
\tikztrue}{}
\def\showclr#1#{\testclr{#1}}
\def\testclr#1#2{{\fboxsep0pt\fbox{\colorbox#1{#2}{\phantom{,MM}}}}}
\makeatletter
\def\@begintheorem#1#2{%
\list{}{}%
\global\advance\@listdepth\m@ne
\item[{\sffamily\bfseries\color{foob}\MakeUppercase{#1}}]}%
\makeatother
\newtheorem{warning}{Warning}
\newtheorem{note}{Note}
\newtheorem{example}{Example}
\begin{document}
{\fontsize{48}{48}\selectfont colorspace\par}
{\LARGE Spot colors, mixed inks and more\par}
\vspace*{1ex}
Version 1.3 (2019-03-25)\par
Javier Bezos (\texttt{http://www.texnia.com})
\vspace*{6ex}
The aim of this package is, as its name implies, to provide tools for
PDF color spaces. It requires \textsf{xcolor}, which is loaded if it
has not been before. It seems to work with \textsf{tikz}.
Currently it supports what I think are the most common tools:
\begin{itemize}
\item Spot colors, with a clean user interface, and including tints
(with the |!| notation).
\item CIE LAB spot colors.
\item Proper switching of color spaces.
\item Mixed spot and process colors (up to 4), like shades (ie, a spot
color with black). Also CIE LAB if a CMYK equivalent is provided.
\item ICC based (or ``tagged'') default CMYK, RGB and Gray spaces.
\item Overprinting (across pages, using the color stack).
\end{itemize}
Currently only \textsf{pdftex} and \textsf{luatex} are
supported. Support for \textsf{xetex} is on the `to do' list, but due
to the limitations of this engine this task is somewhat challenging
and I'm not sure all features will be implemented.
Other functions related to the PDF color spaces (indexed, calibrated,
Lab spaces) are not yet suported, but they are under study. Calibrated
colors, although not directly supported, can be defined with an ICC
profile created with
LPROF\footnote{\texttt{http://lprof.sourceforge.net/}} and then
assigned to a default space as described below.
They apply to text and line art only, not external images. For the
latter, \textsf{graphicx} provides a plea of (undocumented)
transformations: \texttt{interpolate}, \texttt{decodearray},
\texttt{maskarray}, \texttt{intent}, \texttt{ocobjnum}, and
\texttt{ocobjref}. For transparency, see \textsf{transparent}, by
Heiko Oberdiek.
This package is still evolving, but the basic behaviour described here
will be preserved in future versions. However, some functions from
\textsf{xcolor} might not work yet (for example
\verb|\selectcolormodel| and the corresponding package options |cmyk|
and the like).
Declarations are global and should go in the preamble.
This package is built on the previous attempts to provide spot colors
and other additional features by Jens Elstner, Stephan Lehmke and Siep
Kroonenberg (with some inspiration from \textsf{ConTeXt}, too).
\section{CMYK spot colors}
Spot colors are defined with a single macro:
\begin{decl}
|\definespotcolor{<latex-name>}{<PDF-name>}{<CMYK-equivalent>}|
\end{decl}
Here |<latex-name>| is the \LaTeX{} name, as used in \verb|\color| and
the like, |<PDF-name>| is the PDF name (usually taken from a swatch
book; multiple spaces are collapsed into one) as shown by PDF viewers,
and the four numbers are the CMYK equivalent. \LaTeX{} knows nothing
about the PDF name, which is just a string to be written to the
generated file, while the PDF knows nothing about the \LaTeX{} name.
To mix inks, see below.
\begin{example}
Write, for example:
\begin{verbatim}
\definespotcolor{foo}{BarTone 555 GN}{.8,.2,.5,.3}
\end{verbatim}
This creates the color \showclr{foo}, which is used in \LaTeX{} as
|\color{foo}|. If you preflight the PDF file you will see a color
named `BarTone 555 GN' besides cyan, magenta, yellow and black.
You can use tints as usual in \textsf{xcolor}, like:
\begin{verbatim}
\color{foo!50}
\colorlet{foo50}{foo!50}
\end{verbatim}
\ifcolorspace
which would produce \showclr{foo!50}, and
\fi
even set tints from other tints.
\end{example}
\begin{note}
The special PDF names \verb|All| (for all plates) and \verb|None|
work as expected:
\begin{verbatim}
\definespotcolor{registration}{All}{1,1,1,1}
\end{verbatim}
\end{note}
\begin{note}
Remember as far PDF is concerned a spot color is a color space on
its own.
\end{note}
\begin{note}
This package does not provide a list of Pantone, TrueMatch, HKS,
Folcoltone, Toyo, etc., colors. Currently you can find quite easily
CMYK equivalents on the web, and after all they are intended to be
used with a ``physical'' swatch book (and not, as often done, by
picking a color from a ``virtual'' palette just because it looks
nice on screen).
\end{note}
\begin{decl}
|\definespotcolor{<latex-name>}{<PDF-name>}[<model>]{<equivalent>}|
\end{decl}
Internally, only CMYK is used for the equivalent color, but with this
variant you can define the latter with another name space, which is
then converted.
\begin{example} The following definition is based on RGB:
\begin{verbatim}
\definespotcolor{foob}{BarTone 666 GN}[rgb]{.8, .2, .4}
\end{verbatim}
which yields \showclr{foob}. Here \textsf{xcolor} just
converts this value to CMYK, which is still the space used
internally.
\end{example}
\begin{warning}
This conversion relies on the \textsf{xcolor} numerical methods,
which do not take into account any color profile and therefore
should be avoided in production if the alternate space is going to
be actually used. It is provided just for convenience in drafting or
in contexts where accuracy is not essential.
\end{warning}
\section{CIE LAB spot colors}
Instead of targeting the CMYK space, spot colors may be defined using
the CIE LAB (also known as L*a*b*, or even just Lab) space. Unlike the
default CMYK space, which is by default device dependend, the Lab
space is device independent. To define a Lab spot color, you must
first set the illuminant with the package option |illuminant|, which
takes a value:
\begin{verbatim}
\usepackage[illuminant=d65]{colorspace}
\end{verbatim}
Values are \texttt{a}, \texttt{c}, \texttt{e}, \texttt{d50},
\texttt{d55}, \texttt{d65}, \texttt{d75}.
The command to define a color is:
\begin{decl}
|\definespotcolor{<latex-name>}{<PDF-name>}[alt=lab]{<Lab-values>}|
\end{decl}
Note the optional argument with the string |alt=lab| (which cannot be
combined with a model). The three |<Lab-values>| have ranges
\textit{L}* $=$ $0$\ldots$100$, \textit{a}* $=$ $-$128$\ldots$127,
\textit{b}* $=$ $-$128{\ldots}127, respectively.
\begin{example}
With
\begin{verbatim}
\definespotcolor{foolab}{BarTone 888 LB}[alt=lab]{50, -30, -40}
\end{verbatim}
the result is \showclr{foolab}. An example of tint is
\verb|\color{foolab!30}| (\showclr{foolab!30}).
\end{example}
\begin{warning}
The package does not warn if the color falls outside the gamut of
the CMYK space or if the color is not visible. To put it in
other words, you should not just write some arbitrary values to see
what happens.
\end{warning}
\begin{warning}
This model is not available in \textsf{xcolor}. If you need some
transformation, you must resort to an external tool like
\textsf{transicc} (or \textsf{icctrans}) included in Little
CMS\footnote{\texttt{http://www.littlecms.com/1/downloads.htm}}.
\end{warning}
\begin{warning}
There is no default illuminant -- it must be set if Lab colors are
defined.
\end{warning}
\begin{note}
The observer is currently only 2$^\circ$ (1931).
\end{note}
The Lab space allows to define colors accurately, but there is a price
to pay -- mixing Lab colors is not in general possible except after
converting them somehow to CMYK or RGB.\footnote{There are no simple
rules to carry out those transformations, which, I think, explains why
\textsf{xcolor} does not support Lab at all}. Since currently mixing
colors in this package is based on CMYK, you must provide an alternate
value as shown, if mixed inks are required\footnote{Internally, and
in PDF jargon, Lab is the ``alternate space'' and ``tints transforms''
are based on CMYK}:
\begin{verbatim}
\definespotcolor{foolab}{BarTone 888 LB}[alt=lab]{50, -30, -40/1, .20, .15, .07}
\end{verbatim}
\section{Mixing spot colors}
To mix spot colors you must first declare a color space (or model)
including them. This is done with the following macro:
\begin{decl}
|\definecolorspace{<latex-name>}{mixed}{<color-list>}|
\end{decl}
Here, |<latex-name>| is the name to be used in |\color| and the
like as the color model. The second argument is the string |mixed|,
and the last one is a list of up to 4 colors, either defined with
\textsf{xcolor} using the CMYK model or spot.
\begin{example}
A simple and typical usage would be for shades:
\begin{verbatim}
\definecolorspace{fooshaded}{mixed}{foo,black}
\end{verbatim}
Then, you can define a color in this new model named
\verb|fooshaded| with:
\begin{verbatim}
\definecolor{darkfoo}{fooshaded}{.6,.3}
\end{verbatim}
Or set it with:
\begin{verbatim}
\color[fooshaded]{.6,.3}
\end{verbatim}
In both cases, the mix is 60\% \verb|foo| and 30\% \verb|black|.
\end{example}
\begin{example}
If we have two spot colors named \verb|spot1| and \verb|spot2|, and
we want in addition yellow:
\begin{verbatim}
\definecolorspace{mix12y}{mixed}{spot1,spot2,yellow}
\end{verbatim}
To define a new color based on this space:
\begin{verbatim}
\definecolor{mix12y}{mix12y}{.5,.4,.6}
\end{verbatim}
And to set it:
\begin{verbatim}
\color[mix12y]{.5,.4,.6}
\end{verbatim}
\end{example}
\begin{example}
Here is a duotone mixing the \verb|foob| and \verb|foolab| colors defined above:
\begin{verbatim}
\definecolorspace{labshaded}{mixed}{foolab,foob}
\end{verbatim}
The colors corresponding to:
\begin{verbatim}
\color[labshaded]{1,0} \color[labshaded]{.8,.2}
\color[labshaded]{.6,.4} \color[labshaded]{.4,.6}
\color[labshaded]{.2,.8} \color[labshaded]{0,1}
\end{verbatim}
are \showclr[labshaded]{1,0} \showclr[labshaded]{.8,.2}
\showclr[labshaded]{.6,.4} \showclr[labshaded]{.4,.6}
\showclr[labshaded]{.2,.8} \showclr[labshaded]{0,1}
\end{example}
\begin{warning}
Due to internal limitations of \textsf{xcolor}, no more than four
colors are allowed.
\end{warning}
\begin{note}
The alternate color space in the PDF file is that of the spot colors
(which means currently it is CMYK).
\end{note}
\begin{note}
There is an easy trick to mix colors with \verb|!| and
\verb|color,num| -- just define an ortogonal set of colors based on
the new color model:
\begin{verbatim}
\definecolor{xspot1}{mix12y}{1,0,0}
\definecolor{xspot2}{mix12y}{0,1,0}
\definecolor{xyellow}{mix12y}{0,0,1}
\end{verbatim}
and then you can say:
\begin{verbatim}
\color{xspot1!30!xspot2!40!xyellow}
\color{mix12y:xspot1,3;xspot2,2;xyellow,1}
\end{verbatim}
Of course, it is just a trick and a better and direct interface is
under study (none of those provided by \textsf{xcolor} fits well
with the new |mixed| models).
\end{note}
\begin{warning}
Mixing colors in \verb|\color|, \verb|\definecolor| and the like
from diferent spaces can lead to unexpected results (currently no
checking is done).
\end{warning}
Color series (see the \textsf{xcolor} documentation) are also
partially supported. For example:
\begin{verbatim}
\definecolorseries{test}{mix12y}{grad}[mix12y]{.95,.85,.55}{3,11,17}
\definecolorseries{test}{mix12y}{last}{xyellow!50}{xspotA}
\end{verbatim}
\ifcolorspace
\begin{example}
Here is a example with some of the described techniques, based on
the |fooshaded| space defined above (figure 1 shows the |foo|
plate):
\begin{verbatim}
\definecolor{sfoo}{fooshaded}{1,0}
\definecolor{sblack}{fooshaded}{0,1}
\definecolorseries{shseries}{fooshaded}{last}{sfoo!40}{sblack}
\def\testclr#1{{\fboxsep0pt\fbox{\colorbox{#1}{\phantom{XX}}}}}
\resetcolorseries[8]{shseries}
\begin{tabular}{cccccccc}
0 \testclr{shseries!!+} &
1 \testclr{shseries!!+} &
2 \testclr{shseries!!+} &
3 \testclr{shseries!!+} &
4 \testclr{shseries!!+} &
5 \testclr{shseries!!+} &
6 \testclr{shseries!!+} &
7 \testclr{shseries!!+}
\end{tabular}
\end{verbatim}
\begingroup
\def\testclr#1{{\fboxsep0pt\fbox{\colorbox{#1}{\phantom{XX}}}}}
\resetcolorseries[8]{shseries}
\begin{tabular}{cccccccc}
0 \testclr{shseries!!+} &
1 \testclr{shseries!!+} &
2 \testclr{shseries!!+} &
3 \testclr{shseries!!+} &
4 \testclr{shseries!!+} &
5 \testclr{shseries!!+} &
6 \testclr{shseries!!+} &
7 \testclr{shseries!!+}
\end{tabular}
\endgroup
\end{example}
\fi
\begin{figure}
\fbox{\includegraphics[width=\linewidth]{colorspaceshade.png}}
\caption{Plate for the \texttt{foo} spot color as shown by Adobe
Acrobat. Note both \texttt{foob} and \texttt{foolab},
defined in this document, are listed, too.}
\end{figure}
\section{Page color spaces}
Each PDF page must know which colors will be used (other than the
predefined CMYK, RGB and Gray). By default, \textsf{colorspace} turns
on for every page all newly defined colors, and that will be fine in
most cases. However, you may want to set explicitly the list (for
covers or plates). Use this feature with care, because (1) the
asynchronous nature of \TeX{} (remember it affects the whole current
page), and (2) each distinct color list creates a PDF resource.
\begin{decl}
|\pagecolorspace{<color-list>}|\\
|\resetpagecolorspace|
\end{decl}
To change the color space for a page and the subsequent ones, you can
set something like:
\begin{verbatim}
\pagecolorspace{name1,name2,name3}
\end{verbatim}
(It can be empty.) To return to the default color space, which
contains all the defined spot colors, use \verb|\resetpagecolorspace|.
\section{ICC based spaces}
\begin{decl}
|\definecolorspace*{<latex-name>}{iccbased}{<icc-file>}|
\end{decl}
The starred version \verb|\definecolorspace*| does not define a new
color model, but sets the behaviour of the three basic color spaces
(CMYK, RGB and Gray). When belonging to the same space, the last
definition for that space takes precedence and it is considered the
default one. It cannot be used to define new colors or set
them. Currently, only a type is supported -- \verb|iccbased|. For
example,
\begin{verbatim}
\definecolorspace*{sRGB}{iccbased}{sRGB Profile.icc}
\end{verbatim}
The space it applies to is read from the ICC profile.
The name can be used in \verb|\pagecolorspace|. Alternatively, there
are 3 reserved names: \verb|*rgb|, \verb|*gray|, \verb|*cmyk|, which
stand for the last-defined, default ICC based spaces. Named ICC based
spaces are not set by \verb|\resetpagecolorspace|, but the starred
named are. On the other hand, the starred names are not set
automatically by |\pagecolorspace|, and you must set them explicitly
if you want them to be active.
\begin{note}
Those ICC spaces do not go to the output intent dictionary (see
the \textsf{pdfx} package). The latter, as the PDF reference
explains, supplements rather than replaces the ICC profiles in a
default color space.
\end{note}
\begin{example}
Given the following declarations:
\begin{verbatim}
\definecolorspace*{sRGB}{iccbased}{sRGB Profile.icc}
\definecolorspace*{colormatch}{ColorMatchRGB.icc}
\end{verbatim}
and remembering the RGB space is always active (like the CMYK and
Gray ones),
\begin{verbatim}
\pagecolorspace{}
\end{verbatim}
leaves the RGB space unprofiled;
\begin{verbatim}
\pagecolorspace{sRGB}
\end{verbatim}
sets the RGB space to sRGB; while the following are (in this
particular example) equivalent:
\begin{verbatim}
\pagecolorspace{colormatch}
\pagecolorspace{*rgb}
\resetpagecolorspace
\end{verbatim}
\end{example}
\section{Overprinting}
This is usually a pre-print task, but by setting it in the document
you will get a better idea of how the colors are actually overlapped
in soft proofing. However, remember the effect produced is
device-dependent, and colorant overprint decisions should be made at
output time (according to the PDF reference).
Very often, it is set for the whole document with the package options
\verb|knockout| (no overprint), and \verb|overprint|. By default, the
overprint mode is 1, but it can be changed with \verb|opm=0|.
Once set the overprint state for the whole document, you can use
something like:
\begin{verbatim}
{\overprintstate{1}text}
\textoverprint[1]{text}
\end{verbatim}
(or \verb|0|, or \verb|no|; default in \verb|\textoverprint| is
\verb|1|, except with the package option \verb|opm=0|).
Since the color stack is used, pdf\TeX{} $\ge$ 1.40 is required.
\begin{warning}
Some PDF viewers ignore this setting.
\end{warning}
\section{Version}
1.1.1. No new features. Just internal changes related to
\textsc{luatex} and new manual.
1.2.0. CIE LAB spot colors and |illuminant|. Manual rewritten.
1.3. Fixes several incompatibilities with \textsf{pgf}/\textsf{tikz}.
\end{document}
MIT License
-----------
Permission is hereby granted, free of charge, to any person obtaining a
copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be included
in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.