Also, removed the one from modules/python/src2/cv.py and cleared its executable bit, since it's not a script.
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/env python
 | 
						|
 | 
						|
'''
 | 
						|
Watershed segmentation
 | 
						|
=========
 | 
						|
 | 
						|
This program demonstrates the watershed segmentation algorithm
 | 
						|
in OpenCV: watershed().
 | 
						|
 | 
						|
Usage
 | 
						|
-----
 | 
						|
watershed.py [image filename]
 | 
						|
 | 
						|
Keys
 | 
						|
----
 | 
						|
  1-7   - switch marker color
 | 
						|
  SPACE - update segmentation
 | 
						|
  r     - reset
 | 
						|
  a     - toggle autoupdate
 | 
						|
  ESC   - exit
 | 
						|
 | 
						|
'''
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
import numpy as np
 | 
						|
import cv2
 | 
						|
from common import Sketcher
 | 
						|
 | 
						|
class App:
 | 
						|
    def __init__(self, fn):
 | 
						|
        self.img = cv2.imread(fn)
 | 
						|
        h, w = self.img.shape[:2]
 | 
						|
        self.markers = np.zeros((h, w), np.int32)
 | 
						|
        self.markers_vis = self.img.copy()
 | 
						|
        self.cur_marker = 1
 | 
						|
        self.colors = np.int32( list(np.ndindex(2, 2, 2)) ) * 255
 | 
						|
 | 
						|
        self.auto_update = True
 | 
						|
        self.sketch = Sketcher('img', [self.markers_vis, self.markers], self.get_colors)
 | 
						|
 | 
						|
    def get_colors(self):
 | 
						|
        return map(int, self.colors[self.cur_marker]), self.cur_marker
 | 
						|
 | 
						|
    def watershed(self):
 | 
						|
        m = self.markers.copy()
 | 
						|
        cv2.watershed(self.img, m)
 | 
						|
        overlay = self.colors[np.maximum(m, 0)]
 | 
						|
        vis = cv2.addWeighted(self.img, 0.5, overlay, 0.5, 0.0, dtype=cv2.CV_8UC3)
 | 
						|
        cv2.imshow('watershed', vis)
 | 
						|
 | 
						|
    def run(self):
 | 
						|
        while True:
 | 
						|
            ch = 0xFF & cv2.waitKey(50)
 | 
						|
            if ch == 27:
 | 
						|
                break
 | 
						|
            if ch >= ord('1') and ch <= ord('7'):
 | 
						|
                self.cur_marker = ch - ord('0')
 | 
						|
                print 'marker: ', self.cur_marker
 | 
						|
            if ch == ord(' ') or (self.sketch.dirty and self.auto_update):
 | 
						|
                self.watershed()
 | 
						|
                self.sketch.dirty = False
 | 
						|
            if ch in [ord('a'), ord('A')]:
 | 
						|
                self.auto_update = not self.auto_update
 | 
						|
                print 'auto_update if', ['off', 'on'][self.auto_update]
 | 
						|
            if ch in [ord('r'), ord('R')]:
 | 
						|
                self.markers[:] = 0
 | 
						|
                self.markers_vis[:] = self.img
 | 
						|
                self.sketch.show()
 | 
						|
        cv2.destroyAllWindows()
 | 
						|
 | 
						|
 | 
						|
if __name__ == '__main__':
 | 
						|
    import sys
 | 
						|
    try: fn = sys.argv[1]
 | 
						|
    except: fn = '../cpp/fruits.jpg'
 | 
						|
    print __doc__
 | 
						|
    App(fn).run()
 |