Class CMYKColorSpace

  • All Implemented Interfaces:
    Serializable

    public class CMYKColorSpace
    extends ColorSpace

    A subclass of ColorSpace representing the uncalibrated (device-dependent) CMYK color space available in PDF documents.

    If colors need to be specified in CMYK, but device-independent color (the kind available with an ICC Profile) is not required, this ColorSpace should be used, as it doesn't require an ICC profile to be embedded in the PDF (resulting in a much smaller file). For some subsets of PDF (specifically PDF/X), RGB colors are not allowed, so anyone creating documents for that profile will probably make heavy use of this colorspace.

    Typically this class will be used as follows:

     Color cyan = CMYKColorSpace.getColor(1, 0, 0, 0);
     

    Conversion to/from RGB

    When rendering PDFs containing CMYK images or graphics to RGB, the characteristics of this space become important. The CMYKColorSpace prior to version 2.28.3 was suitable for conversion from CMYK to RGB, but not the reverse. As version 2.28.3 introduced a CMYK workflow, the default CMYK profile had to change too, and now defaults to a a fast approximation of the FOGRA39 perceptual intent, but this can be changed by setting the System property org.faceless.pdf2.DeviceCMYK to one of the following options:
    legacyThe generic CMYK profile used with the PDF Library prior to 2.28.3
    swopA fast approximation of US Web Coated (SWOP) v2
    fograA fast approximation of Coated FOGRA39 from ISO12647-2:2004
    See Also:
    Serialized Form
    • Field Detail

      • BLACK

        public static final Color BLACK
        A convenient constant that represents the color black in the uncalibrated CMYK colorspace
      • BLACK0

        public static final Color BLACK0
        A convenient constant that represents the color black in the uncalibated Grayscale colorspace
        Since:
        2.23.1
      • WHITE0

        public static final Color WHITE0
        A convenient constant that represents the color black in the uncalibated Grayscale colorspace
        Since:
        2.23.1
      • WHITE

        public static final Color WHITE
        A convenient constant that represents the color white in the uncalibrated CMYK colorspace
    • Method Detail

      • toRGB

        public float[] toRGB​(float[] cmyk)
        Specified by:
        toRGB in class ColorSpace
      • toCIEXYZ

        public float[] toCIEXYZ​(float[] cmyk)
        Specified by:
        toCIEXYZ in class ColorSpace
      • fromRGB

        public float[] fromRGB​(float[] rgb)
        Specified by:
        fromRGB in class ColorSpace
      • fromCIEXYZ

        public float[] fromCIEXYZ​(float[] xyz)
        Specified by:
        fromCIEXYZ in class ColorSpace
      • toRGB

        public int[] toRGB​(int[] cmyk,
                           int[] rgb,
                           int intent)
      • getColor

        public static Color getColor​(float c,
                                     float m,
                                     float y,
                                     float k)
        A convenience method, returning an opaque color in the CMYK colorspace with the specified levels of cyan, magenta, yellow and black. The parameters must be in the range from 0.0 to 1.0, or an IllegalArgumentException is thrown
        Parameters:
        c - the level of cyan from 0.0 to 1.0
        m - the level of magenta from 0.0 to 1.0
        y - the level of yellow from 0.0 to 1.0
        k - the level of black from 0.0 to 1.0
        Throws:
        IllegalArgumentException - if any of the parameters are outside the renage 0 <= n <= 1
      • getColor

        public static Color getColor​(float c,
                                     float m,
                                     float y,
                                     float k,
                                     float a)
        A convenience method, returning a color in the CMYK colorspace with the specified levels of cyan, magenta, yellow and black, and the specified alpha value. All the parameters must be in the range from 0.0 to 1.0, or an IllegalArgumentException is thrown
        Parameters:
        c - the level of cyan from 0.0 to 1.0
        m - the level of magenta from 0.0 to 1.0
        y - the level of yellow from 0.0 to 1.0
        k - the level of black from 0.0 to 1.0
        a - the alpha level to use - 0 is transparent, 1 is opaque.
        Throws:
        IllegalArgumentException - if any of the parameters are outside the renage 0 <= n <= 1