opencv-图像添加边界(填充)
2013-04-02 20:18
483 查看
为图像填充边界,以便进行滤波,卷积等有关图像边界处理的操作。
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include <stdlib.h>
#include <stdio.h>
using namespace cv;
//全局变量
Mat src, dst;
int top, bottom, left, right;//定义边界大小
int borderType;//边界处理类型
Scalar value;
char* window_name = "copyMakeBorder Demo";
RNG rng(12345);
int main( int argc, char** argv )
{
int c;
//加载图像
src = imread( argv[1] );
if( !src.data )
{ return -1;
printf(" No data entered, please enter the path to an image file \n");
}
/// Brief how-to for this program
printf( "\n \t copyMakeBorder Demo: \n" );
printf( "\t -------------------- \n" );
printf( " ** Press 'c' to set the border to a random constant value \n");
printf( " ** Press 'r' to set the border to be replicated \n");
printf( " ** Press 'ESC' to exit the program \n");
//创建窗口
namedWindow( window_name, CV_WINDOW_AUTOSIZE );
//初始化滤波参数
top = (int) (0.05*src.rows); bottom = (int) (0.05*src.rows);
left = (int) (0.05*src.cols); right = (int) (0.05*src.cols);
dst = src;
imshow( window_name, dst );
while( true )
{
c = waitKey(500);
if( (char)c == 27 )//按ESC退出程序
{ break; }
else if( (char)c == 'c' )
{ borderType = BORDER_CONSTANT; }
else if( (char)c == 'r' )
{ borderType = BORDER_REPLICATE; }
value = Scalar( rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255) );
copyMakeBorder( src, dst, top, bottom, left, right, borderType, value );
imshow( window_name, dst );
}
return 0;
}
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include <stdlib.h>
#include <stdio.h>
using namespace cv;
//全局变量
Mat src, dst;
int top, bottom, left, right;//定义边界大小
int borderType;//边界处理类型
Scalar value;
char* window_name = "copyMakeBorder Demo";
RNG rng(12345);
int main( int argc, char** argv )
{
int c;
//加载图像
src = imread( argv[1] );
if( !src.data )
{ return -1;
printf(" No data entered, please enter the path to an image file \n");
}
/// Brief how-to for this program
printf( "\n \t copyMakeBorder Demo: \n" );
printf( "\t -------------------- \n" );
printf( " ** Press 'c' to set the border to a random constant value \n");
printf( " ** Press 'r' to set the border to be replicated \n");
printf( " ** Press 'ESC' to exit the program \n");
//创建窗口
namedWindow( window_name, CV_WINDOW_AUTOSIZE );
//初始化滤波参数
top = (int) (0.05*src.rows); bottom = (int) (0.05*src.rows);
left = (int) (0.05*src.cols); right = (int) (0.05*src.cols);
dst = src;
imshow( window_name, dst );
while( true )
{
c = waitKey(500);
if( (char)c == 27 )//按ESC退出程序
{ break; }
else if( (char)c == 'c' )
{ borderType = BORDER_CONSTANT; }
else if( (char)c == 'r' )
{ borderType = BORDER_REPLICATE; }
value = Scalar( rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255) );
copyMakeBorder( src, dst, top, bottom, left, right, borderType, value );
imshow( window_name, dst );
}
return 0;
}
相关文章推荐
- 【opencv练习19 - 图像添加边界】
- opencv图像边界的填充
- 图像边界填充OpenCV
- (25)Air Band OpenCV2.4.13_为图像添加边界
- Opencv 给图像添加边界
- OpenCV之imgproc 模块. 图像处理(2)实现自己的线性滤波器 给图像添加边界 Sobel 导数 Laplace 算子 Canny 边缘检测
- 【OpenCV学习】图像填充
- Opencv 图像叠加 添加水印
- opencv 二值图像的孔洞填充
- 图像添加噪声【OpenCV学习笔记1】
- OpenCV图像内轮廓填-孔洞填充
- opencv 降低图像亮度 + 添加噪声处理
- ROS中利用opencv3完成四个视频流拼接成一副图像显示,并添加track条进行参数调节
- Python-OpenCV 处理图像(五):图像中边界和轮廓检测
- OPENCV二值化图像内孔洞填充/小区域去除
- opencv(c++)OpenCV添加(混合)两个图像
- opencv基本图像处理——添加滑动条trackbar
- Opencv 图像叠加 添加水印
- 在OpenCV中图像边界扩展 copyMakeBorder 的实现