python识别图像中人像并打马赛克_opencv马赛克python实现

本文介绍了如何使用Python和OpenCV库实现在图像中识别人像并进行马赛克处理。通过定义函数do_mosaic,利用矩形区域替换颜色的方式模糊细节,同时保留大体轮廓。关键点包括防止溢出的处理、颜色获取以及矩形绘制。最终展示了一个实际应用示例。
摘要由CSDN通过智能技术生成

最近要实现opencv视频打马赛克,在网上找了一下基本是C++的实现,好在原理一样,下面给出python实现。 原理和注意点,我都写在注释里了

import cv2

##马赛克

def do_mosaic(frame, x, y, w, h, neighbor=9):

"""

马赛克的实现原理是把图像上某个像素点一定范围邻域内的所有点用邻域内左上像素点的颜色代替,这样可以模糊细节,但是可以保留大体的轮廓。

:param frame: opencv frame

:param int x : 马赛克左顶点

:param int y: 马赛克右顶点

:param int w: 马赛克宽

:param int h: 马赛克高

:param int neighbor: 马赛克每一块的宽

"""

fh, fw = frame.shape[0], frame.shape[1]

if (y + h > fh) or (x + w > fw):

return

for 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 tolist

left_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)

im = cv2.imread('test.jpg', 1)

do_mosaic(im, 219, 61, 460 - 219, 412 - 61)

while 1:

k = cv2.waitKey(10)

if k == 27:

break

cv2.imshow('mosaic', im)

原图为:

效果如下:

图片来自网上,如有侵权,联系删除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值