import cv2 def get_keypoint_from_image(img): """ convert image int hsv creates a mask for brown color uses blob detection to find a blob in the mask filter the blobs to find the correct one :param img: rgb image :return: location of the pixel which is used to detect different fishing states """ # Setup SimpleBlobDetector parameters. hsv_img = cv2.cvtColor(img, cv2.COLOR_RGB2HSV) lower = (99, 254, 100) upper = (100, 255, 101) mask = cv2.inRange(hsv_img, lower, upper) # Setup SimpleBlobDetector parameters. params = cv2.SimpleBlobDetector_Params() # Change thresholds params.minThreshold = 10 params.maxThreshold = 255 params.filterByColor = True params.blobColor = 255 params.filterByCircularity = False params.filterByConvexity = False params.filterByInertia = False params.filterByArea = True params.minArea = 10.0 detector = cv2.SimpleBlobDetector_create(params) # Detect blobs. key_points = detector.detect(mask) if len(key_points) <= 0: return None return int(key_points[0].pt[0]), int(key_points[0].pt[1]) class PixelLoc: """ finds the pixel loc and store it """ val = None @staticmethod def config(): """ Uses the game window to get an image of the game screen then uses `GetKeypointFromImage()` to find the ProvisionsChalutier pixel location :return: false if pixel loc not found """ PixelLoc.val = (0, 0, 1, 1) return True