opencv中使用copyMakeBorder为图片填充边框

本文介绍了如何使用OpenCV库的copyMakeBorder函数对摄像头采集的长方形图片进行填充,将其调整为深度学习模型所需的正方形输入格式,以FDDB人脸检测数据集为例,提供了Python代码实现和resize_image函数的详细步骤。
摘要由CSDN通过智能技术生成

说明

在使用深度学习模型推理的时候,通常输入图片都是一个正方形,而摄像头采集的图片通常是长方形的,这就要把图片的边上填充一些像素,从而变成所需的正方形。
在opencv中copyMakeBorder可做填充的工作,非常适合做深度学习图片的前处理。
FDDB数据集是用于人脸检测的,经过处理的图片如下所示:
在这里插入图片描述

函数原型

https://docs.opencv.org/3.4/d2/de8/group__core__array.html#ga2ac1049c2c3dd25c2b41bffe17658a36
在这里插入图片描述

python代码示例

这个例子把图片转换为320X320的正方形图片。

import cv2
import numpy as np
import os

#入参是:源图,目标宽度,目标长度
#长宽不等的图片,本函数resize后会在短的那个边上做填充,从而保证图片比例不变
def resize_image(srcimg, targetHeight, targetWidth):
    padh, padw, newh, neww = 0, 0, targetHeight, targetWidth
    if srcimg.shape[0] != srcimg.shape[1]:
        hw_scale = srcimg.shape[0] / srcimg.shape[1]  #shape[0]-h, shape[1]-w
        if hw_scale > 1:  #高度比较大
            newh, neww = targetHeight, int(targetWidth / hw_scale)
            img = cv2.resize(srcimg, (neww, newh), interpolation=cv2.INTER_AREA)
            padw = int((targetWidth - neww) * 0.5)
            img = cv2.copyMakeBorder(img, 0, 0, padw, targetWidth - neww - padw, cv2.BORDER_CONSTANT,
                                     value=0)  # add border
            return img
        else: 
            newh, neww = int(targetHeight * hw_scale) + 1, targetWidth
            img = cv2.resize(srcimg, (neww, newh), interpolation=cv2.INTER_AREA)
            padh = int((targetHeight - newh) * 0.5)
            img = cv2.copyMakeBorder(img, padh, targetHeight - newh - padh, 0, 0, cv2.BORDER_CONSTANT, value=0)
            return img
    else:
        img = cv2.resize(srcimg, (targetWidth, targetHeight), interpolation=cv2.INTER_AREA)
        return img #, newh, neww, padh, padw


f = open("facepictures.txt")
line = f.readline()
num = 0
while line:
    imgpath=line.strip()
    print (num, ":", imgpath)
    img = cv2.imread(imgpath)

    resize_img = resize_image(img, 320, 320)

    newpath = os.path.join("./FDDB/", str(num)+".jpg")
    print("newpath:", newpath)
    cv2.imwrite(newpath, resize_img)

    line = f.readline()
    num+=1
    # if num > 10 :
    #     break


f.close()
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值