- C++: void split(const Mat& src, Mat*mvbegin);
- C++: void split(InputArray m,OutputArrayOfArrays mv);
合成
- C++: void merge(const Mat* mv, size_tcount, OutputArray dst)
- C++: void merge(InputArrayOfArrays mv,OutputArray dst)
例子:
Mat srcImage;
Mat imageROI;
vector<Mat> channels;
srcImage = cv::imread("test.jpg");
// 把一个3通道图像转换成3个单通道图像
split(srcImage,channels);//分离色彩通道
imageROI=channels.at();
addWeighted(imageROI(Rect(,,logoImage.cols,logoImage.rows)),,
logoImage,,,imageROI(Rect(,,logoImage.cols,logoImage.rows)));
merge(channels,srcImage4);
namedWindow("sample");
imshow("sample",srcImage);
图像格式的转换
char ar1[]={,,,};//注意不能用Int类型来初始化
Mat src=Mat(,,CV_8U,ar1);
Mat dst;
src.convertTo(dst,CV_32F);//转换成32F的矩阵。值不变
src.convertTo(dst,CV_32F,/);//转换成32F的矩阵。值区域改为0~255
src.convertTo(dst,
CV_8UC3, -, ); // inverse the mask matrix means I_new(x,j) = -1*I(x,j) + 255.