скрипт на Python с использованием библиотеки OpenCV для обнаружения динамического объекта по цвету и выполнения клика по нему. Скрипт будет искать объект заданного цвета в реальном времени с веб-камеры и выполнять клик мышью, когда объект будет найден.
Убедитесь, что у вас установлены необходимые библиотеки:
pip install opencv-python pyautogui
код скрипта:
import cv2
import numpy as np
import pyautogui
# Задаем диапазон цвета для обнаружения (в формате HSV)
# В данном случае, диапазон для синего цвета
lower_color = np.array([100, 150, 0])
upper_color = np.array([140, 255, 255])
# Открываем видеопоток с веб-камеры
cap = cv2.VideoCapture(0)
while True:
ret, frame = cap.read()
if not ret:
break
# Преобразуем изображение из BGR в HSV
hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
# Маска для фильтрации по цвету
mask = cv2.inRange(hsv, lower_color, upper_color)
# Находим контуры
contours, _ = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
for contour in contours:
# Игнорируем мелкие объекты
if cv2.contourArea(contour) < 500:
continue
# Находим минимальный описывающий прямоугольник
x, y, w, h = cv2.boundingRect(contour)
# Рисуем прямоугольник вокруг объекта
cv2.rectangle(frame, (x, y), (x + w, y + h), (0, 255, 0), 2)
# Переводим координаты центра прямоугольника в экранные координаты
screen_x = int((x + x + w) / 2)
screen_y = int((y + y + h) / 2)
# Выполняем клик
pyautogui.click(screen_x, screen_y)
# После клика можем выйти из цикла, если хотим
break
# Отображаем результат
cv2.imshow('Frame', frame)
# Выход из цикла по нажатию 'q'
if cv2.waitKey(1) & 0xFF == ord('q'):
break
# Освобождаем ресурсы
cap.release()
cv2.destroyAllWindows()
Этот скрипт захватывает видео с веб-камеры, преобразует его в цветовое пространство HSV, создает маску для заданного диапазона цвета и находит контуры объектов этого цвета. Когда обнаруживается объект соответствующего цвета, на экране выполняется клик мыши по его центру.
Напишите плиз скрипт на обнаружение динамического объекта основываясь на цвете и далее клику по нему