-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathimage_view.py
44 lines (33 loc) · 1.37 KB
/
image_view.py
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
from pydm import Display
import threading
from skimage.feature import blob_doh
from marker import ImageMarker
from pyqtgraph import mkPen
class ImageViewer(Display):
def __init__(self, parent=None, args=None):
super().__init__(parent=parent, args=args)
self.markers_lock = threading.Lock()
self.ui.imageView.process_image = self.process_image
self.ui.imageView.newImageSignal.connect(self.draw_markers)
self.markers = list()
self.blobs = list()
def ui_filename(self):
return "image_view.ui"
def draw_markers(self, *args, **kwargs):
with self.markers_lock:
view = self.ui.imageView.getView().getViewBox()
for m in self.markers:
if m in view.addedItems:
view.removeItem(m)
for blob in self.blobs:
x, y, size = blob
m = ImageMarker((y, x), size=size, pen=mkPen((100, 100, 255), width=3))
self.markers.append(m)
view.addItem(m)
self.ui.numBlobsLabel.setText(str(len(self.blobs)))
def process_image(self, new_image):
# Find blobs in the image with scikit-image
self.blobs = blob_doh(new_image, max_sigma=512, min_sigma=64, threshold=0.02)
# Send the original image data to the image widget
return new_image
intelclass = ImageViewer