forked from jayunruh/Jay_Plugins
-
Notifications
You must be signed in to change notification settings - Fork 0
/
combine_all_trajectories_jru_v1.java
88 lines (86 loc) · 3.61 KB
/
combine_all_trajectories_jru_v1.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
/*******************************************************************************
* Copyright (c) 2012 Jay Unruh, Stowers Institute for Medical Research.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the GNU Public License v2.0
* which accompanies this distribution, and is available at
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
******************************************************************************/
import ij.*;
import ij.process.*;
import ij.gui.*;
import java.awt.*;
import ij.plugin.*;
import jguis.*;
public class combine_all_trajectories_jru_v1 implements PlugIn {
public void run(String arg) {
GenericDialog gd=new GenericDialog("Options");
gd.addCheckbox("Combine_all_series",true);
gd.addNumericField("Series_to_combine",0,0);
gd.addCheckbox("Delete_Originals",false);
gd.addCheckbox("Select_Plots",false);
gd.addNumericField("Number_of_Plots (if selecting)",2,0);
gd.showDialog(); if(gd.wasCanceled()){return;}
boolean combineall=gd.getNextBoolean();
int combseries=(int)gd.getNextNumber();
boolean delor=gd.getNextBoolean();
boolean selplots=gd.getNextBoolean();
int nplots=(int)gd.getNextNumber();
ImageWindow[] windows=null;
if(selplots){
windows=jutils.selectPlotFamily(false,nplots);
if(windows==null) return;
} else {
int[] wList = WindowManager.getIDList();
windows=new ImageWindow[wList.length];
nplots=0;
for(int i=0;i<wList.length;i++){
ImagePlus imp = WindowManager.getImage(wList[i]);
ImageWindow iw=imp.getWindow();
if(iw.getClass().getName().equals("jguis.PlotWindow4") || iw.getClass().getName().equals("ij.gui.PlotWindow")){windows[nplots]=iw; nplots++;}
}
}
if(combineall){
PlotWindow4 pw=jutils.getPW4Copy(windows[0]);
for(int j=1;j<nplots;j++){
float[][] xvals2=(float[][])jutils.runPW4VoidMethod(windows[j],"getXValues");
float[][] yvals2=(float[][])jutils.runPW4VoidMethod(windows[j],"getYValues");
int[] npts=(int[])jutils.runPW4VoidMethod(windows[j],"getNpts");
boolean showerrs=(Boolean)jutils.runPW4VoidMethod(windows[j],"getShowErrors");
float[][][] errs=null;
if(showerrs) errs=(float[][][])jutils.runPW4VoidMethod(windows[j],"getErrors");
for(int i=0;i<yvals2.length;i++){
float[] newxvals=new float[npts[i]];
System.arraycopy(xvals2[i],0,newxvals,0,npts[i]);
float[] newyvals=new float[npts[i]];
System.arraycopy(yvals2[i],0,newyvals,0,npts[i]);
pw.addPoints(newxvals,newyvals,true);
if(showerrs && errs!=null){
pw.addSeriesErrors(pw.getNSeries()-1,new float[][]{errs[0][i],errs[1][i]});
}
}
}
} else {
PlotWindow4 pw=jutils.getPW4SelCopy(windows[0],combseries);
for(int j=1;j<nplots;j++){
float[][] xvals2=(float[][])jutils.runPW4VoidMethod(windows[j],"getXValues");
float[][] yvals2=(float[][])jutils.runPW4VoidMethod(windows[j],"getYValues");
int[] npts=(int[])jutils.runPW4VoidMethod(windows[j],"getNpts");
float[] newxvals=new float[npts[combseries]];
System.arraycopy(xvals2[combseries],0,newxvals,0,npts[combseries]);
float[] newyvals=new float[npts[combseries]];
System.arraycopy(yvals2[combseries],0,newyvals,0,npts[combseries]);
pw.addPoints(newxvals,newyvals,true);
boolean showerrs=(Boolean)jutils.runPW4VoidMethod(windows[j],"getShowErrors");
if(showerrs){
float[][][] errs=(float[][][])jutils.runPW4VoidMethod(windows[j],"getErrors");
if(errs!=null) pw.addSeriesErrors(pw.getNSeries()-1,new float[][]{errs[0][combseries],errs[1][combseries]});
}
}
}
if(delor){
for(int i=0;i<nplots;i++){
windows[i].close();
}
}
}
}