fix overwriting variable

This commit is contained in:
Blake Blackshear 2020-08-03 18:03:45 -05:00
parent adcfe699c2
commit 0ae2806eb4

View File

@ -150,10 +150,14 @@ class TrackedObjectProcessor(threading.Thread):
bottom_center = (obj['centroid'][0], obj['box'][3]) bottom_center = (obj['centroid'][0], obj['box'][3])
# check each zone # check each zone
for name, zone in self.zone_data.items(): for name, zone in self.zone_data.items():
# check each camera with a contour for the zone current_contour = zone['contours'].get(camera, None)
for camera, contour in zone['contours'].items(): # if the current camera does not have a contour for this zone, skip
if cv2.pointPolygonTest(contour, bottom_center, False) >= 0 and not zone_filtered(obj, self.zone_config[name][camera].get('filters', {})): if current_contour is None:
current_objects_in_zones[name].append(obj['label']) continue
# check if the object is in the zone and not filtered
if (cv2.pointPolygonTest(current_contour, bottom_center, False) >= 0
and not zone_filtered(obj, self.zone_config[name][camera].get('filters', {}))):
current_objects_in_zones[name].append(obj['label'])
### ###
# Draw tracked objects on the frame # Draw tracked objects on the frame
@ -226,17 +230,17 @@ class TrackedObjectProcessor(threading.Thread):
### ###
# get the zones that are relevant for this camera # get the zones that are relevant for this camera
# TODO: precompute this
relevant_zones = [zone for zone, config in self.zone_config.items() if camera in config] relevant_zones = [zone for zone, config in self.zone_config.items() if camera in config]
# for each zone
for zone in relevant_zones: for zone in relevant_zones:
# create the set of labels in the current frame and previously reported # create the set of labels in the current frame and previously reported
labels_for_zone = set(current_objects_in_zones[zone] + list(self.zone_data[zone]['object_status'][camera].keys())) labels_for_zone = set(current_objects_in_zones[zone] + list(self.zone_data[zone]['object_status'][camera].keys()))
# for each label # for each label
for label in labels_for_zone: for label in labels_for_zone:
# compute the current 'ON' vs 'OFF' status by checking if any camera sees the object in the zone # compute the current 'ON' vs 'OFF' status by checking if any camera sees the object in the zone
previous_state = any([camera[label] == 'ON' for camera in self.zone_data[zone]['object_status'].values()]) previous_state = any([c[label] == 'ON' for c in self.zone_data[zone]['object_status'].values()])
self.zone_data[zone]['object_status'][camera][label] = 'ON' if label in current_objects_in_zones[zone] else 'OFF' self.zone_data[zone]['object_status'][camera][label] = 'ON' if label in current_objects_in_zones[zone] else 'OFF'
new_state = any([camera[label] == 'ON' for camera in self.zone_data[zone]['object_status'].values()]) new_state = any([c[label] == 'ON' for c in self.zone_data[zone]['object_status'].values()])
# if the value is changing, send over MQTT # if the value is changing, send over MQTT
if previous_state == False and new_state == True: if previous_state == False and new_state == True:
self.client.publish(f"{self.topic_prefix}/{zone}/{label}", 'ON', retain=False) self.client.publish(f"{self.topic_prefix}/{zone}/{label}", 'ON', retain=False)