OpenCV 学习笔记(8)彩色图像RGB通道的分离、合并与显示
https://blog.csdn.net/ZYTTAE/article/details/42234989
由于算法的需要,需要把彩色图像的R、G、B值分离出来,OpenCV中正好有split() 和 merge() 函数可以实现。
一、对单独彩色图片的RGB通道分离:
#include <iostream>
#include "cv.h"
#include "highgui.h" using namespace std;
using namespace cv; int main(int argc,char* argv[])
{
Mat img = imread("lena.jpg"/*,CV_LOAD_IMAGE_COLOR*/);
Mat channel[3];
split(img,channel);
imshow("original",img);
imshow("B",channel[0]);
imshow("G",channel[1]);
imshow("R",channel[2]); //set blue channel to 0
channel[0] = Mat::zeros(img.rows,img.cols,CV_8UC1);
//merge red and green channels
merge(channel,3,img);
imshow("R_G_merge",img); waitKey(0);
return 1;
}
二、对摄像头摄入视频帧的RGB彩色通道分离
int main(int argc,char* argv[])
{
VideoCapture cap;
cap.open(0); if(!cap.isOpened())
{
exit(0);
} cap.set(CV_CAP_PROP_FRAME_WIDTH,250);
cap.set(CV_CAP_PROP_FRAME_HEIGHT,250); cout << "Frame Width: " << cap.get(CV_CAP_PROP_FRAME_WIDTH) << endl;
cout << "Frame Height: " << cap.get(CV_CAP_PROP_FRAME_HEIGHT) << endl; Mat frame;
vector<Mat> rgb;
cap >> frame; //rgb.push_back( Mat(frame.rows, frame.cols, CV_8UC1));
//rgb.push_back( Mat(frame.rows, frame.cols, CV_8UC1));
//rgb.push_back( Mat(frame.rows, frame.cols, CV_8UC1));
//rgb.push_back( Mat(frame.rows, frame.cols, CV_8UC1)); namedWindow("original", 1);
namedWindow("red", 1);
namedWindow("green", 1);
namedWindow("blue", 1); for(;;)
{
cap >> frame;
imshow("original", frame);
split(frame, rgb); imshow("red", rgb.at(2));
imshow("green", rgb.at(1));
imshow("blue", rgb.at(0)); if(waitKey(30) >= 0)
break;
} waitKey(0);
return 1;
}
1.split()函数
此函数的作用是将一个图像通道进行分离。
首先看一下split()函数定义:
void split(const Mat& m, vector<Mat>& mv );
参数说明:
第一个参数,const Mat&类型的src,填我们需要进行分离的图像;
第二个参数,vector<Mat>类型的mv,填函数的输出数组或者输出的vector容器,即分离后的图像;
2.merge()函数
merge()函数的功能是split()函数的逆向操作,将多个数组合并成一个多通道的数组。
首先看一下merge()函数定义:
void merge(const vector<Mat>& mv, OutputArray dst );
参数说明:
第一个参数,const <Mat>类型的mv,填需要被合并的vector容器的阵列,这个mv参数中所有的矩阵必须有着一样的尺寸和深度;说白了就是前面被split()函数分离后的图像通道。
第二个参数,保存为合并后的图像;
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
using namespace cv;
using namespace std; int main()
{
//【0】定义相关变量
Mat srcImage, newImage; //源图像、通道合并后的图像
Mat srcImage_B, srcImage_G, srcImage_R; //R、G、B各个通道
Mat image_H, image_S, image_V; //H、S、V各个通道
vector<Mat> channels_BGR; //vector<Mat>: 可以理解为存放Mat类型的容器(数组)
vector<Mat> channels_HSV;
//【1】读取原始图像并检查图像是否读取成功
srcImage = imread("D:\\OutPutResult\\ImageTest\\adog.jpg"); //请修改为自己的图像路径
if (srcImage.empty())
{
cout << "读取图像有误,请重新输入正确路径!\n";
return -1;
}
imshow("srcImage源图像", srcImage); //在窗口显示源图像 //【2】对加载的原图像进行通道分离,即把一个3通道图像转换成为3个单通道图像
split(srcImage, channels_BGR);
//0通道为B分量,1通道为G分量,2通道为R分量。因为:RGB色彩空间在opencv中默认通道顺序为BGR!!!
srcImage_B = channels_BGR.at(0);
srcImage_G = channels_BGR.at(1);
srcImage_R = channels_BGR.at(2);
imshow("srcImage_B通道", srcImage_B); //分别显示R,G,B各个通道图像
imshow("srcImage_G通道", srcImage_G);
imshow("srcImage_R通道", srcImage_R); //【3】将BGR颜色空间转换为HSV颜色空间
Mat image_hsv;
cvtColor(srcImage, image_hsv, CV_BGR2HSV);
imshow("HSV颜色空间图像", image_hsv); //【4】对加载的HSV图像进行通道分离
split(image_hsv, channels_HSV);
//0通道为H分量,1通道为S分量,2通道为V分量
image_H = channels_HSV.at(0);
image_S = channels_HSV.at(1);
image_V = channels_HSV.at(2);
imshow("image_H通道", image_H);//分别显示H,S,V各个通道图像
imshow("image_S通道", image_S);
imshow("image_V通道", image_V); //【5】将3个单通道重新合并成一个三通道图像
merge(channels_HSV, newImage);
imshow("将H,S,V通道合并后的图像", newImage); //【6】保持等待状态
waitKey(0);
return 0;
}
5.程序说明 看到这里,可能有人会问为什么分离出的通道都是黑白灰,而不是红绿蓝? 原因是分离后为单通道,相当于分离通道的同时把其他两个通道填充了相同的数值。比如红色通道,分离出红色通道的同时,绿色和蓝色被填充为和红色相同的数值,这样一来就只有黑白灰了。那么红色体现在哪呢?可以进行观察,会发现原图中颜色越接近红色的地方在红色通道越接近白色。 ====================分割线=============== 此程序共显示9个窗口。 先将RGB图像通道分离,分别显示R、G、B、单个通道; 后将RGB颜色空间转为HSV空间,将HSV图像通道分离,分别显示H、S、V、单个通道; 最后将H、S、V、单个通道重新合并为3通道图像; =========================END======================
OpenCV 学习笔记(8)彩色图像RGB通道的分离、合并与显示的更多相关文章
- OpenCV 学习笔记(16)open创建无边框的显示窗口
https://blog.csdn.net/weixin_41794771/article/details/93198098 讲解地址 // 1获取窗口句柄 winName 窗口名字 HWND win ...
- opencv学习笔记D01
目录 opencv学习笔记D01 一.图片读取 二.图片保存 三.图片展示 四.图片缩放 五.四种常用插值方式的比较 1.最近邻插值 2.双线性插值 3.区域插值 4.三次样条插值 我是尾巴: ope ...
- opencv学习笔记(一)IplImage, CvMat, Mat 的关系
opencv学习笔记(一)IplImage, CvMat, Mat 的关系 opencv中常见的与图像操作有关的数据容器有Mat,cvMat和IplImage,这三种类型都可以代表和显示图像,但是,M ...
- OpenCV 学习笔记03 findContours函数
opencv-python 4.0.1 1 函数释义 词义:发现轮廓! 从二进制图像中查找轮廓(Finds contours in a binary image):轮廓是形状分析和物体检测和识别的 ...
- OpenCV 学习笔记 02 使用opencv处理图像
1 不同色彩空间的转换 opencv 中有数百种关于不同色彩空间的转换方法,但常用的有三种色彩空间:灰度.BRG.HSV(Hue-Saturation-Value) 灰度 - 灰度色彩空间是通过去除彩 ...
- 【opencv学习笔记七】访问图像中的像素与图像亮度对比度调整
今天我们来看一下如何访问图像的像素,以及如何改变图像的亮度与对比度. 在之前我们先来看一下图像矩阵数据的排列方式.我们以一个简单的矩阵来说明: 对单通道图像排列如下: 对于双通道图像排列如下: 那么对 ...
- opencv学习笔记(六)直方图比较图片相似度
opencv学习笔记(六)直方图比较图片相似度 opencv提供了API来比较图片的相似程度,使我们很简单的就能对2个图片进行比较,这就是直方图的比较,直方图英文是histogram, 原理就是就是将 ...
- opencv学习笔记(四)投影
opencv学习笔记(四)投影 任选了一张图片用于测试,图片如下所示: #include <cv.h> #include <highgui.h> using namespace ...
- opencv学习笔记(二)寻找轮廓
opencv学习笔记(二)寻找轮廓 opencv中使用findContours函数来查找轮廓,这个函数的原型为: void findContours(InputOutputArray image, O ...
随机推荐
- 在RedisTemplate中使用scan代替keys指令
keys * 这个命令千万别在生产环境乱用.特别是数据庞大的情况下.因为Keys会引发Redis锁,并且增加Redis的CPU占用.很多公司的运维都是禁止了这个命令的 当需要扫描key,匹配出自己需要 ...
- 使用springboot mybatis 查询时实体类中的驼峰字段值为null
看到返回结果以后主要分析了一下情况: 实体类的get.set方法确实 mapper.xml文件中的resultMap.resultType等原因导致 数据库中数据存在问题 经过检查与验证发现以上都不存 ...
- Java学习:递归
递归的思想 以此类推是递归的基本思想. 具体来讲就是把规模大的问题转化为规模小的相似的子问题来解决.在函数实现时,因为解决大问题的方法和解决小问题的方法往往是同一个方法,所以就产生了函数调用它自身的情 ...
- python matplotlib 设置x轴文本间隔显示(数字的话可以转为字符之后处理)
一个国际友人绘图遇到的问题,查了一手资料.主要参考的是这个老哥的做法(https://blog.csdn.net/wyquin/article/details/80508260) #totalSeed ...
- XAML加载的四种方式
XAML加载与编译可以分为四种: 仅使用代码进行WPF程序的生成 使用代码和未编译的标记 使用代码和编译过的BAML 1.只是用代码进行窗体的生成:优点是可以随意定制应用程序,缺点是没有可视化编辑窗口 ...
- drf之组件(认证、权限、排序、过滤、分页等)和xadmin、coreapi
认证Authentication 可以在配置文件中配置全局默认的认证方案 REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': ( 'rest_fr ...
- 配置 Mac Chrome Inspect
安装libimobiledevice : Could not connect to lockdownd. Exiting. 报错解决 brew uninstall --ignore-depende ...
- 微信小程序调用云函数出错 Error: errCode: -404011 cloud function execution error | errMsg: cloud.callFunction:fail cloud function service error code -501005, error message Environment not found;
错误异常: Error: errCode: -404011 cloud function execution error | errMsg: cloud.callFunction:fail cloud ...
- 前端项目中公共方法汇总utils.js
目录 判断手机类型IOS Android 格式化金钱 金钱字符串变回数字 用aa替换中文 并返回 去除文件后缀,得到文件名称(不带后缀) 获取浏览器类型(名称) post方式下载文件流 动态设置img ...
- JavaScript 之 取消 a 标签的默认行为
方式一 语法格式: <a href="javascript:;">百度</a> javascript: 是一个伪协议,其他的伪协议还有 mail: tel ...