时间:2021-05-22
在深度学习过程中想做手势识别相关应用,需要大量采集手势图片进行训练,作为一个懒人当然希望飞快的连续采集图片并且采集到的图片就已经被处理成统一格式的啦。。于是使用python+openCV调用摄像头,在采集图片的同时顺便处理成想要的格式。
详细代码如下:
import cv2import osprint("=============================================")print("= 热键(请在摄像头的窗口使用): =")print("= z: 更改存储目录 =")print("= x: 拍摄图片 =")print("= q: 退出 =")print("=============================================")print()class_name = input("请输入存储目录:")while os.path.exists(class_name): class_name = input("目录已存在!请输入存储目录:")os.mkdir(class_name)index = 1cap = cv2.VideoCapture(0)width = 640height = 480w = 360cap.set(cv2.CAP_PROP_FRAME_WIDTH, width)cap.set(cv2.CAP_PROP_FRAME_HEIGHT, height)crop_w_start = (width-w)//2crop_h_start = (height-w)//2print(width, height)while True: # get a frame ret, frame = cap.read() # show a frame frame = frame[crop_h_start:crop_h_start+w, crop_w_start:crop_w_start+w] frame = cv2.flip(frame,1,dst=None) cv2.imshow("capture", frame) input = cv2.waitKey(1) & 0xFF if input == ord('z'): class_name = input("请输入存储目录:") while os.path.exists(class_name): class_name = input("目录已存在!请输入存储目录:") os.mkdir(class_name) elif input == ord('x'): cv2.imwrite("%s/%d.jpeg" % (class_name, index), cv2.resize(frame, (224, 224), interpolation=cv2.INTER_AREA)) print("%s: %d 张图片" % (class_name, index)) index += 1 if input == ord('q'): break cap.release()cv2.destroyAllWindows()要点记录:
当前版本opencv-python(3.4.3.18)中摄像头有关属性为cv2.XXXX,其获取和设置函数分别如下:(以帧的宽和高为例)
帧宽和高默认为640x480(这是窗口的大小),画面比例为显示器分辨率,例如我的显示器分辨率为1920x1080,则摄像头画面以640x360的大小显示在窗口中央,并用黑边填充上下部分,摄像头画面长宽比似乎无法被改变
read得到的帧(frame )可以视为普通的图像来处理,本质上这个程序就是不断read一张图片并显示在窗口上,因此可以使用opencv有关图像处理的各种函数对frame进行操作并显示,我这里就是使用这个原理裁剪frame,使摄像头画面显示成正方形
前置摄像头获取的画面是非镜面的,即左手会出现在画面的右侧,此处使用flip进行水平镜像处理
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
利用Python+opencv实现从摄像头捕获图像,识别其中的人眼/人脸,并打上马赛克。系统环境:Windows7+Python3.6.3+opencv3.4.
Python+opencv读取视频的三种情况:情况一:通过摄像头采集视频情况二:通过本地视频文件获取视频情况三:通过摄像头录制视频,再读取录制的视频摄像头采集、
本文实现了用Python和OpenCV配合,调用本地摄像头采集视频,基本上函数的话看opencv的官方文档就Ok了(TheOpenCVReferenceManu
使用Python+OpenCV实现实时眼动追踪,不需要高端硬件简单摄像头即可实现,效果图如下所示。项目演示参见:https:///video/av7518196
前言:vue调用本地摄像头实现拍照功能,由于调用摄像头有使用权限,只能在本地运行,线上需用https域名才可以使用。实现效果:1、摄像头效果:2、拍照效果:实现