chap 6 Laplace 板书
#include<opencv2/opencv.hpp>
#include<iostream>
// chap 6 laplace
void main()
{
IplImage* src=cvLoadImage("D:\\lxlx\\one.jpg");
IplImage* lap=cvCreateImage(cvGetSize(src),IPL_DEPTH_16S,1);// lap 16SC1
IplImage* color_laplace=cvCreateImage(cvGetSize(src),8,3);// color 8UC3
IplImage* plane0=cvCreateImage(cvGetSize(src),8,1); // blue channel
IplImage* plane1=cvCreateImage(cvGetSize(src),8,1); // green channel
IplImage* plane2=cvCreateImage(cvGetSize(src),8,1); // red channel
cvSplit(src,plane0,plane2,plane2,0); // 拆分3个通道分别进行 laplace 变换
cvLaplace(plane0,lap,3);
cvConvertScaleAbs(lap,plane0); // 注意是 cvConvertScaleAbs 绝对值变换
cvLaplace(plane1,lap,3);
cvConvertScaleAbs(lap,plane1);
cvLaplace(plane2,lap,3);
cvConvertScaleAbs(lap,plane2);
cvMerge(plane0,plane1,plane2,0,color_laplace);// 将3通道结果合并
cvNamedWindow("laplace");
cvShowImage("laplace",color_laplace);
cvWaitKey(0);
}
对彩色图片进行拉氏变换,需将3通道拆分(cvSplit( ) ) 成单通道后分别进行变换。
将结果 合并( cvMerge() ) 到3通道显示。
值得注意的是 cvConvertScaleAbs 而不是 cvConvertScale 更不是 cvConvert 。
理由就是拉氏变换结果有正负。。