本文整理匯總了Python中Point.Point.set_on方法的典型用法代碼示例。如果您正苦於以下問題:Python Point.set_on方法的具體用法?Python Point.set_on怎麽用?Python Point.set_on使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Point.Point
的用法示例。
在下文中一共展示了Point.set_on方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: LaserMote
# 需要導入模塊: from Point import Point [as 別名]
# 或者: from Point.Point import set_on [as 別名]
#.........這裏部分代碼省略.........
Displays debug text and draws a circle on detected laser point.
:param laser: image containing only laser dot (i.e image within our threshold).
:param frame: frame to display and writing debug text on.
:return: frame.
"""
contours, hierarchy = cv2.findContours(
laser, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
found_valid_point = False
for cnt in contours:
area = cv2.contourArea(cnt)
M = cv2.moments(cnt)
# check if the contour is withing the area threshold
if self.min_area < area < self.max_area:
cx = int(M['m10'] / M['m00'])
cy = int(M['m01'] / M['m00'])
# if self.debug:
# print "within threshold " + str(area)
if self.point.was_seen() \
: # and self.get_distance(cx, cy) <= self.distance_threshold:
if self.debug:
print "[DEBUG] Distance between last seen point ({0},{1})" \
" and current point ({2},{3}) :{4}".format(str(self.point.last_seen_x),
str(self.point.last_seen_y),
str(cx), str(cy),
str(self.get_distance(cx, cy)))
# update last point locations
self.point.update_last_seen_position(cx, cy)
self.point.set_on()
self.point.current_object = self.is_dot_within_rois(cx, cy)
# cv2.drawContours(frame, cnt, -1, GREEN, 15) # draws the contour
cv2.circle(frame, (cx, cy), 1, GREEN, thickness=4, lineType=8, shift=0) # circle cnt center
elif not self.point.was_seen():
# cv2.drawContours(frame, cnt, -1, BLUE, 15) # draws the contour
self.point.set_on()
self.point.update_last_seen_position(cx, cy)
self.point.current_object = self.is_dot_within_rois(cx, cy)
if self.debug:
print '[DEBUG] First seen point is at: ({0},{1}).'.format(str(cx), str(cy))
print '[DEBUG] Updated last seen coordinates.'
cv2.putText(
frame,
self.debug_text(cx, cy, area, found=True), LaserMote.BOTTOM_LEFT_COORD,
cv2.FONT_HERSHEY_SIMPLEX, 0.5, WHITE, 1)
found_valid_point = True
break # only one contour
if not found_valid_point:
cv2.putText(frame, self.debug_text(),
LaserMote.BOTTOM_LEFT_COORD, cv2.FONT_HERSHEY_SIMPLEX, 0.5, WHITE, 1)
if self.point.is_on() and self.point.was_seen():
current_object = self.is_dot_within_rois(self.point.last_seen_x, self.point.last_seen_y)
self.point.set_off(current_object)
return frame