opencv笔记——分离颜色通道&多通道图像混合

多余的不说,详细函数解析请见

浅墨——毛星云

分离颜色通道&多通道图像混合

#include<opencv2/opencv.hpp>
#include<iostream>
using namespace std;
using namespace cv;
bool Colorchannel();
int main()
{
    system("color 5E");
   if(Colorchannel())
        cout<<"operation success"<<endl;
   waitKey(0);
   return 0;
}
bool Colorchannel()
{
    //定义相关变量
    vector<Mat>channel;
    Mat logo_img;
    Mat Big_img;
    //读入图片
    logo_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/aixin.png",0);//logo灰度图
    Big_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/xinhaicheng.png");
    if((!logo_img.data)&&(!Big_img.data)) {
        cout<<"No image!"<<endl; return false;
    }
    Mat imgbluechannel,imggreenchannel,imgredchannel;//定义三个单通道图像
    split(Big_img,channel);//分离三通道
    //蓝色通道ROI区域与logo线性混合再赋值到ROI区域
    imgbluechannel=channel.at(0);
    addWeighted(imgbluechannel(Rect(0,0,logo_img.cols,logo_img.rows)),1.0,logo_img,0.5,0,
                imgbluechannel(Rect(0,0,logo_img.cols,logo_img.rows)));
                merge(channel,Big_img);//再将三个单通道再重新合并为一个三通道
                namedWindow("蓝色通道的分离与混合");
    imshow("蓝色通道的分离与混合",Big_img);
     logo_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/aixin.png",0);
    Big_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/xinhaicheng.png");
    if((!logo_img.data)&&(!Big_img.data)) {
        cout<<"No image!"<<endl; return false;
    }
    split(Big_img,channel);
    imggreenchannel=channel.at(1);
    //绿色通道ROI区域与logo线性混合再赋值到ROI区域
    addWeighted(imggreenchannel(Rect(0,0,logo_img.cols,logo_img.rows)),1.0,logo_img,0.5,0,
                imggreenchannel(Rect(0,0,logo_img.cols,logo_img.rows)));
                merge(channel,Big_img);
                namedWindow("绿色通道的分离与混合");
    imshow("绿色通道的分离与混合",Big_img);
    logo_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/aixin.png",0);
    Big_img=imread("C:/Users/xihua/Pictures/Saved Pictures/opencv操作图/xinhaicheng.png");
    if((!logo_img.data)&&(!Big_img.data)) {
        cout<<"No image!"<<endl; return false;
    }
    split(Big_img,channel);
    //红色通道ROI区域与logo线性混合再赋值到ROI区域
    imgredchannel=channel.at(2);
    addWeighted(imgredchannel(Rect(0,0,logo_img.cols,logo_img.rows)),1.0,logo_img,0.5,0,
                imgredchannel(Rect(0,0,logo_img.cols,logo_img.rows)));
                merge(channel,Big_img);
                namedWindow("红色通道的分离与混合");
    imshow("红色通道的分离与混合",Big_img);
    return true;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无所畏惧的man

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值