All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.xmlgraphics.image.codec.tiff.TIFFDecodeParam Maven / Gradle / Ivy

Go to download

Apache XML Graphics Commons is a library that consists of several reusable components used by Apache Batik and Apache FOP. Many of these components can easily be used separately outside the domains of SVG and XSL-FO.

There is a newer version: 2.9
Show newest version
/*
 * 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: TIFFDecodeParam.java 1732018 2016-02-24 04:51:06Z gadams $ */

package org.apache.xmlgraphics.image.codec.tiff;

import  org.apache.xmlgraphics.image.codec.util.ImageDecodeParam;

/**
 * An instance of ImageDecodeParam for decoding images in
 * the TIFF format.
 *
 * 

To determine the number of images present in a TIFF file, use * the getNumPages() method on the * ImageDecoder object that will be used to perform the * decoding. The desired page number may be passed as an argument to * the ImageDecoder.decodeAsRaster)() or * decodeAsRenderedImage() methods. * *

For TIFF Palette color images, the colorMap always has entries * of short data type, the color Black being represented by 0,0,0 and * White by 65536,65536,65536. In order to display these images, the * default behavior is to dither the short values down to 8 bits. * The dithering is done by calling the decode16BitsTo8Bits * method for each short value that needs to be dithered. The method has * the following implementation: * * byte b; * short s; * s = s & 0xffff; * b = (byte)((s >> 8) & 0xff); * * If a different algorithm is to be used for the dithering, this class * should be subclassed and an appropriate implementation should be * provided for the decode16BitsTo8Bits method in the subclass. * *

If the palette contains image data that is signed short, as specified * by the SampleFormat tag, the dithering is done by calling * decodeSigned16BitsTo8Bits instead. The method has the * following implementation: * * byte b; * short s; * b = (byte)((s + Short.MIN_VALUE) >> 8); * * In order to use a different algorithm for the dithering, this class * should be subclassed and the method overridden. * *

If it is desired that the Palette be decoded such that the output * image is of short data type and no dithering is performed, the * setDecodePaletteAsShorts method should be used. * *

This class is not a committed part of the JAI API. It may * be removed or changed in future releases of JAI. * * @see TIFFDirectory */ public class TIFFDecodeParam implements ImageDecodeParam { private static final long serialVersionUID = -2371665950056848358L; private boolean decodePaletteAsShorts; private Long ifdOffset; private boolean convertJPEGYCbCrToRGB = true; /** Constructs a default instance of TIFFDecodeParam. */ public TIFFDecodeParam() { } /** * If set, the entries in the palette will be decoded as shorts * and no short to byte lookup will be applied to them. */ public void setDecodePaletteAsShorts(boolean decodePaletteAsShorts) { this.decodePaletteAsShorts = decodePaletteAsShorts; } /** * Returns true if palette entries will be decoded as * shorts, resulting in an output image with short datatype. */ public boolean getDecodePaletteAsShorts() { return decodePaletteAsShorts; } /** * Returns an unsigned 8 bit value computed by dithering the unsigned * 16 bit value. Note that the TIFF specified short datatype is an * unsigned value, while Java's short datatype is a * signed value. Therefore the Java short datatype cannot * be used to store the TIFF specified short value. A Java * int is used as input instead to this method. The method * deals correctly only with 16 bit unsigned values. */ public byte decode16BitsTo8Bits(int s) { return (byte)((s >> 8) & 0xffff); } /** * Returns an unsigned 8 bit value computed by dithering the signed * 16 bit value. This method deals correctly only with values in the * 16 bit signed range. */ public byte decodeSigned16BitsTo8Bits(short s) { return (byte)((s + Short.MIN_VALUE) >> 8); } /** * Sets the offset in the stream from which to read the image. There * must be an Image File Directory (IFD) at that position or an error * will occur. If setIFDOffset() is never invoked then * the decoder will assume that the TIFF stream is at the beginning of * the 8-byte image header. If the directory offset is set and a page * number is supplied to the TIFF ImageDecoder then the * page will be the zero-relative index of the IFD in linked list of * IFDs beginning at the specified offset with a page of zero indicating * the directory at that offset. */ public void setIFDOffset(long offset) { ifdOffset = offset; } /** * Returns the value set by setIFDOffset() or * null if no value has been set. */ public Long getIFDOffset() { return ifdOffset; } /** * Sets a flag indicating whether to convert JPEG-compressed YCbCr data * to RGB. The default value is true. This flag is * ignored if the image data are not JPEG-compressed. */ public void setJPEGDecompressYCbCrToRGB(boolean convertJPEGYCbCrToRGB) { this.convertJPEGYCbCrToRGB = convertJPEGYCbCrToRGB; } /** * Whether JPEG-compressed YCbCr data will be converted to RGB. */ public boolean getJPEGDecompressYCbCrToRGB() { return convertJPEGYCbCrToRGB; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy