当前位置: 首页 > news >正文

西安建站价格高站网站建设

西安建站价格,高站网站建设,湘潭建设路街道网站,网站建设服务合同范本文章目录 前言一、实现思路?二、Coding三、实现效果 前言 前面几篇文章我们尝试了使用opencv完成图像人脸识别以及识别后贴图或者打马赛克的方法。 偶尔我们也会有需求在视频中将人脸马赛克化,opencv也提供了相应的方法来实现这个功能。 一、实现思路&a…

文章目录

  • 前言
  • 一、实现思路?
  • 二、Coding
  • 三、实现效果


前言

前面几篇文章我们尝试了使用opencv完成图像人脸识别以及识别后贴图或者打马赛克的方法。
偶尔我们也会有需求在视频中将人脸马赛克化,opencv也提供了相应的方法来实现这个功能。


一、实现思路?

视频究其本质是图像按照一定的帧率去播放。如果需要将视频中的人脸马赛克化,那么我们可以逐帧输出图像后进行识别人脸再对其马赛克化,最终将所有的图像再按一定的帧率组合播放。

二、Coding

#识别视频人脸并增加马赛克
#实现原理:cv2读取视频后逐帧识别人脸并增加马赛克/贴图,处理完毕后保存视频import cv2
# laod opencv schema
classifier = cv2.CascadeClassifier("haarcascade_frontalface_alt2.xml")#实践下来貌似这个schema匹配度最高
blockimg = "block.jpg"#贴图路径#马赛克化
def do_mosaic(frame, x, y, w, h, neighbor=20):fh, fw = frame.shape[0], frame.shape[1]if (y + h > fh) or (x + w > fw):returnfor i in range(0, h - neighbor, neighbor):  # 关键点0 减去neightbour 防止溢出for j in range(0, w - neighbor, neighbor):rect = [j + x, i + y, neighbor, neighbor]color = frame[i + y][j + x].tolist()  # 关键点1 tolistleft_up = (rect[0], rect[1])right_down = (rect[0] + neighbor - 1, rect[1] + neighbor - 1)  # 关键点2 减去一个像素cv2.rectangle(frame, left_up, right_down, color, -1)#贴图处理
def do_blockpic(frame, x, y, w, h):resizeimg = cv2.imread(blockimg)resizeimg_f = cv2.resize(resizeimg,(w,h))frame[y:y+h, x:x+w] = resizeimg_f#识别人脸
def do_identifyFace(frame):color = (0, 255, 0)gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)  # convert to grey# begin to identify facefaceRects = classifier.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=3, minSize=(32, 32))if len(faceRects):  # get faces if above zerofor faceRect in faceRects:  # loop each facex, y, w, h = faceRect#do_blockpic(frame, x, y, w, h)do_mosaic(frame, x, y, w, h)#main starts
srcVideo = "srcVideo.mp4"#源视频
savedVideo = "savedVideo.mp4"#处理后的视频
cap = cv2.VideoCapture(srcVideo)if not cap.isOpened():print("error to open source video")exit()print("got source video")
w = cap.get(cv2.CAP_PROP_FRAME_WIDTH)
h = cap.get(cv2.CAP_PROP_FRAME_HEIGHT)
fps = cap.get(cv2.CAP_PROP_FPS)
fcount = cap.get(cv2.CAP_PROP_FRAME_COUNT)
print("total frames %s"%fcount)#获取所有帧数
writer = cv2.VideoWriter(savedVideo, cv2.VideoWriter_fourcc('m', 'p', '4', 'v'), int(fps), (int(w), int(h)))print("start handle source video")
i = 0
while cap.isOpened():success, frame = cap.read()while success:do_identifyFace(frame)print("finish frame %s"%i)writer.write(frame)#cv2.imwrite("frame%s.jpg"%i, frame)i += 1success, frame = cap.read()if (cv2.waitKey(20) & 0xff) == ord('q'):breakcap.release()print("finish handle source video")
writer.release()
cv2.destroyAllWindows()

三、实现效果

处理后的视频效果

http://www.yayakq.cn/news/59998/

相关文章:

  • 受欢迎的网站建设平台镇江网站建设
  • 有没有学做家具的网站建设工程资料下载网站
  • 南昌seo网站推广费用网站备案信息
  • 网站关键词优化公司哪家好莱芜网站优化排名
  • 化妆品企业网站建设的缺点个人网站规划书模板
  • 网站建设意义模板wordpress手机适应
  • 淡水网站建设定制网站开发后台做些什么
  • 三金网手机网站wordpress做支付
  • 重庆建设网站的公司简介千锋教育培训多少钱费用
  • 做片头网站秦皇岛的网站建设公司
  • 专业做网站团队手机app 网站
  • 地方网站有何作用汕头seo建站
  • 寺庙网站开发建设方案曹县网站建设
  • 网络网站推广选择乐云seo开发一个软件需要什么过程
  • 网站注册价格免费注册网站有哪些
  • 织梦做淘宝客网站环球网最新国际新闻
  • 网站做任务挣钱做垂直网站
  • 免费无限建站手机百度安装下载
  • 网站建设推广服务商ci框架建设网站
  • 小江高端网站建设可视化响应式网站建设
  • 企业网站建设流程图本地云主机搭建wordpress
  • 外贸服装接单网站政务信息公开与网站建设报告
  • wordpress简体中文版下载地址惠州企业网站seo公司
  • php网站游客试用怎么做网站专题制作 公司
  • 网站头部代码渭南韩城
  • 东莞做网站推广网站备案被注销吗
  • 镇江网站优化免费团购网站模板
  • 2024微信最新版本下载广告seo是什么意思
  • 平台网站建设在哪里免费网站2022年能用的网址
  • 手机网站建设哪家好dw做网站时怎么改为绝对路径