47 lines
1.5 KiB
Python
47 lines
1.5 KiB
Python
###################################################################################################
|
|
# Example of using ImageJ functionalities through ijutils.
|
|
###################################################################################################
|
|
|
|
from ijutils import *
|
|
import java.awt.Color as Color
|
|
|
|
import ch.psi.pshell.imaging.Filter as Filter
|
|
from ch.psi.pshell.imaging.Overlays import *
|
|
import ch.psi.pshell.imaging.Pen as Pen
|
|
|
|
|
|
"""
|
|
def detect_led(ip):
|
|
aux = grayscale(ip, in_place=False)
|
|
threshold(aux,0,50)
|
|
binary_fill_holes(aux)
|
|
return analyse_particles(aux, 10000,50000,
|
|
fill_holes = False, exclude_edges = True,print_table=True,
|
|
output_image = "outlines", minCirc = 0.4, maxCirc = 1.0)
|
|
"""
|
|
|
|
def detect_led(ip):
|
|
aux = grayscale(ip, in_place=False)
|
|
invert(aux)
|
|
subtract_background(aux)
|
|
auto_threshold(aux)
|
|
binary_open(aux)
|
|
return analyse_particles(aux, 900,2500,
|
|
fill_holes = True, exclude_edges = True,print_table=True,
|
|
output_image = "outlines", minCirc = 0.4
|
|
, maxCirc = 1.0)
|
|
|
|
|
|
class MyFilter(Filter):
|
|
def process(self, image, data):
|
|
ip = load_image(image)
|
|
(results,output) = detect_led(ip)
|
|
set_lut(output, outline_lut1[0], outline_lut1[1], outline_lut1[2])
|
|
op_image(ip, output, "and")
|
|
#return ip.getBufferedImage()
|
|
return output.getBufferedImage()
|
|
|
|
#Setting the filter to a source
|
|
img.setFilter(MyFilter())
|
|
|