aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/org/apache/fop/image/analyser/BMPReader.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/java/org/apache/fop/image/analyser/BMPReader.java')
-rw-r--r--src/java/org/apache/fop/image/analyser/BMPReader.java134
1 files changed, 0 insertions, 134 deletions
diff --git a/src/java/org/apache/fop/image/analyser/BMPReader.java b/src/java/org/apache/fop/image/analyser/BMPReader.java
deleted file mode 100644
index caca6f3dd..000000000
--- a/src/java/org/apache/fop/image/analyser/BMPReader.java
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * 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$ */
-
-package org.apache.fop.image.analyser;
-
-// Java
-import java.io.InputStream;
-import java.io.IOException;
-
-// FOP
-import org.apache.fop.image.FopImage;
-import org.apache.fop.apps.FOUserAgent;
-
-/**
- * ImageReader object for BMP image type.
- *
- * @author Pankaj Narula
- * @version $Id$
- */
-public class BMPReader implements ImageReader {
-
- /** Length of the BMP header */
- protected static final int BMP_SIG_LENGTH = 46;
-
- /** offset to width */
- private static final int WIDTH_OFFSET = 18;
- /** offset to height */
- private static final int HEIGHT_OFFSET = 22;
- /** offset to horizontal res */
- private static final int HRES_OFFSET = 38;
- /** offset to vertical res */
- private static final int VRES_OFFSET = 42;
-
- /** {@inheritDoc} */
- public FopImage.ImageInfo verifySignature(String uri, InputStream bis,
- FOUserAgent ua) throws IOException {
- byte[] header = getDefaultHeader(bis);
- boolean supported = ((header[0] == (byte) 0x42)
- && (header[1] == (byte) 0x4d));
- if (supported) {
- FopImage.ImageInfo info = new FopImage.ImageInfo();
- info.dpiHorizontal = ua.getFactory().getSourceResolution();
- info.dpiVertical = info.dpiHorizontal;
-
- getDimension(header, info);
- info.originalURI = uri;
- info.mimeType = getMimeType();
- info.inputStream = bis;
- return info;
- } else {
- return null;
- }
- }
-
- /**
- * Returns the MIME type supported by this implementation.
- *
- * @return The MIME type
- */
- public String getMimeType() {
- return "image/bmp";
- }
-
- private void getDimension(byte[] header, FopImage.ImageInfo info) {
- // little endian notation
- int byte1 = header[WIDTH_OFFSET] & 0xff;
- int byte2 = header[WIDTH_OFFSET + 1] & 0xff;
- int byte3 = header[WIDTH_OFFSET + 2] & 0xff;
- int byte4 = header[WIDTH_OFFSET + 3] & 0xff;
- long l = (long) ((byte4 << 24) | (byte3 << 16)
- | (byte2 << 8) | byte1);
- info.width = (int) (l & 0xffffffff);
-
- byte1 = header[HEIGHT_OFFSET] & 0xff;
- byte2 = header[HEIGHT_OFFSET + 1] & 0xff;
- byte3 = header[HEIGHT_OFFSET + 2] & 0xff;
- byte4 = header[HEIGHT_OFFSET + 3] & 0xff;
- l = (long) ((byte4 << 24) | (byte3 << 16) | (byte2 << 8) | byte1);
- info.height = (int) (l & 0xffffffff);
-
- byte1 = header[HRES_OFFSET] & 0xff;
- byte2 = header[HRES_OFFSET + 1] & 0xff;
- byte3 = header[HRES_OFFSET + 2] & 0xff;
- byte4 = header[HRES_OFFSET + 3] & 0xff;
- l = (long) ((byte4 << 24) | (byte3 << 16) | (byte2 << 8) | byte1);
- if (l > 0) {
- info.dpiHorizontal = l / 39.37d;
- }
-
- byte1 = header[VRES_OFFSET] & 0xff;
- byte2 = header[VRES_OFFSET + 1] & 0xff;
- byte3 = header[VRES_OFFSET + 2] & 0xff;
- byte4 = header[VRES_OFFSET + 3] & 0xff;
- l = (long) ((byte4 << 24) | (byte3 << 16) | (byte2 << 8) | byte1);
- if (l > 0) {
- info.dpiVertical = l / 39.37d;
- }
- }
-
- private byte[] getDefaultHeader(InputStream imageStream)
- throws IOException {
- byte[] header = new byte[BMP_SIG_LENGTH];
- try {
- imageStream.mark(BMP_SIG_LENGTH + 1);
- imageStream.read(header);
- imageStream.reset();
- } catch (IOException ex) {
- try {
- imageStream.reset();
- } catch (IOException exbis) {
- // throw the original exception, not this one
- }
- throw ex;
- }
- return header;
- }
-
-}