OpenCV笔记(十三)——为图像加上边框

看这个题目,为什么要为一幅图像加上边框呢?

第一,做卷积的需要。当我们做卷积的时候,kernel往往不小于3X3的矩阵,那么首行、末行、首列、末列的元素就不能正确地与这个kernel做卷积。当我们给图像加上边框之后,就解决了这个问题。

第二、两幅大小不一致的图像进行操作的时候,为了保证运算的正确性,我们也要为图像加上边框,使两幅图像大小一致。

 

加边框有什么方法呢?

第一,很直接地,我们把图像的扩大之后,将边框的值设为一个固定的常量,常常是0,其他值亦可。这在OpenCV中叫BORDER_CONSTANT。

第二,我们也可以将首行、末行、首列、末列上对应像素的值,复制给边框使用。这在OpenCV中焦灼BORDER_REPLICATE。 replicate在英语中有“复制"的意思。

 

OpenCV中,对应的函数为

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

top,bottom,left和right四个参数表示要在上、下、左和右四个方向上加的边框的像素数。

borderType参数表示所要进行的加边框的方式:BORDER_CONSTANT和BORDER_REPLICATE。

当borderType为BORDER_CONSTANT的时候,value的值表示边框的颜色。

 

posted @ 2014-12-02 17:31  nipan  阅读(1795)  评论(0编辑  收藏  举报