opencv Mat 多通道c++ 操作方法(适用于Windows/Linux)

最近在做opencv Mat 多通道操作时发现网上例子很少,为了方便记忆就自己写了个demo。

例子在vs2010 + opencv 2.4.9 编译通过,只要配置好opencv 的lib路径就可以运行了。

该方法适用于Windows/Linux下的c++ 操作,Windows 和Ubuntu 都试过没问题。

#include <opencv2/opencv.hpp>	
#include <iostream>

#pragma comment ( lib, "opencv_core249d.lib")	

using namespace std;
using namespace cv;

void testChannels()
{
	FileStorage fs;
	string file = "channel_methods.xml";
	fs.open(file, FileStorage::WRITE);
	if(!fs.isOpened()){
		cerr << "Error: Could not open  '" << file << endl;
	}
		
	// Vec2f需要对应矩阵定义的通道数和数据类型CV_32FC2,如果是4通道float型就应定义为Vec4f
	// 第一种用法
	Mat code(1, 10, CV_32FC2, Scalar::all(0));
	Mat_<Vec2f> _code = code; 
	for(int k = 0; k < 10; k++){
		_code(0, k)[0]++; 
		_code(0, k)[1]=1; 
	}
	code = _code;
	fs << "method_1st" << code;
		
	// 第二种用法
	Mat code_2(1, 10, CV_32FC2, Scalar::all(0));
	for(int k = 0; k < 10; k++){
		code_2.at<Vec2f>(0, k)[0]++; 
		code_2.at<Vec2f>(0, k)[1]=2; 
	}
	fs << "method_2nd" << code_2;

	// 第三种用法
	vector<Mat> split_code;
	split(code, split_code);
	for(int k = 0; k < 10; k++){
		split_code[0].at<float>(0, k)++; 
		split_code[1].at<float>(0, k)=3; 
	}	
	Mat merge_code(1, 10, CV_32FC2, Scalar::all(0));
	merge(split_code, merge_code);
	fs << "method_3rd" << merge_code;

	// 释放资源,如code.release();等
}

int main(int argc, char** argv)
{
	testChannels();
}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
反向投影是一种用于图像分割的技术,它可以将图像中某个特定区域中的像素值与整个图像中的像素值进行比较,从而实现对该区域的分离。OpenCV中提供了多通道直方图算法来实现反向投影,以下是一些示例代码: ```c++ #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat image, hsv; image = imread("image.jpg"); // 转换为HSV格式 cvtColor(image, hsv, COLOR_BGR2HSV); // 设置H、S通道的范围 float h_ranges[] = { 0, 180 }; float s_ranges[] = { 0, 256 }; const float* ranges[] = { h_ranges, s_ranges }; // 设置H、S通道的数量 int h_bins = 16, s_bins = 16; int hist_sizes[] = { h_bins, s_bins }; // 计算图像的直方图 MatND hist; int channels[] = { 0, 1 }; calcHist(&hsv, 1, channels, Mat(), hist, 2, hist_sizes, ranges, true, false); // 归一化直方图 normalize(hist, hist, 0, 255, NORM_MINMAX, -1, Mat()); // 反向投影 Mat dst; calcBackProject(&hsv, 1, channels, hist, dst, ranges, 1, true); // 显示结果 imshow("image", image); imshow("back projection", dst); waitKey(0); return 0; } ``` 在这个示例中,我们首先将图像转换为HSV格式,然后计算出H、S通道的直方图,并将其归一化。接下来,我们使用`calcBackProject`函数来计算反向投影图像,并将结果显示出来。 注意,我们在调用`calcHist`和`calcBackProject`函数时,都需要指定通道数量和通道范围。在本例中,我们使用了两个通道(H、S),并将H通道的范围设置为0到180,S通道的范围设置为0到256。我们还指定了16个bin用于计算直方图,这个值可以根据实际需要进行调整。 希望这些代码可以对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值