1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
package ij.plugin.filter;
import ij.*;
import ij.gui.*;
import ij.process.*;
import java.awt.*;
import java.awt.geom.*;
/** This plugin implements the Image/Translate command. */
public class Translator implements ExtendedPlugInFilter, DialogListener {
private int flags = DOES_ALL|PARALLELIZE_STACKS;
private static double xOffset = 15;
private static double yOffset = 15;
private ImagePlus imp;
private GenericDialog gd;
private PlugInFilterRunner pfr;
private static int interpolationMethod = ImageProcessor.NONE;
private String[] methods = ImageProcessor.getInterpolationMethods();
private boolean previewing;
private Overlay origOverlay;
private boolean overlayOnly;
public int setup(String arg, ImagePlus imp) {
this.imp = imp;
if (imp!=null) {
origOverlay = imp.getOverlay();
Undo.saveOverlay(imp);
}
return flags;
}
public void run(ImageProcessor ip) {
ip.setInterpolationMethod(interpolationMethod);
if (!overlayOnly || origOverlay==null)
ip.translate(xOffset, yOffset);
if (origOverlay!=null) {
Overlay overlay = origOverlay.duplicate();
overlay.translate(xOffset, yOffset);
imp.setOverlay(overlay);
}
}
public int showDialog(ImagePlus imp, String command, PlugInFilterRunner pfr) {
this.pfr = pfr;
int digits = xOffset==(int)xOffset&&yOffset==(int)yOffset?1:3;
if (IJ.isMacro())
interpolationMethod = ImageProcessor.NONE;
gd = new GenericDialog("Translate");
gd.addSlider("X offset:", -100, 100, xOffset, 0.1);
gd.addSlider("Y offset:", -100, 100, xOffset, 0.1);
gd.addChoice("Interpolation:", methods, methods[interpolationMethod]);
if (origOverlay!=null)
gd.addCheckbox("Overlay only", false);
gd.addPreviewCheckbox(pfr);
gd.addDialogListener(this);
previewing = true;
gd.showDialog();
if (gd.wasCanceled()) {
imp.setOverlay(origOverlay);
return DONE;
}
previewing = false;
return IJ.setupDialog(imp, flags);
}
public boolean dialogItemChanged(GenericDialog gd, AWTEvent e) {
xOffset = gd.getNextNumber();
yOffset = gd.getNextNumber();
interpolationMethod = gd.getNextChoiceIndex();
if (origOverlay!=null)
overlayOnly = gd.getNextBoolean();
if (gd.invalidNumber()) {
if (gd.wasOKed()) IJ.error("Offset is invalid.");
return false;
}
return true;
}
public void setNPasses(int nPasses) {
}
}
|