Python을 사용하여 사진에서 대상 추적을 수행하는 방법
대상 추적은 컴퓨터 비전 분야의 중요한 응용 프로그램 중 하나이며 이미지 데이터의 연속 프레임에서 특정 대상을 추적할 수 있습니다. Python은 목표 추적을 상대적으로 쉽게 만드는 많은 라이브러리와 도구를 제공하는 강력한 프로그래밍 언어입니다. 이 기사에서는 Python과 OpenCV 라이브러리를 사용하여 이미지에서 객체 추적을 수행하는 방법을 소개합니다.
먼저 코드 작성을 시작하기 전에 OpenCV 라이브러리를 설치해야 합니다. 다음 명령을 사용하여 설치할 수 있습니다:
pip install opencv-python
다음으로 Python으로 목표 추적을 구현하는 코드를 작성하겠습니다. 다음은 OpenCV를 사용하여 이미지의 파란색 개체를 추적하는 방법을 보여주는 간단한 코드 예제입니다.
import cv2 import numpy as np # 定义蓝色的HSV范围 lower_blue = np.array([90, 50, 50]) upper_blue = np.array([130, 255, 255]) # 初始化摄像头 cap = cv2.VideoCapture(0) while True: # 读取摄像头捕获的图像 ret, frame = cap.read() # 将图像从BGR转换为HSV颜色空间 hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV) # 创建一个掩膜,将满足蓝色范围内的像素点设置为白色(255),其余设置为黑色(0) mask = cv2.inRange(hsv, lower_blue, upper_blue) # 对掩膜进行模糊处理,以去除噪声 mask = cv2.blur(mask, (5, 5)) # 找到图像中的轮廓 contours, _ = cv2.findContours(mask, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) if len(contours) > 0: # 找到最大的轮廓 max_contour = max(contours, key=cv2.contourArea) # 计算最小外接矩形 x, y, w, h = cv2.boundingRect(max_contour) # 在图像上绘制矩形 cv2.rectangle(frame, (x, y), (x+w, y+h), (0, 255, 0), 2) # 显示图像 cv2.imshow("Tracking", frame) # 按下ESC键退出循环 if cv2.waitKey(1) == 27: break # 释放摄像头和窗口 cap.release() cv2.destroyAllWindows()
위 코드에서는 먼저 파란색 HSV 범위를 정의합니다. 그런 다음 카메라를 초기화하고 무한 루프에서 이미지를 읽습니다. 각 루프 반복에서 이미지를 BGR에서 HSV로 변환하고 마스크를 생성한 다음 마스크를 흐리게 처리하여 노이즈를 제거합니다. 다음으로, 이미지에서 윤곽선을 찾고 가장 큰 윤곽선을 찾습니다. 그런 다음 최소 둘러싸는 직사각형을 계산하고 이미지에 해당 직사각형을 그립니다. 마지막으로 추적 결과를 표시하고 ESC 키를 누르면 루프를 종료합니다. 마지막으로 카메라를 놓고 창을 닫습니다.
위 코드를 사용하면 카메라에 포착된 이미지에서 파란색 물체를 추적할 수 있습니다. 물론, 다른 색상의 객체를 추적하려면 HSV 범위를 파란색으로 변경하면 됩니다.
요약하자면 Python 및 OpenCV 라이브러리는 이미지 처리 및 대상 추적을 위한 여러 가지 편리한 방법을 제공합니다. 해당 코드를 작성하면 이미지에서 관심 있는 객체를 쉽게 추적할 수 있습니다. 이 기사가 목표 추적을 시작하고 Python에서 이 흥미로운 작업을 구현하는 데 도움이 되기를 바랍니다.
위 내용은 사진의 표적 추적을 위해 Python을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!