第六章 - 图像变换 - 卷积(cvFilter2D) - 卷积边界(cvCopyMakeBorder)

先来了解卷积的概念与作用(转自网络):


对图像做卷积:

void cvFilter2D( const CvArr* src, CvArr* dst,
                 const CvMat* kernel,
                 CvPoint anchor=cvPoint(-1,-1));
#define cvConvolve2D cvFilter2D

src
输入图像.
dst
输出图像.
kernel
卷积核, 单通道浮点矩阵. 如果想要应用不同的核于不同的通道,先用  cvSplit 函数分解图像到单个色彩通道上,然后单独处理。
anchor
核的锚点表示一个被滤波的点在核内的位置。 锚点应该处于核内部。缺省值 (-1,-1) 表示锚点在核中心。
函数  cvFilter2D 对图像进行线性滤波,支持 In-place 操作。当核运算部分超出输入图像时,函数从最近邻的图像内部象素差值得到边界外面的象素值。
代码:

// learningOpenCV_12.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include<cv.h>
#include<highgui.h>

int _tmain(int argc, _TCHAR* argv[])
{
	float k[9]={
	
		1.0  ,2.0 ,1.0  ,
		-1.0 ,1.0 ,-2.0 ,
		1.0  ,-1.0,1.0
	};

	CvMat km=cvMat(3,3,CV_32FC1,k); //构造单通道浮点矩阵,将图像IplImage结构转换为图像数组
	IplImage *src=cvLoadImage("E:\\picture\\fruits.jpg");
	IplImage *dst=cvCreateImage(cvGetSize(src),IPL_DEPTH_8U,3);

	cvNamedWindow("src");
	cvShowImage("src",src);
	cvNamedWindow("Filtering");
	cvFilter2D(src,dst,&km,cvPoint(-1,-1));
	cvShowImage("Filtering",dst);

	cvWaitKey(0);
	cvReleaseImage( &src );
	cvReleaseImage( &dst );
	return 0;
}


卷积边界(cvCopyMakeBorder)

cvCopyMakeBorder()函数可以复制图像并制作边界,将特定图像轻微变大,然后以各种方式自动填充图像边界,当Bordertype=IPL_BORDER_REPLICATE时,原始图像边缘的行和列被复制到大图像的边缘,当Bordertype=IPL_BORDER_CONSTANT时,有一个像素宽的黑色边界。

--------------------------------------------------------------------------------------------------

CopyMakeBorder

复制图像并且制作边界。

void cvCopyMakeBorder( const CvArr* src, CvArr* dst, CvPoint offset, int bordertype, CvScalar value=cvScalarAll(0) );
src
输入图像。
dst
输出图像。
offset
输入图像(或者其ROI)欲拷贝到的输出图像长方形的左上角坐标(或者左下角坐标,如果以左下角为原点)。长方形的尺寸要和原图像的尺寸的ROI分之一匹配。
bordertype
已拷贝的原图像长方形的边界的类型:
IPL_BORDER_CONSTANT - 填充边界为固定值,值由函数最后一个参数指定。IPL_BORDER_REPLICATE -边界用上下行或者左右列来复制填充。(其他两种IPL边界类型, IPL_BORDER_REFLECT 和IPL_BORDER_WRAP现已不支持)。
value
如果边界类型为IPL_BORDER_CONSTANT的话,那么此为边界像素的值。

函数cvCopyMakeBorder拷贝输入2维阵列到输出阵列的内部并且在拷贝区域的周围制作一个指定类型的边界。函数可以用来模拟和嵌入在指定算法实现中的边界不同的类型。例如:和opencv中大多数其他滤波函数一样,一些形态学函数内部使用复制边界类型,但是用户可能需要零边界或者填充为1或255的边界。

代码:
#include <highgui.h>
#include <cv.h>

int main(int argc,char**argv)
{
	IplImage* src, *dst;

	src = cvLoadImage( argv[1] );
	dst = cvCreateImage( cvSize( src -> width+20, src -> height+20 ), IPL_DEPTH_8U, 3 );
	cvNamedWindow( "src", 0 );
	cvShowImage( "src", src );
	cvNamedWindow( "filtering", 0 );
	cvCopyMakeBorder( src, dst, cvPoint( 1, 1 ), IPL_BORDER_CONSTANT );
	cvShowImage( "filtering", dst );
	cvWaitKey(0);
	cvCopyMakeBorder( src, dst, cvPoint( 1, 1 ), IPL_BORDER_REPLICATE );
	cvShowImage( "filtering", dst );
	cvWaitKey(0);

	cvReleaseImage( &src );
	cvReleaseImage( &dst );
	cvDestroyAllWindows();

	return 0;
}





转载自:http://blog.csdn.net/hitwengqi/article/details/6877435


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值