-
Notifications
You must be signed in to change notification settings - Fork 5
/
Export-as-individual-images.ijm
162 lines (140 loc) · 5.82 KB
/
Export-as-individual-images.ijm
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
// -------------------------------------------------------------------
// Written by: Patrice Mascalchi
// Date: 2019
// Location: Cancer Research Institute, University of Cambridge, UK
// New Location: DRVision Technologies LLC, Bordeaux, France
// Contact: [email protected]
// Other contributors for new versions are listed on GitHub
// -------------------------------------------------------------------
/*
Macro to export multi-image (i.e. multi FOV) files such as some .lif, .nd2, .czi, etc.
By default, all images embedded in the same input file will be output in an individual subfolder
*/
// v1.3: - Bug fixed with file separator
// v1.4: - Includes comparison of names to skip multi-scale/pyramidal images
// v1.5: - For pyramidal images, compares pixel sizes to detect change in field of view
// v1.6: - Adding a file extension filter for the input + fixed bug with output image naming
// - Added option to save all in the same output folder
// v1.7: - MIPs will have a suffix "_MIP" for clarity
// - MIPs are saved in their own folder "converted_MIPs" (can run this macro with/without MIP)
requires("1.48a");
run("Bio-Formats Macro Extensions");
// Dialog window for parameters choice ----------------
yesno = newArray("no", "yes");
ftypes = newArray("tif", "jpg", "ics (better compatibility with Aivia)");
Dialog.create("Settings for all files");
Dialog.addChoice("Batch process (multiple files in same folder)", yesno);
Dialog.addString("File extension filter: (leave blank to disable)", ".tif");
Dialog.addMessage("");
Dialog.addChoice("For multi-channel images, save merge as RGB? ", yesno);
Dialog.addChoice("For z-stack images, save maximum projection? ", yesno);
Dialog.addMessage("");
Dialog.addChoice("Output format: ", ftypes);
Dialog.addChoice("Generate numbers in front of image name: ", yesno, "no");
Dialog.addChoice("Output in a subfolder for each input file", yesno, "yes");
Dialog.show();
batch = Dialog.getChoice;
inputType = Dialog.getString;
merge = Dialog.getChoice;
maxproj = Dialog.getChoice;
ftyp = Dialog.getChoice;
prefix = Dialog.getChoice;
indivfolder = Dialog.getChoice;
// End of Dialog --------------------------------------
if (batch=="yes") {
Mypath = getDirectory("Choose the directory containing files to convert");
Mylist = SortFileList(Mypath, inputType);
} else {
Mylist = newArray(1);
tmppa = File.openDialog("Select file to convert");
if (endsWith(tmppa, inputType)==0) exit("error while selecting "+inputType+" file...");
Mylist[0] = File.getName(tmppa);
Mypath = File.getParent(tmppa);
if (!endsWith(Mypath, File.separator)) Mypath = Mypath + File.separator;
print(Mypath);
}
setBatchMode(true);
count = 0;
for (i=0; i<Mylist.length; i++) {
// Setting output folder
outdir = Mypath + "converted" + File.separator;
if (maxproj == "yes") outdir = Mypath + "converted_MIPs" + File.separator;
if (indivfolder == "yes") outdir = Mypath + replace(Mylist[i], ".", "_") + File.separator; // TODO
if ((indivfolder == "yes") && (maxproj == "yes") == true ) outdir = Mypath + replace(Mylist[i], ".", "_") + "_MIPs" + File.separator;
if (!File.exists(outdir)) {
File.makeDirectory(outdir);
}
if (!File.exists(outdir)) exit("Cannot create export folder\n" + outdir);
showProgress(i/(Mylist.length-1));
Ext.setGroupFiles("false");
Ext.setId(Mypath + Mylist[i]);
Ext.getSeriesCount(count);
tmpName = "";
tmpSizeX = 0;
tmpI = 0;
pyramidal = false;
for (f=1;f<count+1;f++) {
Ext.setSeries(f-1);
Ext.getSeriesName(sname);
proceed = 1;
if (indexOf(sname, "TileScan_") > -1) proceed = 0;
if (indexOf(sname, "TileScan_") > -1 && indexOf(sname, "Merging") > -1) proceed = 1;
// pyramidal detection
tmpInd = indexOf(sname, "#");
snamePart = sname;
if (tmpInd > -1) snamePart = substring(sname, 0, tmpInd-1);
// pixel size detection for pyramidal comparison
Ext.getSizeX(sizeX);
print("*"+ snamePart +"* // *"+ tmpName +"*, sizeX="+ sizeX +" // "+tmpSizeX);
if (snamePart == tmpName) {
if (sizeX < tmpSizeX) {
proceed = 0;
} else {
tmpI++;
pyramidal = true;
}
}
tmpSizeX = sizeX;
tmpName = snamePart;
if (proceed==1) {
print("Processing: "+sname);
run("Bio-Formats Importer", "open=[" + Mypath + Mylist[i] +"] autoscale color_mode=Composite view=Hyperstack stack_order=XYCZT series_" + f);
getDimensions(wi, he, ch, sl, fr);
if (maxproj=="yes" && sl>1) run("Z Project...", "projection=[Max Intensity]");
if (merge=="yes" && ch>1) run("Stack to RGB");
// Rename images
t = getTitle();
if (lengthOf(t) > lengthOf(Mylist[i])) t = replace(t, Mylist[i], "");
t = substring(t, 3, lengthOf(t));
t = replace(t,"/","_");
t = replace(t,"_ - ",""); // MIPs won't have a "_" prefix starting in v1.7
t = replace(t, " #", "series");
if (pyramidal) t = t + "_" + tmpI;
if (prefix == "yes") t = IJ.pad(f, 3) +"_"+ t;
if (maxproj=="yes") t = t + "_MIP";
// Only for multipositions filtering
if (indexOf(t, "Pos0") > -1) t = replace(t, "Mark_and_Find_", "");
if (ftyp=="tif") saveAs("Tiff", outdir + t + ".tif");
if (ftyp=="jpg") saveAs("Jpeg", outdir + t + ".jpg");
if (ftyp=="ics (better compatibility with Aivia)") run("Bio-Formats Exporter", "save=["+ outdir + t + ".ids]");
run("Close All");
}
}
Ext.close();
}
setBatchMode(false);
print("done!");
// ************************ FUNCTIONS *************************************************
function SortFileList(path, filter) { // Sort with endsWith
flist = getFileList(path);
OutAr = newArray(flist.length);
ind = 0;
for (f=0; f<flist.length; f++) {
//print(flist[f] + " : "+endsWith(flist[f], filter));
if (endsWith(flist[f], filter)) {
OutAr[ind] = flist[f];
ind++;
}
}
return Array.trim(OutAr, ind);
}