forked from imagej/ImageJ
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFreehandRoi.java
98 lines (90 loc) · 2.28 KB
/
FreehandRoi.java
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package ij.gui;
import java.awt.*;
import java.awt.image.*;
import ij.*;
/** Freehand region of interest or freehand line of interest*/
public class FreehandRoi extends PolygonRoi {
public FreehandRoi(int sx, int sy, ImagePlus imp) {
super(sx, sy, imp);
if (Toolbar.getToolId()==Toolbar.FREEROI)
type = FREEROI;
else
type = FREELINE;
if (nPoints==2) nPoints--;
}
protected void grow(int sx, int sy) {
if (subPixelResolution() && xpf!=null) {
growFloat(sx, sy);
return;
}
int ox = offScreenX(sx);
int oy = offScreenY(sy);
if (ox<0) ox = 0;
if (oy<0) oy = 0;
if (ox>xMax) ox = xMax;
if (oy>yMax) oy = yMax;
if (ox!=xp[nPoints-1]+x || oy!=yp[nPoints-1]+y) {
xp[nPoints] = ox-x;
yp[nPoints] = oy-y;
nPoints++;
if (IJ.altKeyDown())
wipeBack();
if (nPoints==xp.length)
enlargeArrays();
drawLine();
}
}
private void growFloat(int sx, int sy) {
double ox = offScreenXD(sx);
double oy = offScreenYD(sy);
if (ox<0.0) ox = 0.0;
if (oy<0.0) oy = 0.0;
if (ox>xMax) ox = xMax;
if (oy>yMax) oy = yMax;
double xbase = getXBase();
double ybase = getYBase();
if (ox!=xpf[nPoints-1]+xbase || oy!=ypf[nPoints-1]+ybase) {
xpf[nPoints] = (float)(ox-xbase);
ypf[nPoints] = (float)(oy-ybase);
nPoints++;
if (nPoints==xpf.length)
enlargeArrays();
drawLine();
}
}
void drawLine() {
int x1, y1, x2, y2;
if (xpf!=null) {
x1 = (int)Math.round(xpf[nPoints-2]+x);
y1 = (int)Math.round(ypf[nPoints-2]+y);
x2 = (int)Math.round(xpf[nPoints-1]+x);
y2 = (int)Math.round(ypf[nPoints-1]+y);
} else {
x1 = xp[nPoints-2]+x;
y1 = yp[nPoints-2]+y;
x2 = xp[nPoints-1]+x;
y2 = yp[nPoints-1]+y;
}
int xmin = Math.min(x1, x2);
int xmax = Math.max(x1, x2);
int ymin = Math.min(y1, y2);
int ymax = Math.max(y1, y2);
int margin = 4;
if (lineWidth>margin && isLine())
margin = lineWidth;
if (ic!=null) {
double mag = ic.getMagnification();
if (mag<1.0) margin = (int)(margin/mag);
}
if (IJ.altKeyDown())
margin += 20; // for wipeBack
imp.draw(xmin-margin, ymin-margin, (xmax-xmin)+margin*2, (ymax-ymin)+margin*2);
}
protected void handleMouseUp(int screenX, int screenY) {
if (state==CONSTRUCTING) {
addOffset();
finishPolygon();
}
state = NORMAL;
}
}