-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathdemo_pre_seg__felz_slic.py
73 lines (56 loc) · 2.28 KB
/
demo_pre_seg__felz_slic.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
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
import cv2
from skimage import segmentation
mark_boundaries = segmentation.mark_boundaries
def press_wasdqe_to_adjust_parameter_of_felz(img):
paras = [64, 0.5, 128] # pieces
# paras = [1, 0.8, 20] # default
act_dict = {0: (0, 1.0)}
act_dict.update(zip([119, 97, 113], [(i, 1.2) for i in range(len(paras))], )) # _KeyBoard: W A Q
act_dict.update(zip([115, 100, 101], [(i, 0.8) for i in range(len(paras))], )) # KeyBoard: S D E
key = 0
while True:
if key != -1:
i, multi = act_dict[key]
paras[i] *= multi
print(key, paras)
seg_map = segmentation.felzenszwalb(img,
scale=int(paras[0]),
sigma=paras[1],
min_size=int(paras[2]))
show = mark_boundaries(img, seg_map)
cv2.imshow('', show)
wait_time = 1
else:
wait_time = 100
key = cv2.waitKey(wait_time)
break
cv2.imwrite('tiger_felz.jpg', show * 255)
def press_wasdqe_to_adjust_parameter_of_slic(img):
paras = [100, 10000, 10] # pieces
# paras = [100, 10, 10] # default
# paras = [16, 64, 6] # appropriate
act_dict = {0: (0, 1.0)}
act_dict.update(zip([119, 97, 113], [(i, 1.2) for i in range(len(paras))], )) # _KeyBoard: W A Q
act_dict.update(zip([115, 100, 101], [(i, 0.8) for i in range(len(paras))], )) # KeyBoard: S D E
key = 0
while True:
if key != -1:
i, multi = act_dict[key]
paras[i] *= multi
print(key, paras)
seg_map = segmentation.slic(img,
compactness=int(paras[0]),
n_segments=int(paras[1]),
max_iter=int(paras[2]), )
show = mark_boundaries(img, seg_map)
cv2.imshow('', show)
wait_time = 1
else:
wait_time = 100
key = cv2.waitKey(wait_time)
# break
# cv2.imwrite('tiger_slic.jpg', show * 255)
if __name__ == '__main__':
image = cv2.imread('image/tiger.jpg')
press_wasdqe_to_adjust_parameter_of_felz(image)
# press_wasdqe_to_adjust_parameter_of_slic(image)