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的值表示边框的颜色。