/*
* List colorspaces used in the document
* See topic "page_colorspaces" for retrieving colorspaces for each page.
*
* Required software: pCOS interface 8 (PDFlib+PDI/PPS 9, TET 4.1, PLOP 5.0)
* Required data: PDF document
*/
package com.pdflib.cookbook.pcos.resources;
import com.pdflib.IpCOS;
import com.pdflib.cookbook.pcos.pcos_cookbook_example;
public class colorspaces extends pcos_cookbook_example {
/* This is where the data files are. Adjust as necessary. */
private final static String SEARCH_PATH = "../input";
public void example_code(IpCOS p, int doc) throws Exception {
System.out.println("File name: " + p.pcos_get_string(doc, "filename"));
int colorspacecount = (int) p.pcos_get_number(doc, "length:colorspaces");
System.out.print(colorspacecount + " color space");
if (colorspacecount != 1) {
System.out.print("s");
}
if (colorspacecount > 0) {
System.out.print(":");
}
System.out.println();
int id;
for (id = 0; id < colorspacecount; id++) {
print_colorspace(p, doc, 0, "colorspaces[" + id + "]");
}
System.out.println();
int patterncount = (int) p.pcos_get_number(doc, "length:patterns");
System.out.print(patterncount + " pattern");
if (patterncount != 1) {
System.out.print("s");
}
if (patterncount > 0) {
System.out.print(":");
}
System.out.println();
for (id = 0; id < patterncount; id++) {
print_pattern(p, doc, "patterns[" + id + "]");
}
}
/**
* Analyze and print information about a single colorspace.
*
* @param p
* IpCOS object
* @param doc
* Document handle
* @level
* Recursion level, used for indenting
* @param colorspace_path
* The pCOS path to the colorspace of interest
*
* @throws Exception
*/
private void print_colorspace(IpCOS p, int doc, int level, String colorspace_path)
throws Exception {
String prefix = get_prefix(level);
String colorspace = p.pcos_get_string(doc, colorspace_path + "/name");
System.out.println(prefix + " " + colorspace);
int pcosinterface = (int) p.pcos_get_number(doc, "pcosinterface");
int componentcount = (int) p.pcos_get_number(doc,
colorspace_path + "/components");
System.out.println(prefix + " " + componentcount + " component"
+ (componentcount == 1 ? "" : "s"));
if (colorspace.equals("ICCBased")) {
System.out.println(prefix + " size of ICC profile in bytes: "
+ (int) p.pcos_get_number(doc, colorspace_path + "/Length"));
if (pcosinterface >= 10) {
int iccprofileid = (int) p.pcos_get_number(doc,
colorspace_path + "/iccprofileid");
String errormessage = p.pcos_get_string(doc,
"iccprofiles[" + iccprofileid + "]/errormessage");
/* Check whether the embedded profile is damaged */
if (errormessage != null && errormessage.length() > 0) {
System.out.println(" (" + errormessage + ")");
}
else {
String profilename = p.pcos_get_string(doc,
"iccprofiles[" + iccprofileid + "]/profilename");
System.out.println(prefix + " name: '" + profilename + "'");
String profilecs = p.pcos_get_string(doc,
"iccprofiles[" + iccprofileid + "]/profilecs");
System.out.println(prefix + " cs: '" + profilecs + "'");
String deviceclass = p.pcos_get_string(doc,
"iccprofiles[" + iccprofileid + "]/deviceclass");
System.out.println(prefix + " deviceclass: '" + deviceclass + "'");
String iccversion = p.pcos_get_string(doc,
"iccprofiles[" + iccprofileid + "]/iccversion");
System.out.println(prefix + " iccversion: '" + iccversion + "'");
}
}
}
else if (colorspace.equals("Lab")) {
System.out.print(prefix + " WhitePoint: ");
for (int j = 0; j < 3; j += 1) {
System.out.print(p.pcos_get_number(doc, colorspace_path
+ "/csarray[1]/WhitePoint[" + j + "]")
+ " ");
}
System.out.println();
}
else if (colorspace.equals("CalGray") || colorspace.equals("CalRGB")) {
System.out.print(prefix + " WhitePoint: ");
for (int j = 0; j < 3; j += 1) {
System.out.print(p.pcos_get_number(doc, colorspace_path
+ "/csarray[1]/WhitePoint[" + j + "]")
+ " ");
}
System.out.println();
}
else if (colorspace.equals("Separation")) {
String colorant = p.pcos_get_string(doc, colorspace_path
+ "/colorantname");
System.out.println(prefix + " colorant \"" + colorant + "\"");
int alternateid = (int) p.pcos_get_number(doc, colorspace_path
+ "/alternateid");
System.out.println(prefix + " alternate color space:");
print_colorspace(p, doc, level + 1, "colorspaces[" + alternateid + "]");
}
else if (colorspace.equals("DeviceN")) {
int colorantcount = (int) p.pcos_get_number(doc, "length:"
+ colorspace_path + "/colorantnames");
System.out.println(prefix + " colorants:");
for (int j = 0; j < colorantcount; j += 1) {
System.out.println(prefix + " \""
+ p.pcos_get_string(doc, colorspace_path
+ "/colorantnames[" + j + "]") + "\"");
}
int alternateid = (int) p.pcos_get_number(doc, colorspace_path
+ "/alternateid");
System.out.println(prefix + " alternate color space:");
print_colorspace(p, doc, level + 1, "colorspaces[" + alternateid + "]");
}
else if (colorspace.equals("Indexed")) {
int palettesize = (int) p.pcos_get_number(doc, colorspace_path
+ "/csarray[2]");
System.out.println(prefix + " palette size: " + palettesize);
int baseid = (int) p.pcos_get_number(doc, colorspace_path
+ "/baseid");
System.out.println(prefix + " base color space: ");
print_colorspace(p, doc, level + 1, "colorspaces[" + baseid + "]");
}
else if (colorspace.equals("Pattern")) {
/*
* Check whether the Pattern color space has an underlying color
* space, and print it recursively if present.
*
* This only works with a pcosinterface >= 10, for pcosinterface
* < 10 Pattern colorspaces are not present in the colorspaces[]
* array.
*/
int baseid = (int) p.pcos_get_number(doc, colorspace_path
+ "/baseid");
if (baseid != -1) {
System.out.println(prefix + " underlying color space:");
print_colorspace(p, doc, level + 1, "colorspaces[" + baseid + "]");
}
}
}
/**
* Analyze and print information about a single pattern.
*
* @param p
* IpCOS object
* @param doc
* Document handle
* @param pattern_path
* The pCOS path to the pattern of interest
*
* @throws Exception
*/
private void print_pattern(IpCOS p, int doc, String pattern_path)
throws Exception {
int patterntype = (int) p.pcos_get_number(doc, pattern_path + "/PatternType");
switch (patterntype)
{
case 1:
System.out.print(" Tiling Pattern ");
int painttype = (int) p.pcos_get_number(doc, pattern_path + "/PaintType");
switch (painttype)
{
case 1:
System.out.println("(colored)");
break;
case 2:
System.out.println("(uncolored)");
break;
default:
System.out.println("(unknown PaintType " + painttype + ")");
break;
}
break;
case 2:
System.out.println(" Shading Pattern");
break;
default:
System.out.println(" Pattern with unknown PatternType " + patterntype);
break;
}
}
/**
* Get a prefix string consisting of spaces that can be used to indent
* lines.
*
* @param level
* indentation level
* @return
* indentation string
*
* @throws Exception
*/
private String get_prefix(int level) {
StringBuilder prefix = new StringBuilder();
for (int i = 0; i < level; i += 1) {
prefix.append(" ");
}
return prefix.toString();
}
public colorspaces(String[] argv, String readable_name, String search_path) {
super(argv, readable_name, search_path);
}
public static void main(String argv[]) {
colorspaces example = new colorspaces(argv, "Colorspaces", SEARCH_PATH);
example.execute();
}
}