EmguCV-第08讲-访问图像像素

1 预备知识

在这里插入图片描述

2 Image类的定义

Image类与Mat类类似,后者是新版本的,Image类访问像素更直接,可以Image类访问像素,然后转换为Mat类。
在这里插入图片描述

创建类在这里插入图片描述
访问像素
在这里插入图片描述

在这里插入图片描述
Image和Mat转换
在这里插入图片描述

2 代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Drawing;

using Emgu.CV;
using Emgu.CV.Structure;
using Emgu.CV.CvEnum;
using Emgu.Util;

namespace Lesson8
{
    class Program
    {
        static void Main(string[] args)
        {
            #region 访问像素
            /**********方法一:直接访问像素***************/
            //Image<Bgr, byte> img = new Image<Bgr, byte>("cat.jpg");//Image 类似于新版本的Mat类,访问像素更方便,可以转为Mat类
            //for (int i = 0; i < img.Rows; i++)
            //{
            //    for (int j = 0; j < img.Cols; j++)
            //    {
            //        if (i == j)
            //        {
            //            img[i, j ]= new Bgr(0, 0, 225);
            //        }
            //    }
            //}

            //CvInvoke.Imshow("img", img);
            //CvInvoke.WaitKey(0);


            /**********方法二:通过data属性访问像素***************/
            //Image<Bgr, byte> img = new Image<Bgr, byte>("cat.jpg");//Image 类似于新版本的Mat类,访问像素更方便,可以转为Mat类
            //for (int i = 0; i < img.Rows; i++)
            //{
            //    for (int j = 0; j < img.Cols; j++)
            //    {
            //        if (i == j)
            //        {
            //            img.Data[i, j, 0] = 0;
            //            img.Data[i, j, 1] = 255;
            //            img.Data[i, j, 2] = 0;
            //        }
            //    }
            //}

            //CvInvoke.Imshow("img", img);
            //CvInvoke.WaitKey(0);
            #endregion

            #region 图像减色算法演示
            //Image<Bgr, Byte> img = new Image<Bgr, Byte>("cat.jpg");
            //byte reduceValue = 30; //减色系数(值越大输出颜色越少)
            //for (int i = 0; i < img.Rows; i++) //遍历行数
            //{
            //    for (int j = 0; j < img.Cols; j++) //遍历列数
            //    {
            //        img.Data[i, j, 0] = (byte)((byte)((byte)(img.Data[i, j, 0] / reduceValue) * reduceValue) + (byte)(reduceValue / 2)); //蓝色通道或灰度图像
            //        img.Data[i, j, 1] = (byte)((byte)((byte)(img.Data[i, j, 1] / reduceValue) * reduceValue) + (byte)(reduceValue / 2)); //绿色通道
            //        img.Data[i, j, 2] = (byte)((byte)((byte)(img.Data[i, j, 2] / reduceValue) * reduceValue) + (byte)(reduceValue / 2)); //红色通道
            //    }
            //}

            //CvInvoke.Imshow("img", img);
            //CvInvoke.WaitKey(0);
            #endregion

            //雪花效果
            Image<Bgr, byte> img = new Image<Bgr, byte>("cat.jpg");
            int snowNum = 1000;
            Random random = new Random();
            for (int k = 0; k < snowNum; k++)
            {
                var i = random.Next() % img.Rows;
                var j = random.Next() % img.Cols;
                img.Data[i, j, 0] = 255;  //蓝色通道
                img.Data[i, j, 1] = 255;  //绿色通道
                img.Data[i, j, 2] = 255;  //红色通道
            }

            CvInvoke.Imshow("img", img);
            CvInvoke.WaitKey(0);
        }
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值