File: Translator.java

package info (click to toggle)
imagej 1.54g-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,520 kB
  • sloc: java: 132,209; sh: 286; xml: 255; makefile: 6
file content (83 lines) | stat: -rw-r--r-- 2,335 bytes parent folder | download | duplicates (3)
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) {
	}

}