python结合opencv实现人脸检测与跟踪


Posted in Python onJune 08, 2015

模式识别课上老师留了个实验,在VC++环境下利用OpenCV库编程实现人脸检测与跟踪。

然后就开始下载opencv和vs2012,再然后,配置了好几次还是配置不成功,这里不得不吐槽下微软,软件做这么大,这么难用真的好吗?

于是就尝试了一下使用python完成实验任务,大概过程就是这样子的:

首先,配置运行环境:

下载opencv和python的比较新的版本,推荐opencv2.4.X和python2.7.X。

直接去官网下载就ok了,python安装时一路next就行,下载的opencv.exe文件运行后基本上是一个解压的过程,自己选择一个解压路径(尽量不要出现中文),然后就坐等解压完成。

然后从opencv解压后的路径中找(D:\My Documents\Downloads)\opencv\build\python\2.7\x86,()里面的部分是你自己的安装路径,其中x86对应32位的机器,x64代表64位的机器,当然要按照你机器的实际情况选择了。将这个路径里面的cv2.pyd拷贝至python2.7的模块路径C:\Python27\Lib\site-packages里,python2.7默认安装在C盘跟目录下。

此时打开python,在cmd下输入python,或者直接打开“所有程序->active state active python->Python Interactive Shell”都行。

接下来输入import cv2,出错了对不对?为什么呢?

这是因为没有安装numpy这个python模块,去numpy的官网下载一个比较新的版本,因为最新的版本一般都是源代码,需要去命令行中安装,比较麻烦,推荐找一个exe文件。注意,在官网给出的链接中,切记看完全名称,后面一般都会提示这个模块在哪个python版本下安装时比较和谐,选择你自己安装的python版本对应的numpy模块。下载完成后安装时看一下该模块给出的python路径对不对,对的话然后next就行了,不对的话可能就是你的python是2.7,却下了numpy for python 3.0.

这时再去import一下cv2,如果什么也没有输出的话就是import成功了。

简直比vs下的配置简单了好几个数量级,对不对?

配置好环境后,跟着opencv嗨起来!

然后在pythonwin或idle(python gui)下新建一个py文件,输入以下代码:

import cv2
import numpy as np
cv2.namedWindow("test")
cap=cv2.VideoCapture(0)
success,frame=cap.read()
classifier=cv2.CascadeClassifier("haarcascade_frontalface_alt.xml")   #确保此xml文件与该py文件在一个文件夹下,否则将这里改为绝对路径,此xml文件可在D:\My Documents\Downloads\opencv\sources\data\haarcascades下找到。

while success:
success,frame=cap.read()

size=frame.shape[:2]

image=np.zeros(size,dtype=np.float16)

image=cv2.cvtColor(frame,cv2.cv.CV_BGR2GRAY)

cv2.equalizeHist(image,image)

divisor=8

h,w=size

minSize=(w/divisor,h/divisor)

faceRects=classifier.detectMultiScale(image,1.2,2,cv2.CASCADE_SCALE_IMAGE,minSize)

if len(faceRects)>0:


for faceRect in faceRects:



x,y,w,h=faceRect



cv2.circle(frame,(x+w/2,y+h/2),min(w/2,h/2),(255,0,0))



cv2.circle(frame,(x+w/4,y+h/4),min(w/8,h/8),(255,0,0))



cv2.circle(frame,(x+3*w/4,y+h/4),min(w/8,h/8),(255,0,0))



cv2.rectangle(frame,(x+3*w/8,y+3*h/4),(x+5*w/8,y+7*h/8),(255,0,0))

cv2.imshow("test",frame) 

key=cv2.waitKey(10)

c=chr(key&255)

if c in ['q','Q',chr(27)]:


break
cv2.destroyWindow("test")

为什么没有注释,你恐怕知道下雨天,dir()和help()更配呦。

这段代码的功能就是对计算机摄像头拍到的视频加以处理,使其显示并追踪人脸。下图是运行效果:

python结合opencv实现人脸检测与跟踪

