-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy path优先绿点后黑点.py
112 lines (102 loc) · 3.54 KB
/
优先绿点后黑点.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import sensor, image, time, pyb
from pyb import UART
uart = UART(3, 57600)#timeout_char =10
from pyb import Pin
p8_pin = pyb.Pin.board.P8
p8_pin.init(Pin.IN,Pin.PULL_UP)
sensor.reset() # 初始化摄像头
sensor.set_pixformat(sensor.RGB565) # 格式为 RGB565.
sensor.set_framesize(sensor.QQVGA) # 使用 QQVGA 速度快一些
sensor.set_auto_whitebal(False)
clock = time.clock() # 追踪帧率
a=1
position_X=80
position_Y=60
new_point_ready = 0
Has_dected_piont =0
detect_mode = 1# 1黑色 0彩色
def led_blink(x):
led = pyb.LED(x)
led.on()
time.sleep(5)
led.off()
def send_position():
if (new_point_ready):
uart.writechar(0xFF)
uart.writechar(position_X)
uart.writechar(position_Y)
if (detect_mode == 0):
uart.writechar(0xFD)
led_blink(3)
else:
led_blink(3)
else:
if (detect_mode == 0):
uart.writechar(0xFE)
tim4 = pyb.Timer(4) # create a timer object using timer 4
tim4.init(freq=50) # trigger at 50Hz
tim4.callback(lambda t:send_position())
def find_max(blobs):
max_size=0
for blob in blobs:
if blob.pixels() > max_size:
max_blob=blob
max_size = blob.pixels()
return max_blob
while(True):
if p8_pin.value():
detect_mode = 1
blob_thresholds=(0, 54, -10, 13, -5, 24)#黑色
else:
detect_mode = 0
blob_thresholds=(14, 73, -70, -21, -5, 53)#绿色
img = sensor.snapshot() # 从感光芯片获得一张图像
clock.tick() # Track elapsed milliseconds between snapshots().
blobs = img.find_blobs([blob_thresholds])
if blobs:
b=find_max(blobs)
if b.pixels()/(b.w()*b.h())>0.60 and b.pixels()>160:
new_point_ready = 1
Has_dected_piont = 1
img.draw_rectangle(b[0:4],color=(0,0,255)) # rect
#用矩形标记出目标颜色区域
img.draw_cross(b[5], b[6]) # cx, cy
#在目标颜色区域的中心画十字形标记
print ("主点位置X= %d,Y=%d" %(b[5], b[6]))
position_X=b[5]
position_Y=b[6]
else:
new_point_ready = 0
if detect_mode or Has_dected_piont:
continue
else:
black_thresholds=(0, 54, -10, 13, -5, 24)#黑色
blobs_B = img.find_blobs([black_thresholds])
if blobs_B:
bB=find_max(blobs_B)
if bB.pixels()>160 and bB.pixels()/(bB.w()*bB.h())>0.60:
img.draw_rectangle(bB[0:4],color=(0,0,255)) # rect
#用矩形标记出目标颜色区域
img.draw_cross(bB[5], bB[6]) # cx, cy
print ("副点位置X= %d,Y=%d" %(bB[5], bB[6]))
new_point_ready = 1
position_X=bB[5]
position_Y=bB[6]
else:
new_point_ready = 0
if detect_mode or Has_dected_piont:
continue
else:
black_thresholds=(0, 54, -10, 13, -5, 24)#黑色
blobs_B = img.find_blobs([black_thresholds])
if blobs_B:
bB=find_max(blobs_B)
if bB.pixels()>160 and bB.pixels()/(bB.w()*bB.h())>0.60:
img.draw_rectangle(bB[0:4],color=(0,0,255)) # rect
#用矩形标记出目标颜色区域
img.draw_cross(bB[5], bB[6]) # cx, cy
print ("副点位置X= %d,Y=%d" %(bB[5], bB[6]))
new_point_ready = 1
position_X=bB[5]
position_Y=bB[6]
print(clock.fps())