C# - Opencv应用(2) 之矩阵Mat使用[矩阵创建、图像显示、像素读取与赋值]

C# - Opencv应用(2) 之矩阵Mat使用[矩阵创建、图像显示、像素读取与赋值]

  • 矩阵创建
  • 图像显示与保存
  • 像素读取与赋值
  • 新建sample02项目,配置opencv4相关包,新建.cs进行测试

1.矩阵创建

csharp 复制代码
//创建空白矩阵
var dst = new Mat()

//创建并赋值
var src = new Mat(new Size(128, 128), MatType.CV_8U, Scalar.All(125));

//图像拷贝
Mat dst = src.Clone();

2.图像显示与保存

csharp 复制代码
private static void test_0()
{
     //全黑
     var mat = new Mat(new Size(600, 600), MatType.CV_8UC3, new Scalar(0, 0, 0));
     Cv2.NamedWindow("black", 0);
     Cv2.ImShow("black", mat);

     // 全白
     mat = new Mat(new Size(600, 600), MatType.CV_8UC3, new Scalar(255, 255, 255));
     Cv2.NamedWindow("white", 0);
     Cv2.ImShow("white", mat);
     Cv2.ImWrite("white.jpg", mat);
}

3.像素读取与赋值

  • 两种常用的图像遍历方式
csharp 复制代码
        private void GetSet()
        {
            using var mat = new Mat(ImagePath.Lenna, ImreadModes.Color);
            for (int y = 0; y < mat.Height; y++)
            {
                for (int x = 0; x < mat.Width; x++)
                {
                    Vec3b color = mat.Get<Vec3b>(y, x);
                    Vec3b newColor = new Vec3b(color.Item2, color.Item1, color.Item0);
                    mat.Set<Vec3b>(y, x, newColor);
                }
            }
            Cv2.ImShow("Slow", mat);
            Cv2.WaitKey(0);
            Cv2.DestroyAllWindows();
        }

        /// <summary>
        /// Reasonably fast
        /// </summary>
        private void GenericIndexer()
        {
            using var mat = new Mat(ImagePath.Lenna, ImreadModes.Color);
            var indexer = mat.GetGenericIndexer<Vec3b>();
            for (int y = 0; y < mat.Height; y++)
            {
                for (int x = 0; x < mat.Width; x++)
                {
                    Vec3b color = indexer[y, x];
                    Vec3b newColor = new Vec3b(color.Item2, color.Item1, color.Item0);
                    indexer[y, x] = newColor;
                }
            }
            Cv2.ImShow("GenericIndexer", mat);
            Cv2.WaitKey(0);
            Cv2.DestroyAllWindows();
        }
  • 灰度图操作
csharp 复制代码
 private static void test_1()
 {
      var img = new Mat(new Size(128, 128), MatType.CV_8U, 1);
      var pixel = img.GetGenericIndexer<int>();
      for (var y = 0; y < img.Height; y++)
      {
            for (var x = 0; x < img.Width; x++)
            {
                 pixel[y, x] = x + y;
            }
       }

       Cv2.NamedWindow("单通道",0);
       Cv2.ImShow("单通道", img);
       Cv2.WaitKey(0);
}
  • 三通道图操作
csharp 复制代码
private static void test_2()
{
     //三通道
     using (var src = new Mat(new Size(128, 128), MatType.CV_8UC3, new Scalar(20, 129, 250)))
     using (var dst = new Mat())
     {

          for (var y = 0; y < src.Height; y++)
          {
               for (var x = 0; x < src.Width; x++)
               {
                    var color = src.Get<Vec3b>(y, x);
                    var temp = color.Item0;
                    color.Item0 = color.Item2; // B <- R
                    color.Item2 = temp;        // R <- B
                    src.Set(y, x, color);
               }
           }

           src.CopyTo(dst);
           Mat dat = dst.Clone();

           Cv2.NamedWindow("dst", 0);
           Cv2.ImShow("dst", dst);
           Cv2.WaitKey(0);
      }
}
  • 完整代码
cpp 复制代码
using OpenCvSharp;

namespace OpenCVSharpSample01
{
    class Program
    {
        static void Main(string[] args)
        {
            test_0();

            test_1();

            test_2();

        }

        private static void test_0()
        {
            var mat = new Mat(new Size(600, 600), MatType.CV_8UC3, new Scalar(0, 0, 0));
            Cv2.NamedWindow("black", 0);
            Cv2.ImShow("black", mat);

            // 全白
            mat = new Mat(new Size(600, 600), MatType.CV_8UC3, new Scalar(255, 255, 255));
            Cv2.NamedWindow("white", 0);
            Cv2.ImShow("white", mat);
            Cv2.ImWrite("white.jpg", mat);
        }
        private static void test_1()
        {
            var img = new Mat(new Size(128, 128), MatType.CV_8U, 1);
            var pixel = img.GetGenericIndexer<int>();
            for (var y = 0; y < img.Height; y++)
            {
                for (var x = 0; x < img.Width; x++)
                {
                    pixel[y, x] = x + y;
                }
            }

            Cv2.NamedWindow("单通道",0);
            Cv2.ImShow("单通道", img);
            Cv2.WaitKey(0);
        }
        private static void test_2()
        {
            //三通道
            using (var src = new Mat(new Size(128, 128), MatType.CV_8U, Scalar.All(125)))
            using (var dst = new Mat())
            {

                for (var y = 0; y < src.Height; y++)
                {
                    for (var x = 0; x < src.Width; x++)
                    {
                        var color = src.Get<Vec3b>(y, x);
                        var temp = color.Item0;
                        color.Item0 = color.Item2; // B <- R
                        color.Item2 = temp;        // R <- B
                        src.Set(y, x, color);
                    }
                }

                src.CopyTo(dst);
                Mat dat = dst.Clone();

                Cv2.NamedWindow("dst", 0);
                Cv2.ImShow("dst", dst);
                Cv2.WaitKey(0);
            }
        }
    }
}
相关推荐
金井PRATHAMA2 小时前
描述逻辑(Description Logic)对自然语言处理深层语义分析的影响与启示
人工智能·自然语言处理·知识图谱
Rock_yzh2 小时前
AI学习日记——参数的初始化
人工智能·python·深度学习·学习·机器学习
Hcoco_me3 小时前
YOLO入门教程(番外):目标检测的一阶段学习方法
yolo·目标检测·学习方法
CiLerLinux4 小时前
第四十九章 ESP32S3 WiFi 路由实验
网络·人工智能·单片机·嵌入式硬件
-dzk-5 小时前
【3DGS复现】Autodl服务器复现3DGS《简单快速》《一次成功》《新手练习复现必备》
运维·服务器·python·计算机视觉·3d·三维重建·三维
七芒星20235 小时前
多目标识别YOLO :YOLOV3 原理
图像处理·人工智能·yolo·计算机视觉·目标跟踪·分类·聚类
Learn Beyond Limits6 小时前
Mean Normalization|均值归一化
人工智能·神经网络·算法·机器学习·均值算法·ai·吴恩达
byzy6 小时前
【论文笔记】VisionPAD: A Vision-Centric Pre-training Paradigm for Autonomous Driving
论文阅读·深度学习·计算机视觉·自动驾驶
ACERT3336 小时前
5.吴恩达机器学习—神经网络的基本使用
人工智能·python·神经网络·机器学习
C嘎嘎嵌入式开发6 小时前
(一) 机器学习之深度神经网络
人工智能·神经网络·dnn