# -*- coding: utf-8 -*-
"""
Created on Tue Dec 30 07:35:33 2014
@author: aaron
"""
#!/usr/bin/env python
#coding=utf-8
import os
from PIL import Image, ImageDraw
import cv
import cv2
def detect_object(image):
'''检测图片,获取人脸在图片中的坐标'''
grayscale = cv.CreateImage((image.width, image.height), 8, 1)
cv.CvtColor(image, grayscale, cv.CV_BGR2GRAY)
cascade = cv.Load("/usr/local/share/OpenCV/haarcascades/haarcascade_eye_tree_eyeglasses.xml")
rect = cv.HaarDetectObjects(grayscale, cascade, cv.CreateMemStorage(), 1.1, 2,
cv.CV_HAAR_DO_CANNY_PRUNING, (20,20))
result = []
for r in rect:
result.append((r[0][0], r[0][1], r[0][0]+r[0][2], r[0][1]+r[0][3]))
return result
def process(infile):
'''在原图上框出头像并且截取每个头像到单独文件夹'''
image = cv.LoadImage(infile);
if image:
faces = detect_object(image)
im = Image.open(infile)
path = os.path.abspath(infile)
save_path = os.path.splitext(path)[0]+"_face"
try:
os.mkdir(save_path)
except:
pass
if faces:
draw = ImageDraw.Draw(im)
count = 0
for f in faces:
count += 1
draw.rectangle(f, outline=(255, 0, 0))
a = im.crop(f)
file_name = os.path.join(save_path,str(count)+".jpg")
# print file_name
a.save(file_name)
drow_save_path = os.path.join(save_path,"out.jpg")
im.save(drow_save_path, "JPEG", quality=80)
img = cv2.imread(drow_save_path)
cv2.imshow('eye',img)
else:
print "Error: cannot detect faces on %s" % infile
if __name__ == "__main__":
cv2.namedWindow('Video')
cv2.namedWindow('eye')
capture = cv2.VideoCapture(0)
_, frame = capture.read()
while frame is not None:
cv2.imshow('Video', frame)
key = cv2.waitKey(10)
cv2.imwrite('screenshot.bmp', frame)
process('screenshot.bmp')
if key == ord('s'): # 当按下"s"键时,将保存当前画面
cv2.imwrite('screenshot.bmp', frame)
process('screenshot.bmp')
elif key == ord('q'): # 当按下"q"键时,将退出循环
cv2.destroyWindow('Video')
break
_, frame = capture.read()
cv2.destroyWindow('Video')
cv2.destroyWindow('eye')
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
opencv-face-master.zip (60个子文件)
opencv-face-master
opencvtest.py 2KB
face.py 2KB
testopencv.py 553B
screenshot_face
out.jpg 31KB
40.jpg 1005B
43.jpg 1KB
44.jpg 2KB
2.jpg 1KB
41.jpg 952B
42.jpg 1KB
27.jpg 2KB
10.jpg 726B
28.jpg 1KB
47.jpg 1KB
25.jpg 2KB
13.jpg 782B
39.jpg 4KB
46.jpg 1KB
14.jpg 796B
30.jpg 1KB
6.jpg 908B
22.jpg 982B
15.jpg 869B
16.jpg 962B
45.jpg 1KB
36.jpg 2KB
1.jpg 825B
48.jpg 1KB
17.jpg 930B
35.jpg 1KB
21.jpg 924B
52.jpg 1KB
23.jpg 974B
26.jpg 1KB
12.jpg 851B
32.jpg 952B
5.jpg 771B
50.jpg 3KB
54.jpg 2KB
8.jpg 866B
24.jpg 1KB
56.jpg 5KB
20.jpg 1KB
18.jpg 877B
11.jpg 963B
29.jpg 1KB
31.jpg 1KB
37.jpg 2KB
19.jpg 1011B
38.jpg 1KB
49.jpg 2KB
33.jpg 977B
3.jpg 1KB
53.jpg 2KB
7.jpg 1KB
51.jpg 5KB
9.jpg 823B
55.jpg 4KB
4.jpg 1KB
34.jpg 1KB
共 60 条
- 1
资源评论
程序员柳
- 粉丝: 6597
- 资源: 1443
下载权益
C知道特权
VIP文章
课程特权
开通VIP
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功