2014-04-13 50 views
1

我是一个新的python。我试图检测脸部并找出脸部的边界。 如何制作它?它可以是许多点是脸部的边界。检测脸部,获取脸部的边框

我想获得这样的事:

enter image description here

+2

欢迎这样的! - )如果下面的答案之一解决了您的问题,您应该接受它(点击相应答案旁边的复选标记)。这有两件事。它可以让每个人都知道你的问题已经得到解决,并且可以帮助你获得帮助。请参阅[此处](http://meta.stackexchange.com/a/5235/187716)以获取完整说明 –

回答

0

http://fideloper.com/facial-detection

我们可以使用OpenCV的面部检测。 OpenCV是用C编写的,但 还有bindings for Python,实际上是PHP。

import cv2 

def detect(path): 
    img = cv2.imread(path) 
    cascade = cv2.CascadeClassifier("/vagrant/detect/haarcascade_frontalface_alt.xml") 
    rects = cascade.detectMultiScale(img, 1.3, 4, cv2.cv.CV_HAAR_SCALE_IMAGE, (20,20)) 

    if len(rects) == 0: 
     return [], img 
    rects[:, 2:] += rects[:, :2] 
    return rects, img 

def box(rects, img): 
    for x1, y1, x2, y2 in rects: 
     cv2.rectangle(img, (x1, y1), (x2, y2), (127, 255, 0), 2) 
    cv2.imwrite('/vagrant/img/detected.jpg', img); 

rects, img = detect("/vagrant/img/one.jpg") 
box(rects, img) 

原始图像: enter image description here

随着脸检测 enter image description here

+0

我知道这一点,但我想在不像矩形的表单行中获得边框。我想获得更精确的界限。我想获得这样的东西http://my-files.ru/sxy798 – NAlmaz

+0

ок,我在等待答案 – NAlmaz