當前位置: 首頁>>代碼示例>>Python>>正文


Python Point.set_on方法代碼示例

本文整理匯總了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
開發者ID:seanjensengrey,項目名稱:LaserMote,代碼行數:70,代碼來源:LaserMote.py


注:本文中的Point.Point.set_on方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。