//
// VirtualImagePlus.java
//
/*
LOCI Plugins for ImageJ: a collection of ImageJ plugins including the
Bio-Formats Importer, Bio-Formats Exporter, Bio-Formats Macro Extensions,
Data Browser and Stack Slicer. Copyright (C) 2005-@year@ Melissa Linkert,
Curtis Rueden and Christopher Peterson.
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 2 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, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package loci.plugins.util;
import ij.ImagePlus;
import ij.ImageStack;
import ij.process.ImageStatistics;
import ij.process.LUT;
import java.io.IOException;
import java.util.List;
import loci.formats.IFormatReader;
import loci.plugins.util.RecordedImageProcessor.MethodEntry;
/**
* Extension of {@link ij.ImagePlus} that supports
* Bio-Formats-driven virtual stacks.
*
* <dl><dt><b>Source code:</b></dt>
* <dd><a href="http://trac.openmicroscopy.org.uk/ome/browser/bioformats.git/components/loci-plugins/src/loci/plugins/util/VirtualImagePlus.java">Trac</a>,
* <a href="http://git.openmicroscopy.org/?p=bioformats.git;a=blob;f=components/loci-plugins/src/loci/plugins/util/VirtualImagePlus.java;hb=HEAD">Gitweb</a></dd></dl>
*
* @author Melissa Linkert melissa at glencoesoftware.com
*/
public class VirtualImagePlus extends ImagePlus {
// -- Fields --
private IFormatReader r;
private LUT[] luts;
// -- Constructor --
public VirtualImagePlus(String title, ImageStack stack) {
super(title, stack);
// call getStatistics() to ensure that single-slice stacks have the
// correct pixel type
getStatistics();
}
// -- VirtualImagePlus API methods --
public void setReader(IFormatReader r) {
this.r = r;
}
public void setLUTs(LUT[] luts) {
this.luts = luts;
}
// -- ImagePlus API methods --
public synchronized void setSlice(int index) {
super.setSlice(index);
BFVirtualStack stack = null;
if (getStack() instanceof BFVirtualStack) {
stack = (BFVirtualStack) getStack();
RecordedImageProcessor proc = stack.getRecordedProcessor();
List<MethodEntry> methods = stack.getMethodStack();
if (methods != null) {
proc.applyMethodStack(methods);
}
// if we call setProcessor(getTitle(), proc), the type will be set
// to GRAY32 (regardless of the actual processor type)
setProcessor(getTitle(), proc.getChild());
int channel = getChannel() - 1;
if (channel >= 0 && luts != null && channel < luts.length) {
getProcessor().setColorModel(luts[channel]);
}
this.ip = proc;
}
}
public void close() {
super.close();
try {
r.close();
}
catch (IOException e) { }
}
public ImageStatistics getStatistics(int mOptions, int nBins,
double histMin, double histMax)
{
if (this.ip instanceof RecordedImageProcessor) {
RecordedImageProcessor currentProc = (RecordedImageProcessor) this.ip;
this.ip = currentProc.getChild();
setProcessor(getTitle(), this.ip);
ImageStatistics s =
super.getStatistics(mOptions, nBins, histMin, histMax);
this.ip = currentProc;
return s;
}
return super.getStatistics(mOptions, nBins, histMin, histMax);
}
}