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

edu.harvard.hul.ois.jhove.module.tiff.TiffProfileFXJ Maven / Gradle / Ivy

/**********************************************************************
 * Jhove - JSTOR/Harvard Object Validation Environment
 * Copyright 2004 by JSTOR and the President and Fellows of Harvard College
 **********************************************************************/

package edu.harvard.hul.ois.jhove.module.tiff;

import edu.harvard.hul.ois.jhove.*;

/**
 *  Profile checker for TIFF FX, Profile J (lossless JBIG).
 *
 *  Image data content is not checked for profile conformance.
 *  Only tags are checked.
 *
 * @author Gary McGath
 *
 */
public class TiffProfileFXJ extends TiffFXBase {

    /**
     *  Constructor.
     */
    public TiffProfileFXJ ()
    {
        super ();
        _profileText = "TIFF-FX (Profile J)";
        _mimeClass = MIME_FX;
    }


    /**
     *  Returns true if the IFD satisfies the requirements of a
     *  TIFF/FX J profile.  See the TIFF/FX specification for
     *  details.
     */
    public boolean satisfiesThisProfile(IFD ifd) {
        if (!(ifd instanceof TiffIFD)) {
            return false;
        }
        TiffIFD tifd = (TiffIFD) ifd;
        if (!satisfiesClass (tifd)) {
            return false;
        }
        NisoImageMetadata niso = tifd.getNisoImageMetadata ();
        int[] bps = niso.getBitsPerSample ();
        if (bps[0] != 1) {
            return false;
        }
        int cmp = niso.getCompressionScheme();
        if (cmp != 9) {
            return false;
        }
        if (!satisfiesFillOrder (tifd,
                new int[] {1, 2} )) {
            return false;
            // RFC 2301 (1998) is internally inconsistent about
            // whether a FillOrder of 1 is permitted.  The latest
            // working draft allows a FillOrder of 1, so I've
            // resolved the conflict in favor of that interpretation.
        }
        // We've already established that if the compression
        // scheme is 3, T4Options exists.  But we must establish
        // that if it's 4, T6Options exists and has a value of 0.
        if (cmp == 4) {
            if (tifd.getT6Options () != 0) {
                return false;
            }
        }

        // XResolution, YResolution, and ImageWidth have codependencies.
        boolean xywOK = false;    // guilty till proven innocent
        long xRes = niso.getXSamplingFrequency ().toLong();
        long yRes = niso.getYSamplingFrequency ().toLong();
        if (niso.getSamplingFrequencyUnit() == 3) {
            // Convert from units/cm to units/inch, with rounding
            xRes = perCMtoPerInch ((int) xRes);
            yRes = perCMtoPerInch ((int) yRes);
        }
        long wid = niso.getImageWidth();
        if ((xRes == 200 && yRes == 100) ||
                (xRes == 204 && yRes == 98) ||
                (xRes == 200 && yRes == 200) ||
                (xRes == 204 && yRes == 196) ||
                (xRes == 204 && yRes == 391)) {
            if (wid == 1728 || wid == 2048 || wid == 2432) {
                xywOK = true;
            }
        }
        if (xRes == 300 && yRes == 300) {
            if (wid == 2592 || wid == 3072 || wid == 3648) {
                xywOK = true;
            }
        }
        if ((xRes == 408 && yRes == 391) ||
                (xRes == 400 && yRes == 400)) {
            if (wid == 3456 || wid == 4096 || wid == 4864) {
                xywOK = true;
            }
        }
        if (!xywOK) {
            return false;
        }
        return true;         // passed all tests
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy