opencv人脸打马赛克

复制代码
import cv2


def FaceFind(imgPath: str) -> list:
    image = cv2.imread(imgPath)

    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
    # 返回人脸坐标列表
    faces = face_cascade.detectMultiScale(gray, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30))

    # 保存图片
    # for (x, y, w, h) in faces:
    #    cv2.rectangle(image, (x, y), (x+w, y+h), (0, 255, 0), 3)
    #    cv2.imwrite('face.jpg', image)

    return faces


def ApplyMosaic(ImagePath: str, BoxList: list):
    # 加载原始图像
    image = cv2.imread(ImagePath)
    # 马赛克坐标
    for box in BoxList:
        (x, y, w, h) = box
        # 从原始图片中获取马赛克图片位置
        roi = image[y:y + h, x:x + w]
        # 马赛克块大小 10x10
        roi_small = cv2.resize(roi, (10, 10), interpolation=cv2.INTER_LINEAR)
        roi_back = cv2.resize(roi_small, (w, h), interpolation=cv2.INTER_NEAREST)
        image[y:y + h, x:x + w] = roi_back
    cv2.imwrite('output_image.jpg', image)


def main():
    # 图片路径
    ImagePath = "img_2.png"
    # 马赛克应用的区域
    BoxList = FaceFind(ImagePath)
    ApplyMosaic(ImagePath, BoxList)


if __name__ == '__main__':
    main()

效果:

相关推荐
minglie14 小时前
zynq环境用opencv测摄像头
人工智能·opencv·计算机视觉
Fleshy数模4 小时前
基于MediaPipe实现人体姿态与脸部关键点检测
python·opencv·计算机视觉
輕華5 小时前
OpenCV答题卡识别:从图像预处理到自动评分
人工智能·opencv·计算机视觉
程序员JerrySUN6 小时前
RK3588 项目实战总结:从 GStreamer、DP 显示、OpenCV 到 YOLO 部署的一次完整梳理
人工智能·opencv·yolo
躺平的赶海人8 小时前
python opencv实现相机内参标定之安装OpenCv
python·opencv·计算机视觉
Westward-sun.9 小时前
OpenCV物体跟踪实战:基于KCF算法的实时摄像头目标跟踪(Python实现)
opencv·算法·目标跟踪
qq_3859990810 小时前
Win7 64 位 + MinGW64 + CMake + OpenCV 之二
人工智能·opencv·webpack
Daydream.V1 天前
【Opencv+MediaPipe】实现手部检测、识别
人工智能·opencv·计算机视觉
Daydream.V2 天前
基于Opencv和Dlib的人脸换脸实现
人工智能·opencv·计算机视觉·仿射变换·换脸·视频换脸·图片换脸
Westward-sun.2 天前
背景建模详解与OpenCV实现:从原理到代码实战
人工智能·opencv·计算机视觉