opencv函数实例练习——copyMakeBorder 扩展边界

函数

void copyMakeBorder(InputArray src, OutputArray dst, int top, int bottom, int left, int right, int borderType, const Scalar& value = Scalar() );

扩展边界函数,原图像扩展上下左右尺寸,按不同borderType填充不同像素

参数:

enum BorderTypes {
    BORDER_CONSTANT    = 0, //!< `iiiiii|abcdefgh|iiiiiii`  with some specified `i`
    BORDER_REPLICATE   = 1, //!< `aaaaaa|abcdefgh|hhhhhhh`
    BORDER_REFLECT     = 2, //!< `fedcba|abcdefgh|hgfedcb`
    BORDER_WRAP        = 3, //!< `cdefgh|abcdefgh|abcdefg`
    BORDER_REFLECT_101 = 4, //!< `gfedcb|abcdefgh|gfedcba`
    BORDER_TRANSPARENT = 5, //!< `uvwxyz|absdefgh|ijklmno`
    BORDER_REFLECT101  = BORDER_REFLECT_101, //!< same as BORDER_REFLECT_101
    BORDER_DEFAULT     = BORDER_REFLECT_101, //!< same as BORDER_REFLECT_101
    BORDER_ISOLATED    = 16 //!< do not look outside of ROI
};

代码:

void test_copyMakeBorder(Mat & srcimg){
    printf("srcimg w=%d,h=%d\n",srcimg.cols,srcimg.rows);
    imshow("1 srcimg",srcimg);
    int size=100;
    Mat copyMakeBorder_img;
    copyMakeBorder(srcimg,copyMakeBorder_img,size,size,size,size,BORDER_CONSTANT);
    imshow("2 BORDER_CONSTANT",copyMakeBorder_img);
    copyMakeBorder(srcimg,copyMakeBorder_img,size,size,size,size,BORDER_REPLICATE);
    imshow("3 BORDER_REPLICATE",copyMakeBorder_img);
    copyMakeBorder(srcimg,copyMakeBorder_img,size,size,size,size,BORDER_REFLECT);
    imshow("4 BORDER_REFLECT",copyMakeBorder_img);
     copyMakeBorder(srcimg,copyMakeBorder_img,size,size,size,size,BORDER_WRAP);
    imshow("5 BORDER_WRAP",copyMakeBorder_img);
    copyMakeBorder(srcimg,copyMakeBorder_img,size,size,size,size,BORDER_REFLECT101);
    imshow("6 BORDER_REFLECT101",copyMakeBorder_img);
    printf("srcimg w=%d,h=%d\n",copyMakeBorder_img.cols,copyMakeBorder_img.rows);

    while(waitKey(30) ==255);
}
int main(){
    Mat srcimg=imread("test_plane.png");
    test_copyMakeBorder(srcimg);
    return 0;
}

结果:

在这里插入图片描述
总结:
BORDER_CONSTANT——填充固定值
BORDER_REPLICATE——复制边缘的像素扩展边界
BORDER_REFLECT——镜像复制扩展边界
BORDER_WRAP——复制对边的像素扩展边界
BORDER_REFLECT_101——镜像复制扩展边界,边界像素除外

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值