No tutorial explicando sobre o reconhecimento de face (LINKAR AQUI) foi explicado sobre o uso do arquivo haar cascade e como fazer o uso dele para fazer o reconhecimento de um rosto.
Em princípio, para detectar qualquer tipo de elemento basta ter o arquivo cascade correspondente e o algoritmo é o mesmo, sofrendo apenas ajustes nos parâmetros para melhor desempenho nas identificações.
Os arquivos utilizados podem ser baixados aqui ou em https://github.com/Itseez/opencv/tree/master/data/haarcascades. No segundo link também é possível encontrar outros arquivos cascade para utilizar, podendo fazer a detecção de olhos com óculos, parte superior e inferior do corpo, corpo inteiro, sorriso, etc.
O código a seguir estende o mostrado no reconhecimento de face adicionando o reconhecimento dos olhos. Para isso foi criado mais um classificador, tendo um para a face e outro para os olhos.
A utilização do método detectMultiScale() e feita com a mesma imagem capturada da webcam, mas com configurações diferentes, sendo deixado o tamanho mínimo e máximo para a detecção dos olhos menor do que a da detecção da face.
Para a face é desenhado um retângulo verde e para os olhos são desenhados retângulos na cor azul.
import cv2
arqCasc1 = 'haarcascade_frontalface_default.xml'
arqCasc2 = 'haarcascade_eye.xml'
faceCascade1 = cv2.CascadeClassifier(arqCasc1) #classificador para o rosto
faceCascade2 = cv2.CascadeClassifier(arqCasc2) #classificador para os olhos
webcam = cv2.VideoCapture(0) #instancia o uso da webcam
while True:
s, imagem = webcam.read() #pega efeticamente a imagem da webcam
imagem = cv2.flip(imagem,180) #espelha a imagem
faces = faceCascade1.detectMultiScale(
imagem,
minNeighbors=20,
minSize=(30, 30),
maxSize=(300,300)
)
olhos = faceCascade2.detectMultiScale(
imagem,
minNeighbors=20,
minSize=(10, 10),
maxSize=(90,90)
)
# Desenha um retangulo nas faces e olhos detectados
for (x, y, w, h) in faces:
cv2.rectangle(imagem, (x, y), (x+w, y+h), (0, 255, 0), 4)
for (x, y, w, h) in olhos:
cv2.rectangle(imagem, (x, y), (x+w, y+h), (255, 0, 0), 2)
cv2.imshow('Video', imagem) #mostra a imagem captura na janela
#o trecho seguinte e apenas para parar o codigo e fechar a janela
if cv2.waitKey(1) & 0xFF == ord('q'):
break
webcam.release() #dispensa o uso da webcam
cv2.destroyAllWindows() #fecha todas a janelas abertas
Como treinar o objeto em python para openCV? Alguma dica ou tutorial?
Como posso reconhecer objetos,exemplo um pneu em uma imagem ?
O openCV tem uma função para detecção de círculos. Dê uma conferida no link:
http://docs.opencv.org/2.4/doc/tutorials/imgproc/imgtrans/hough_circle/hough_circle.html