little cms Engine 1.19
API Definition
by Marti Maria
---------------------------------------------------
Index
-----
0 - Compilation toggles
1 - Profile & Transform functions
2 - Information functions
3 - On-the-fly profile creation functions
4 - Build-In profiles
5 - White point
6 - Gamma handling
7 - Error handling
8 - Conversion functions
9 - CIECAM97s/CIECAM02
10 - Profile creation functions
11 - LUT manipultation
12 - Named color functions
13 - PostScript
14 - CGATS.13 - 200
0 - Compilation toggles
_________________________________
Generally, there is no need to touch anything. Comment/uncomment if the
testbet hints to do so.
Optimization mode.
USE_ASSEMBLER Is fastest by far, but it is limited to Pentium.
USE_FLOAT are the generic floating-point routines.
USE_C should work on virtually any machine.
Define this if you are using this package as a DLL (windows only)
LCMS_DLL
Define this if you are compiling using this package as a DLL (windows only)
LCMS_DLL_BUILD
Uncomment if you are trying the engine in a non-windows environment
like linux, SGI, VAX, FreeBSD, BeOS, etc.
NON_WINDOWS
Uncomment this one if you are using big endian machines (only meaningful
when NON_WINDOWS is used)
USE_BIG_ENDIAN
Uncomment this one if your compiler/machine does support the
"long long" type This will speedup fixed point math. (USE_C only)
USE_INT64
Some machines does not have a reliable 'swab' function. Usually
leave commented unless the testbed diagnoses the contrary.
USE_CUSTOM_SWAB
Uncomment this if your compiler supports inline
USE_INLINE
Uncomment this if your compiler doesn't work with fast floor function
USE_DEFAULT_FLOOR_CONVERSION
Define this one if you are using windows.h in a non-windows environment
LCMS_WIN_TYPES_ALREADY_DEFINED
Define this one if you want lcms.h just defining public API
LCMS_APIONLY
1 - Profile & Transform functions
_________________________________
These are the basic functions on making transformations. For
simpler operation, you must open two profiles using
cmsOpenProfileFromFile(), then create a transform with these
opened profiles with cmsCreateTransform(). Using this transform
you can color correct your bitmaps by cmsDoTransform(). When you
are done you must free the transform AND the profiles by
cmsDeleteTransform() and cmsCloseProfile().
_________________________________________________________________________________
cmsHPROFILE cmsOpenProfileFromFile(const char *ICCProfile, const char *sAccess);
_________________________________________________________________________________
Opens a profile returning a handle to it. The profile must be
contained in a file on disk.
Parameters:
ICCProfile: File name w/ full path.
sAccess: "r" for normal operation, "w" for profile creation
Returns:
NULL on error, a profile handle on success.
Example:
void GetProductNameOf(const char *ICMProfileFile)
{
cmsHPROFILE hProfile
hProfile = cmsOpenProfileFromFile(ICMProfileFile, "r");
if (hProfile == NULL) printf("Error!");
else {
printf("%s\n", cmsGetProductName(hProfile));
cmsCloseProfile(hProfile);
}
}
_________________________________________________________________________________
cmsHPROFILE cmsOpenProfileFromMem(LPVOID MemPtr, DWORD dwSize);
_________________________________________________________________________________
Same as anterior, but profile is contained in memory. Usefull
for embedded profiles. MemPtr must point to a buffer of at
least dwSize bytes. This buffer must hold a full profile image.
Memory must be contiguous.
Parameters:
MemPtr: Points to a block of contiguous memory containing the profile
dwSize: Profile's size measured in bytes.
Returns:
NULL on error, a profile handle on success.
_________________________________________________________________________________
LCMSBOOL cmsCloseProfile(cmsHPROFILE hProfile);
_________________________________________________________________________________
Closes a profile handle and frees associated memory. Note that
cmsDeleteTransform() does NOT close the involved profiles. You
must close any opened profile handle on cleanup.
Parameters:
hProfile: Handle to an open profile
Returns:
FALSE on error, TRUE on success
Comments:
Can return error when creating profile if the profile is not
properly flushed to disk.
_________________________________________________________________________________
cmsHTRANSFORM cmsCreateTransform(cmsHPROFILE Input,
DWORD InputFormat,
cmsHPROFILE Output,
DWORD OutputFormat,
int Intent,
DWORD dwFlags); .
_________________________________________________________________________________
Creates a transform for translating bitmaps.
Parameters:
Input, Output: Input, Output profile handles
Input, Output format: This value describes how values are to be
coded. It is formed by a combination of
channels, bitdepths andextra samples. See
below.
for example:
TYPE_BGR_8 : 3 channels of 8 bits, using Windows convention
TYPE_RGB_8 : 3 channels of 8 bits per component
TYPE_RGB_16 : 3 channels of 16 bits per component
TYPE_RGBA_8 : 4 channels, 3 containing RGB of 8 bpc, and one channel of 8 bits holding alpha
...
Note than even some Lab and XYZ are defined, these specifiers
has nothing to do with colorspaces, but only how data is
encoded. The CMM will only check for same colorspace as profile.
Intent: The ICC intent to apply. If an appropiate tag for this
intent is not found, no error is raised and the intent
is reverted to perceptual. See the tutorial for a
explanation of intents.
INTENT_PERCEPTUAL 0
INTENT_RELATIVE_COLORIMETRIC 1
INTENT_SATURATION 2
INTENT_ABSOLUTE_COLORIMETRIC 3
dwFlags: This value commands on how to handle the whole
process. Some or none of this values can be joined
via the or | operator.
cmsFLAGS_MATRIXINPUT: CLUT ignored on input profile,
matrix-shaper used instead (for
speed, and debugging purposes)
cmsFLAGS_MATRIXOUTPUT: Same as anterior, but for output
profile only.
cmsFLAGS_MATRIXONLY: Both input and output are forced to
matrix-shaper.
cmsFLAGS_NOTPRECALC: By default, lcms smelt luts into a
device-link CLUT. This speedup whole
transform greatly. If you don't
wanna this, and wish every value to
be translated to PCS and back to
output space, include this flag.
cmsFLAGS_NULLTRANFORM: Don't transform anyway, only apply
pack/unpack routines (usefull to
deactivate color correction but keep
formatting capabilities)
cmsFLAGS_HIGHRESPRECALC: Use 48 points instead of 33 for
device-link CLUT precalculation. Not needed
but for the most extreme cases of mismatch
of "impedance" between profiles.
cmsFLAGS_LOWRESPRECALC: Use lower resolution table.
cmsFLAGS_GRIDPOINTS(n): You can specify the desired number of gridpoints
in devicelink by using this macro in the flags.
cmsFLAGS_BLACKPOINTCOMPENSATION: Use BPC algorithm.
cmsFLAGS_PRESERVEBLACK: Preserve K channel on CMYK -> CMYK transforms
cmsFLAGS_NOTCACHE: Inhibit the 1-pixel built-in cache
cmsFLAGS_NOWHITEONWHITEFIXUP: Do NOT fix white-on-white broken profiles
cmsFLAGS_NOPRELINEARIZATION: Do NOT use prelinearization tables
Returns:
NULL on error, a transform handle on success.
Comments:
This function tries to build a device link profile using the
Input and Output profiles. This small time-consuming penalty (3
sec. on a Pentium-100) does accelerate the bitmap transform
process greately. You can override this behaviour if you wish,
or if you plan to transform only a couple of pixels by using
cmsFLAGS_NOTPRECALC on dwFlags parameter. But normally it will
be better leave this flag alone.
Also, in this function is where you must specify the format of
the input and output bitmaps. The InputFormat and OutputFormat
parameters are formed by combining several bits:
// Format of pixel is defined by one integer, using bits as follows
//
// TTTTT - Y F P X S EEE CCCC BBB
//
// T: Pixeltype
// F: Flavor 0=MinIsBlack(Chocolate) 1=MinIsWhite(Vanilla)
// P: Planar? 0=Chunky, 1=Planar
// X: swap 16 bps endianess?
// S: Do swap? ie, BGR, KYMC
// E: Extra samples
// C: Channels (Samples per pixel)
// B: Bytes per sample
// Y: Swap first - changes ABGR to BGRA and KCMY to CMYK
// -: Unused (reserved)
lcms.h does include several predefined specifiers, as examples:
TYPE_RGB_8 8 bits per sample RGB
TYPE_BGR_8 8 bits per sample BGR (Windows Bitmaps are often
coded in this way)
TYPE_RGB_16 16 bits per sample RGB
TYPE_RGBA_8 8 bits per sample RGB plus alpha channel. Alpha is
ignored by lcms.
TYPE_RGBA_16 16 bits per sample RGB plus alpha.
TYPE_XYZ_16 16 bits fixed 15.16 XYZ (used in PCS)
TYPE_Lab_8 8 bits per sample Lab
TYPE_Lab_16 16 bits per sample Lab
TYPE_CMY_8 8 bits per sample CMY
TYPE_CMY_16 16 bits per sample CMY
TYPE_CMYK_8 8 bits per sample CMYK
TYPE_CMYK_16 16 bits per sample CMY
You can build your own specifiers if you wish by combining the following macros with the bitwise OR operator |
DOSWAP_SH(e) 1 or 0 depending on swap even channels
EXTRA_SH(e) up to 7 extra channels
CHANNELS_SH(c) up to 4 handled channels
BYTES_SH(b) 1 if 16 bits per sample, 0 if 8 bits per sample
ENDIAN16_SH(e) 1 if 16 bits samples comes swapped.
SWAPFIRST_SH(s) 1 changes ABGR to BGRA and KCMY to CMYK
FLAVOR_SH(s) 0 = BlackIsZero (Chocolate) 1=WhiteIsZero (Vanilla, Negative)
PLANAR_SH(p) 0 = Chunky, 1=Planar
COLORSPACE_SH(s)
Available Colorspaces
=====================
PT_ANY Don't check colorspace
1 & 2 are reserved
PT_GRAY
PT_RGB
PT_CMY
PT_CMYK
PT_YCbCr
PT_YUV
PT_XYZ
PT_Lab
PT_YUVK
PT_HSV
PT_HLS
PT_Yxy
See the lcms.h for more information on how to build format specifiers.
_________________________________________________________________________________
cmsHTRANSFORM cdecl cmsCreateProofingTransform(cmsHPROFILE Input,
DWORD InputFormat,
cmsHPROFILE Output,
DWORD OutputFormat,
cmsHPROFILE Proofing,
int Intent,
int ProofingIntent,
DWORD dwFlags);
_________________________________________________________________________________
Same as cmsCreateTransform(), but including soft-proofing. The
obtained transform emulates the device described by the
"Proofing" profile. Useful to preview final result whithout
rendering to physical medium.
Parameters and returns same as anterior, but with the addition of
Proofing: a handle to proofing profile.
ProofingIntent: Is the intent for translating emulated
colors. Default is
INTENT_ABSOLUTE_COLORIMETRIC.
dwFlags:
cmsFLAGS_GAMUTCHECK: Color out of gamut are flagged to a
fixed color defined by the function
cmsSetAlarmCodes(int r, int g, int b);
cmsFLAGS_SOFTPROOFING: (Does need preview tag to work) does
emulate the Proofing device.
You need to add a combination of these flags to enable any proof!
_________________________________________________________________________________
cmsHTRANSFORM cmsCreateMultiprofileTransform(cmsHPROFILE hProfiles[],
int nProfiles,
DWORD InputFormat,
DWORD OutputFormat,
int Intent,
DWORD dwFlags);
_________________________________________________________________________________
User passes in an array of handles to open profiles. The returned handle
does "smelt" all profiles in only one devicelink. Following rules should
be followed:
- Colorspaces must be paired with the exception of
Lab/XYZ, that can be interchanged.
- Profile must be Matrix-shaper, or hold the
apropiate tag, device-to-pcs or pcs-to-device on depending
on profile location.
- All colorspaces up to 4 (significant) channels can be used
anywhere on the chain, Hexachrome separation or more can only
appair at last step. This limitation is intended to be solved in
future releases.
Let's take as example, how to apply a abstract profile into a SRGB image.
The chain would be sRGB -> Abstract -> sRGB. So, we would open sRGB and the
abstract profile, and fill the array
Profiles[0] = hsRGB;
Profiles[1] = hAbstract;
Profiles[2] = hsRGB;
cmsCreateMultiprofileTransform(Profiles, 3, TYPE_RGB_8, TYPE_RGB_8, INTENT_PERCEPTUAL, 0);
WARNING: he dE rises with the number of profiles.
This can be used, for example, with abstract profiles. For example, abstract
profiles can be applied into a typical profile-to-profile color flow to model
viewing conditions.
Once created, the transform will behave just like any other.
_________________________________________________________________________________
void cmsDeleteTransform(cmsHTRANSFORM hTransform);
_________________________________________________________________________________
Closes a transform handle and frees associated memory.
Parameters:
hTransform: The transform handle to be deleted.
Comments: This function does NOT free any profiles associated
with the transform. Is programmer's responsability to free
them.
_________________________________________________________________________________
void cmsDoTransform(cmsHTRANSFORM hTransform,
LPVOID InputBuffer,
LPVOID OutputBuffer, unsigned int Size);
_________________________________________________________________________________
This function translates bitmaps according of transform. Format
of buffers is described by InputFormat and OutputFormat
parameters in function cmsCreateTransform() or
cmsCreateProofingTransform()
Parameters:
hTransform: A handle to a transform describing the translation.
InputBuffer: A pointer to a input bitmap
OutputBuffer: A pointer to a output bitmap.
Size: the number of PIXELS to be transformed.
Comments:
Windows, stores the bitmaps in a particular way... for speed
purposes, does align the scanlines to doubleword boundaries, so
a bitmap has in windows always a size multiple of 4. This is
ok, since no matter if you waste a couple of bytes, but if you
call cmsDoTransform() and passes it WHOLE image, lcms doesn't
know nothing about this extra padding bytes. So, it assumes
that you are passing a block of BGR triplets with no alignment
at all. This result in a strange looking "lines" in obtained
bitmap.
The solution most evident is to convert scanline by scanline
instead of whole image. This is as easy as to add a for() loop,
and the time penalty is so low that is impossible to detect.
_________________________________________________________________________________
void cmsChangeBuffersFormat(cmsHTRANSFORM hTransform,
DWORD dwInputFormat,
DWORD dwOutputFormat)
_________________________________________________________________________________
This function does change the encoding of buffers in a yet-existing transform.
Parameters:
hTransform: A handle to the transform.
Input, Output format: This value describes how values are to be
coded. It is formed by a combination of
channels, bitdepths andextra samples.
See cmsCreateTransform for more info.
Notes:
Colorspace is *not* checked
_________________________________________________________________________________
cmsHPROFILE cmsTransform2DeviceLink(cmsHTRANSFORM hTransform, DWORD dwFlags);
_________________________________________________________________________________
Generates a device-link profile from a transform. This profile can then be used
by any other function accepting profile handle, or be saved on disk
by _cmsSaveProfile(). See icclink.c for a sample.
Parameters:
hTransform: A handle to the transform.
Flags:
cmsFLAGS_GUESSDEVICECLASS: Mark the profile profile class "guessing"
from input & output colorspaces.
cmsFLAGS_HIGHRESPRECALC: Use 48 points instead of 33 for
device-link CLUT precalculation. Not needed
but for the most extreme cases of mismatch
of "impedance" between profiles.
cmsFLAGS_LOWRESPRECALC: Use lower resolution table.
cmsFLAGS_GRIDPOINTS(n): You can specify the desired number of gridpoints
in devicelink by using this macro in the flags.
cmsFLAGS_BLACKPOINTCOMPENSATION: Use BPC algorithm.
cmsFLAGS_PRESERVEBLACK: Preserve K channel on CMYK -> CMYK transforms
cmsFLAGS_NOTCACHE: Inhibit the 1-pixel built-in cache
cmsFLAGS_NOWHITEONWHITEFIXUP: Do NOT fix white-on-white broken profiles
cmsFLAGS_NOPRELINEARIZATION: Do NOT use prelinearization tables
2 - Information functions
_________________________________________________________________________________
These functions are intended for identify profiles. Its main use
if for building user interfaces.
_________________________________________________________________________________
void cmsSetLanguage(int LanguageCode, int CountryCode);
_________________________________________________________________________________
This function applies only to v4 profiles, which may have multilocalized
strings for information functions. Using cmsSetLanguage(), you set the preferred
language and country in what you want the information. All strings are searched
for an exact match of language and country. In none found, then another search
is done for same language, ignoring country. If no matching is found, the first
string in table is returned.
Parameters:
LanguageCode: first name language code from ISO-639.
http://lcweb.loc.gov/standards/iso639-2/iso639jac.html
CountryCode: first name region code from ISO-3166.
http://www.iso.ch/iso/en/prods-services/iso3166ma/index.html
_________________________________________________________________________________
const char* cmsTakeProductName(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing the product name. The
string is holded in a static buffer that is overwritten in
every call to this function.
Parameters:
hProfile: Handle to an open profile
_________________________________________________________________________________
const char* cmsTakeProductDesc(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing the product Description. The
string is holded in a static buffer that is overwritten in
every call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
Product description in a static buffer overwritten in each
call to this function.
_________________________________________________________________________________
const char* cmsTakeProductInfo(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing additional info about
hProfile. The string is holded in a static buffer overwritten
in each call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
Product info in a static buffer overwritten in each
call to this function.
_________________________________________________________________________________
const char* cmsTakeManufacturer(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing uncooked info about
manufacturer. The string is holded in a static buffer overwritten
in each call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
Manufacturer in a static buffer overwritten in each
call to this function.
_________________________________________________________________________________
const char* cmsTakeModel(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing uncooked info about
model. The string is holded in a static buffer overwritten
in each call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
Model description in a static buffer overwritten in each
call to this function.
_________________________________________________________________________________
const char* cmsTakeCopyright(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns a pointer to a string containing uncooked info about
copyright. The string is holded in a static buffer overwritten
in each call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
Copyright info in a static buffer overwritten in each
call to this function.
_________________________________________________________________________________
icColorSpaceSignature cmsGetPCS(cmsHPROFILE hProfile)
_________________________________________________________________________________
This function returns the PCS used by the hProfile, using the
ICC convention.
Parameters:
hProfile: Handle to an open profile
Returns:
The PCS of the profile
_________________________________________________________________________________
icColorSpaceSignature cmsGetColorSpace(cmsHPROFILE hProfile)
_________________________________________________________________________________
This function returns the Color space used by the hProfile,
using the ICC convention.
Parameters:
hProfile: Handle to an open profile
Returns:
The color space of the profile
_________________________________________________________________________________
DWORD cmsGetProfileICCversion(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns the ICC version as stated in the header of the profile.
Examples:
V2 profiles: 0x2000000
V4 profiles: 0x4000000
Parameters:
hProfile: Handle to an open profile
Returns:
The profile version stamp
_________________________________________________________________________________
icProfileClassSignature cmsGetDeviceClass(cmsHPROFILE hProfile)
_________________________________________________________________________________
This function returns the Device class of hProfile, using the
ICC convention.
Parameters:
hProfile: Handle to an open profile
Returns:
The device class of the profile
_________________________________________________________________________________
LCMSBOOL cmsTakeMediaWhitePoint(LPcmsCIEXYZ Dest, cmsHPROFILE hProfile);
_________________________________________________________________________________
This function takes the white point of hProfile.
Parameters:
Dest: a pointer to an cmsCIEXYZ struct that will hold the
media white point
hProfile: Handle to an open profile
Returns:
FALSE on error, TRUE on success
_________________________________________________________________________________
LCMSBOOL cmsTakeMediaBlackPoint(LPcmsCIEXYZ Dest, cmsHPROFILE hProfile);
_________________________________________________________________________________
This function takes the contents of black point tag of hProfile if present.
Parameters:
Dest: a pointer to an cmsCIEXYZ struct that will
hold the media black point.
hProfile: Handle to an open profile
Returns:
FALSE on error, TRUE on success
NOTES: Most profiles have garbage in this tag, for a suitable black point
detection use cmsDetectBlackPoint() instead.
_________________________________________________________________________________
LCMSBOOL cmsTakeIluminant(LPcmsCIEXYZ Dest, cmsHPROFILE hProfile);
_________________________________________________________________________________
This function takes the value of PCS illuminant of hProfile.
Parameters:
hProfile: Handle to an open profile
Dest: a pointer to an cmsCIEXYZ struct that will
hold the illuminant white point
Returns:
FALSE on error, TRUE on success
Notes: ICC states that profile illuminants MUST be D50. However,
in real world, each manufacturer uses an illuminant value that
differs slightly of D50. lcms forces it to D50 to prevent errors.
_________________________________________________________________________________
LCMSBOOL cmsTakeColorants(LPcmsCIEXYZTRIPLE Dest, cmsHPROFILE hProfile);
_________________________________________________________________________________
This function takes the value of colorant matrix of hProfile if
present.
Parameters:
hProfile: Handle to an open profile
Dest: a pointer to an cmsCIEXYZ struct that will
hold the illuminant white point
Returns:
FALSE on error, TRUE on success
Notes: Some profiles includes colorants even if a CLUT is already present.
Often this colorants are private values, or a way to allow the profile
operate in reverse direction.
_________________________________________________________________________________
icInt32Number cmsGetTagCount(cmsHPROFILE hProfile);
_________________________________________________________________________________
Return number of tags contained in a profile
Parameters:
hProfile: Handle to an open profile
Returns:
Number of tags
_________________________________________________________________________________
icTagSignature cmsGetTagSignature(cmsHPROFILE hProfile, icInt32Number n);
_________________________________________________________________________________
Enumerates tags in a profile
Parameters:
hProfile: Handle to an open profile
n : Tag ordinal
Returns:
Tag signature
_________________________________________________________________________________
LCMSBOOL cmsIsTag(cmsHPROFILE hProfile, icTagSignature sig);
_________________________________________________________________________________
Tests whatever a particular tag is present in hProfile.
Parameters:
hProfile: Handle to an open profile
sig: a tag signature
Returns:
FALSE if not present, TRUE if tag is found
_________________________________________________________________________________
int cmsTakeRenderingIntent(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns the rendering intent field of the header. This field is informative and not
used by the CMM for any purpose.
Parameters:
hProfile: Handle to an open profile
Returns: one of the following values:
INTENT_PERCEPTUAL 0
INTENT_RELATIVE_COLORIMETRIC 1
INTENT_SATURATION 2
INTENT_ABSOLUTE_COLORIMETRIC 3
_________________________________________________________________________________
int cmsTakeHeaderFlags(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns the flags field of the ICC profile header. These are flags to indicate
various hints for the CMM such as distributed processing and caching options.
The least significant 16 bits are reserved for the ICC.
Currently (v4.2) there are only two ICC flags defined:
Bit Meaning
--- -------------------------------------------------------------
0 Embedded Profile (0 if not embedded, 1 if embedded in file)
1 Profile cannot be used independently from the embedded color data
(set to 1 if true, 0 if false)
Parameters:
hProfile: Handle to an open profile
Returns:
The header flags
_________________________________________________________________________________
int cmsTakeHeaderAttributes(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns the attributes field of the ICC profile header. The device attributes
field shall contain flags used to identify attributes unique to the particular
device setup for which the profile is applicable.
Currently (v4.2) there are only two ICC attributes defined:
Bit Meaning
--- -------------------------------------------------------------
0 0=icReflective 1=icTransparency
1 0=icGlossy 1=icMatte
Parameters:
hProfile: Handle to an open profile
Returns:
The header attributes
_________________________________________________________________________________
LCMSBOOL cmsIsIntentSupported(cmsHPROFILE hProfile, int Intent, int UsedDirection);
_________________________________________________________________________________
This one helps on inquiring if a determinate intent is
supported by an opened profile. You must give a handle to
profile, the intent and a third parameter specifying how the
profile would be used. The function does return TRUE if intent
is supported or FALSE if not. If the intent is not supported,
lcms will use default intent (usually perceptual).
Parameters:
hProfile: Handle to an open profile
Intent: one of the following values:
INTENT_PERCEPTUAL 0
INTENT_RELATIVE_COLORIMETRIC 1
INTENT_SATURATION 2
INTENT_ABSOLUTE_COLORIMETRIC 3
Direction:
LCMS_USED_AS_INPUT 0
LCMS_USED_AS_OUTPUT 1
LCMS_USED_AS_PROOF 2
Returns:
TRUE if intent is supported or FALSE if not.
If the intent is not supported, lcms will use default
intent (usually perceptual).
_________________________________________________________________________________
LCMSBOOL cmsTakeCharTargetData(cmsHPROFILE hProfile, char** Data, size_t* len);
_________________________________________________________________________________
Retrieves the target data the profiler has used to build the profile. Usage
of this tag is optional. The lprof profiles does store such information when
"verbose" mode is selected.
Parameters:
hProfile: Handle to an open profile
Data: Pointer to a pointer to a bite block. This function allocates
this block by calling malloc(). User is responsible of free it after
use.
size: Pointer to a size_t variable holding the size of datablock.
Returns:
TRUE on success, FALSE on error or if the profile has not such tag.
Example:
char* TargetData;
size_t len;
cmsTakeCharTargetData(hProfile, &Data, &len);
... do whatsever with Data...
free(Data);
_________________________________________________________________________________
const LPBYTE cmsTakeProfileID(cmsHPROFILE hProfile);
_________________________________________________________________________________
Returns the 16-bytes profile ID (version 4 only). The ProfileID is holded in
a static buffer overwritten in each call to this function.
Parameters:
hProfile: Handle to an open profile
Returns:
A pointer to a static buffer holding the 16 bytes ID. This buffer
is overwritten in each function call.
_________________________________________________________________________________
LCMSBOOL _cmsIsMatrixShaper(cmsHPROFILE hProfile);
_________________________________________________________________________________
Tests whatever a particular profile is implemented as Matrix-shaper-
Parameters:
hProfile: Handle to an open profile
Returns:
TRUE or FALSE about profile being implemented as matrix-shaper
_________________________________________________________________________________
void cmsSetAlarmCodes(int r, int g, int b)
_________________________________________________________________________________
Used to establish the out-of-gamut alarm color. This color will
replace all out-of-gamut colors if sFLAGS_GAMUTCHEK is used in
dwFlags parameter. See cmsCreateTransform()
_________________________________________________________________________________
void _cmsSetLUTdepth(cmsHPROFILE hProfile, int depth);
_________________________________________________________________________________
INTERNAL, USE WITH CAUTION.
Used to inform the profile writting logic that all LUTS should be written
in 8-bit resolution. lcms currently allows to write profiles with same
resolution in all LUTS. Incoming versions may fix that.
Parameters:
hProfile: Handle to an open profile
depth: either 8 or 16
_________________________________________________________________________________
LCMSBOOL _cmsSaveProfile(cmsHPROFILE hProfile, const char* FileName);
LCMSBOOL _cmsSaveProfileToMem(cmsHPROFILE hProfile, void *MemPtr, size_t* BytesNeeded);
_________________________________________________________________________________
INTERNAL, USE WITH CAUTION.
Dumps the contents of a profile FULLY GENERATED BY USING VIRTUAL PROFILES to disk
or memory. Disk based profiles are not suitable for these functions.
DEPRECATED, use cmsOpenProfileFromFile() with a "w" as access mode instead.
_________________________________________________________________________________
3 - On-the-fly (virtual) profile creation functions
_________________________________________________________________________________
These function gives the ability of create virtual profiles.
These profiles are often used in modelling monitors, but can
also be used as any input or output device. Once created, you
can use the profile handle like another file-based profile.
_________________________________________________________________________________
cmsHPROFILE cmsCreateGrayProfile(LPcmsCIExyY WhitePoint,
LPGAMMATABLE TransferFunction)
_________________________________________________________________________________
Creates a grayscale virtual profile based on white point and transfer tables.
Parameters:
White point: You can specify chromacity of white point,
or use cmsWhitePointFromTemp() to generate
the white point from temperature.
Gamma tables: You can directly specify tables or use the
gamma handling functions for obtaining these
tables
_________________________________________________________________________________
cmsHPROFILE cmsCreateRGBProfile(LPcmsCIExyY WhitePoint,
LPcmsCIExyYTRIPLE Primaries,
LPGAMMATABLE TransferFunction[3])
_________________________________________________________________________________
Creates a virtual profile based in primaries, white point and
transfer tables.
Parameters:
White point: You can specify chromacity of white point,
or use cmsWhitePointFromTemp() to generate
the white point from temperature.
Primaries: The primaries (the TRUE primaries, not the
colorants) of the device.
Gamma tables: You can directly specify tables or use the
gamma handling functions for obtaining these
tables
_________________________________________________________________________________
cmsHPROFILE cmsCreateLinearizationDeviceLink(icColorSpaceSignature ColorSpace,
LPGAMMATABLE TransferFunctions[]);
_________________________________________________________________________________
Creates a specialized devicelink, operating in space "ColorSpace". This devicelink
has only linearization tables. Usefull for embedding gamma/brightness/contrast controls
in a multiprofile transform.
TransferFunctions[] must contain as many curves as components has the target
color space. For example, RGB must be 3 curves. CMYK needs 4 curves.
_________________________________________________________________________________
cmsHPROFILE LCMSEXPORT cmsCreateInkLimitingDeviceLink(icColorSpaceSignature ColorSpace,
double Limit)
_________________________________________________________________________________
Creates a specialized devicelink, operating in space "ColorSpace". This devicelink
handles ink-limiting feature. Useful for RIP construction and other goodies
Parameters:
hTransform: A handle to the transform.
Limit: The amount of ink-limit, in pertentage. Allowable values are from 0% to 400%
Notes:
Currently only works on CMYK, but Hexachrome support is expected in
future revisions.
_________________________________________________________________________________
cmsHPROFILE cmsCreateBCHSWabstractProfile(int nLUTPoints,
double Bright,
double Contrast,
double Hue,
double Saturation,
int TempSrc,
int TempDest);
_________________________________________________________________________________
Creates a abstract devicelink operating in Lab for Bright/Contrast/Hue/Saturation
and white point translation. White points are specified as temperatures ºK
Parameters:
int nLUTPoints : Resulting CLUT resolution
double Bright : Bright increment. May be negative
double Contrast : Contrast increment. May be negative.
double Hue : Hue displacement in degree.
double Saturation : Saturation increment. May be negative
int TempSrc : Source white point temperature
int TempDest : Destination white point temperature.
Renges:
Bright:
_________________________________________________________________________________
4 - Built-In profiles
_________________________________________________________________________________
These are standard profiles optimized for speed.
_________________________________________________________________________________
cmsHPROFILE cmsCreateLabProfile(LPcmsCIExyY WhitePoint);
_________________________________________________________________________________
Creates a virtual profile of CIE Lab. If WhitePoint is NULL,
then D50 is assumed. It uses v2 PCS encoding.
_________________________________________________________________________________
cmsHPROFILE cmsCreateLab4Profile(LPcmsCIExyY WhitePoint);
_________________________________________________________________________________
Creates a virtual profile of CIE Lab operanting in v4 PCS encoding.
If WhitePoint is NULL, then D50 is assumed.
_________________________________________________________________________________
cmsHPROFILE cmsCreateXYZProfile(void);
_________________________________________________________________________________
Creates a virtual XYZ profile (Assumes D50)
_________________________________________________________________________________
cmsHPROFILE cmsCreate_sRGBProfile(void);
_________________________________________________________________________________
Creates a virtual profile of sRGB standard colorspace.
_________________________________________________________________________________
5 - White point
_________________________________________________________________________________
_________________________________________________________________________________
LCMSBOOL cmsWhitePointFromTemp(int TempK, LPcmsCIExyY WhitePoint);
_________________________________________________________________________________
Obtains the chromaticity of white point based on temperature §K
Parameters:
TempK: Temperature in §K
Returns:
FALSE on error, TRUE on success
_________________________________________________________________________________
LCMSAPI LCMSBOOL LCMSEXPORT cmsAdaptToIlluminant(LPcmsCIEXYZ Result,
LPcmsCIEXYZ SourceWhitePt,
LPcmsCIEXYZ Illuminant,
LPcmsCIEXYZ Value);
_________________________________________________________________________________
Provides a model-dependent chromatic adaptation between two illuminants,
actually it uses a Von-Kries approximation of Bradford, using the Lam-Rigg
cone responses. It Is under consideration to be replaced for a more
proper model like CIECAM97s in futures versions.
Parameters:
Result: Points to resulting XYZ color
SourceWhitePoint: original white point
Illuminant: adapting illuminant
Value: the original color
Returns:
FALSE on error, TRUE on success
_________________________________________________________________________________
double cmsSetAdaptationState(double d);
_________________________________________________________________________________
Specifies adaptation state of observer for V4 absolute colorimetric transforms.
Only two values are implemented:
d = 0: No adaptation
d = 1: Observer is fully adapted
_________________________________________________________________________________
6 - Gamma handling functions
_________________________________________________________________________________
This is the struct of a gamma table (or transfer function)
typedef struct {
int nEntries;
WORD GammaTable[1];
} GAMMATABLE, FAR* LPGAMMATABLE;
That is, first it comes a 32 integer for entry count, followed of
a variable number of words describing the table. The easiest way to
generate a gamma table is to use the following function
_________________________________________________________________________________
LPGAMMATABLE cmsBuildGamma(int nEntries, double Gamma);
_________________________________________________________________________________
Allocates an fill a table describing generic gamma.
You must specify the number of entries your table will consist of,
and the float value for gamma.
_________________________________________________________________________________
LPGAMMATABLE cmsBuildParametricGamma(int nEntries, int Type, double Params[]);
_________________________________________________________________________________
Does build a parametric curve based on parameters.
Params[] does contain Gamma, a, b, c, d, e, f
Type 1 :
X = Y ^ Gamma | Gamma = Params[0]
Type 2 :
CIE 122-1966
Y = (aX + b)^Gamma | X >= -b/a
Y = 0 | else
Type 3:
IEC 61966-3
Y = (aX + b)^Gamma | X <= -b/a
Y = c | else
Type 4:
IEC 61966-2.1 (sRGB)
Y = (aX + b)^Gamma | X >= d
Y = cX | X < d
Type 5:
Y = (aX + b)^Gamma + e | X <= d
Y = cX + f | else
Giving negative values for Type does result in reversed curve.
_________________________________________________________________________________
LPGAMMATABLE cmsAllocGamma(int nEntries);
_________________________________________________________________________________
Allocates space for a gamma table, memory is unitialized.
_________________________________________________________________________________
void cmsFreeGamma(LPGAMMATABLE Gamma);
_________________________________________________________________________________
Frees a gamma table
_________________________________________________________________________________
LPGAMMATABLE cmsReverseGamma(int nResultSamples, LPGAMMATABLE InGamma);
_________________________________________________________________________________
Reverses a gamma table resampling it in a new table.
This function reverses the gamma table if it can be done. lcms does not
detect whatever a non-monotonic function is given, so wrong input can
result in ugly results: not to be a problem since "normal" gamma curves
are not collapsing inputs at same output value. The new curve will be
resampled to nResultSamples entries.
_________________________________________________________________________________
LPGAMMATABLE cmsJoinGamma(LPGAMMATABLE InGamma, LPGAMMATABLE OutGamma);
_________________________________________________________________________________
Obtains a table joining two tables, one as input and other as
output. Output table is reversed and then composited with input gamma.
This will let you to "refine" the generic gamma for monitors (2.1 or 2.2
are usual values) to match viewing conditions of more or less background
light. Note that this function uses TABULATED functions, so very exotic
curves can be obtained by combining transfer functions with reversed
gamma curves. Normally there is no need of worry about such gamma
manipulations, but the functionality is here if you wish to use.
_________________________________________________________________________________
LCMSBOOL cmsSmoothGamma(LPGAMMATABLE Tab, double lambda);
_________________________________________________________________________________
Does smooth the curve contained into Tab. Smooth curves does work better
and more pleasant to eye.
Parameters:
Tab: Table to be smoothed
lambda: The smoothing factor. 0..500 is the working range.
Returns:
TRUE on success. FALSE on error
_________________________________________________________________________________
double cmsEstimateGamma(LPGAMMATABLE t);
double cmsEstimateGammaEx(LPWORD Table, int nEntries, double Thereshold);
_________________________________________________________________________________
Returns a numerical estimation of the apparent gamma on the given table.
_________________________________________________________________________________
LPGAMMATABLE cmsReadICCGamma(cmsHPROFILE hProfile, icTagSignature sig);
LPGAMMATABLE cmsReadICCGammaReversed(cmsHPROFILE hProfile, icTagSignature sig);
int cmsReadICCText(cmsHPROFILE hProfile, icTagSignature sig, char *Text);
int cmsReadICCTextEx(cmsHPROFILE hProfile, icTagSignature sig, char *Text, size_t size);
_________________________________________________________________________________
_________________________________________________________________________________
LPcmsSEQ cmsReadProfileSequenceDescription(cmsHPROFILE hProfile);
void cmsFreeProfileSequenceDescription(LPcmsSEQ pseq);
_________________________________________________________________________________
Reads and free profile sequence description structure
_________________________________________________________________________________
void cmsSetUserFormatters(cmsHTRANSFORM hTransform, DWORD dwInput, cmsFORMATTER Input,
DWORD dwOutput, cmsFORMATTER Output);
void cmsGetUserFormatters(cmsHTRANSFORM hTransform,
LPDWORD InputFormat, cmsFORMATTER* Input,
LPDWORD OutputFormat, cmsFORMATTER* Output);
_________________________________________________________________________________
_________________________________________________________________________________
7 - Error handling
_________________________________________________________________________________
_________________________________________________________________________________
void cmsErrorAction(int nAction)
_________________________________________________________________________________
Tells lcms how to react if an error is raised.
Parameters:
nAction: can be one of these:
LCMS_ERROR_ABORT Aborts whole application
LCMS_ERROR_SHOW Displays a message, but does not abort application
LCMS_ERROR_IGNORE Does not show any message, however, operation is aborted.
_________________________________________________________________________________
void cmsSignalError(int ErrorCode, const char *ErrorText, ...)
_________________________________________________________________________________
This is the default error handler. If you are using lcms as a
static library, you can replace it by one of your own.
Parameters:
ErrorCode: a number for coding error (with not meaning by now)
ErrorText: a format specifier describing the error
... : additional parameters needed by ErrorText, in a printf like fashion.
_________________________________________________________________________________
void cmsSetErrorHandler(cmsErrorHandlerFunction Fn);
_________________________________________________________________________________
This function sets an user-defined error handler. The error handler must be
defined as:
int ErrorHandlerFunction(int ErrorCode, const char *ErrorText);
ErrorCode can be one of the following values:
LCMS_ERRC_WARNING 0x1000
LCMS_ERRC_RECOVERABLE 0x2000
LCMS_ERRC_ABORTED 0x3000
ErrorText is a text holding an english description of error.
_________________________________________________________________________________
8 - Conversion functions
_________________________________________________________________________________
These functions can be used to convert from several colorimetric spaces
and to/from fixed encoding in spaces XYZ and Lab used by profiles.
_________________________________________________________________________________
LCMSAPI void LCMSEXPORT cmsXYZ2xyY(LPcmsCIExyY Dest,
CONST LPcmsCIEXYZ Source);
LCMSAPI void LCMSEXPORT cmsxyY2XYZ(LPcmsCIEXYZ Dest,
CONST LPcmsCIExyY Source);
_________________________________________________________________________________
Does convert form/to XYZ Color Space to xyY color space
Parameters:
Dest, Source: points to vectors to convert
_________________________________________________________________________________
void cmsXYZ2Lab(LPcmsCIEXYZ WhitePoint, LPcmsCIELab Lab, const LPcmsCIEXYZ xyz);
void cmsLab2XYZ(LPcmsCIEXYZ WhitePoint, LPcmsCIEXYZ xyz, const LPcmsCIELab Lab);
_________________________________________________________________________________
Does convert from/to XYZ Color Space to CIE L a* b* Color Space
Parameters:
xyz, Lab : Pointers to values
WhitePoint: Pointer to media white. If NULL, the D50 is assumed.
_________________________________________________________________________________
void cmsLabEncoded2Float(LPcmsCIELab Lab, const WORD wLab[3]);
void cmsFloat2LabEncoded(WORD wLab[3], const LPcmsCIELab Lab);
_________________________________________________________________________________
Does convert form/to the encoded notation of Lab pcs to floating point.
Parameters:
wLab, Lab : Pointers to values
_________________________________________________________________________________
void cmsXYZEncoded2Float(LPcmsCIEXYZ fxyz, const WORD XYZ[3]);
void cmsFloat2XYZEncoded(WORD XYZ[3], const LPcmsCIEXYZ fXYZ);
_________________________________________________________________________________
Does convert form/to the encoded notation of XYZ pcs to floating point.
Parameters:
fxyz, XYZ : Pointers to values
_________________________________________________________________________________
void cmsLab2LCh(LPcmsCIELCh LCh, const LPcmsCIELab Lab);
void cmsLCh2Lab(LPcmsCIELab Lab, const LPcmsCIELCh LCh);
_________________________________________________________________________________
Does convert between polar/rectangulat form of CIE L*a*b*
L = L
C = sqrt(a*a+b*b)
h = atan(b/a)
Where C=colorfulness and h=hue.
Parameters:
Lab, LCh : Pointers to values
_________________________________________________________________________________
double cmsDeltaE(LPcmsCIELab Lab1, LPcmsCIELab Lab2);
_________________________________________________________________________________
Computes the dE between two Lab values. The formula is
dE = sqrt (dL^2 + da^2 + db^2)
Parameters:
Lab1, Lab2: Points to the Lab values.
Returns:
The dE. If any Lab is negative, or with L>100 it returns 65535.
_________________________________________________________________________________
double cmsCIE94DeltaE(LPcmsCIELab Lab1, LPcmsCIELab Lab2);
double cmsBFDdeltaE(LPcmsCIELab Lab1, LPcmsCIELab Lab2);
double cmsCMCdeltaE(LPcmsCIELab Lab1, LPcmsCIELab Lab2);
double cmsCIE2000DeltaE(LPcmsCIELab Lab1, LPcmsCIELab Lab2, double Kl, double Kc, double Kh);
_________________________________________________________________________________
Several additional error measurement systems.
_________________________________________________________________________________
void cmsClampLab(LPcmsCIELab Lab, double amax, double amin, double bmax, double bmin);
_________________________________________________________________________________
Clamps carefully a Lab value, keeping hue constant.
L is unchanged and not used. The gamut boundaries are given
by the rectangle (amin, bmin) - (amax, bmax)
if Lab value is inside gamut, this function don't touch anything, if outside,
converts to LCh, and keeping h constant, reduce C until inside gamut.
_________________________________________________________________________________
LCMSAPI icColorSpaceSignature LCMSEXPORT _cmsICCcolorSpace(int OurNotation);
LCMSAPI int LCMSEXPORT _cmsLCMScolorSpace(icColorSpaceSignature ProfileSpace);
LCMSAPI int LCMSEXPORT _cmsChannelsOf(icColorSpaceSignature ColorSpace);
_________________________________________________________________________________
_________________________________________________________________________________
9 - CIECAM97s/CIECAM02
_________________________________________________________________________________
The model input data are the adapting field luminance in cd/m2
(normally taken to be 20% of the luminance of white in the adapting field),
La , the relative tristimulus values of the stimulus, XYZ, the relative
tristimulus values of white in the same viewing conditions, "whitePoint",
and the relative luminance of the background, Yb . Relative tristimulus
values should be expressed on a scale from Y = 0 for a perfect black
to Y = 100 for a perfect reflecting diffuser.
All CIE tristimulus values are obtained using the CIE 1931 Standard
Colorimetric Observer (2°).
typedef struct {
cmsCIEXYZ whitePoint; // The media white in XYZ
double Yb;
double La;
int surround;
double D_value;
} cmsViewingConditions, FAR* LPcmsViewingConditions;
surround can be one of these
#define AVG_SURROUND 1
#define DIM_SURROUND 2
#define DARK_SURROUND 3
D_value (adaptation degree) is any value between 0 and 1, and additionally:
#define D_CALCULATE (-1) // Calculate D
#define D_CALCULATE_DISCOUNT (-2) // Calculate w/ partial discounting
_________________________________________________________________________________
HANDLE cmsCIECAM97sInit(LPcmsViewingConditions pVC)/cmsCIECAM02Init
_________________________________________________________________________________
Does init the model. It returns a handle for further reference
Parameters:
pVC: points to a cmsViewingConditions struct holding viewing condition
parameters
Returns:
A handle to a model instance, or NULL if error.
_________________________________________________________________________________
void cmsCIECAM97sDone(HANDLE hModel)/cmsCIECAM02Done
_________________________________________________________________________________
Terminates a model
Parameters:
hModel: A handle to the model instance to terminate.
_________________________________________________________________________________
void cmsCIECAM97sForward(HANDLE hModel, LPcmsCIEXYZ pIn, LPcmsJCh pOut)/
cmsCIECAM02Forward
_________________________________________________________________________________
Model forward. Transforms from XYZ to JCh.
Parameters:
hModel: A handle to the model instance
pIn, POut: Pointers to values
_________________________________________________________________________________
void cmsCIECAM97sReverse(HANDLE hModel, LPcmsJCh pIn, LPcmsCIEXYZ pOut)/
cmsCIECAM02Reverse
_________________________________________________________________________________
Model reverse. Transforms from JCh to XYZ.
Parameters:
hModel: A handle to the model instance
pIn, POut: Pointers to values
_________________________________________________________________________________
10 - Profile creation functions
_________________________________________________________________________________
_________________________________________________________________________________
void cmsSetDeviceClass(cmsHPROFILE hProfile, icProfileClassSignature sig);
_________________________________________________________________________________
Does set device class signature in profile header
_________________________________________________________________________________
void cmsSetColorSpace(cmsHPROFILE hProfile, icColorSpaceSignature sig);
_________________________________________________________________________________
Does set colorspace signaure in profile header
_________________________________________________________________________________
void cmsSetPCS(cmsHPROFILE hProfile, icColorSpaceSignature pcs);
_________________________________________________________________________________
Does set PCS signature in profile header
_________________________________________________________________________________
void cmsSetRenderingIntent(cmsHPROFILE hProfile, int RenderingIntent);
_________________________________________________________________________________
Sets the rendering intent in profile header
_________________________________________________________________________________
void cmsSetProfileID(cmsHPROFILE hProfile, LPBYTE ProfileID);
_________________________________________________________________________________
Sets the profile ID in profile header (ver 4 only)
_________________________________________________________________________________
void cmsSetHeaderFlags(cmsSetHeaderFlags(cmsHPROFILE hProfile, DWORD Flags)
_________________________________________________________________________________
Does set flags in profile header
_________________________________________________________________________________
void cmsSetHeaderAttributes(cmsSetHeaderFlags(cmsHPROFILE hProfile, DWORD Flags)
_________________________________________________________________________________
Does set attribute flags in profile header
_________________________________________________________________________________
LCMSBOOL cmsAddTag(cmsHPROFILE hProfile, icTagSignature sig, void* data);
_________________________________________________________________________________
Adds a new tag to a profile. Supported tags are:
Signature Expected data type
================= ==================
icSigCharTargetTag const char*
icSigCopyrightTag const char*
icSigProfileDescriptionTag const char*
icSigDeviceMfgDescTag const char*
icSigDeviceModelDescTag const char*
icSigRedColorantTag LPcmsCIEXYZ
icSigGreenColorantTag LPcmsCIEXYZ
icSigBlueColorantTag LPcmsCIEXYZ
icSigMediaWhitePointTag LPcmsCIEXYZ
icSigMediaBlackPointTag LPcmsCIEXYZ
icSigRedTRCTag LPGAMMATABLE
icSigGreenTRCTag LPGAMMATABLE
icSigBlueTRCTag LPGAMMATABLE
icSigGrayTRCTag LPGAMMATABLE
icSigAToB0Tag LPLUT
icSigAToB1Tag LPLUT
icSigAToB2Tag LPLUT
icSigBToA0Tag LPLUT
icSigBToA1Tag LPLUT
icSigBToA2Tag LPLUT
icSigGamutTag LPLUT
icSigPreview0Tag LPLUT
icSigPreview1Tag LPLUT
icSigPreview2Tag LPLUT
icSigChromaticityTag LPcmsCIExyYTRIPLE
icSigNamedColor2Tag LPcmsNAMEDCOLORLIST
icSigColorantTableTag LPcmsNAMEDCOLORLIST
icSigColorantTableOutTag LPcmsNAMEDCOLORLIST
icSigCalibrationDateTimeTag const struct tm*
_________________________________________________________________________________
11 - LUT manipulation
_________________________________________________________________________________
This is the pipeline LUT is implementing
[Mat] -> [L1] -> [Mat3] -> [Ofs3] -> [L3]
-> [CLUT] -> [L4] -> [Mat4] -> [Ofs4] -> [L2]
_________________________________________________________________________________
LPLUT cmsAllocLUT(void);
_________________________________________________________________________________
Does allocate an empty LUT. Input is passed transparently to output by default
Returns:
A handle to a new LUT, or NULL if error.
_________________________________________________________________________________
LPLUT cmsDupLUT(LPLUT Orig);
_________________________________________________________________________________
Duplicates a LUT.
Returns:
A handle to a new LUT, or NULL if error.
_________________________________________________________________________________
LPLUT cmsAllocLinearTable(LPLUT NewLUT, LPGAMMATABLE Tables[], int nTable);
_________________________________________________________________________________
Does include a prelinearization tables set into a LUT
Parameters:
NewLUT: The target LUT
Tables[]: A set of tables to be set
nTable: Identificates the position of tables in pipeline
1 - Prelinearization
2 - Postlinearization
3 - L3
4 - L4
Values 3 and 4 are reserved for v4 profiles
_________________________________________________________________________________
LPLUT cmsAlloc3DGrid(LPLUT Lut, int clutPoints, int inputChan, int outputChan);
_________________________________________________________________________________
Allocates an empty 3D CLUT table.
Parameters:
Lut: The target LUT
clutPoints: The points number of a side of the (hyper)cube
inputChan, outputChan: The channels count
Returns:
A handle to the LUT, or NULL if error.
_________________________________________________________________________________
void cmsFreeLUT(LPLUT Lut);
_________________________________________________________________________________
Free any used memory. After this call the LUT is not longer valid
Parameters:
Lut: The target LUT
_________________________________________________________________________________
void cmsEvalLUT(LPLUT Lut, WORD In[], WORD Out[]);
_________________________________________________________________________________
Evaluates a LUT, giving In[] values. Returns Out[] values.
Parameters:
Lut: The target LUT
In: Input Values
Out: Output Values
_________________________________________________________________________________
LPLUT cmsSetMatrixLUT(LPLUT Lut, LPMAT3 M);
_________________________________________________________________________________
Provided for backwards compatibility sake. Sets the 'Mat' Matrix in the LUT pipeline
_________________________________________________________________________________
LPLUT cmsSetMatrixLUT4(LPLUT Lut, LPMAT3 M, LPVEC3 off, DWORD dwFlags);
_________________________________________________________________________________
Set a matrix in V4 style. Flags defines the location in the LUT pipeline:
LUT_HASMATRIX: Mat
LUT_HASMATRIX3: Mat3
LUT_HASMATRIX4: Mat4
_________________________________________________________________________________
LPLUT cmsReadICCLut(cmsHPROFILE hProfile, icTagSignature sig);
_________________________________________________________________________________
Does retrive a LUT from a profile handle.
Parameters:
hProfile: a handle to a open profile
sig: The tag signature
Returns:
A pointer to newly created LUT on success
NULL on error
_________________________________________________________________________________
int cmsSample3DGrid(LPLUT Lut,
_cmsSAMPLER Sampler,
LPVOID Cargo, DWORD dwFlags);
_________________________________________________________________________________
Builds the CLUT table by calling repeatly a supplied callback function
typedef int (* _cmsSAMPLER)(register WORD In[],
register WORD Out[],
register LPVOID Cargo);
The programmer has to write a callback function. This function
should calculate Out values given a In[] set. For example, if we
want a LUT to invert channels, a sampler could be:
int InvertSampler(register WORD In[],
register WORD Out[],
register LPVOID Cargo)
{
for (i=0; i < 3; i++)
Out[i] = ~ In[i];
return 0;
}
cmsSample3DGrid does call this function to build the CLUT.
Pre/post linearization tables may be taken into account across
flags parameter
Flags Meaning
================ =======================================
LUT_HASTL1 Do reverse linear interpolation on
prelinearization table before calling
the callback.
LUT_HASTL2 Do reverse linear interpolation on
postlinearization table after calling
the callback.
Flags are intended as an aid for building non-uniformly spaced
CLUTs. Using flags results in "undoing" any linearization tables
could apply. In such way, the programmer is expected to have in
In[] always the original colorspace, and must return Out[] values
always in original (non-postlinearized) space as well.
The callback must return 0 if all is ok, or any other value
to indicate error. If error condition is raised, whole CLUT
construction is aborted.
Parameters:
Lut: a pointer to LUT structure
Sampler: The callback function
Cargo: A 32-bit value. Could be used as pointer to pass
parameters to callback.
dwFlags: any combination of LUT_HASTL1 or LUT_HASTL2
joined by bitwise-or operator '|'
_________________________________________________________________________________
12 - Named color functions
_________________________________________________________________________________
Named color profiles are a special kind of profiles handling lists of spot
colors. The typical example is PANTONE. CMM deals with named color profiles like
all other types, except they must be in input stage and the encoding supported
is limited to a one single channel of 16-bit indexes.
Let's assume we have a Named color profile holding only 4 colors:
· CYAN
· MAGENTA
· YELLOW
· BLACK
We create a transform using:
hTransform = cmsCreateColorTransform(hNamedColorProfile,
TYPE_NAMED_COLOR_INDEX,
hOutputProfile,
TYPE_BGR_8,
INTENT_PERCEPTUAL, 0);
"TYPE_NAMED_COLOR_INDEX" is a special encoding for these profiles, it
represents a single channel holding the spot color index. In our case
value 0 will be "CYAN", value 1 "MAGENTA" and so one.
For converting between string and index there is an auxiliary function:
int cmsNamedColorIndex(cmsHTRANSFORM hTransform, const char* ColorName);
That will perform a look up on the spot colors database and return the color
number or -1 if the color was not found. Other additional functions for named
color transforms are:
int cmsNamedColorCount(cmsHTRANSFORM hTransform);
That returns the number of colors present on transform database.
int cmsNamedColorInfo(cmsHTRANSFORM hTransform,
int nColor, LPNAMEDCOLORINFO Info);
That returns extended information about a given color. Named color profiles
can also be grouped by using multiprofile transforms. In such case, the database
will be formed by the union of all colors in all named color profiles present in
transform.
Named color profiles does hold two coordinates for each color, let's
take our PANTONE example. This profile would contain for each color
the CMYK colorants plus its PCS coordinates, usually in Lab space.
lcms can work with named color using both coordinates. Creating a
transform with two profiles, if the input one is a named color, then you
obtain the translated color using PCS.
Example, named color -> sRGB will give the color patches in sRGB
In the other hand, setting second profile to NULL, returns the device
coordinates, that is, CMYK colorants in our PANTONE sample.
Example: Named color -> NULL will give the CMYK amount for each spot color.
The transform must use TYPE_NAMED_COLOR_INDEX on input. That is, a single
channel containing the 0-based color index.
Then you have:
cmsNamedColorIndex(cmsHTRANSFORM xform, const char* Name)
for obtaining index from color name, and
cmsNamedColorInfo(), cmsNamedColorCount() to retrieve the list.
The profile is supposed to be for a unique device. Then the CMYK
values does represent the amount of inks THIS PRINTER needs to render
the spot color. The profile also has the Lab values corresponding to
the color. This really would have no sense if gamut of printer were
infinite, but since printers does have a limited gamut a PANTONE-certified
printer renders colors near gamut boundaries with some limitations.
The named color profile is somehow explaining which are these limitation
for that printer.
So, you can use a named color profile in two different ways, as output,
giving the index and getting the CMYK values or as input and getting the
Lab for that color.
A transform named color -> NULL will give the CMYK values for the spot
color on the printer the profile is describing. This would be the normal usage.
A transform Named color -> another printer will give on the output printer
the spot colors as if they were printed in the printer named color profile
is describing. This is useful for soft proofing.
As an additional feature, lcms can "group" several named color profiles
into a single database by means of cmsCreateMultiprofileTransform().
Such case works as described above, but joining all named colors as they
were in a single profile.
_________________________________________________________________________________
13. PostScript generation
_________________________________________________________________________________
3 functions carry the task of obtaining CRD and CSA.
DWORD cmsGetPostScriptCSA(cmsHPROFILE hProfile, int Intent, LPVOID Buffer, DWORD dwBufferLen);
DWORD cmsGetPostScriptCRD(cmsHPROFILE hProfile, int Intent, LPVOID Buffer, DWORD dwBufferLen);
DWORD cmsGetPostScriptCRDEx(cmsHPROFILE hProfile, int Intent, DWORD dwFlags, LPVOID Buffer, DWORD dwBufferLen);
cmsGetPostScriptCRDEx allows black point compensation using
cmsFLAGS_BLACKPOINTCOMPENSATION in flags field.
PostScrip colorflow is often done in a different way. Insted of creating a
transform, it is sometimes desirable to delegate the color management to
PostScript interpreter. These functions does translate input and output
profiles into Color Space Arrays (CSA) and Color Rendering Dictionaries (CRD)
· CRD are equivalent to output (printer) profiles. Can be
loaded into printer at startup and can be stored as resources.
· CSA are equivalent to input and workspace profiles, and are
intended to be included in the document definition.
These functions does generate the PostScript equivalents. Since the lenght of
the resultant PostScript code is unknown in advance, you can call the
functions with len=0 and Buffer=NULL to get the lenght. After that, you need
to allocate enough memory to contain the whole block
Example:
Size = cmsGetPostScriptCSA(hProfile, INTENT_PERCEPTUAL, NULL, 0);
If (Size == 0) error()
Block = malloc(Size);
cmsGetPostScriptCSA(hProfile, INTENT_PERCEPTUAL, Block, Size);
Devicelink profiles are supported, as long as input colorspace matches
Lab/XYZ for CSA or output colorspace matches Lab/XYZ for CRD. This can
be used in conjuntion with cmsCreateMultiprofileTransform(),
and cmsTransform2DeviceLink() to embed complex color flow into PostScript.
WARNING: Preccision of PostScript is limited to 8 bits per sample. If you
can choose between normal transforms and CSA/CRD, normal transforms will
give more accurancy. However, there are situations where there is no
chance.
_________________________________________________________________________________
14 - CGATS.13 - 200
_________________________________________________________________________________
This standard defines an exchange format for spectral measurement data,
colorimetric data, and densitometric data in electronic form using
keywords and data tables. It maintains human readability of the data as
well as enabling machine readability. It includes a series of predefined
keywords and data format identifiers and makes provision for the dynamic
definition of additional keywords and data format identifiers as
necessary.
It was prepared by CGATS/SC3 in an effort to consolidate the common format
requirements for the exchange of spectral measurement data, colorimetric
data, and densitometric data in electronic form.
These requirements presently appear in a number of CGATS and IT8 standards
such as CGAT S.5, IT8.7/1, IT8.7/2, and IT8.7/3. While it is the intent that
each of these individual standards will continue to identify required data,
the basic data format and keywords and data identifier s will be defined in
this standard for consistent use across all applicable standards.
The Committee for Graphic Arts Technologies Standards (CGATS) was accredited
by the American National Standards Institute in 1989 to serve as the
coordinator of graphic arts standards activities.
CGATS recommends the adoption and use of this standard by the graphic
arts industry and its suppliers at their earliest convenience.
lcms parser has following additions:
.INCLUDE directive
------------------
Works like #include in C language.
LABEL special keyword
---------------------
_________________________________________________________________________________
LCMSHANDLE cmsIT8Alloc(void);
_________________________________________________________________________________
Does allocate an empty CGATS.13/IT8 object. Mostly used for creating new IT8 files
Returns:
A handle to a CGATS.13, or NULL if error.
_________________________________________________________________________________
void cmsIT8Free(LCMSHANDLE hIT8);
_________________________________________________________________________________
Free any used memory. After this call the IT8 parser is not longer valid
Parameters:
hIT8: The CGATS.13 parser handle
_________________________________________________________________________________
Tables
_________________________________________________________________________________
In the lcms implementation, a CGATS.13/IT8 object may contain any number of
tables. Tables are separated by END_DATA keyword.
_________________________________________________________________________________
int cmsIT8TableCount(LCMSHANDLE hIT8);
_________________________________________________________________________________
Returns the number of tables the CGATS.13/IT8 object contains.
Parameters:
hIT8: The CGATS.13 parser handle
_________________________________________________________________________________
int cmsIT8SetTable(LCMSHANDLE hIT8, int nTable);
_________________________________________________________________________________
Sets the current table on a given CGATS.13/IT8 object
Parameters:
hIT8: The CGATS.13 parser handle
nTable: The table number (0 based)
Returns:
the number of tables the CGATS.13/IT8 object contains.
Comments:
Setting nTable to TableCount + 1 does allocate a new empty table
_________________________________________________________________________________
Persistence
_________________________________________________________________________________
These are functions to load/save CGATS.13/IT8 objects from file and memory stream.
_________________________________________________________________________________
LCMSHANDLE cmsIT8LoadFromFile(const char* cFileName);
_________________________________________________________________________________
Does allocate an CGATS.13/IT8 object and fills it with the contents of cFileName.
Mostly used for reading existing IT8 files.
Parameters:
cFileName: The IT8/CGATS.13 file name to read/parse
Returns:
A handle to a CGATS.13, or NULL if error.
_________________________________________________________________________________
LCMSHANDLE cmsIT8LoadFromMem(void *Ptr, size_t len);
_________________________________________________________________________________
Same as anterior, but the IT8/CGATS.13 stream is readed from a memory block.
Parameters:
Ptr: Points to a block of contiguous memory containing the IT8/CGATS.13 stream.
len: IT8/CGATS.13 stream s size measured in bytes.
Returns:
NULL on error, a profile handle on success.
_________________________________________________________________________________
LCMSBOOL cmsIT8SaveToFile(LCMSHANDLE hIT8, const char* cFileName);
_________________________________________________________________________________
Saves a IT8/CGATS.13 object to a file.
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SaveToMem(LCMSHANDLE hIT8, void *MemPtr, size_t* BytesNeeded);
_________________________________________________________________________________
Saves a IT8/CGATS.13 object to a memory stream.
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
Type and comments
_________________________________________________________________________________
The sheet type is a identifier placed on the very first line of the IT8/CGATS.13
stream. It can be IT8.7/xx or whatever.
_________________________________________________________________________________
const char* cmsIT8GetSheetType(LCMSHANDLE hIT8);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetSheetType(LCMSHANDLE hIT8, const char* Type);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetComment(LCMSHANDLE hIT8, const char* cComment);
_________________________________________________________________________________
This function is intended to provide a way automated IT8 creators can embed comments
into file. Comments have no effect, and its only purpose is to document any of the
file meaning.
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
Properties
_________________________________________________________________________________
Properties are pairs <identifier> <value>. Each table may contain any number of
properties. Its primary purpose is store simpler settings.
_________________________________________________________________________________
LCMSBOOL cmsIT8SetPropertyStr(LCMSHANDLE hIT8, const char* cProp, const char *Str);
LCMSBOOL cmsIT8SetPropertyDbl(LCMSHANDLE hIT8, const char* cProp, double Val);
LCMSBOOL cmsIT8SetPropertyHex(LCMSHANDLE hIT8, const char* cProp, int Val);
LCMSBOOL cmsIT8SetPropertyUncooked(LCMSHANDLE hIT8, const char* Key, const char* Buffer);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
const char* cmsIT8GetProperty(LCMSHANDLE hIT8, const char* cProp);
double cmsIT8GetPropertyDbl(LCMSHANDLE hIT8, const char* cProp);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
int cmsIT8EnumProperties(LCMSHANDLE IT8, char ***PropertyNames);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
PropertyNames: A pointer to a variable which would recive a pointer to an
array of property name strings.
Returns:
_________________________________________________________________________________
Datasets
_________________________________________________________________________________
_________________________________________________________________________________
const char* cmsIT8GetDataRowCol(LCMSHANDLE IT8, int row, int col);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
double cmsIT8GetDataRowColDbl(LCMSHANDLE IT8, int row, int col);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetDataRowCol(LCMSHANDLE hIT8, int row, int col,
const char* Val);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetDataRowColDbl(LCMSHANDLE hIT8, int row, int col,
double Val);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
const char* cmsIT8GetData(LCMSHANDLE IT8, const char* cPatch,
const char* cSample);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
double cmsIT8GetDataDbl(LCMSHANDLE IT8, const char* cPatch,
const char* cSample);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetData(LCMSHANDLE IT8, const char* cPatch,
const char* cSample,
char *Val);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetDataDbl(LCMSHANDLE hIT8, const char* cPatch,
const char* cSample,
double Val);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
LCMSBOOL cmsIT8SetDataFormat(LCMSHANDLE IT8, int n, const char *Sample);
_________________________________________________________________________________
Parameters:
hIT8: The CGATS.13 parser handle
Returns:
_________________________________________________________________________________
int cmsIT8EnumDataFormat(LCMSHANDLE IT8, char ***SampleNames);
_________________________________________________________________________________
Returns an array with pointers to the column names of currect table.
Parameters:
hIT8: The CGATS.13 parser handle
SampleNames: A pointer to a variable of type char** which will hold the table.
Returns:
The number of column names in table.
_________________________________________________________________________________
const char* cmsIT8GetPatchName(LCMSHANDLE hIT8, int nPatch, char* buffer);
_________________________________________________________________________________
Fills buffer with the contents of SAMPLE_ID column for the set given in nPatch.
That usually corresponds to patch name.
Parameters:
hIT8: The CGATS.13 parser handle
nPatch : patch number to retreive name
buffer: A memory buffer to recivepatch name, or NULL to allow function to
allocate it own buffer.
Returns:
A pointer to the patch name, either the user-supplied buffer or an internal
memory block.
Copyright 2K16 - 2K18 Indonesian Hacker Rulez