package ij.plugin;
import ij.*;
import ij.process.*;
import ij.measure.Calibration;
public class StackReverser implements PlugIn {
public void run(String arg) {
ImagePlus imp = IJ.getImage();
if (imp.getStackSize()==1) {
IJ.error("Flip Z", "This command requires a stack");
return;
}
if (imp.isHyperStack()) {
IJ.error("Flip Z", "This command does not currently work with hyperstacks.");
return;
}
flipStack(imp);
}
public void flipStack(ImagePlus imp) {
ImageStack stack = imp.getStack();
int n = stack.size();
if (n==1)
return;
Calibration cal = imp.getCalibration();
double min = cal.getCValue(imp.getDisplayRangeMin());
double max = cal.getCValue(imp.getDisplayRangeMax());
ImageStack stack2 = new ImageStack(imp.getWidth(), imp.getHeight(), n);
for (int i=1; i<=n; i++) {
stack2.setPixels(stack.getPixels(i), n-i+1);
stack2.setSliceLabel(stack.getSliceLabel(i), n-i+1);
}
stack2.setColorModel(stack.getColorModel());
imp.setStack(stack2);
if (imp.isComposite()) {
((CompositeImage)imp).reset();
imp.updateAndDraw();
}
IJ.setMinAndMax(imp, min, max);
}
}