/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* $Id: ImageIOUtil.java 1804124 2017-08-04 14:13:54Z ssteiner $ */

package org.apache.xmlgraphics.image.loader.impl.imageio;

import javax.imageio.metadata.IIOMetadata;
import javax.imageio.metadata.IIOMetadataFormatImpl;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import org.apache.xmlgraphics.image.loader.ImageSize;
import org.apache.xmlgraphics.util.UnitConv;

Helper and convenience methods for ImageIO.
/** * Helper and convenience methods for ImageIO. */
public final class ImageIOUtil { private ImageIOUtil() { }
Key for ImageInfo's custom objects to embed the ImageIO metadata
/** Key for ImageInfo's custom objects to embed the ImageIO metadata */
public static final Object IMAGEIO_METADATA = IIOMetadata.class;
Extracts the resolution information from the standard ImageIO metadata.
Params:
  • iiometa – the metadata provided by ImageIO
  • size – the image size object
/** * Extracts the resolution information from the standard ImageIO metadata. * @param iiometa the metadata provided by ImageIO * @param size the image size object */
public static void extractResolution(IIOMetadata iiometa, ImageSize size) { if (iiometa != null && iiometa.isStandardMetadataFormatSupported()) { Element metanode = (Element)iiometa.getAsTree( IIOMetadataFormatImpl.standardMetadataFormatName); Element dim = getChild(metanode, "Dimension"); if (dim != null) { Element child; double dpiHorz = size.getDpiHorizontal(); double dpiVert = size.getDpiVertical(); child = getChild(dim, "HorizontalPixelSize"); if (child != null) { float value = Float.parseFloat(child.getAttribute("value")); if (value != 0 && !Float.isInfinite(value)) { dpiHorz = UnitConv.IN2MM / value; } } child = getChild(dim, "VerticalPixelSize"); if (child != null) { float value = Float.parseFloat(child.getAttribute("value")); if (value != 0 && !Float.isInfinite(value)) { dpiVert = UnitConv.IN2MM / value; } } size.setResolution(dpiHorz, dpiVert); size.calcSizeFromPixels(); } } }
Returns a child element of another element or null if there's no such child.
Params:
  • el – the parent element
  • name – the name of the requested child
Returns:the child or null if there's no such child
/** * Returns a child element of another element or null if there's no such child. * @param el the parent element * @param name the name of the requested child * @return the child or null if there's no such child */
public static Element getChild(Element el, String name) { NodeList nodes = el.getElementsByTagName(name); if (nodes.getLength() > 0) { return (Element)nodes.item(0); } else { return null; } }
Dumps the content of an IIOMetadata instance to System.out.
Params:
  • iiometa – the metadata
/** * Dumps the content of an IIOMetadata instance to System.out. * @param iiometa the metadata */
public static void dumpMetadataToSystemOut(IIOMetadata iiometa) { String[] metanames = iiometa.getMetadataFormatNames(); for (String metaname : metanames) { System.out.println("--->" + metaname); dumpNodeToSystemOut(iiometa.getAsTree(metaname)); } }
Serializes a W3C DOM node to a String and dumps it to System.out.
Params:
  • node – a W3C DOM node
/** * Serializes a W3C DOM node to a String and dumps it to System.out. * @param node a W3C DOM node */
private static void dumpNodeToSystemOut(Node node) { Transformer trans = null; try { trans = TransformerFactory.newInstance().newTransformer(); trans.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes"); trans.setOutputProperty(OutputKeys.INDENT, "yes"); Source src = new DOMSource(node); Result res = new StreamResult(System.out); trans.transform(src, res); } catch (TransformerConfigurationException e) { e.printStackTrace(); } catch (TransformerException e) { e.printStackTrace(); } } }