[OpenCV]拓展图像边界

来源:互联网 发布:文字ocr识别软件 编辑:程序博客网 时间:2024/05/16 18:38

图像处理中经常遇到使用当前像素邻的像素来计算当前像素位置的某些属性值,这样就会导致边界像素处越界访问,一般有两种方法解决这种问题:只对不越界的像素进行处理;对图像边界进行拓展,本文主要介绍如何使用OpenCV简单的对边界进行拓展。


边界的拓展方式

opencv提供了几种不同的边界拓展策略:

[plain] view plain copy
print?
  1. * BORDER_REPLICATE: aaaaaa|abcdefgh|hhhhhhh  
  2. * BORDER_REFLECT: fedcba|abcdefgh|hgfedcb  
  3. * BORDER_REFLECT_101: gfedcb|abcdefgh|gfedcba  
  4. * BORDER_WRAP: cdefgh|abcdefgh|abcdefg  
  5. * BORDER_CONSTANT: iiiiii|abcdefgh|iiiiiii with some specified ’i’  
* BORDER_REPLICATE: aaaaaa|abcdefgh|hhhhhhh* BORDER_REFLECT: fedcba|abcdefgh|hgfedcb* BORDER_REFLECT_101: gfedcb|abcdefgh|gfedcba* BORDER_WRAP: cdefgh|abcdefgh|abcdefg* BORDER_CONSTANT: iiiiii|abcdefgh|iiiiiii with some specified ’i’

以上内容取自OpenCV的帮助文档。其中 “|” 表示的是图像的边界,连个“|”中间是图像的内容,最后一个边界拓展策略还要额外给定一个i值,用于对额外的边界进行赋值。


边界拓展

使用OpenCV提供的函数copyMakeBorder()来拓展边界,其原型如下

[cpp] view plain copy
print?
  1. void copyMakeBorder( InputArray src, OutputArray dst, int top, int bottom, int left, int right, int borderType, const Scalar& value=Scalar() )  
void copyMakeBorder( InputArray src, OutputArray dst, int top, int bottom, int left, int right, int borderType, const Scalar& value=Scalar() )

src:输入的数组。

dst:输出的拓展边界后的数组。

top:在src上边界向上拓展的行数。

bottom:在src下边界向下拓展的行数。

left:在src的左边界向左拓展的列数。

right:在src的右边界向右拓展的列数。

borderType:上一节中的边界拓展策略中的一个。

value:当你的边界策略使用的是BORDER_CONSTANT的时候,此处是指边界处填写的常数值。


实例

用一个简单实例来解释下如何拓展边界。

[cpp] view plain copy
print?
  1. Mat extendedIm;  
  2. copyMakeBorder( orgIm, extendedIm, extRows, extRows, extCols, extCols, BORDER_REFLECT_101, Scalar::all(0) );  
Mat extendedIm;copyMakeBorder( orgIm, extendedIm, extRows, extRows, extCols, extCols, BORDER_REFLECT_101, Scalar::all(0) );

在实例中,上下边界分别拓展extRows行,左右分别拓展extCols列,使用的是BORDER_REFLECT_101,最有一个参数,可以不写,我这里写上是为了告诉大家函数可以填写这些参数。

以下是实验代码和结果:

[cpp] view plain copy
print?
  1. #include <iostream>  
  2. #include <opencv2/opencv.hpp>  
  3. using namespace std;  
  4. using namespace cv;  
  5. int main(int argc, char**argv){  
  6.     Mat orgIm = imread(”theImage.png”);  
  7.     int extRows = 19;  
  8.     int extCols = 15;     
  9.     Mat extendedIm;  
  10.     copyMakeBorder( orgIm, extendedIm, extRows, extRows, extCols, extCols, BORDER_REFLECT_101);  
  11.     imshow(”original image”, orgIm);  
  12.     imshow(”extended image”, extendedIm);  
  13.     waitKey();  
  14.     return 0;  
  15. }  
#include <iostream>
#include <opencv2/opencv.hpp>using namespace std;using namespace cv;int main(int argc, char**argv){ Mat orgIm = imread("theImage.png"); int extRows = 19; int extCols = 15; Mat extendedIm; copyMakeBorder( orgIm, extendedIm, extRows, extRows, extCols, extCols, BORDER_REFLECT_101); imshow("original image", orgIm); imshow("extended image", extendedIm); waitKey(); return 0;}

上图是原始图像。



上图是拓展后的图像。




原创粉丝点击