/* Splits a multi-channel array into the set of single-channel arrays or extracts particular [color] plane */ CVAPI(void) cvSplit( const CvArr* src, CvArr* dst0, CvArr* dst1, CvArr* dst2, CvArr* dst3 );
src:多通道源图像
dst0、dst1、dst2、dst3:单通道结果图像
源图像和结果图像的大小相同,深度类型相同,仅有通道类型不同
##############################################################
/* Merges a set of single-channel arrays into the single multi-channel array or inserts one particular [color] plane to the array */ CVAPI(void) cvMerge( const CvArr* src0, const CvArr* src1, const CvArr* src2, const CvArr* src3, CvArr* dst );
src0、src1、src2、src3:单通道源图像
dst:多通道结果图像
源图像和结果图像的大小相同,深度类型相同,仅有通道类型不同
###########################################################
程序:将图像lena.jpg分离为三个单通道图像c1、c2、c3,再将其合并为单通道图像(蓝、绿、红)
void splitAndMerge(void) { IplImage *img=cvLoadImage("lena.jpg"); IplImage *c1=cvCreateImage(cvGetSize(img), img->depth, 1); IplImage *c2=cvCreateImage(cvGetSize(img), img->depth, 1); IplImage *c3=cvCreateImage(cvGetSize(img), img->depth, 1); IplImage *rImg=cvCreateImage(cvGetSize(img), img->depth, 3); IplImage *gImg=cvCreateImage(cvGetSize(img), img->depth, 3); IplImage *bImg=cvCreateImage(cvGetSize(img), img->depth, 3); if (NULL == img || NULL == c1 || NULL == c2 || NULL == c3 || NULL == rImg || NULL == gImg || NULL == bImg) exit(0); cvSplit(img, c1, c2, c3, NULL); cvNamedWindow("img"); cvShowImage("img", img); cvZero(rImg); cvZero(gImg); cvZero(bImg); cvMerge(c1, NULL, NULL, NULL, bImg); cvMerge(NULL, c2, NULL, NULL, gImg); cvMerge(NULL, NULL, c3, NULL, rImg); cvNamedWindow("rImg"); cvNamedWindow("gImg"); cvNamedWindow("bImg"); cvShowImage("rImg", rImg); cvShowImage("gImg", gImg); cvShowImage("bImg", bImg); cvWaitKey(0); cvReleaseImage(&img); cvReleaseImage(&c1); cvReleaseImage(&c2); cvReleaseImage(&c3); cvReleaseImage(&rImg); cvReleaseImage(&gImg); cvReleaseImage(&bImg); cvDestroyAllWindows(); }