annotate jython_script.py @ 1:269923244cc8 draft

planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
author iuc
date Wed, 26 Aug 2015 14:38:34 -0400
parents 8b787f641b9c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
1 import jython_utils
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
2 import sys
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
3 from ij import IJ
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
4
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
5 # Fiji Jython interpreter implements Python 2.5 which does not
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
6 # provide support for argparse.
1
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
7 error_log = sys.argv[ -5 ]
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
8 input = sys.argv[ -4 ]
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
9 black_background = jython_utils.asbool( sys.argv[ -3 ] )
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
10 tmp_output_path = sys.argv[ -2 ]
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
11 output_datatype = sys.argv[ -1 ]
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
12
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
13 # Open the input image file.
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
14 input_image_plus = IJ.openImage( input )
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
15
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
16 # Create a copy of the image.
1
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
17 input_image_plus_copy = input_image_plus.duplicate()
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
18 image_processor_copy = input_image_plus_copy.getProcessor()
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
19
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
20 try:
1
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
21 # Set binary options.
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
22 options = jython_utils.get_binary_options( black_background=black_background )
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
23 IJ.run( input_image_plus_copy, "Options...", options )
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
24
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
25 # Convert image to binary if necessary.
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
26 if not image_processor_copy.isBinary():
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
27 # Convert the image to binary grayscale.
1
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
28 IJ.run( input_image_plus_copy, "Make Binary", "" )
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
29
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
30 # Run the command.
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
31 IJ.run( input_image_plus_copy, "Skeletonize (2D/3D)", "" )
1
269923244cc8 planemo upload commit 18df9e67efd4adafcde4eb9b62cd815e4afe9733-dirty
iuc
parents: 0
diff changeset
32
0
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
33 # Save the ImagePlus object as a new image.
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
34 IJ.saveAs( input_image_plus_copy, output_datatype, tmp_output_path )
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
35 except Exception, e:
8b787f641b9c planemo upload commit 98c34e070343a117019ffd25a3af117808159bf5-dirty
iuc
parents:
diff changeset
36 jython_utils.handle_error( error_log, str( e ) )