帆软使用的第三方框架。
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

180 lines
6.1 KiB

package com.fr.third.JAI;
/*
* Copyright (c) 2001 Sun Microsystems, Inc. All Rights Reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* -Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* -Redistribution in binary form must reproduct the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of Sun Microsystems, Inc. or the names of contributors may
* be used to endorse or promote products derived from this software without
* specific prior written permission.
*
* This software is provided "AS IS," without a warranty of any kind. ALL
* EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY
* IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
* NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE
* LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING
* OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS
* LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT,
* INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER
* CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF
* OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES.
*
* You acknowledge that Software is not designed,licensed or intended for use in
* the design, construction, operation or maintenance of any nuclear facility.
*/
import java.awt.image.ColorModel;
import java.awt.image.DataBuffer;
import java.awt.image.IndexColorModel;
import java.awt.image.RenderedImage;
import java.awt.image.SampleModel;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.IOException;
import java.io.OutputStream;
/**
*/
public final class PNGCodec extends ImageCodec {
public PNGCodec() {}
public String getFormatName() {
return "png";
}
public Class getEncodeParamClass() {
return PNGEncodeParam.class;
}
public Class getDecodeParamClass() {
return PNGDecodeParam.class;
}
public boolean canEncodeImage(RenderedImage im,
ImageEncodeParam param) {
SampleModel sampleModel = im.getSampleModel();
// PNG doesn't handle float or double pixels
int dataType = sampleModel.getTransferType();
if ((dataType == DataBuffer.TYPE_FLOAT) ||
(dataType == DataBuffer.TYPE_DOUBLE)) {
return false;
}
int[] sampleSize = sampleModel.getSampleSize();
int bitDepth = sampleSize[0];
// Ensure all channels have the same bit depth
for (int i = 1; i < sampleSize.length; i++) {
if (sampleSize[i] != bitDepth) {
return false;
}
}
// Bit depth must be between 1 and 16
if (bitDepth < 1 || bitDepth > 16) {
return false;
}
// Number of bands must be between 1 and 4
int numBands = sampleModel.getNumBands();
if (numBands < 1 || numBands > 4) {
return false;
}
// Palette images must be 1-banded, depth 8 or less
ColorModel colorModel = im.getColorModel();
if (colorModel instanceof IndexColorModel) {
if (numBands != 1 || bitDepth > 8) {
return false;
}
}
// If a param object is supplied, check that it is of the right type
if (param != null) {
if (param instanceof PNGEncodeParam) {
if (colorModel instanceof IndexColorModel) {
if (!(param instanceof PNGEncodeParam.Palette) ) {
return false;
}
} else if (numBands < 3) {
if (!(param instanceof PNGEncodeParam.Gray) ) {
return false;
}
} else {
if (!(param instanceof PNGEncodeParam.RGB) ) {
return false;
}
}
} else {
return false;
}
}
return true;
}
protected ImageEncoder createImageEncoder(OutputStream dst,
ImageEncodeParam param) {
PNGEncodeParam p = null;
if (param != null) {
p = (PNGEncodeParam)param;
}
return new PNGImageEncoder(dst, p);
}
protected ImageDecoder createImageDecoder(InputStream src,
ImageDecodeParam param) {
PNGDecodeParam p = null;
if (param != null) {
p = (PNGDecodeParam)param;
}
return new PNGImageDecoder(src, p);
}
protected ImageDecoder createImageDecoder(File src,
ImageDecodeParam param)
throws IOException {
PNGDecodeParam p = null;
if (param != null) {
p = (PNGDecodeParam)param;
}
return new PNGImageDecoder(new FileInputStream(src), p);
}
protected ImageDecoder createImageDecoder(SeekableStream src,
ImageDecodeParam param) {
PNGDecodeParam p = null;
if (param != null) {
p = (PNGDecodeParam)param;
}
return new PNGImageDecoder(src, p);
}
public int getNumHeaderBytes() {
return 8;
}
public boolean isFormatRecognized(byte[] header) {
return ((header[0] == (byte)0x89) &&
(header[1] == (byte)0x50) &&
(header[2] == (byte)0x4e) &&
(header[3] == (byte)0x47) &&
(header[4] == (byte)0x0d) &&
(header[5] == (byte)0x0a) &&
(header[6] == (byte)0x1a) &&
(header[7] == (byte)0x0a));
}
}