最后再说一句,这个过程说起来简单,但很容易出错,希望大家能自己找到错误的原因,并解决错误。如果自己解决不了的话,不妨把问题贴在评论里,大家来共同解决,共同进步。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Python 相关文章推荐
python多线程编程中的join函数使用心得
Sep 02 Python
python subprocess 杀掉全部派生的子进程方法
Jan 16 Python
Python实现PS图像调整黑白效果示例
Jan 25 Python
pip安装py_zipkin时提示的SSL问题对应
Dec 29 Python
Django实现发送邮件功能
Jul 18 Python
python子线程退出及线程退出控制的代码
Oct 16 Python
Python中的sys.stdout.write实现打印刷新功能
Feb 21 Python
Python3 xml.etree.ElementTree支持的XPath语法详解
Mar 06 Python
动态设置django的model field的默认值操作步骤
Mar 30 Python
python操作yaml说明
Apr 08 Python
Spring http服务远程调用实现过程解析
Jun 11 Python
python异步的ASGI与Fast Api实现
Jul 16 Python
python实现数值积分的Simpson方法实例分析
Jun 05 #Python
python采集百度百科的方法
Jun 05 #Python
python中引用与复制用法实例分析
Jun 04 #Python
Python进程间通信用法实例
Jun 04 #Python
python中__slots__用法实例
Jun 04 #Python
python协程用法实例分析
Jun 04 #Python
Python获取系统默认字符编码的方法
Jun 04 #Python
You might like
Yii中CGridView禁止列排序的设置方法
2016/07/12 PHP
PHP实现将几张照片拼接到一起的合成图片功能【便于整体打印输出】
2017/11/14 PHP
php DES加密算法实例分析
2019/09/18 PHP
日期函数扩展类Ver0.1.1
2006/09/07 Javascript
Javascript下的keyCode键码值表
2007/04/10 Javascript
解析JavaScript中的标签语句
2013/06/19 Javascript
javascript中简单的进制转换代码实例
2013/10/26 Javascript
jquery如何通过name名称获取当前name的value值
2013/12/20 Javascript
jQuery判断数组是否包含了指定的元素
2015/03/10 Javascript
使用JQuery实现Ctrl+Enter提交表单的方法
2015/10/22 Javascript
基于JavaScript代码实现微信扫一扫下载APP
2015/12/30 Javascript
JS实现合并json对象的方法
2017/10/10 Javascript
webpack+express实现文件精确缓存的示例代码
2020/06/11 Javascript
微信小程序实现身份证取景框拍摄
2020/09/09 Javascript
vue下载二进制流图片操作
2020/10/26 Javascript
Python 用户登录验证的小例子
2013/03/06 Python
Python的print用法示例
2014/02/11 Python
在Python中封装GObject模块进行图形化程序编程的教程
2015/04/14 Python
Pandas 数据框增、删、改、查、去重、抽样基本操作方法
2018/04/12 Python
python面向对象入门教程之从代码复用开始(一)
2018/12/11 Python
对python中xlsx,csv以及json文件的相互转化方法详解
2018/12/25 Python
Django之提交表单与前后端交互的方法
2019/07/19 Python
使用 Python 快速实现 HTTP 和 FTP 服务器的方法
2019/07/22 Python
Python 二叉树的层序建立与三种遍历实现详解
2019/07/29 Python
python实现桌面托盘气泡提示
2019/07/29 Python
Django之编辑时根据条件跳转回原页面的方法
2019/08/21 Python
python 二维矩阵转三维矩阵示例
2019/11/30 Python
Python可变对象与不可变对象原理解析
2020/02/25 Python
IntelliJ 中配置 Anaconda的过程图解
2020/06/01 Python
python3实现飞机大战
2020/11/29 Python
芬兰灯具网上商店:Nettilamppu.fi
2018/06/30 全球购物
总经理岗位职责范本
2014/02/02 职场文书
咖啡店创业计划书范文
2014/09/15 职场文书
演讲开场白和结束语
2015/05/29 职场文书
病房管理制度范本
2015/08/06 职场文书
解决Pytorch中关于model.eval的问题
2021/05/22 Python