C#图像处理之边缘检测(Sobel)的方法

作者:沧海一粟…… 时间:2022-05-12 02:05:50 

本文实例讲述了C#图像处理之边缘检测(Sobel)的方法。分享给大家供大家参考。具体如下:


//定义sobel算子函数
private static Bitmap sobel(Bitmap a)
{
int w = a.Width;
int h = a.Height;
try
{
 Bitmap dstBitmap = new Bitmap(w, h, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
 System.Drawing.Imaging.BitmapData srcData = a.LockBits(new Rectangle
  (0, 0, w, h), System.Drawing.Imaging.ImageLockMode.ReadOnly, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
 System.Drawing.Imaging.BitmapData dstData = dstBitmap.LockBits(new Rectangle
  (0, 0, w, h), System.Drawing.Imaging.ImageLockMode.WriteOnly, System.Drawing.Imaging.PixelFormat.Format24bppRgb);
 unsafe
 {
  byte* pIn = (byte*)srcData.Scan0.ToPointer();
  byte* pOut = (byte*)dstData.Scan0.ToPointer();
  byte* p;
  int stride = srcData.Stride;
  for (int y = 0; y < h; y++)
  {
  for (int x = 0; x < w; x++)
  {
   //边缘八个点像素不变
   if (x == 0 || x == w - 1 || y == 0 || y == h - 1)
   {
   pOut[0] = pIn[0];
   pOut[1] = pIn[1];
   pOut[2] = pIn[2];
   }
   else
   {
   int r0, r1, r2, r3, r4, r5, r6, r7, r8;
   int g1, g2, g3, g4, g5, g6, g7, g8, g0;
   int b1, b2, b3, b4, b5, b6, b7, b8, b0;
   double vR, vG, vB;
   //左上
   p = pIn - stride - 3;
   r1 = p[2];
   g1 = p[1];
   b1 = p[0];
   //正上
   p = pIn - stride;
   r2 = p[2];
   g2 = p[1];
   b2 = p[0];
   //右上
   p = pIn - stride + 3;
   r3 = p[2];
   g3 = p[1];
   b3 = p[0];
   //左
   p = pIn - 3;
   r4 = p[2];
   g4 = p[1];
   b4 = p[0];
   //右
   p = pIn + 3;
   r5 = p[2];
   g5 = p[1];
   b5 = p[0];
   //左下
   p = pIn + stride - 3;
   r6 = p[2];
   g6 = p[1];
   b6 = p[0];
   //正下
   p = pIn + stride;
   r7 = p[2];
   g7 = p[1];
   b7 = p[0];
   // 右下
   p = pIn + stride + 3;
   r8 = p[2];
   g8 = p[1];
   b8 = p[0];
   //中心点
   p = pIn;
   r0 = p[2];
   g0 = p[1];
   b0 = p[0];
   //使用模板
   vR = (double)(Math .Abs (r1+2*r4+r6-r3-2*r5-r8)+Math .Abs (r1+2*r2+r3-r6-2*r7-r8));
   vG = (double)(Math .Abs (g1+2*g4+g6-g3-2*g5-g8)+Math .Abs (g1+2*g2+g3-g6-2*g7-g8));
   vB = (double)(Math .Abs (b1+2*b4+b6-b3-2*b5-b8)+Math .Abs (b1+2*b2+b3-b6-2*b7-b8));
   if (vR > 0)
   {
    vR = Math.Min(255, vR);
   }
   else
   {
    vR = Math.Max(0, vR);
   }
   if (vG > 0)
   {
    vG = Math.Min(255, vG);
   }
   else
   {
    vG = Math.Max(0, vG);
   }
   if (vB > 0)
   {
    vB = Math.Min(255, vB);
   }
   else
   {
    vB = Math.Max(0, vB);
   }
   pOut[0] = (byte)vB;
   pOut[1] = (byte)vG;
   pOut[2] = (byte)vR;
   }
   pIn += 3;
   pOut += 3;
  }
  pIn += srcData.Stride - w * 3;
  pOut += srcData.Stride - w * 3;
  }
 }
 a.UnlockBits(srcData);
 dstBitmap.UnlockBits(dstData);
 return dstBitmap;
}
catch
{
 return null;
}
}

希望本文所述对大家的C#程序设计有所帮助。

标签:C#,图像,边缘
0
投稿

猜你喜欢

  • 带你了解Java数据结构和算法之无权无向图

    2023-12-24 10:54:05
  • SpringBoot统一功能处理的方式详解

    2021-08-17 10:46:07
  • Android Studio3.2中导出jar包的过程详解

    2021-10-14 07:06:05
  • android studio 安装完成ButterKnife插件却无法使用(解决方案)

    2023-03-14 17:54:58
  • java并发之ArrayBlockingQueue详细介绍

    2023-04-23 07:30:01
  • Java 将List中的实体类按照某个字段进行分组并存放至Map中操作

    2022-09-13 20:25:35
  • C语言数据结构之单链表与双链表的增删改查操作实现

    2023-01-24 07:27:35
  • HashSet和TreeSet使用方法的区别解析

    2022-05-03 12:54:05
  • SpringBoot集成Redis的实现示例

    2022-10-22 14:50:33
  • unity实现UI元素跟随3D物体

    2021-11-15 02:00:48
  • zookeeper实现分布式锁

    2023-08-03 13:44:18
  • SpringBoot实现分页功能

    2021-11-07 12:33:16
  • Unity UI或3D场景实现跟随手机陀螺仪的晃动效果

    2021-12-09 01:09:32
  • java开发_图片截取工具实现原理

    2023-10-23 22:52:06
  • JAVA MyBatis入门学习过程记录

    2022-04-23 13:49:24
  • IDEA配置JRebel实现热部署的方法

    2022-08-28 20:53:00
  • Java8如何将Array转换为Stream的实现代码

    2022-09-15 06:41:31
  • Struts2中validate数据校验的两种方法详解附Struts2常用校验器

    2022-06-03 11:08:13
  • java sql ResultSet 之getRow()用法说明

    2022-07-01 02:43:15
  • JDBC+GUI实现简单学生管理系统

    2022-08-21 02:52:00
  • asp之家 软件编程 m.aspxhome.com