C# OpenCvSharp 通道分离

效果

项目

代码

cs 复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;
using OpenCvSharp.Extensions;

namespace OpenCvSharp_通道分离
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private string fileFilter = "*.*|*.bmp;*.jpg;*.jpeg;*.tiff;*.tiff;*.png";
        Bitmap bmp;
        String imgPath = "";
        Mat mat;

        private void button2_Click(object sender, EventArgs e)
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Filter = fileFilter;
            if (ofd.ShowDialog() != DialogResult.OK) return;
            imgPath = ofd.FileName;
            bmp = new Bitmap(imgPath);
            mat = new Mat(imgPath, ImreadModes.AnyColor);
            pictureBox1.Image = bmp;
        }

        private void button1_Click(object sender, EventArgs e)
        {
            if (pictureBox1.Image == null)
            {
                return;
            }

            //BGR
            Mat[] mats = Cv2.Split(mat);

            if (radioButton1.Checked)
            {
                //灰度图
                pictureBox2.Image = BitmapConverter.ToBitmap(mats[0]);
                pictureBox3.Image = BitmapConverter.ToBitmap(mats[1]);
                pictureBox4.Image = BitmapConverter.ToBitmap(mats[2]);

                //Window b = new Window("B", WindowMode.Normal);
                //Window g = new Window("G", WindowMode.Normal);
                //Window r = new Window("R", WindowMode.Normal);

                //b.ShowImage(mats[0]);
                //g.ShowImage(mats[1]);
                //r.ShowImage(mats[2]);
            }
            else
            {
                //彩色图

                //创建一个空通道0
                Mat zero = new Mat(mats[0].Size(), MatType.CV_8UC1, new Scalar(0));
                Mat bsum = new Mat();
                Mat gsum = new Mat();
                Mat rsum = new Mat();
                Cv2.Merge(new Mat[] { mats[0], zero, zero }, bsum);//(b,0,0)图像
                Cv2.Merge(new Mat[] { zero, mats[1], zero }, gsum);//(0,g,0)图像
                Cv2.Merge(new Mat[] { zero, zero, mats[2] }, rsum);//(0,0,r)图像

                pictureBox2.Image = BitmapConverter.ToBitmap(bsum);
                pictureBox3.Image = BitmapConverter.ToBitmap(gsum);
                pictureBox4.Image = BitmapConverter.ToBitmap(rsum);

            }


        }

        private void Form1_Load(object sender, EventArgs e)
        {
            radioButton1.Checked = true;
        }
    }
}

Demo下载

相关推荐
C#Thread7 分钟前
C#上位机--流程控制(IF语句)
开发语言·javascript·ecmascript
万兴丶31 分钟前
Unity 适用于单机游戏的红点系统(前缀树 | 数据结构 | 设计模式 | 算法 | 含源码)
数据结构·unity·设计模式·c#
牵牛老人40 分钟前
Qt开发中出现中文乱码问题深度解析与解决方案
开发语言·qt
大脑经常闹风暴@小猿42 分钟前
1.1 go环境搭建及基本使用
开发语言·后端·golang
奔跑吧邓邓子1 小时前
【Python爬虫(45)】Python爬虫新境界:分布式与大数据框架的融合之旅
开发语言·分布式·爬虫·python·大数据框架
Evaporator Core1 小时前
MATLAB学习之旅:数据建模与仿真应用
开发语言·学习·matlab
Zfox_1 小时前
【QT】信号与槽 & 窗口坐标
开发语言·c++·qt·qt5
张鱼小丸子1 小时前
【无标题】云原生作业六
开发语言·php
程序猿多布2 小时前
C#设计模式 学习笔记
设计模式·c#
项目申报小狂人2 小时前
改进收敛因子和比例权重的灰狼优化算法【期刊论文完美复现】(Matlab代码实现)
开发语言·算法·matlab