/* * Copyright (C) 2015 by Array Systems Computing Inc. http://www.array.ca * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 3 of the License, or (at your option) * any later version. * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, see http://www.gnu.org/licenses/ */ package org.esa.s1tbx.io.ceos.basic; import org.esa.s1tbx.io.binary.BinaryDBReader; import org.esa.s1tbx.io.binary.BinaryFileReader; import org.esa.s1tbx.io.binary.BinaryRecord; import org.esa.s1tbx.io.binary.IllegalBinaryFormatException; import org.esa.s1tbx.io.ceos.CEOSImageFile; import org.jdom2.Document; import javax.imageio.stream.ImageInputStream; import java.io.IOException; /** * This class represents an image file of a CEOS product. */ class BasicCeosImageFile extends CEOSImageFile { private final static String mission = "radarsat"; private final static String image_recordDefinitionFile = "image_file.xml"; private final static String image_recordDefinition = "image_record.xml"; private final static Document imgDefXML = BinaryDBReader.loadDefinitionFile(mission, image_recordDefinitionFile); private final static Document imgRecordXML = BinaryDBReader.loadDefinitionFile(mission, image_recordDefinition); public BasicCeosImageFile(final ImageInputStream imageStream, final BinaryRecord histogramRecord) throws IOException, IllegalBinaryFormatException { binaryReader = new BinaryFileReader(imageStream); imageFDR = new BinaryRecord(binaryReader, -1, imgDefXML, image_recordDefinitionFile); binaryReader.seek(imageFDR.getAbsolutPosition(imageFDR.getRecordLength())); if (getRasterHeight() == 0) { final int height = histogramRecord.getAttributeInt("Data samples in line"); imageFDR.getBinaryDatabase().set("Number of lines per data set", height); } imageRecords = new BinaryRecord[getRasterHeight()]; imageRecords[0] = createNewImageRecord(0); _imageRecordLength = imageRecords[0].getRecordLength(); startPosImageRecords = imageRecords[0].getStartPos(); imageHeaderLength = imageFDR.getAttributeInt("Number of bytes of prefix data per record"); } protected BinaryRecord createNewImageRecord(final int line) throws IOException { final long pos = imageFDR.getAbsolutPosition(imageFDR.getRecordLength()) + (line * _imageRecordLength); return new BinaryRecord(binaryReader, pos, imgRecordXML, image_recordDefinition); } }