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);
            }
        }
    }
}
相关推荐
从孑开始20 分钟前
ManySpeech.MoonshineAsr 使用指南
人工智能·ai·c#·.net·私有化部署·语音识别·onnx·asr·moonshine
涛涛讲AI24 分钟前
一段音频多段字幕,让音频能够流畅自然对应字幕 AI生成视频,扣子生成剪映视频草稿
人工智能·音视频·语音识别
可触的未来,发芽的智生38 分钟前
新奇特:黑猫警长的纳米世界,忆阻器与神经网络的智慧
javascript·人工智能·python·神经网络·架构
YuanlongWang38 分钟前
C# 中,依赖注入(DI)的实现方式
c#
WWZZ20251 小时前
快速上手大模型:机器学习2(一元线性回归、代价函数、梯度下降法)
人工智能·算法·机器学习·计算机视觉·机器人·大模型·slam
AKAMAI1 小时前
数据孤岛破局之战 :跨业务分析的难题攻坚
运维·人工智能·云计算
Chicheng_MA1 小时前
算能 CV184 智能相机整体方案介绍
人工智能·数码相机·算能
Element_南笙1 小时前
吴恩达新课程:Agentic AI(笔记2)
数据库·人工智能·笔记·python·深度学习·ui·自然语言处理
倔强青铜三2 小时前
苦练Python第69天:subprocess模块从入门到上瘾,手把手教你驯服系统命令!
人工智能·python·面试
Antonio9152 小时前
【图像处理】rgb和srgb
图像处理·人工智能·数码相机